Custom Query (2152 matches)
Results (511 - 513 of 2152)
| Ticket | Resolution | Summary | Owner | Reporter |
|---|---|---|---|---|
| #1206 | fixed | "Content-Type json" header scuppers package POST | wwaites | dread |
| Description |
Compare these two requests to create a package: curl http://test.ckan.net/api/rest/package -d '{name:"test"}' -H 'Content-Type: application/json' -H 'X-CKAN-API-KEY: tester'
curl http://test.ckan.net/api/rest/package -d '{name:"test"}' -H 'X-CKAN-API-KEY: tester'
The second one gets the payload through (ckan log): Retrieving request params: UnicodeMultiDict([('{name:"test"}', u'')])
But the first one causes a ServerError? because the payload (name:"test") doesn't make it to request.POST or request.params: Retrieving request params: UnicodeMultiDict([]) The only difference is the "ContentType?: application/json" header, which seems a reasonable thing to include. Javascript lib backbone.js (for example) inserts this automatically. So why does this header cause the payload to not get through to the request object? |
|||
| #1207 | fixed | ckanclient.package_entity_get should raise more specific exception | dread | dread |
| Description |
When package does not exist in ckan catalogue, ckanclient.package_entity_get should raise more specific exception, such as CkanNotFoundError? instead of generic CkanApiError?. |
|||
| #1210 | fixed | POST application/json error handling with newer WebOb | dread | dread |
| Description |
WebOb? from v1.0.7 has some interesting new behaviour with reading request data for different Content-Types:
Example: Module ckan.controllers.api:206 in create
<< log.debug('create: %s' % (context))
try:
request_data = self._get_request_data()
except ValueError, inst:
response.status_int = 400
>> request_data = self._get_request_data()
Module ckan.lib.base:149 in _get_request_data
<< cls.log.debug('Retrieving request params: %r' % request.params)
cls.log.debug('Retrieving request POST: %r' % request.POST)
cls.log.debug('Retrieving request POST body: %r' % request.body)
if request.POST:
try:
>> cls.log.debug('Retrieving request POST body: %r' % request.body)
Module paste.registry:137 in __getattr__
<<
def __getattr__(self, attr):
return getattr(self._current_obj(), attr)
def __setattr__(self, attr, value):
>> return getattr(self._current_obj(), attr)
Module webob.request:470 in _body__get
<< Return the content of the request body.
"""
self.make_body_seekable() # we need this to have content_length
r = self.body_file.read(self.content_length)
self.body_file.seek(0)
>> self.make_body_seekable() # we need this to have content_length
Module webob.request:697 in make_body_seekable
<< self.body_file_raw.seek(0)
else:
self.copy_body()
>> self.copy_body()
Module webob.request:714 in copy_body
<< self.body = self.body_file_raw.read(length)
elif self.is_body_readable:
self.body = self.body_file_raw.read()
self._copy_body_tempfile()
else:
>> self.body = self.body_file_raw.read()
Module webob.request:1190 in read
<< def read(self, size=-1):
body = self._get_body()
if size < 0:
v = body[self.position:]
>> body = self._get_body()
Module webob.request:1207 in _get_body
<< self._body = _encode_multipart(self.vars, self.content_type)
else:
assert 0, ('Bad content type: %r' % self.content_type)
return self._body
>> assert 0, ('Bad content type: %r' % self.content_type)
AssertionError: Bad content type: '; charset=utf-8'
|
|||
