wcs/wcs/carddata.py

129 lines
4.4 KiB
Python

# w.c.s. - web application for online forms
# Copyright (C) 2005-2019 Entr'ouvert
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, see <http://www.gnu.org/licenses/>.
from quixote import get_publisher, get_request, get_session
from wcs.formdata import FormData
from .qommon import _
from .qommon.storage import Equal
class CardData(FormData):
uuid = None
def get_formdef(self):
if self._formdef:
return self._formdef
from .carddef import CardDef
id = self._names.split('-', 1)[1]
try:
self._formdef = CardDef.get_by_urlname(id)
except KeyError:
self._formdef = None
return self._formdef
formdef = property(get_formdef)
def get_data_source_structured_item(
self, digest_key='default', with_related_urls=False, with_files_urls=False
):
if self.digests is None:
if digest_key == 'default':
summary = _('Digest (default) not defined')
else:
summary = _('Digest (custom view "%s") not defined') % digest_key.replace('custom-view:', '')
get_publisher().record_error(summary, formdata=self)
item = {
'id': self.id,
'text': (self.digests or {}).get(digest_key) or '',
}
if with_related_urls:
edit_related_url = self.get_edit_related_url()
if edit_related_url:
item['edit_related_url'] = edit_related_url
view_related_url = self.get_view_related_url()
if view_related_url:
item['view_related_url'] = view_related_url
for field in self.formdef.get_all_fields():
if not field.varname or field.varname in ('id', 'text'):
continue
value = self.data and self.data.get(field.id)
if with_files_urls and hasattr(value, 'file_digest'):
item['%s_url' % field.varname] = self.get_file_by_token_url(value.file_digest())
if isinstance(value, str):
item[field.varname] = value
return item
def get_edit_related_url(self):
wf_status = self.get_status()
for _item in wf_status.items:
if not _item.key == 'editable':
continue
if not _item.check_auth(self, get_request().user):
continue
return (
self.get_url(
backoffice=get_request().is_in_backoffice(),
include_category=True,
language=get_publisher().current_language,
)
+ 'wfedit-%s' % _item.id
)
def get_view_related_url(self):
if not self.formdef.is_user_allowed_read(get_request().user, self):
return
return self.get_url(backoffice=True)
def get_display_label(self, digest_key='default'):
return (self.digests or {}).get(digest_key) or self.get_display_name()
def get_author_qualification(self):
return None
def get_file_base_url(self):
return '%sdownload' % self.get_api_url()
def just_created(self):
super().just_created()
if self.submission_agent_id:
self.evolution[0].who = self.submission_agent_id
@classmethod
def get_submission_channels(cls):
return {'web': _('Web'), 'file-import': _('File Import')}
@classmethod
def get_by_uuid(cls, value):
try:
return cls.select([Equal('uuid', value)], limit=1)[0]
except IndexError:
raise KeyError(value)
def get_file_by_token_url(self, file_digest):
context = {
'carddef_slug': self.formdef.url_name,
'data_id': self.id,
'file_digest': file_digest,
}
token = get_session().create_token('card-file-by-token', context)
return '/api/card-file-by-token/%s' % token.id