/usr/lib/python3/dist-packages/recurrence/fields.py is in python3-django-recurrence 1.5.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | from django.db.models import fields
from django.utils.six import string_types
import recurrence
from recurrence import forms
from recurrence.compat import Creator
try:
from south.modelsinspector import add_introspection_rules
add_introspection_rules([], [
"^recurrence\.fields\.RecurrenceField",
])
except ImportError:
pass
# Do not use SubfieldBase meta class because is removed in Django 1.10
class RecurrenceField(fields.Field):
"""Field that stores a `recurrence.base.Recurrence` to the database."""
def __init__(self, include_dtstart=True, **kwargs):
self.include_dtstart = include_dtstart
super(RecurrenceField, self).__init__(**kwargs)
def get_internal_type(self):
return 'TextField'
def to_python(self, value):
if value is None or isinstance(value, recurrence.Recurrence):
return value
value = super(RecurrenceField, self).to_python(value) or u''
return recurrence.deserialize(value, self.include_dtstart)
def from_db_value(self, value, *args, **kwargs):
return self.to_python(value)
def get_prep_value(self, value):
if not isinstance(value, string_types):
value = recurrence.serialize(value)
return value
def contribute_to_class(self, cls, *args, **kwargs):
super(RecurrenceField, self).contribute_to_class(cls, *args, **kwargs)
setattr(cls, self.name, Creator(self))
def value_to_string(self, obj):
return self.get_prep_value(self._get_val_from_obj(obj))
def formfield(self, **kwargs):
defaults = {
'form_class': forms.RecurrenceField,
'widget': forms.RecurrenceWidget,
}
defaults.update(kwargs)
return super(RecurrenceField, self).formfield(**defaults)
|