mirror of https://github.com/tfussell/xlnt
240 lines
6.5 KiB
C++
240 lines
6.5 KiB
C++
// Copyright (c) 2014-2018 Thomas Fussell
|
|
//
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
// of this software and associated documentation files (the "Software"), to deal
|
|
// in the Software without restriction, including without limitation the rights
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
// copies of the Software, and to permit persons to whom the Software is
|
|
// furnished to do so, subject to the following conditions:
|
|
//
|
|
// The above copyright notice and this permission notice shall be included in
|
|
// all copies or substantial portions of the Software.
|
|
//
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, WRISING FROM,
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
// THE SOFTWARE
|
|
//
|
|
// @license: http://www.opensource.org/licenses/mit-license.php
|
|
// @author: see AUTHORS file
|
|
|
|
#pragma once
|
|
|
|
#include <string>
|
|
|
|
#include <xlnt/xlnt_config.hpp>
|
|
#include <xlnt/utils/path.hpp>
|
|
|
|
namespace xlnt {
|
|
|
|
/// <summary>
|
|
/// Encapsulates a uniform resource identifier (URI) as described
|
|
/// by RFC 3986.
|
|
/// </summary>
|
|
class XLNT_API uri
|
|
{
|
|
public:
|
|
/// <summary>
|
|
/// Constructs an empty URI.
|
|
/// </summary>
|
|
uri();
|
|
|
|
/// <summary>
|
|
/// Constructs a URI by combining base with relative.
|
|
/// </summary>
|
|
uri(const uri &base, const uri &relative);
|
|
|
|
/// <summary>
|
|
/// Constructs a URI by combining base with relative path.
|
|
/// </summary>
|
|
uri(const uri &base, const path &relative);
|
|
|
|
/// <summary>
|
|
/// Constructs a URI by parsing the given uri_string.
|
|
/// </summary>
|
|
uri(const std::string &uri_string);
|
|
|
|
/// <summary>
|
|
/// Returns true if this URI is relative.
|
|
/// </summary>
|
|
bool is_relative() const;
|
|
|
|
/// <summary>
|
|
/// Returns true if this URI is not relative (i.e. absolute).
|
|
/// </summary>
|
|
bool is_absolute() const;
|
|
|
|
/// <summary>
|
|
/// Returns the scheme of this URI.
|
|
/// E.g. the scheme of http://user:pass@example.com is "http"
|
|
/// </summary>
|
|
std::string scheme() const;
|
|
|
|
/// <summary>
|
|
/// Returns the authority of this URI.
|
|
/// E.g. the authority of http://user:pass@example.com:80/document is "user:pass@example.com:80"
|
|
/// </summary>
|
|
std::string authority() const;
|
|
|
|
/// <summary>
|
|
/// Returns true if an authentication section is specified for this URI.
|
|
/// </summary>
|
|
bool has_authentication() const;
|
|
|
|
/// <summary>
|
|
/// Returns the authentication of this URI.
|
|
/// E.g. the authentication of http://user:pass@example.com is "user:pass"
|
|
/// </summary>
|
|
std::string authentication() const;
|
|
|
|
/// <summary>
|
|
/// Returns the username of this URI.
|
|
/// E.g. the username of http://user:pass@example.com is "user"
|
|
/// </summary>
|
|
std::string username() const;
|
|
|
|
/// <summary>
|
|
/// Returns the password of this URI.
|
|
/// E.g. the password of http://user:pass@example.com is "pass"
|
|
/// </summary>
|
|
std::string password() const;
|
|
|
|
/// <summary>
|
|
/// Returns the host of this URI.
|
|
/// E.g. the host of http://example.com:80/document is "example.com"
|
|
/// </summary>
|
|
std::string host() const;
|
|
|
|
/// <summary>
|
|
/// Returns true if a non-default port is specified for this URI.
|
|
/// </summary>
|
|
bool has_port() const;
|
|
|
|
/// <summary>
|
|
/// Returns the port of this URI.
|
|
/// E.g. the port of https://example.com:443/document is "443"
|
|
/// </summary>
|
|
std::size_t port() const;
|
|
|
|
/// <summary>
|
|
/// Returns the path of this URI.
|
|
/// E.g. the path of http://example.com/document is "/document"
|
|
/// </summary>
|
|
class path path() const;
|
|
|
|
/// <summary>
|
|
/// Returns true if this URI has a non-null query string section.
|
|
/// </summary>
|
|
bool has_query() const;
|
|
|
|
/// <summary>
|
|
/// Returns the query string of this URI.
|
|
/// E.g. the query of http://example.com/document?v=1&x=3#abc is "v=1&x=3"
|
|
/// </summary>
|
|
std::string query() const;
|
|
|
|
/// <summary>
|
|
/// Returns true if this URI has a non-empty fragment section.
|
|
/// </summary>
|
|
bool has_fragment() const;
|
|
|
|
/// <summary>
|
|
/// Returns the fragment section of this URI.
|
|
/// E.g. the fragment of http://example.com/document#abc is "abc"
|
|
/// </summary>
|
|
std::string fragment() const;
|
|
|
|
/// <summary>
|
|
/// Returns a string representation of this URI.
|
|
/// </summary>
|
|
std::string to_string() const;
|
|
|
|
/// <summary>
|
|
/// If this URI is relative, an absolute URI will be returned by appending
|
|
/// the path to the given absolute base URI.
|
|
/// </summary>
|
|
uri make_absolute(const uri &base);
|
|
|
|
/// <summary>
|
|
/// If this URI is absolute, a relative URI will be returned by removing the
|
|
/// common base path from the given absolute base URI.
|
|
/// </summary>
|
|
uri make_reference(const uri &base);
|
|
|
|
/// <summary>
|
|
/// Returns true if this URI is equivalent to other.
|
|
/// </summary>
|
|
bool operator==(const uri &other) const;
|
|
|
|
private:
|
|
/// <summary>
|
|
/// True if this URI is absolute.
|
|
/// </summary>
|
|
bool absolute_ = false;
|
|
|
|
/// <summary>
|
|
/// The scheme, like "http"
|
|
/// </summary>
|
|
std::string scheme_;
|
|
|
|
/// <summary>
|
|
/// True if this URI has an authentication section.
|
|
/// </summary>
|
|
bool has_authentication_ = false;
|
|
|
|
/// <summary>
|
|
/// The username
|
|
/// </summary>
|
|
std::string username_;
|
|
|
|
/// <summary>
|
|
/// The password
|
|
/// </summary>
|
|
std::string password_;
|
|
|
|
/// <summary>
|
|
/// The host
|
|
/// </summary>
|
|
std::string host_;
|
|
|
|
/// <summary>
|
|
/// True if this URI has a non-default port specified
|
|
/// </summary>
|
|
bool has_port_ = false;
|
|
|
|
/// <summary>
|
|
/// The numeric port
|
|
/// </summary>
|
|
std::size_t port_ = 0;
|
|
|
|
/// <summary>
|
|
/// True if this URI has a query section
|
|
/// </summary>
|
|
bool has_query_ = false;
|
|
|
|
/// <summary>
|
|
/// The query section
|
|
/// </summary>
|
|
std::string query_;
|
|
|
|
/// <summary>
|
|
/// True if this URI has a fragment section
|
|
/// </summary>
|
|
bool has_fragment_ = false;
|
|
|
|
/// <summary>
|
|
/// The fragment section
|
|
/// </summary>
|
|
std::string fragment_;
|
|
|
|
/// <summary>
|
|
/// The path section
|
|
/// </summary>
|
|
class path path_;
|
|
};
|
|
|
|
} // namespace xlnt
|