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 !v8Headers.IsEmpty() && !v8Headers->IsUndefined(); |
yhirano
2017/02/14 03:28:50
The same applies for null, I believe.
| |
37 exceptionState)) { | 38 areAnyMembersSet |= isHeadersSet; |
38 headers = Headers::create(headersVector, exceptionState); | 39 |
39 areAnyMembersSet = true; | |
40 } else { | |
41 areAnyMembersSet |= | |
42 DictionaryHelper::get(options, "headers", headersDictionary); | |
43 } | |
44 } | |
45 areAnyMembersSet |= DictionaryHelper::get(options, "mode", mode); | 40 areAnyMembersSet |= DictionaryHelper::get(options, "mode", mode); |
46 areAnyMembersSet |= DictionaryHelper::get(options, "redirect", redirect); | 41 areAnyMembersSet |= DictionaryHelper::get(options, "redirect", redirect); |
47 AtomicString referrerString; | 42 AtomicString referrerString; |
48 bool isReferrerStringSet = | 43 bool isReferrerStringSet = |
49 DictionaryHelper::get(options, "referrer", referrerString); | 44 DictionaryHelper::get(options, "referrer", referrerString); |
50 areAnyMembersSet |= isReferrerStringSet; | 45 areAnyMembersSet |= isReferrerStringSet; |
51 areAnyMembersSet |= DictionaryHelper::get(options, "integrity", integrity); | 46 areAnyMembersSet |= DictionaryHelper::get(options, "integrity", integrity); |
52 AtomicString referrerPolicyString; | 47 AtomicString referrerPolicyString; |
53 bool isReferrerPolicySet = | 48 bool isReferrerPolicySet = |
54 DictionaryHelper::get(options, "referrerPolicy", referrerPolicyString); | 49 DictionaryHelper::get(options, "referrerPolicy", referrerPolicyString); |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
92 referrer.referrerPolicy = | 87 referrer.referrerPolicy = |
93 ReferrerPolicyNoReferrerWhenDowngradeOriginWhenCrossOrigin; | 88 ReferrerPolicyNoReferrerWhenDowngradeOriginWhenCrossOrigin; |
94 } else { | 89 } else { |
95 exceptionState.throwTypeError("Invalid referrer policy"); | 90 exceptionState.throwTypeError("Invalid referrer policy"); |
96 return; | 91 return; |
97 } | 92 } |
98 } | 93 } |
99 } | 94 } |
100 | 95 |
101 v8::Isolate* isolate = toIsolate(context); | 96 v8::Isolate* isolate = toIsolate(context); |
97 | |
98 if (isHeadersSet) { | |
99 ByteStringSequenceSequenceOrDictionaryOrHeaders headersInit; | |
100 V8ByteStringSequenceSequenceOrDictionaryOrHeaders::toImpl( | |
101 isolate, v8Headers, headersInit, UnionTypeConversionMode::NotNullable, | |
102 exceptionState); | |
103 headers = Headers::create(headersInit, exceptionState); | |
104 } | |
105 | |
102 if (isCredentialSet) { | 106 if (isCredentialSet) { |
103 if (V8PasswordCredential::hasInstance(v8Credential, isolate)) { | 107 if (V8PasswordCredential::hasInstance(v8Credential, isolate)) { |
104 // TODO(mkwst): According to the spec, we'd serialize this once we touch | 108 // 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 | 109 // the network. We're serializing it here, ahead of time, because lifetime |
106 // issues around ResourceRequest make it pretty difficult to pass a | 110 // issues around ResourceRequest make it pretty difficult to pass a |
107 // PasswordCredential around at the platform level, and the hop between | 111 // PasswordCredential around at the platform level, and the hop between |
108 // the browser and renderer processes to deal with service workers is | 112 // the browser and renderer processes to deal with service workers is |
109 // equally painful. There should be no developer-visible difference in | 113 // equally painful. There should be no developer-visible difference in |
110 // behavior with this option, except that the `Content-Type` header will | 114 // behavior with this option, except that the `Content-Type` header will |
111 // be set early. That seems reasonable. | 115 // 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"); | 152 AtomicString("application/x-www-form-urlencoded;charset=UTF-8"); |
149 body = new FormDataBytesConsumer(context, formData.release()); | 153 body = new FormDataBytesConsumer(context, formData.release()); |
150 } else if (v8Body->IsString()) { | 154 } else if (v8Body->IsString()) { |
151 contentType = "text/plain;charset=UTF-8"; | 155 contentType = "text/plain;charset=UTF-8"; |
152 body = | 156 body = |
153 new FormDataBytesConsumer(toUSVString(isolate, v8Body, exceptionState)); | 157 new FormDataBytesConsumer(toUSVString(isolate, v8Body, exceptionState)); |
154 } | 158 } |
155 } | 159 } |
156 | 160 |
157 } // namespace blink | 161 } // namespace blink |
OLD | NEW |