OLD | NEW |
(Empty) | |
| 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 |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "config.h" |
| 6 #include "FetchResponseData.h" |
| 7 |
| 8 #include "core/fetch/CrossOriginAccessControl.h" |
| 9 #include "modules/serviceworkers/FetchHeaderList.h" |
| 10 #include "public/platform/WebServiceWorkerResponse.h" |
| 11 |
| 12 namespace WebCore { |
| 13 |
| 14 PassRefPtr<FetchResponseData> FetchResponseData::create() |
| 15 { |
| 16 // "Unless stated otherwise, a response's url is null, status is 200, status |
| 17 // message is `OK`, header list is an empty header list, and body is null." |
| 18 return adoptRef(new FetchResponseData(DefaultType, 200, "OK")); |
| 19 } |
| 20 |
| 21 PassRefPtr<FetchResponseData> FetchResponseData::createNetworkErrorResponse() |
| 22 { |
| 23 // "A network error is a response whose status is always 0, status message |
| 24 // is always the empty byte sequence, header list is aways an empty list, |
| 25 // and body is always null." |
| 26 return adoptRef(new FetchResponseData(ErrorType, 0, "")); |
| 27 } |
| 28 |
| 29 PassRefPtr<FetchResponseData> FetchResponseData::createBasicFilteredResponse() |
| 30 { |
| 31 // "A basic filtered response is a filtered response whose type is |basic|, |
| 32 // header list excludes any headers in internal response's header list whose |
| 33 // name is `Set-Cookie` or `Set-Cookie2`." |
| 34 RefPtr<FetchResponseData> response = adoptRef(new FetchResponseData(BasicTyp
e, m_status, m_statusMessage)); |
| 35 response->m_url = m_url; |
| 36 for (size_t i = 0; i < m_headerList->size(); ++i) { |
| 37 const FetchHeaderList::Header* header = m_headerList->list()[i].get(); |
| 38 if (header->first == "set-cookie" || header->first == "set-cookie2") |
| 39 continue; |
| 40 response->m_headerList->append(header->first, header->second); |
| 41 } |
| 42 response->m_blobDataHandle = m_blobDataHandle; |
| 43 response->m_internalResponse = this; |
| 44 return response.release(); |
| 45 } |
| 46 |
| 47 PassRefPtr<FetchResponseData> FetchResponseData::createCORSFilteredResponse() |
| 48 { |
| 49 // "A CORS filtered response is a filtered response whose type is |CORS|, |
| 50 // header list excludes all headers in internal response's header list, |
| 51 // except those whose name is either one of `Cache-Control`, |
| 52 // `Content-Language`, `Content-Type`, `Expires`, `Last-Modified`, and |
| 53 // `Pragma`, and except those whose name is one of the values resulting from |
| 54 // parsing `Access-Control-Expose-Headers` in internal response's header |
| 55 // list." |
| 56 RefPtr<FetchResponseData> response = adoptRef(new FetchResponseData(CORSType
, m_status, m_statusMessage)); |
| 57 response->m_url = m_url; |
| 58 HTTPHeaderSet accessControlExposeHeaderSet; |
| 59 String accessControlExposeHeaders; |
| 60 if (m_headerList->get("access-control-expose-headers", accessControlExposeHe
aders)) |
| 61 parseAccessControlExposeHeadersAllowList(accessControlExposeHeaders, acc
essControlExposeHeaderSet); |
| 62 for (size_t i = 0; i < m_headerList->size(); ++i) { |
| 63 const FetchHeaderList::Header* header = m_headerList->list()[i].get(); |
| 64 if (!isOnAccessControlResponseHeaderWhitelist(header->first) && !accessC
ontrolExposeHeaderSet.contains(header->first)) |
| 65 continue; |
| 66 response->m_headerList->append(header->first, header->second); |
| 67 } |
| 68 response->m_blobDataHandle = m_blobDataHandle; |
| 69 response->m_internalResponse = this; |
| 70 return response.release(); |
| 71 } |
| 72 |
| 73 PassRefPtr<FetchResponseData> FetchResponseData::createOpaqueFilteredResponse() |
| 74 { |
| 75 // "An opaque filtered response is a filtered response whose type is |
| 76 // |opaque|, status is 0, status message is the empty byte sequence, header |
| 77 // list is an empty list, and body is null." |
| 78 RefPtr<FetchResponseData> response = adoptRef(new FetchResponseData(OpaqueTy
pe, 0, "")); |
| 79 response->m_internalResponse = this; |
| 80 return response.release(); |
| 81 } |
| 82 |
| 83 void FetchResponseData::populateWebServiceWorkerResponse(blink::WebServiceWorker
Response& response) |
| 84 { |
| 85 if (m_internalResponse) { |
| 86 m_internalResponse->populateWebServiceWorkerResponse(response); |
| 87 return; |
| 88 } |
| 89 response.setURL(url()); |
| 90 response.setStatus(status()); |
| 91 response.setStatusText(statusMessage()); |
| 92 for (size_t i = 0; i < headerList()->size(); ++i) { |
| 93 const FetchHeaderList::Header* header = headerList()->list()[i].get(); |
| 94 response.setHeader(header->first, header->second); |
| 95 } |
| 96 response.setBlobDataHandle(blobDataHandle()); |
| 97 } |
| 98 |
| 99 FetchResponseData::FetchResponseData(Type type, unsigned short status, AtomicStr
ing statusMessage) |
| 100 : m_type(type) |
| 101 , m_status(status) |
| 102 , m_statusMessage(statusMessage) |
| 103 , m_headerList(FetchHeaderList::create()) |
| 104 { |
| 105 } |
| 106 |
| 107 } // namespace WebCore |
OLD | NEW |