Index: third_party/WebKit/Source/platform/network/LinkHeader.cpp |
diff --git a/third_party/WebKit/Source/platform/network/LinkHeader.cpp b/third_party/WebKit/Source/platform/network/LinkHeader.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..35d4739c05e682709854c2e215f2c4b71e976713 |
--- /dev/null |
+++ b/third_party/WebKit/Source/platform/network/LinkHeader.cpp |
@@ -0,0 +1,88 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "platform/network/LinkHeader.h" |
+ |
+#include "components/link_header_util/link_header_util.h" |
+#include "platform/ParsingUtilities.h" |
+ |
+namespace blink { |
+ |
+// Verify that the parameter is a link-extension which according to spec doesn't have to have a value. |
+static bool isExtensionParameter(LinkHeader::LinkParameterName name) |
+{ |
+ return name >= LinkHeader::LinkParameterUnknown; |
+} |
+ |
+static LinkHeader::LinkParameterName parameterNameFromString(const String& name) |
esprehn
2016/04/27 08:10:17
We could also take a base::StringPiece and use wha
Marijn Kruisselbrink
2016/05/11 00:36:56
Good point. Changed it to base::StringPiece and ba
|
+{ |
+ if (equalIgnoringCase(name, "rel")) |
esprehn
2016/04/27 08:10:17
This is unicode aware, the other code uses ASCII c
|
+ return LinkHeader::LinkParameterRel; |
+ if (equalIgnoringCase(name, "anchor")) |
+ return LinkHeader::LinkParameterAnchor; |
+ if (equalIgnoringCase(name, "crossorigin")) |
+ return LinkHeader::LinkParameterCrossOrigin; |
+ if (equalIgnoringCase(name, "title")) |
+ return LinkHeader::LinkParameterTitle; |
+ if (equalIgnoringCase(name, "media")) |
+ return LinkHeader::LinkParameterMedia; |
+ if (equalIgnoringCase(name, "type")) |
+ return LinkHeader::LinkParameterType; |
+ if (equalIgnoringCase(name, "rev")) |
+ return LinkHeader::LinkParameterRev; |
+ if (equalIgnoringCase(name, "hreflang")) |
+ return LinkHeader::LinkParameterHreflang; |
+ if (equalIgnoringCase(name, "as")) |
+ return LinkHeader::LinkParameterAs; |
+ return LinkHeader::LinkParameterUnknown; |
+} |
+ |
+void LinkHeader::setValue(LinkParameterName name, const String& value) |
+{ |
+ if (name == LinkParameterRel && !m_rel) |
+ m_rel = value.lower(); |
+ else if (name == LinkParameterAnchor) |
+ m_isValid = false; |
+ else if (name == LinkParameterCrossOrigin) |
+ m_crossOrigin = value; |
+ else if (name == LinkParameterAs) |
+ m_as = value.lower(); |
+ else if (name == LinkParameterType) |
+ m_mimeType = value.lower(); |
+ else if (name == LinkParameterMedia) |
+ m_media = value.lower(); |
+} |
+ |
+template <typename Iterator> |
esprehn
2016/04/27 08:10:17
why do we need the template?
Marijn Kruisselbrink
2016/05/11 00:36:56
Without a template the header file would need to i
|
+LinkHeader::LinkHeader(Iterator begin, Iterator end) |
+ : m_isValid(true) |
+{ |
+ std::string url; |
+ std::unordered_map<std::string, base::Optional<std::string>> params; |
+ m_isValid = link_header_util::ParseLinkHeaderValue(begin, end, &url, ¶ms); |
+ if (!m_isValid) |
+ return; |
+ |
+ m_url = String(&url[0], url.length()); |
esprehn
2016/04/27 08:10:17
It's always latin1?
Marijn Kruisselbrink
2016/05/11 00:36:56
LinkHeaderSet bellow DCHECKs to make sure it's alw
|
+ for (const auto& param : params) { |
+ LinkParameterName name = parameterNameFromString(String(¶m.first[0], param.first.length())); |
+ if (!isExtensionParameter(name) && !param.second) |
+ m_isValid = false; |
+ std::string value = param.second.value_or(""); |
+ setValue(name, String(&value[0], value.length())); |
+ } |
+} |
+ |
+LinkHeaderSet::LinkHeaderSet(const String& header) |
+{ |
+ if (header.isNull()) |
+ return; |
+ |
+ DCHECK(header.is8Bit()) << "Headers should always be 8 bit"; |
+ std::string headerString(reinterpret_cast<const char*>(header.characters8()), header.length()); |
+ for (const auto& value : link_header_util::SplitLinkHeader(headerString)) |
+ m_headerSet.append(LinkHeader(value.first, value.second)); |
+} |
+ |
+} // namespace blink |