summaryrefslogtreecommitdiff
path: root/src/useragent
diff options
context:
space:
mode:
Diffstat (limited to 'src/useragent')
-rw-r--r--src/useragent/useragentinfo.cpp19
-rw-r--r--src/useragent/useragentinfo.h6
-rw-r--r--src/useragent/useragentmanager.cpp171
-rw-r--r--src/useragent/useragentmanager.h60
4 files changed, 244 insertions, 12 deletions
diff --git a/src/useragent/useragentinfo.cpp b/src/useragent/useragentinfo.cpp
index 0829a7e1..6ac411ba 100644
--- a/src/useragent/useragentinfo.cpp
+++ b/src/useragent/useragentinfo.cpp
@@ -46,18 +46,13 @@
UserAgentInfo::UserAgentInfo()
{
- /* KService::List m_providers = KServiceTypeTrader::self()->query("UserAgentStrings");*/
-
- // NOTE: limiting User Agent Numbers
- m_providers << KService::serviceByDesktopName("firefox36oncurrent");
- m_providers << KService::serviceByDesktopName("ie70onwinnt51");
- m_providers << KService::serviceByDesktopName("ie60oncurrent");
- m_providers << KService::serviceByDesktopName("chrome50oncurrent");
- m_providers << KService::serviceByDesktopName("safari40");
- m_providers << KService::serviceByDesktopName("op962oncurrent");
- m_providers << KService::serviceByDesktopName("ns71oncurrent");
- m_providers << KService::serviceByDesktopName("android10");
- m_providers << KService::serviceByDesktopName("googlebot");
+ m_providers = KServiceTypeTrader::self()->query("UserAgentStrings");
+}
+
+
+KService::List UserAgentInfo::availableProviders() const
+{
+ return m_providers;
}
diff --git a/src/useragent/useragentinfo.h b/src/useragent/useragentinfo.h
index 417aeea1..86319d9e 100644
--- a/src/useragent/useragentinfo.h
+++ b/src/useragent/useragentinfo.h
@@ -46,6 +46,12 @@ public:
UserAgentInfo();
/**
+ * Lists all available providers
+ *
+ */
+ KService::List availableProviders() const;
+
+ /**
* Lists all available User Agents
*
* @returns the list of the UA descriptions
diff --git a/src/useragent/useragentmanager.cpp b/src/useragent/useragentmanager.cpp
new file mode 100644
index 00000000..20043549
--- /dev/null
+++ b/src/useragent/useragentmanager.cpp
@@ -0,0 +1,171 @@
+/* ============================================================
+*
+* This file is a part of the rekonq project
+*
+* Copyright (C) 2011 by Andrea Diamantini <adjam7 at gmail dot 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 2 of
+* the License or (at your option) version 3 or any later version
+* accepted by the membership of KDE e.V. (or its successor approved
+* by the membership of KDE e.V.), which shall act as a proxy
+* defined in Section 14 of version 3 of the license.
+*
+* 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/>.
+*
+* ============================================================ */
+
+
+// Self Includes
+#include "useragentmanager.h"
+#include "useragentmanager.moc"
+
+// Local Includes
+#include "useragentinfo.h"
+#include "useragentwidget.h"
+#include "webtab.h"
+#include "webview.h"
+
+// KDE Includes
+#include <KAction>
+#include <KDialog>
+#include <KMenu>
+
+
+UserAgentManager::UserAgentManager(QObject *parent)
+ : QObject(parent)
+ , m_uaSettingsAction(0)
+ , m_uaTab(0)
+{
+ m_uaSettingsAction = new KAction(KIcon("preferences-web-browser-identification"), i18n("Browser Identification"), this);
+ connect(m_uaSettingsAction, SIGNAL(triggered(bool)), this, SLOT(showSettings()));
+}
+
+
+void UserAgentManager::showSettings()
+{
+ QPointer<KDialog> dialog = new KDialog(m_uaTab);
+ dialog->setCaption(i18nc("@title:window", "User Agent Settings"));
+ dialog->setButtons(KDialog::Ok);
+
+ UserAgentWidget widget;
+ dialog->setMainWidget(&widget);
+ dialog->exec();
+
+ dialog->deleteLater();
+}
+
+
+void UserAgentManager::populateUAMenuForTabUrl(KMenu *uaMenu, WebTab *uaTab)
+{
+ if (m_uaTab)
+ disconnect(this, SIGNAL(reloadTab()), m_uaTab->view(), SLOT(reload()));
+
+ m_uaTab = uaTab;
+ connect(this, SIGNAL(reloadTab()), m_uaTab->view(), SLOT(reload()));
+
+ bool defaultUA = true;
+
+ QAction *a, *defaultAction;
+
+ // just to be sure...
+ uaMenu->clear();
+
+ defaultAction = new QAction(i18nc("Default rekonq user agent", "Default"), uaMenu);
+ defaultAction->setData(-1);
+ defaultAction->setCheckable(true);
+ connect(defaultAction, SIGNAL(triggered(bool)), this, SLOT(setUserAgent()));
+
+ uaMenu->addAction(defaultAction);
+ uaMenu->addSeparator();
+
+ // Main Browsers Menus
+ KMenu *ffMenu = new KMenu(i18n("Firefox"), uaMenu);
+ uaMenu->addMenu(ffMenu);
+
+ KMenu *ieMenu = new KMenu(i18n("Internet Explorer"), uaMenu);
+ uaMenu->addMenu(ieMenu);
+
+ KMenu *nsMenu = new KMenu(i18n("Netscape"), uaMenu);
+ uaMenu->addMenu(nsMenu);
+
+ KMenu *opMenu = new KMenu(i18n("Opera"), uaMenu);
+ uaMenu->addMenu(opMenu);
+
+ KMenu *sfMenu = new KMenu(i18n("Safari"), uaMenu);
+ uaMenu->addMenu(sfMenu);
+
+ KMenu *otMenu = new KMenu(i18n("Other"), uaMenu);
+ uaMenu->addMenu(otMenu);
+
+ UserAgentInfo uaInfo;
+ QStringList UAlist = uaInfo.availableUserAgents();
+ const KService::List providers = uaInfo.availableProviders();
+ int uaIndex = uaInfo.uaIndexForHost(m_uaTab->url().host());
+
+ for (int i = 0; i < UAlist.count(); ++i)
+ {
+ QString uaDesc = UAlist.at(i);
+
+ a = new QAction(uaDesc, uaMenu);
+ a->setData(i);
+ a->setCheckable(true);
+ connect(a, SIGNAL(triggered(bool)), this, SLOT(setUserAgent()));
+
+ if (i == uaIndex)
+ {
+ a->setChecked(true);
+ defaultUA = false;
+ }
+
+ QString tag = providers.at(i)->property("X-KDE-UA-TAG").toString();
+ if (tag == QL1S("FF"))
+ {
+ ffMenu->addAction(a);
+ }
+ else if (tag == QL1S("IE"))
+ {
+ ieMenu->addAction(a);
+ }
+ else if (tag == QL1S("NN"))
+ {
+ nsMenu->addAction(a);
+ }
+ else if (tag == QL1S("OPR"))
+ {
+ opMenu->addAction(a);
+ }
+ else if (tag == QL1S("SAF"))
+ {
+ sfMenu->addAction(a);
+ }
+ else // OTHERs
+ {
+ otMenu->addAction(a);
+ }
+ }
+ defaultAction->setChecked(defaultUA);
+
+ uaMenu->addSeparator();
+ uaMenu->addAction(m_uaSettingsAction);
+}
+
+
+void UserAgentManager::setUserAgent()
+{
+ QAction *sender = static_cast<QAction *>(QObject::sender());
+
+ int uaIndex = sender->data().toInt();
+
+ UserAgentInfo uaInfo;
+ uaInfo.setUserAgentForHost(uaIndex, m_uaTab->url().host());
+ emit reloadTab();
+}
diff --git a/src/useragent/useragentmanager.h b/src/useragent/useragentmanager.h
new file mode 100644
index 00000000..0592e55c
--- /dev/null
+++ b/src/useragent/useragentmanager.h
@@ -0,0 +1,60 @@
+/* ============================================================
+*
+* This file is a part of the rekonq project
+*
+* Copyright (C) 2011 by Andrea Diamantini <adjam7 at gmail dot 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 2 of
+* the License or (at your option) version 3 or any later version
+* accepted by the membership of KDE e.V. (or its successor approved
+* by the membership of KDE e.V.), which shall act as a proxy
+* defined in Section 14 of version 3 of the license.
+*
+* 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/>.
+*
+* ============================================================ */
+
+
+#ifndef USER_AGENT_MANAGER_H
+#define USER_AGENT_MANAGER_H
+
+
+#include <QObject>
+
+class WebTab;
+
+class KAction;
+class KMenu;
+
+
+class UserAgentManager : public QObject
+{
+ Q_OBJECT
+
+public:
+ UserAgentManager(QObject *parent = 0);
+
+ void populateUAMenuForTabUrl(KMenu *, WebTab *);
+
+private Q_SLOTS:
+ void showSettings();
+ void setUserAgent();
+
+Q_SIGNALS:
+ void reloadTab();
+
+private:
+ KAction *m_uaSettingsAction;
+ WebTab *m_uaTab;
+};
+
+#endif // USER_AGENT_MANAGER_H