From f5f56e1a1c4d9e9496fcb9d81131066a964ccd23 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 13 Apr 2024 14:15:43 +0200 Subject: Adding upstream version 2.4.1. Signed-off-by: Daniel Baumann --- src/lib/http/url.h | 131 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 131 insertions(+) create mode 100644 src/lib/http/url.h (limited to 'src/lib/http/url.h') diff --git a/src/lib/http/url.h b/src/lib/http/url.h new file mode 100644 index 0000000..d6ec9e2 --- /dev/null +++ b/src/lib/http/url.h @@ -0,0 +1,131 @@ +// Copyright (C) 2017-2022 Internet Systems Consortium, Inc. ("ISC") +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +#ifndef KEA_URL_H +#define KEA_URL_H + +#include +#include + +namespace isc { +namespace http { + +/// @brief Represents an URL. +/// +/// It parses the provided URL and allows for retrieving the parts +/// of it after parsing. +class Url { +public: + + /// @brief Scheme: https or http. + enum Scheme { + HTTP, + HTTPS + }; + + /// @brief Constructor. + /// + /// Parses provided URL. + /// + /// @param url URL. + explicit Url(const std::string& url); + + /// @brief compares URLs lexically. + /// + /// Both URLs are compared as text. + /// + /// @param url URL to be compared with + /// @return true if the other operator is larger (in lexical sense) + bool operator<(const Url& url) const; + + /// @brief Checks if the URL is valid. + /// + /// @return true if the URL is valid, false otherwise. + bool isValid() const { + return (valid_); + } + + /// @brief Returns parsing error message. + std::string getErrorMessage() const { + return (error_message_); + } + + /// @brief Returns parsed scheme. + /// + /// @throw InvalidOperation if URL is invalid. + Scheme getScheme() const; + + /// @brief Returns hostname stripped from [ ] characters surrounding + /// IPv6 address. + /// + /// @throw InvalidOperation if URL is invalid. + std::string getStrippedHostname() const; + + /// @brief Returns port number. + /// + /// @return Port number or 0 if URL doesn't contain port number. + /// @throw InvalidOperation if URL is invalid. + unsigned getPort() const; + + /// @brief Returns path. + /// + /// @return URL path + /// @throw InvalidOperation if URL is invalid. + std::string getPath() const; + + /// @brief Returns textual representation of the URL. + /// + /// @return Text version of the URL. + std::string toText() const; + + /// @brief Returns the raw, unparsed URL string. + /// + /// @return Unparsed URL string. + const std::string& rawUrl() const { + return (url_); + } + +private: + /// @brief Returns hostname. + /// + /// @throw InvalidOperation if URL is invalid. + std::string getHostname() const; + + /// @brief Returns boolean value indicating if the URL is valid. + void checkValid() const; + + /// @brief Parses URL. + /// + /// This method doesn't throw an exception. Call @c isValid to see + /// if the URL is valid. + void parse(); + + /// @brief Holds specified URL. + std::string url_; + + /// @brief A flag indicating if the URL is valid. + bool valid_; + + /// @brief Holds error message after parsing. + std::string error_message_; + + /// @brief Parsed scheme. + Scheme scheme_; + + /// @brief Parsed hostname. + std::string hostname_; + + /// @brief Parsed port number. + unsigned port_; + + /// @brief Parsed path. + std::string path_; +}; + +} // end of namespace isc::http +} // end of namespace isc + +#endif // endif -- cgit v1.2.3