Hi -
I must be getting tired, because I can't for the life of me weed out this problem that's been bugging me all night... Thanks in advance to all of you looking into this.
The code:
class TemplateHours(models.Model):
employee = models.ForeignKey(Employee)
weekday = models.SmallIntegerField()
start = models.TimeField()
end = models.TimeField()
class TemplateHoursSerializer(serializers.Serializer):
weekday = serializers.IntegerField()
start = HourField()
end = HourField()
employee = EmployeeSerializer()
def restore_object(self, attrs, instance=None):
if instance:
for attr, value in attrs.items():
setattr(instance, attr, value)
return instance
return TemplateHours(**attrs)
class TemplateHoursRootView(generics.ListCreateAPIView):
"""
Endpoint for block of hours in a template (TemplateHours model).
"""
model = TemplateHours
serializer_class = TemplateHoursSerializer
POSTing
{
"employee":
{
"id":1,
"user": {"username":"mathieu", "id":1}
},
"weekday":"0",
"start":"09:00:00",
"end":"16:0:00"
} to the url results in
IntegrityError at /api/template-block/
planning_templatehours.employee_id may not be NULL
Environment:
Request Method: POST
Request URL: http://127.0.0.1:8000/api/template-block/
Django Version: 1.4.1
Python Version: 2.7.2
Installed Applications:
('django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
'django.contrib.admin',
'rest_framework',
'hours',
'planning',
'debug_toolbar',
'django_extensions',
'django_coverage')
Installed Middleware:
('django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'debug_toolbar.middleware.DebugToolbarMiddleware')
Traceback:
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\core\handlers\base.py" in get_response
111. response = callback(request, *callback_args, **callback_kwargs)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\views\generic\base.py" in view
48. return self.dispatch(request, *args, **kwargs)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\views\decorators\csrf.py" in wrapped_view
77. return view_func(*args, **kwargs)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\rest_framework\views.py" in dispatch
340. response = self.handle_exception(exc)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\rest_framework\views.py" in dispatch
337. response = handler(request, *args, **kwargs)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\rest_framework\generics.py" in post
117. return self.create(request, *args, **kwargs)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\rest_framework\mixins.py" in create
23. self.object = serializer.save()
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\rest_framework\serializers.py" in save
275. self.object.save()
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\db\models\base.py" in save
463. self.save_base(using=using, force_insert=force_insert, force_update=force_update)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\db\models\base.py" in save_base
551. result = manager._insert([self], fields=fields, return_id=update_pk, using=using, raw=raw)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\db\models\manager.py" in _insert
203. return insert_query(self.model, objs, fields, **kwargs)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\db\models\query.py" in insert_query
1576. return query.get_compiler(using=using).execute_sql(return_id)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\db\models\sql\compiler.py" in execute_sql
910. cursor.execute(sql, params)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\db\backends\util.py" in execute
40. return self.cursor.execute(sql, params)
File "C:\Users\Mathieu\Development\django_projects\hedron\Lib\site-packages\django\db\backends\sqlite3\base.py" in execute
337. return Database.Cursor.execute(self, query, params)
Exception Type: IntegrityError at /api/template-block/
Exception Value: planning_templatehours.employee_id may not be NULL