Rovak/InlineAttachment

Issues when adding extra headers

tanordheim opened this issue · 4 comments

In issue #46 support for extraHeaders was added; I attempted to use this now by adding the following to my InlineAttachment configuration:

{
  extraHeaders: { "Accept": "application/json" }
}

Whenever InlineAttachment attempts to upload files now, I get this error:

Uncaught InvalidStateError: Failed to execute 'setRequestHeader' on 'XMLHttpRequest': the object's state must be OPENED.

I tried moving the block that sets the headers down until after the XMLHttpRequest has been opened, but this did strangely enough not seem to have any effect; the error still occured. I'm not familiar with this code, or really XMLHttpRequest in general, so I'm not quite sure what is going on here. I'd be happy to fix and submit a pull request, but some ideas about what might be going on here would be great.

Moving the code below the xhr.open solves the error for me:

xhr.open('POST', settings.uploadUrl);

// Add any available extra headers
if (typeof settings.extraHeaders === "object") {
    for (var header in settings.extraHeaders) {
        if (settings.extraHeaders.hasOwnProperty(header)) {
            xhr.setRequestHeader(header, settings.extraHeaders[header]);
        }
    }
}

xhr.onload = function() {
  // If HTTP status is OK or Created
  if (xhr.status === 200 || xhr.status === 201) {
    me.onFileUploadResponse(xhr);
  } else {
    me.onFileUploadError(xhr);
  }
};
if (settings.beforeFileUpload(xhr) !== false) {
  xhr.send(formData);
}
return xhr;

Could you try it and check if it works for you as well? Tested in Chrome Version 40.0.2214.91 (64-bit) on Ubuntu

after providing extra headers, immediately after the image uploaded, the browser would redirect to the local path to the dropped image (default event it seems).

Moving the extra headers block below xhr.open as suggested above worked perfectly.

@tamagokun thanks for the confirmation, i will make a fix soonish

Fixed in #54