| // Copyright (c) 2013 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. |
| |
| #ifndef NET_QUIC_PLATFORM_IMPL_QUIC_URL_UTILS_IMPL_H_ |
| #define NET_QUIC_PLATFORM_IMPL_QUIC_URL_UTILS_IMPL_H_ |
| |
| #include "base/macros.h" |
| #include "base/strings/string_piece.h" |
| #include "net/quic/core/quic_server_id.h" |
| #include "net/quic/platform/api/quic_export.h" |
| |
| namespace net { |
| |
| class QUIC_EXPORT_PRIVATE QuicUrlUtilsImpl { |
| public: |
| // Returns hostname, or empty std::string if missing. |
| static std::string HostName(base::StringPiece url); |
| |
| // Returns false if any of these conditions occur: (1) Host name too long; (2) |
| // Invalid characters in host name, path or params; (3) Invalid port number |
| // (e.g. greater than 65535). |
| static bool IsValidUrl(base::StringPiece url); |
| |
| // Returns true if the sni is valid, false otherwise. |
| // (1) disallow IP addresses; |
| // (2) check that the hostname contains valid characters only; and |
| // (3) contains at least one dot. |
| static bool IsValidSNI(base::StringPiece sni); |
| |
| // Convert hostname to lowercase and remove the trailing '.'. |
| // WARNING: mutates |hostname| in place and returns |hostname|. |
| static char* NormalizeHostname(char* hostname); |
| |
| // Creates a QuicServerId from a string formatted in same manner as |
| // QuicServerId::ToString(). |
| static void StringToQuicServerId(const std::string& str, QuicServerId* out); |
| |
| private: |
| DISALLOW_COPY_AND_ASSIGN(QuicUrlUtilsImpl); |
| }; |
| |
| } // namespace net |
| |
| #endif // NET_QUIC_PLATFORM_IMPL_QUIC_URL_UTILS_IMPL_H_ |