Как настроить Tastypie для обработки поля как уникального? Я ожидал бы получить в качестве ответа какую-то ошибку, не связанную с 500 (возможно, конфликт 409?), Если я попытаюсь вставить повторяющиеся записи в поле, помеченное как уникальное.
Я просмотрел документы, и, похоже, это должно быть для меня очевидно, но по какой-то причине я не получил ответ, который ожидал увидеть.
Вот ссылка на документацию:
http://readthedocs.org/docs/django-tastypie/en/latest/fields.html?highlight=unique
Пример кода следующий:
urls.py
v1_api = Api(api_name='v1')
v1_api.register(CompanyResource())
urlpatterns = patterns('',
(r'^api/', include(v1_api.urls)),
)
resource.py
class CompanyResource(ModelResource):
CompanyName = fields.CharField(attribute='company_name')
CompanyId = fields.CharField(attribute='company_id', unique=True)
Contact = fields.CharField(attribute='contact')
Email = fields.CharField(attribute='email')
Phone = fields.CharField(attribute='phone')
class Meta:
queryset = Company.objects.all()
authentication = BasicAuthentication()
authorization = Authorization()
allowed_methods = ['get', 'post']
models.py
class Company(models.Model):
company_name = models.TextField(default=None, blank=True, null=True)
company_id = models.CharField(default='', unique=True, db_index=True, max_length=20)
contact = models.TextField(default=None, blank=True, null=True)
email = models.EmailField(default=None, blank=True, null=True)
phone = models.TextField(default=None, blank=True, null=True)
Я получаю следующее сообщение об ошибке (используя curl для доступа к моей локальной службе):
curl --dump-header - -H "Content-Type: application/json" -X POST --user user:password --data '{"CompanyName": "company", "CompanyId": "1234567890", "Contact": "John", "Email": "example@example.com", "Phone": "555-555-5555"}' http://localhost:8000/api/v1/company/
HTTP/1.0 500 INTERNAL SERVER ERROR
Date: Thu, 15 Sep 2011 18:25:20 GMT
Server: WSGIServer/0.1 Python/2.7.1
Content-Type: application/json; charset=utf-8
{"error_message": "(1062, \"Duplicate entry '1234567890' for key 'api_company_company_id_uniq'\")",
...<snip>...
raise errorclass, errorvalue\n\nIntegrityError: (1062, \"Duplicate entry '1234567890' for key 'api_company_company_id_uniq'\")\n"}
Когда я удаляю unique=True, db_index=True,
из модели Компании, я не получаю сообщение об ошибке целостности, но вместо этого создается новый дубликат ресурса. Опять же, это не ожидаемый результат, так как я ожидал бы, что уникальный преформ выполнит некоторую проверку и вызовет не-500 ответ.