mirror of
https://invent.kde.org/network/falkon.git
synced 2024-11-14 19:12:11 +01:00
NetworkManager: Add support for "extension://" scheme
This commit is contained in:
parent
ea432a7de7
commit
e28b2048df
|
@ -132,6 +132,7 @@ set(SRCS ${SRCS}
|
||||||
network/networkmanager.cpp
|
network/networkmanager.cpp
|
||||||
network/networkproxyfactory.cpp
|
network/networkproxyfactory.cpp
|
||||||
network/networkurlinterceptor.cpp
|
network/networkurlinterceptor.cpp
|
||||||
|
network/schemehandlers/extensionschemehandler.cpp
|
||||||
network/schemehandlers/falkonschemehandler.cpp
|
network/schemehandlers/falkonschemehandler.cpp
|
||||||
network/sslerrordialog.cpp
|
network/sslerrordialog.cpp
|
||||||
notifications/desktopnotification.cpp
|
notifications/desktopnotification.cpp
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/* ============================================================
|
/* ============================================================
|
||||||
* Falkon - Qt web browser
|
* Falkon - Qt web browser
|
||||||
* Copyright (C) 2010-2017 David Rosca <nowrep@gmail.com>
|
* Copyright (C) 2010-2018 David Rosca <nowrep@gmail.com>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -26,6 +26,7 @@
|
||||||
#include "sslerrordialog.h"
|
#include "sslerrordialog.h"
|
||||||
#include "networkurlinterceptor.h"
|
#include "networkurlinterceptor.h"
|
||||||
#include "schemehandlers/falkonschemehandler.h"
|
#include "schemehandlers/falkonschemehandler.h"
|
||||||
|
#include "schemehandlers/extensionschemehandler.h"
|
||||||
|
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QDialog>
|
#include <QDialog>
|
||||||
|
@ -44,6 +45,8 @@ NetworkManager::NetworkManager(QObject *parent)
|
||||||
{
|
{
|
||||||
// Create scheme handlers
|
// Create scheme handlers
|
||||||
mApp->webProfile()->installUrlSchemeHandler(QByteArrayLiteral("falkon"), new FalkonSchemeHandler());
|
mApp->webProfile()->installUrlSchemeHandler(QByteArrayLiteral("falkon"), new FalkonSchemeHandler());
|
||||||
|
m_extensionScheme = new ExtensionSchemeManager();
|
||||||
|
mApp->webProfile()->installUrlSchemeHandler(QByteArrayLiteral("extension"), m_extensionScheme);
|
||||||
|
|
||||||
// Create url interceptor
|
// Create url interceptor
|
||||||
m_urlInterceptor = new NetworkUrlInterceptor(this);
|
m_urlInterceptor = new NetworkUrlInterceptor(this);
|
||||||
|
@ -228,6 +231,16 @@ void NetworkManager::removeUrlInterceptor(UrlInterceptor *interceptor)
|
||||||
m_urlInterceptor->removeUrlInterceptor(interceptor);
|
m_urlInterceptor->removeUrlInterceptor(interceptor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void NetworkManager::registerExtensionSchemeHandler(const QString &name, ExtensionSchemeHandler *handler)
|
||||||
|
{
|
||||||
|
m_extensionScheme->registerHandler(name, handler);
|
||||||
|
}
|
||||||
|
|
||||||
|
void NetworkManager::unregisterExtensionSchemeHandler(const QString &name)
|
||||||
|
{
|
||||||
|
m_extensionScheme->unregisterHandler(name);
|
||||||
|
}
|
||||||
|
|
||||||
void NetworkManager::loadSettings()
|
void NetworkManager::loadSettings()
|
||||||
{
|
{
|
||||||
Settings settings;
|
Settings settings;
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/* ============================================================
|
/* ============================================================
|
||||||
* Falkon - Qt web browser
|
* Falkon - Qt web browser
|
||||||
* Copyright (C) 2010-2017 David Rosca <nowrep@gmail.com>
|
* Copyright (C) 2010-2018 David Rosca <nowrep@gmail.com>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -25,6 +25,8 @@
|
||||||
|
|
||||||
class UrlInterceptor;
|
class UrlInterceptor;
|
||||||
class NetworkUrlInterceptor;
|
class NetworkUrlInterceptor;
|
||||||
|
class ExtensionSchemeManager;
|
||||||
|
class ExtensionSchemeHandler;
|
||||||
|
|
||||||
class FALKON_EXPORT NetworkManager : public QNetworkAccessManager
|
class FALKON_EXPORT NetworkManager : public QNetworkAccessManager
|
||||||
{
|
{
|
||||||
|
@ -40,6 +42,9 @@ public:
|
||||||
void installUrlInterceptor(UrlInterceptor *interceptor);
|
void installUrlInterceptor(UrlInterceptor *interceptor);
|
||||||
void removeUrlInterceptor(UrlInterceptor *interceptor);
|
void removeUrlInterceptor(UrlInterceptor *interceptor);
|
||||||
|
|
||||||
|
void registerExtensionSchemeHandler(const QString &name, ExtensionSchemeHandler *handler);
|
||||||
|
void unregisterExtensionSchemeHandler(const QString &name);
|
||||||
|
|
||||||
void loadSettings();
|
void loadSettings();
|
||||||
void shutdown();
|
void shutdown();
|
||||||
|
|
||||||
|
@ -48,6 +53,7 @@ protected:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
NetworkUrlInterceptor *m_urlInterceptor;
|
NetworkUrlInterceptor *m_urlInterceptor;
|
||||||
|
ExtensionSchemeManager *m_extensionScheme;
|
||||||
QHash<QString, QWebEngineCertificateError::Error> m_ignoredSslErrors;
|
QHash<QString, QWebEngineCertificateError::Error> m_ignoredSslErrors;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
58
src/lib/network/schemehandlers/extensionschemehandler.cpp
Normal file
58
src/lib/network/schemehandlers/extensionschemehandler.cpp
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/* ============================================================
|
||||||
|
* Falkon - Qt web browser
|
||||||
|
* Copyright (C) 2018 David Rosca <nowrep@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
* ============================================================ */
|
||||||
|
#include "extensionschemehandler.h"
|
||||||
|
|
||||||
|
#include <QBuffer>
|
||||||
|
#include <QUrlQuery>
|
||||||
|
#include <QWebEngineUrlRequestJob>
|
||||||
|
|
||||||
|
// ExtensionSchemeHandler
|
||||||
|
void ExtensionSchemeHandler::setReply(QWebEngineUrlRequestJob *job, const QByteArray &contentType, const QByteArray &content)
|
||||||
|
{
|
||||||
|
QBuffer *buffer = new QBuffer();
|
||||||
|
buffer->open(QIODevice::ReadWrite);
|
||||||
|
buffer->write(content);
|
||||||
|
buffer->seek(0);
|
||||||
|
job->reply(contentType, buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ExtensionSchemeManager
|
||||||
|
ExtensionSchemeManager::ExtensionSchemeManager(QObject *parent)
|
||||||
|
: QWebEngineUrlSchemeHandler(parent)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void ExtensionSchemeManager::requestStarted(QWebEngineUrlRequestJob *job)
|
||||||
|
{
|
||||||
|
ExtensionSchemeHandler *handler = m_handlers.value(job->requestUrl().host());
|
||||||
|
if (handler) {
|
||||||
|
handler->requestStarted(job);
|
||||||
|
} else {
|
||||||
|
job->fail(QWebEngineUrlRequestJob::UrlInvalid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ExtensionSchemeManager::registerHandler(const QString &name, ExtensionSchemeHandler *handler)
|
||||||
|
{
|
||||||
|
m_handlers[name] = handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ExtensionSchemeManager::unregisterHandler(const QString &name)
|
||||||
|
{
|
||||||
|
m_handlers.remove(name);
|
||||||
|
}
|
47
src/lib/network/schemehandlers/extensionschemehandler.h
Normal file
47
src/lib/network/schemehandlers/extensionschemehandler.h
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
/* ============================================================
|
||||||
|
* Falkon - Qt web browser
|
||||||
|
* Copyright (C) 2018 David Rosca <nowrep@gmail.com>
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
* ============================================================ */
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QWebEngineUrlSchemeHandler>
|
||||||
|
|
||||||
|
#include "qzcommon.h"
|
||||||
|
|
||||||
|
class FALKON_EXPORT ExtensionSchemeHandler : public QObject
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit ExtensionSchemeHandler(QObject *parent = nullptr) : QObject(parent) { }
|
||||||
|
|
||||||
|
virtual void requestStarted(QWebEngineUrlRequestJob *job) = 0;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void setReply(QWebEngineUrlRequestJob *job, const QByteArray &contentType, const QByteArray &content);
|
||||||
|
};
|
||||||
|
|
||||||
|
class FALKON_EXPORT ExtensionSchemeManager : public QWebEngineUrlSchemeHandler
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit ExtensionSchemeManager(QObject *parent = nullptr);
|
||||||
|
|
||||||
|
void requestStarted(QWebEngineUrlRequestJob *job) override;
|
||||||
|
|
||||||
|
void registerHandler(const QString &name, ExtensionSchemeHandler *handler);
|
||||||
|
void unregisterHandler(const QString &name);
|
||||||
|
|
||||||
|
private:
|
||||||
|
QHash<QString, ExtensionSchemeHandler*> m_handlers;
|
||||||
|
};
|
|
@ -1,6 +1,6 @@
|
||||||
/* ============================================================
|
/* ============================================================
|
||||||
* Falkon - Qt web browser
|
* Falkon - Qt web browser
|
||||||
* Copyright (C) 2010-2016 David Rosca <nowrep@gmail.com>
|
* Copyright (C) 2010-2018 David Rosca <nowrep@gmail.com>
|
||||||
*
|
*
|
||||||
* This program is free software: you can redistribute it and/or modify
|
* This program is free software: you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License as published by
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -139,7 +139,7 @@ bool SiteInfo::canShowSiteInfo(const QUrl &url)
|
||||||
if (LocationBar::convertUrlToText(url).isEmpty())
|
if (LocationBar::convertUrlToText(url).isEmpty())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (url.scheme() == QL1S("falkon") || url.scheme() == QL1S("view-source"))
|
if (url.scheme() == QL1S("falkon") || url.scheme() == QL1S("view-source") || url.scheme() == QL1S("extension"))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -377,7 +377,7 @@ void WebPage::setupWebChannelForUrl(const QUrl &url)
|
||||||
channel = new QWebChannel(this);
|
channel = new QWebChannel(this);
|
||||||
ExternalJsObject::setupWebChannel(channel, this);
|
ExternalJsObject::setupWebChannel(channel, this);
|
||||||
}
|
}
|
||||||
if (url.scheme() == QL1S("falkon")) {
|
if (url.scheme() == QL1S("falkon") || url.scheme() == QL1S("extension")) {
|
||||||
setWebChannel(channel, UnsafeJsWorld);
|
setWebChannel(channel, UnsafeJsWorld);
|
||||||
} else {
|
} else {
|
||||||
setWebChannel(channel, SafeJsWorld);
|
setWebChannel(channel, SafeJsWorld);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user