| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "modules/fetch/RequestInit.h" | 5 #include "modules/fetch/RequestInit.h" |
| 6 | 6 |
| 7 #include "bindings/core/v8/Dictionary.h" | 7 #include "bindings/core/v8/Dictionary.h" |
| 8 #include "bindings/core/v8/V8ArrayBuffer.h" | 8 #include "bindings/core/v8/V8ArrayBuffer.h" |
| 9 #include "bindings/core/v8/V8ArrayBufferView.h" | 9 #include "bindings/core/v8/V8ArrayBufferView.h" |
| 10 #include "bindings/core/v8/V8Binding.h" | 10 #include "bindings/core/v8/V8Binding.h" |
| 11 #include "bindings/core/v8/V8Blob.h" | 11 #include "bindings/core/v8/V8Blob.h" |
| 12 #include "bindings/core/v8/V8FormData.h" | 12 #include "bindings/core/v8/V8FormData.h" |
| 13 #include "bindings/core/v8/V8URLSearchParams.h" | 13 #include "bindings/core/v8/V8URLSearchParams.h" |
| 14 #include "bindings/modules/v8/ByteStringSequenceSequenceOrDictionaryOrHeaders.h" |
| 14 #include "bindings/modules/v8/V8PasswordCredential.h" | 15 #include "bindings/modules/v8/V8PasswordCredential.h" |
| 15 #include "core/dom/URLSearchParams.h" | 16 #include "core/dom/URLSearchParams.h" |
| 16 #include "core/fileapi/Blob.h" | 17 #include "core/fileapi/Blob.h" |
| 17 #include "core/html/FormData.h" | 18 #include "core/html/FormData.h" |
| 18 #include "modules/fetch/BlobBytesConsumer.h" | 19 #include "modules/fetch/BlobBytesConsumer.h" |
| 19 #include "modules/fetch/FormDataBytesConsumer.h" | 20 #include "modules/fetch/FormDataBytesConsumer.h" |
| 20 #include "modules/fetch/Headers.h" | 21 #include "modules/fetch/Headers.h" |
| 21 #include "platform/RuntimeEnabledFeatures.h" | 22 #include "platform/RuntimeEnabledFeatures.h" |
| 22 #include "platform/blob/BlobData.h" | 23 #include "platform/blob/BlobData.h" |
| 23 #include "platform/network/EncodedFormData.h" | 24 #include "platform/network/EncodedFormData.h" |
| 24 #include "platform/weborigin/ReferrerPolicy.h" | 25 #include "platform/weborigin/ReferrerPolicy.h" |
| 25 | 26 |
| 26 namespace blink { | 27 namespace blink { |
| 27 | 28 |
| 28 RequestInit::RequestInit(ExecutionContext* context, | 29 RequestInit::RequestInit(ExecutionContext* context, |
| 29 const Dictionary& options, | 30 const Dictionary& options, |
| 30 ExceptionState& exceptionState) | 31 ExceptionState& exceptionState) |
| 31 : areAnyMembersSet(false) { | 32 : areAnyMembersSet(false) { |
| 32 areAnyMembersSet |= DictionaryHelper::get(options, "method", method); | 33 areAnyMembersSet |= DictionaryHelper::get(options, "method", method); |
| 33 areAnyMembersSet |= DictionaryHelper::get(options, "headers", headers); | 34 |
| 34 if (!headers) { | 35 v8::Local<v8::Value> v8Headers; |
| 35 Vector<Vector<String>> headersVector; | 36 bool isHeadersSet = DictionaryHelper::get(options, "headers", v8Headers); |
| 36 if (DictionaryHelper::get(options, "headers", headersVector, | 37 areAnyMembersSet |= isHeadersSet; |
| 37 exceptionState)) { | 38 |
| 38 headers = Headers::create(headersVector, exceptionState); | |
| 39 areAnyMembersSet = true; | |
| 40 } else { | |
| 41 areAnyMembersSet |= | |
| 42 DictionaryHelper::get(options, "headers", headersDictionary); | |
| 43 } | |
| 44 } | |
| 45 areAnyMembersSet |= DictionaryHelper::get(options, "mode", mode); | 39 areAnyMembersSet |= DictionaryHelper::get(options, "mode", mode); |
| 46 areAnyMembersSet |= DictionaryHelper::get(options, "redirect", redirect); | 40 areAnyMembersSet |= DictionaryHelper::get(options, "redirect", redirect); |
| 47 AtomicString referrerString; | 41 AtomicString referrerString; |
| 48 bool isReferrerStringSet = | 42 bool isReferrerStringSet = |
| 49 DictionaryHelper::get(options, "referrer", referrerString); | 43 DictionaryHelper::get(options, "referrer", referrerString); |
| 50 areAnyMembersSet |= isReferrerStringSet; | 44 areAnyMembersSet |= isReferrerStringSet; |
| 51 areAnyMembersSet |= DictionaryHelper::get(options, "integrity", integrity); | 45 areAnyMembersSet |= DictionaryHelper::get(options, "integrity", integrity); |
| 52 AtomicString referrerPolicyString; | 46 AtomicString referrerPolicyString; |
| 53 bool isReferrerPolicySet = | 47 bool isReferrerPolicySet = |
| 54 DictionaryHelper::get(options, "referrerPolicy", referrerPolicyString); | 48 DictionaryHelper::get(options, "referrerPolicy", referrerPolicyString); |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 92 referrer.referrerPolicy = | 86 referrer.referrerPolicy = |
| 93 ReferrerPolicyNoReferrerWhenDowngradeOriginWhenCrossOrigin; | 87 ReferrerPolicyNoReferrerWhenDowngradeOriginWhenCrossOrigin; |
| 94 } else { | 88 } else { |
| 95 exceptionState.throwTypeError("Invalid referrer policy"); | 89 exceptionState.throwTypeError("Invalid referrer policy"); |
| 96 return; | 90 return; |
| 97 } | 91 } |
| 98 } | 92 } |
| 99 } | 93 } |
| 100 | 94 |
| 101 v8::Isolate* isolate = toIsolate(context); | 95 v8::Isolate* isolate = toIsolate(context); |
| 96 |
| 97 if (isHeadersSet) { |
| 98 ByteStringSequenceSequenceOrDictionaryOrHeaders headersInit; |
| 99 V8ByteStringSequenceSequenceOrDictionaryOrHeaders::toImpl( |
| 100 isolate, v8Headers, headersInit, UnionTypeConversionMode::NotNullable, |
| 101 exceptionState); |
| 102 headers = Headers::create(headersInit, exceptionState); |
| 103 } |
| 104 |
| 102 if (isCredentialSet) { | 105 if (isCredentialSet) { |
| 103 if (V8PasswordCredential::hasInstance(v8Credential, isolate)) { | 106 if (V8PasswordCredential::hasInstance(v8Credential, isolate)) { |
| 104 // TODO(mkwst): According to the spec, we'd serialize this once we touch | 107 // TODO(mkwst): According to the spec, we'd serialize this once we touch |
| 105 // the network. We're serializing it here, ahead of time, because lifetime | 108 // the network. We're serializing it here, ahead of time, because lifetime |
| 106 // issues around ResourceRequest make it pretty difficult to pass a | 109 // issues around ResourceRequest make it pretty difficult to pass a |
| 107 // PasswordCredential around at the platform level, and the hop between | 110 // PasswordCredential around at the platform level, and the hop between |
| 108 // the browser and renderer processes to deal with service workers is | 111 // the browser and renderer processes to deal with service workers is |
| 109 // equally painful. There should be no developer-visible difference in | 112 // equally painful. There should be no developer-visible difference in |
| 110 // behavior with this option, except that the `Content-Type` header will | 113 // behavior with this option, except that the `Content-Type` header will |
| 111 // be set early. That seems reasonable. | 114 // be set early. That seems reasonable. |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 148 AtomicString("application/x-www-form-urlencoded;charset=UTF-8"); | 151 AtomicString("application/x-www-form-urlencoded;charset=UTF-8"); |
| 149 body = new FormDataBytesConsumer(context, formData.release()); | 152 body = new FormDataBytesConsumer(context, formData.release()); |
| 150 } else if (v8Body->IsString()) { | 153 } else if (v8Body->IsString()) { |
| 151 contentType = "text/plain;charset=UTF-8"; | 154 contentType = "text/plain;charset=UTF-8"; |
| 152 body = | 155 body = |
| 153 new FormDataBytesConsumer(toUSVString(isolate, v8Body, exceptionState)); | 156 new FormDataBytesConsumer(toUSVString(isolate, v8Body, exceptionState)); |
| 154 } | 157 } |
| 155 } | 158 } |
| 156 | 159 |
| 157 } // namespace blink | 160 } // namespace blink |
| OLD | NEW |