First try at implementing required / optional metadata
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
|
|
||||||
from django import forms
|
from django import forms
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
from django.utils.translation import ugettext
|
||||||
from django.http import HttpResponseRedirect
|
from django.http import HttpResponseRedirect
|
||||||
from django.utils.http import urlencode
|
from django.utils.http import urlencode
|
||||||
from django.core.urlresolvers import reverse
|
from django.core.urlresolvers import reverse
|
||||||
@@ -84,7 +85,17 @@ class MetadataForm(forms.Form):
|
|||||||
self.document_type = kwargs['initial'].pop('document_type', None)
|
self.document_type = kwargs['initial'].pop('document_type', None)
|
||||||
self.metadata_options = kwargs['initial'].pop('metadata_options', None)
|
self.metadata_options = kwargs['initial'].pop('metadata_options', None)
|
||||||
|
|
||||||
self.fields['name'].initial=self.metadata_type.title if self.metadata_type.title else self.metadata_type.name
|
|
||||||
|
required=self.document_type.documenttypemetadatatype_set.get(metadata_type=self.metadata_type).required
|
||||||
|
required_string = u''
|
||||||
|
if required:
|
||||||
|
self.fields['value'].required=True
|
||||||
|
required_string = ' (%s)' % ugettext(u'required')
|
||||||
|
else:
|
||||||
|
#TODO: FIXME: not working correctly
|
||||||
|
self.fields['value'].required=False
|
||||||
|
|
||||||
|
self.fields['name'].initial='%s%s' % ((self.metadata_type.title if self.metadata_type.title else self.metadata_type.name), required_string)
|
||||||
self.fields['id'].initial=self.metadata_type.id
|
self.fields['id'].initial=self.metadata_type.id
|
||||||
if self.metadata_type.default:
|
if self.metadata_type.default:
|
||||||
try:
|
try:
|
||||||
@@ -97,6 +108,7 @@ class MetadataForm(forms.Form):
|
|||||||
choices = eval(self.metadata_type.lookup, AVAILABLE_MODELS)
|
choices = eval(self.metadata_type.lookup, AVAILABLE_MODELS)
|
||||||
self.fields['value'] = forms.ChoiceField(label=self.fields['value'].label)
|
self.fields['value'] = forms.ChoiceField(label=self.fields['value'].label)
|
||||||
self.fields['value'].choices = zip(choices, choices)
|
self.fields['value'].choices = zip(choices, choices)
|
||||||
|
self.fields['value'].required = False
|
||||||
except Exception, err:
|
except Exception, err:
|
||||||
self.fields['value'].initial = err
|
self.fields['value'].initial = err
|
||||||
self.fields['value'].widget=forms.TextInput(attrs={'readonly':'readonly'})
|
self.fields['value'].widget=forms.TextInput(attrs={'readonly':'readonly'})
|
||||||
@@ -104,7 +116,7 @@ class MetadataForm(forms.Form):
|
|||||||
id = forms.CharField(label=_(u'id'), widget=forms.HiddenInput)
|
id = forms.CharField(label=_(u'id'), widget=forms.HiddenInput)
|
||||||
name = forms.CharField(label=_(u'Name'),
|
name = forms.CharField(label=_(u'Name'),
|
||||||
required=False, widget=forms.TextInput(attrs={'readonly':'readonly'}))
|
required=False, widget=forms.TextInput(attrs={'readonly':'readonly'}))
|
||||||
value = forms.CharField(label=_(u'Value'))
|
value = forms.CharField(label=_(u'Value'), required=False)
|
||||||
|
|
||||||
|
|
||||||
class DocumentCreateWizard(BoundFormWizard):
|
class DocumentCreateWizard(BoundFormWizard):
|
||||||
@@ -138,6 +150,7 @@ class DocumentCreateWizard(BoundFormWizard):
|
|||||||
if step == 1:
|
if step == 1:
|
||||||
self.urldata = []
|
self.urldata = []
|
||||||
for id, metadata in enumerate(form.cleaned_data):
|
for id, metadata in enumerate(form.cleaned_data):
|
||||||
|
if metadata['value']:
|
||||||
self.urldata.append(('metadata%s_id' % id,metadata['id']))
|
self.urldata.append(('metadata%s_id' % id,metadata['id']))
|
||||||
self.urldata.append(('metadata%s_value' % id,metadata['value']))
|
self.urldata.append(('metadata%s_value' % id,metadata['value']))
|
||||||
|
|
||||||
|
|||||||
@@ -43,27 +43,6 @@ def populate_file_extension_and_mimetype(instance, filename):
|
|||||||
#remove prefix '.'
|
#remove prefix '.'
|
||||||
instance.file_extension = extension[1:]
|
instance.file_extension = extension[1:]
|
||||||
|
|
||||||
'''
|
|
||||||
def custom_eval(format, dictionary):
|
|
||||||
try:
|
|
||||||
#Do a normal substitution
|
|
||||||
return format % dictionary
|
|
||||||
except:
|
|
||||||
#Use exception to catch unknown elements
|
|
||||||
(exc_type, exc_info, tb) = sys.exc_info()
|
|
||||||
key = unicode(exc_info)[2:-1]
|
|
||||||
try:
|
|
||||||
#Resolve unknown element
|
|
||||||
dictionary[key] = eval(key, dictionary)
|
|
||||||
#Call itself again, but with an additional resolved element in
|
|
||||||
#the dictionary
|
|
||||||
return custom_eval(format, dictionary)
|
|
||||||
except Exception, e:
|
|
||||||
#Can't resolve elemtent, give up
|
|
||||||
(exc_type, exc_info, tb) = sys.exc_info()
|
|
||||||
print exc_info
|
|
||||||
raise Exception(e)
|
|
||||||
'''
|
|
||||||
|
|
||||||
class DocumentType(models.Model):
|
class DocumentType(models.Model):
|
||||||
name = models.CharField(max_length=32, verbose_name=_(u'name'))
|
name = models.CharField(max_length=32, verbose_name=_(u'name'))
|
||||||
@@ -93,7 +72,6 @@ class Document(models.Model):
|
|||||||
ordering = ['-date_updated', '-date_added']
|
ordering = ['-date_updated', '-date_added']
|
||||||
|
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
#return self.uuid
|
|
||||||
return '%s.%s' % (self.file_filename, self.file_extension)
|
return '%s.%s' % (self.file_filename, self.file_extension)
|
||||||
|
|
||||||
@models.permalink
|
@models.permalink
|
||||||
@@ -125,6 +103,7 @@ class Document(models.Model):
|
|||||||
|
|
||||||
for metadata_index in self.document_type.metadataindex_set.all():
|
for metadata_index in self.document_type.metadataindex_set.all():
|
||||||
if metadata_index.enabled:
|
if metadata_index.enabled:
|
||||||
|
try:
|
||||||
fabricated_directory = eval(metadata_index.expression, metadata_dict)
|
fabricated_directory = eval(metadata_index.expression, metadata_dict)
|
||||||
target_directory = os.path.join(FILESYSTEM_FILESERVING_PATH, fabricated_directory)
|
target_directory = os.path.join(FILESYSTEM_FILESERVING_PATH, fabricated_directory)
|
||||||
try:
|
try:
|
||||||
@@ -137,24 +116,10 @@ class Document(models.Model):
|
|||||||
|
|
||||||
|
|
||||||
next_available_filename(self, metadata_index, target_directory, slugify(self.file_filename), slugify(self.file_extension))
|
next_available_filename(self, metadata_index, target_directory, slugify(self.file_filename), slugify(self.file_extension))
|
||||||
|
except NameError:
|
||||||
|
#Error in eval
|
||||||
#try:
|
#TODO: find way to notify user
|
||||||
# os.symlink(os.path.abspath(self.file.path), filepath)
|
pass
|
||||||
#except OSError, exc:
|
|
||||||
# raise OSError(ugettext(u'Unable to create symbolic link: %s') % exc)
|
|
||||||
|
|
||||||
'''
|
|
||||||
try:
|
|
||||||
filepath = create_symlink(os.path.abspath(self.file.path), target_directory, slugify(self.file_filename), slugify(self.file_extension))
|
|
||||||
document_metadata_index = DocumentMetadataIndex(
|
|
||||||
document=self, metadata_index=metadata_index,
|
|
||||||
filename=filepath)
|
|
||||||
document_metadata_index.save()
|
|
||||||
except Exception, e:
|
|
||||||
raise Exception(ugettext(u'Unable to create metadata indexing symbolic link: %s') % e)
|
|
||||||
'''
|
|
||||||
|
|
||||||
|
|
||||||
def delete_fs_links(self):
|
def delete_fs_links(self):
|
||||||
if FILESYSTEM_FILESERVING_ENABLE:
|
if FILESYSTEM_FILESERVING_ENABLE:
|
||||||
@@ -232,23 +197,6 @@ def next_available_filename(document, metadata_index, path, filename, extension,
|
|||||||
raise Exception(ugettext(u'Maximum rename count reached, not creating symbolic link'))
|
raise Exception(ugettext(u'Maximum rename count reached, not creating symbolic link'))
|
||||||
return next_available_filename(document, metadata_index, path, filename, extension, suffix+1)
|
return next_available_filename(document, metadata_index, path, filename, extension, suffix+1)
|
||||||
|
|
||||||
'''
|
|
||||||
def create_symlink(source, path, filename, extension, suffix=0):
|
|
||||||
try:
|
|
||||||
target = filename
|
|
||||||
if suffix:
|
|
||||||
target = '_'.join([filename, unicode(suffix)])
|
|
||||||
filepath = os.path.join(path, os.extsep.join([target, extension]))
|
|
||||||
os.symlink(source, filepath)
|
|
||||||
return filepath
|
|
||||||
except OSError, exc:
|
|
||||||
if exc.errno == errno.EEXIST:
|
|
||||||
if suffix > FILESYSTEM_MAX_RENAME_COUNT:
|
|
||||||
raise Exception(ugettext(u'Maximum rename count reached, not creating symbolic link'))
|
|
||||||
return create_symlink(source, path, filename, extension, suffix+1)
|
|
||||||
else:
|
|
||||||
raise OSError(ugettext(u'Unable to create symbolic link: %s') % exc)
|
|
||||||
'''
|
|
||||||
|
|
||||||
available_functions_string = (_(u' Available functions: %s') % ','.join(['%s()' % name for name, function in AVAILABLE_FUNCTIONS.items()])) if AVAILABLE_FUNCTIONS else ''
|
available_functions_string = (_(u' Available functions: %s') % ','.join(['%s()' % name for name, function in AVAILABLE_FUNCTIONS.items()])) if AVAILABLE_FUNCTIONS else ''
|
||||||
available_models_string = (_(u' Available models: %s') % ','.join([name for name, model in AVAILABLE_MODELS.items()])) if AVAILABLE_MODELS else ''
|
available_models_string = (_(u' Available models: %s') % ','.join([name for name, model in AVAILABLE_MODELS.items()])) if AVAILABLE_MODELS else ''
|
||||||
@@ -276,9 +224,8 @@ class MetadataType(models.Model):
|
|||||||
class DocumentTypeMetadataType(models.Model):
|
class DocumentTypeMetadataType(models.Model):
|
||||||
document_type = models.ForeignKey(DocumentType, verbose_name=_(u'document type'))
|
document_type = models.ForeignKey(DocumentType, verbose_name=_(u'document type'))
|
||||||
metadata_type = models.ForeignKey(MetadataType, verbose_name=_(u'metadata type'))
|
metadata_type = models.ForeignKey(MetadataType, verbose_name=_(u'metadata type'))
|
||||||
#create_directory_link = models.BooleanField(verbose_name=_(u'create directory link'))
|
required = models.BooleanField(default=True, verbose_name=_(u'required'))
|
||||||
#TODO: override default for this document type
|
#TODO: override default for this document type
|
||||||
#TODO: required? -bool
|
|
||||||
|
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return unicode(self.metadata_type)
|
return unicode(self.metadata_type)
|
||||||
|
|||||||
Reference in New Issue
Block a user