| 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 "config.h" | 5 #include "config.h" |
| 6 #include "FetchRequestData.h" | 6 #include "FetchRequestData.h" |
| 7 | 7 |
| 8 #include "core/dom/Document.h" | 8 #include "core/dom/Document.h" |
| 9 #include "core/dom/ExecutionContext.h" | 9 #include "core/dom/ExecutionContext.h" |
| 10 #include "core/fetch/ResourceLoaderOptions.h" | 10 #include "core/fetch/ResourceLoaderOptions.h" |
| 11 #include "core/loader/ThreadableLoader.h" | 11 #include "core/loader/ThreadableLoader.h" |
| 12 #include "modules/serviceworkers/FetchHeaderList.h" | 12 #include "modules/serviceworkers/FetchHeaderList.h" |
| 13 #include "platform/network/ResourceRequest.h" | 13 #include "platform/network/ResourceRequest.h" |
| 14 #include "public/platform/WebServiceWorkerRequest.h" | 14 #include "public/platform/WebServiceWorkerRequest.h" |
| 15 #include "public/platform/WebURLRequest.h" | 15 #include "public/platform/WebURLRequest.h" |
| 16 | 16 |
| 17 namespace blink { | 17 namespace blink { |
| 18 | 18 |
| 19 FetchRequestData* FetchRequestData::create() | 19 FetchRequestData* FetchRequestData::create() |
| 20 { | 20 { |
| 21 return new FetchRequestData(); | 21 return new FetchRequestData(); |
| 22 } | 22 } |
| 23 | 23 |
| 24 FetchRequestData* FetchRequestData::create(ExecutionContext* context) | |
| 25 { | |
| 26 FetchRequestData* request = FetchRequestData::create(); | |
| 27 if (context->isDocument()) | |
| 28 request->m_referrer.setClient(blink::Referrer(context->url().strippedFor
UseAsReferrer(), toDocument(context)->referrerPolicy())); | |
| 29 else | |
| 30 request->m_referrer.setClient(blink::Referrer(context->url().strippedFor
UseAsReferrer(), ReferrerPolicyDefault)); | |
| 31 return request; | |
| 32 } | |
| 33 | |
| 34 FetchRequestData* FetchRequestData::create(const WebServiceWorkerRequest& webReq
uest) | 24 FetchRequestData* FetchRequestData::create(const WebServiceWorkerRequest& webReq
uest) |
| 35 { | 25 { |
| 36 FetchRequestData* request = FetchRequestData::create(); | 26 FetchRequestData* request = FetchRequestData::create(); |
| 37 request->m_url = webRequest.url(); | 27 request->m_url = webRequest.url(); |
| 38 request->m_method = webRequest.method(); | 28 request->m_method = webRequest.method(); |
| 39 for (HTTPHeaderMap::const_iterator it = webRequest.headers().begin(); it !=
webRequest.headers().end(); ++it) | 29 for (HTTPHeaderMap::const_iterator it = webRequest.headers().begin(); it !=
webRequest.headers().end(); ++it) |
| 40 request->m_headerList->append(it->key, it->value); | 30 request->m_headerList->append(it->key, it->value); |
| 41 request->m_blobDataHandle = webRequest.blobDataHandle(); | 31 request->m_blobDataHandle = webRequest.blobDataHandle(); |
| 42 request->m_referrer.setURL(webRequest.referrer()); | 32 request->m_referrer.setURL(webRequest.referrer()); |
| 43 request->setMode(webRequest.mode()); | 33 request->setMode(webRequest.mode()); |
| 44 request->setCredentials(webRequest.credentialsMode()); | 34 request->setCredentials(webRequest.credentialsMode()); |
| 45 return request; | 35 return request; |
| 46 } | 36 } |
| 47 | 37 |
| 48 FetchRequestData* FetchRequestData::createRestrictedCopy(ExecutionContext* conte
xt, PassRefPtr<SecurityOrigin> origin) const | 38 FetchRequestData* FetchRequestData::createRestrictedCopy(ExecutionContext* conte
xt, PassRefPtr<SecurityOrigin> origin) const |
| 49 { | 39 { |
| 50 // "To make a restricted copy of a request |request|, run these steps: | 40 // "To make a restricted copy of a request |request|, run these steps: |
| 51 // 1. Let |r| be a new request whose url is |request|'s url, method is | 41 // 1. Let |r| be a new request whose url is |request|'s url, method is |
| 52 // |request|'s method, header list is a copy of |request|'s header list, | 42 // |request|'s method, header list is a copy of |request|'s header list, |
| 53 // body is a tee of |request|'s body, client is entry settings object's | 43 // body is a tee of |request|'s body, client is entry settings object's |
| 54 // global object, origin is entry settings object's origin, referrer is | 44 // global object, origin is entry settings object's origin, referrer is |
| 55 // |client|, context is |connect|, mode is |request|'s mode, and credentials | 45 // |client|, context is |connect|, mode is |request|'s mode, and credentials |
| 56 // mode is |request|'s credentials mode." | 46 // mode is |request|'s credentials mode." |
| 57 FetchRequestData* request = FetchRequestData::create(); | 47 FetchRequestData* request = FetchRequestData::create(); |
| 58 request->m_url = m_url; | 48 request->m_url = m_url; |
| 59 request->m_method = m_method; | 49 request->m_method = m_method; |
| 60 request->m_headerList = m_headerList->createCopy(); | 50 request->m_headerList = m_headerList->createCopy(); |
| 61 request->m_blobDataHandle = m_blobDataHandle; | 51 request->m_blobDataHandle = m_blobDataHandle; |
| 62 request->m_origin = origin; | 52 request->m_origin = origin; |
| 63 if (context->isDocument()) | 53 request->m_referrer.setClient(); |
| 64 request->m_referrer.setClient(blink::Referrer(context->url().strippedFor
UseAsReferrer(), toDocument(context)->referrerPolicy())); | |
| 65 else | |
| 66 request->m_referrer.setClient(blink::Referrer(context->url().strippedFor
UseAsReferrer(), ReferrerPolicyDefault)); | |
| 67 request->m_context = WebURLRequest::RequestContextFetch; | 54 request->m_context = WebURLRequest::RequestContextFetch; |
| 68 request->m_mode = m_mode; | 55 request->m_mode = m_mode; |
| 69 request->m_credentials = m_credentials; | 56 request->m_credentials = m_credentials; |
| 70 // "2. Return |r|." | 57 // "2. Return |r|." |
| 71 return request; | 58 return request; |
| 72 } | 59 } |
| 73 | 60 |
| 74 FetchRequestData* FetchRequestData::createCopy() const | 61 FetchRequestData* FetchRequestData::createCopy() const |
| 75 { | 62 { |
| 76 FetchRequestData* request = FetchRequestData::create(); | 63 FetchRequestData* request = FetchRequestData::create(); |
| (...skipping 27 matching lines...) Expand all Loading... |
| 104 , m_responseTainting(BasicTainting) | 91 , m_responseTainting(BasicTainting) |
| 105 { | 92 { |
| 106 } | 93 } |
| 107 | 94 |
| 108 void FetchRequestData::trace(Visitor* visitor) | 95 void FetchRequestData::trace(Visitor* visitor) |
| 109 { | 96 { |
| 110 visitor->trace(m_headerList); | 97 visitor->trace(m_headerList); |
| 111 } | 98 } |
| 112 | 99 |
| 113 } // namespace blink | 100 } // namespace blink |
| OLD | NEW |