// Copyright (C) 2021 The Qt Company Ltd. // SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only #include #include QT_BEGIN_NAMESPACE using LoadStatus = QWebEngineLoadingInfo::LoadStatus; using ErrorDomain = QWebEngineLoadingInfo::ErrorDomain; Q_STATIC_ASSERT(static_cast(WebEngineError::NoErrorDomain) == static_cast(ErrorDomain::NoErrorDomain)); Q_STATIC_ASSERT(static_cast(WebEngineError::InternalErrorDomain) == static_cast(ErrorDomain::InternalErrorDomain)); Q_STATIC_ASSERT(static_cast(WebEngineError::ConnectionErrorDomain) == static_cast(ErrorDomain::ConnectionErrorDomain)); Q_STATIC_ASSERT(static_cast(WebEngineError::CertificateErrorDomain) == static_cast(ErrorDomain::CertificateErrorDomain)); Q_STATIC_ASSERT(static_cast(WebEngineError::HttpErrorDomain) == static_cast(ErrorDomain::HttpErrorDomain)); Q_STATIC_ASSERT(static_cast(WebEngineError::FtpErrorDomain) == static_cast(ErrorDomain::FtpErrorDomain)); Q_STATIC_ASSERT(static_cast(WebEngineError::DnsErrorDomain) == static_cast(ErrorDomain::DnsErrorDomain)); Q_STATIC_ASSERT(static_cast(WebEngineError::HttpStatusCodeDomain) == static_cast(ErrorDomain::HttpStatusCodeDomain)); class QWebEngineLoadingInfo::QWebEngineLoadingInfoPrivate : public QSharedData { public: QWebEngineLoadingInfoPrivate(const QUrl& url, LoadStatus status, bool isErrorPage, const QString& errorString, int errorCode, ErrorDomain errorDomain, const QHash& responseHeaders) : url(url) , status(status) , isErrorPage(isErrorPage) , errorString(errorString) , errorCode(errorCode) , errorDomain(errorDomain) , responseHeaders(responseHeaders) { } QUrl url; LoadStatus status; bool isErrorPage; QString errorString; int errorCode; ErrorDomain errorDomain; QHash responseHeaders; }; /*! \class QWebEngineLoadingInfo \brief A utility type for the WebEngineView::loadingChanged signal. \inmodule QtWebEngineCore \since 6.2 Contains information about a web page loading status change, such as the URL and current loading status (started, succeeded, stopped, failed). \sa QWebEnginePage::loadStarted, QWebEnginePage::loadFinished, WebEngineView::loadingChanged */ QWebEngineLoadingInfo::QWebEngineLoadingInfo(const QUrl& url, LoadStatus status, bool isErrorPage, const QString& errorString, int errorCode, ErrorDomain errorDomain, const QHash& responseHeaders) : d_ptr(new QWebEngineLoadingInfoPrivate(url, status, isErrorPage, errorString, errorCode, errorDomain, responseHeaders)) { } QWebEngineLoadingInfo::QWebEngineLoadingInfo(const QWebEngineLoadingInfo &other) = default; QWebEngineLoadingInfo& QWebEngineLoadingInfo::operator=(const QWebEngineLoadingInfo &other) = default; QWebEngineLoadingInfo::QWebEngineLoadingInfo(QWebEngineLoadingInfo &&other) = default; QWebEngineLoadingInfo& QWebEngineLoadingInfo::operator=(QWebEngineLoadingInfo &&other) = default; QWebEngineLoadingInfo::~QWebEngineLoadingInfo() { } /*! \property QWebEngineLoadingInfo::url \brief Holds the URL of the load request. */ /*! Returns the URL of the load request. */ QUrl QWebEngineLoadingInfo::url() const { Q_D(const QWebEngineLoadingInfo); return d->url; } /*! \enum QWebEngineLoadingInfo::LoadStatus This enumeration represents the load status of a web page load request: \value LoadStartedStatus Page is currently loading. \value LoadStoppedStatus Loading the page was stopped by the stop() method or by the loader code or network stack in Chromium. \value LoadSucceededStatus Page has been loaded with success. \value LoadFailedStatus Page could not be loaded. */ /*! \property QWebEngineLoadingInfo::status \brief The load status of the page. */ LoadStatus QWebEngineLoadingInfo::status() const { Q_D(const QWebEngineLoadingInfo); return d->status; } /*! \property QWebEngineLoadingInfo::isErrorPage \brief Indicates if the load resulted in an error page. */ bool QWebEngineLoadingInfo::isErrorPage() const { Q_D(const QWebEngineLoadingInfo); return d->isErrorPage; } /*! \property QWebEngineLoadingInfo::errorString \brief Holds the error message. */ QString QWebEngineLoadingInfo::errorString() const { Q_D(const QWebEngineLoadingInfo); return d->errorString; } /*! \enum QWebEngineLoadingInfo::ErrorDomain This enumeration holds the type of a load error: \value NoErrorDomain Error type is not known. \value InternalErrorDomain Content cannot be interpreted by \QWE. \value ConnectionErrorDomain Error results from a faulty network connection. \value CertificateErrorDomain Error is related to the SSL/TLS certificate. \value HttpErrorDomain Error is related to the HTTP connection. \value FtpErrorDomain Error is related to the FTP connection. \value DnsErrorDomain Error is related to the DNS connection. \value HttpStatusCodeDomain Error is the HTTP response status code, even in case of success e.g. the server replied with status 200. */ /* \property QWebEngineLoadingInfo::errorDomain \brief Holds the error domain. */ ErrorDomain QWebEngineLoadingInfo::errorDomain() const { Q_D(const QWebEngineLoadingInfo); return d->errorDomain; } /*! \property QWebEngineLoadingInfo::errorCode \brief Holds the error code. */ int QWebEngineLoadingInfo::errorCode() const { Q_D(const QWebEngineLoadingInfo); return d->errorCode; } /*! \property QWebEngineLoadingInfo::responseHeaders \brief Holds the response headers when \c QWebEngineLoadingInfo::status() is equal to \c QWebEngineLoadingInfo::LoadSucceededStatus or \c QWebEngineLoadingInfo::LoadFailedStatus. */ QHash QWebEngineLoadingInfo::responseHeaders() const { Q_D(const QWebEngineLoadingInfo); return d->responseHeaders; } QT_END_NAMESPACE #include "moc_qwebengineloadinginfo.cpp"