| Index: Source/modules/fetch/RequestInit.cpp
|
| diff --git a/Source/modules/fetch/RequestInit.cpp b/Source/modules/fetch/RequestInit.cpp
|
| index 31b13a3ca1b9ef0f460f60188e78bf925c96901c..b0c315bf6c818de48e49671ca7f77e325a962141 100644
|
| --- a/Source/modules/fetch/RequestInit.cpp
|
| +++ b/Source/modules/fetch/RequestInit.cpp
|
| @@ -12,6 +12,8 @@
|
| #include "bindings/core/v8/V8Blob.h"
|
| #include "bindings/core/v8/V8FormData.h"
|
| #include "core/fileapi/Blob.h"
|
| +#include "modules/fetch/FetchBlobDataConsumerHandle.h"
|
| +#include "modules/fetch/FetchFormDataConsumerHandle.h"
|
| #include "modules/fetch/Headers.h"
|
| #include "platform/blob/BlobData.h"
|
| #include "platform/network/FormData.h"
|
| @@ -33,59 +35,29 @@ RequestInit::RequestInit(ExecutionContext* context, const Dictionary& options, E
|
| DictionaryHelper::get(options, "credentials", credentials);
|
| DictionaryHelper::get(options, "redirect", redirect);
|
|
|
| - v8::Local<v8::Value> body;
|
| - if (!DictionaryHelper::get(options, "body", body) || body->IsUndefined() || body->IsNull())
|
| + v8::Local<v8::Value> v8Body;
|
| + if (!DictionaryHelper::get(options, "body", v8Body) || v8Body->IsUndefined() || v8Body->IsNull())
|
| return;
|
| - OwnPtr<BlobData> blobData = BlobData::create();
|
| + RefPtr<FormData> formData = FormData::create();
|
| v8::Isolate* isolate = toIsolate(context);
|
| - if (body->IsArrayBuffer()) {
|
| - DOMArrayBuffer* arrayBuffer = V8ArrayBuffer::toImpl(v8::Local<v8::Object>::Cast(body));
|
| - ASSERT(arrayBuffer);
|
| - blobData->appendBytes(arrayBuffer->data(), arrayBuffer->byteLength());
|
| - } else if (body->IsArrayBufferView()) {
|
| - DOMArrayBufferView* arrayBufferView = V8ArrayBufferView::toImpl(v8::Local<v8::Object>::Cast(body));
|
| - ASSERT(arrayBufferView);
|
| - blobData->appendBytes(arrayBufferView->baseAddress(), arrayBufferView->byteLength());
|
| - } else if (V8Blob::hasInstance(body, isolate)) {
|
| - Blob* blob = V8Blob::toImpl(v8::Local<v8::Object>::Cast(body));
|
| - ASSERT(blob);
|
| - blob->appendTo(*blobData);
|
| - blobData->setContentType(blob->type());
|
| - } else if (V8FormData::hasInstance(body, isolate)) {
|
| - DOMFormData* domFormData = V8FormData::toImpl(v8::Local<v8::Object>::Cast(body));
|
| - ASSERT(domFormData);
|
| - RefPtr<FormData> httpBody = domFormData->createMultiPartFormData();
|
| - for (size_t i = 0; i < httpBody->elements().size(); ++i) {
|
| - const FormDataElement& element = httpBody->elements()[i];
|
| - switch (element.m_type) {
|
| - case FormDataElement::data: {
|
| - blobData->appendBytes(element.m_data.data(), element.m_data.size());
|
| - break;
|
| - }
|
| - case FormDataElement::encodedFile:
|
| - blobData->appendFile(element.m_filename, element.m_fileStart, element.m_fileLength, element.m_expectedFileModificationTime);
|
| - break;
|
| - case FormDataElement::encodedBlob:
|
| - if (element.m_optionalBlobDataHandle)
|
| - blobData->appendBlob(element.m_optionalBlobDataHandle, 0, element.m_optionalBlobDataHandle->size());
|
| - break;
|
| - case FormDataElement::encodedFileSystemURL:
|
| - blobData->appendFileSystemURL(element.m_fileSystemURL, element.m_fileStart, element.m_fileLength, element.m_expectedFileModificationTime);
|
| - break;
|
| - default:
|
| - ASSERT_NOT_REACHED();
|
| - }
|
| - }
|
| - blobData->setContentType(AtomicString("multipart/form-data; boundary=", AtomicString::ConstructFromLiteral) + httpBody->boundary().data());
|
| - } else if (body->IsString()) {
|
| - String stringValue(toUSVString(isolate, body, exceptionState));
|
| - blobData->appendText(stringValue, false);
|
| - blobData->setContentType("text/plain;charset=UTF-8");
|
| - } else {
|
| - return;
|
| + if (v8Body->IsArrayBuffer()) {
|
| + body = FetchFormDataConsumerHandle::create(V8ArrayBuffer::toImpl(v8::Local<v8::Object>::Cast(v8Body)));
|
| + } else if (v8Body->IsArrayBufferView()) {
|
| + body = FetchFormDataConsumerHandle::create(V8ArrayBufferView::toImpl(v8::Local<v8::Object>::Cast(v8Body)));
|
| + } else if (V8Blob::hasInstance(v8Body, isolate)) {
|
| + RefPtr<BlobDataHandle> blobDataHandle = V8Blob::toImpl(v8::Local<v8::Object>::Cast(v8Body))->blobDataHandle();
|
| + contentType = blobDataHandle->type();
|
| + body = FetchBlobDataConsumerHandle::create(context, blobDataHandle.release());
|
| + } else if (V8FormData::hasInstance(v8Body, isolate)) {
|
| + RefPtr<FormData> formData = V8FormData::toImpl(v8::Local<v8::Object>::Cast(v8Body))->createMultiPartFormData();
|
| + // Here we handle formData->boundary() as a C-style string. See
|
| + // FormDataBuilder::generateUniqueBoundaryString.
|
| + contentType = AtomicString("multipart/form-data; boundary=", AtomicString::ConstructFromLiteral) + formData->boundary().data();
|
| + body = FetchFormDataConsumerHandle::create(context, formData.release());
|
| + } else if (v8Body->IsString()) {
|
| + contentType = "text/plain;charset=UTF-8";
|
| + body = FetchFormDataConsumerHandle::create(toUSVString(isolate, v8Body, exceptionState));
|
| }
|
| - const long long blobSize = blobData->length();
|
| - bodyBlobHandle = BlobDataHandle::create(blobData.release(), blobSize);
|
| }
|
|
|
| }
|
|
|