diff options
Diffstat (limited to 'plugins/smolblok_hostlist')
-rw-r--r-- | plugins/smolblok_hostlist/corpus/apple.txt | 1 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/corpus/banana.txt | 1 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/corpus/kiwi.txt | 1 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/corpus/orange.txt | 1 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/filterlist.cpp | 58 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/filterlist.h | 58 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/meson.build | 50 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/plugin/plugin.cpp | 32 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/plugin/plugin.h | 28 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/plugin/smolblokHostlistPlugin.json | 4 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/test/filterlist.cpp | 29 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/test/hostlist.txt | 6 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/test/plugin.cpp | 27 | ||||
-rw-r--r-- | plugins/smolblok_hostlist/test/rule.cpp | 57 |
14 files changed, 0 insertions, 353 deletions
diff --git a/plugins/smolblok_hostlist/corpus/apple.txt b/plugins/smolblok_hostlist/corpus/apple.txt deleted file mode 100644 index 3a8973b..0000000 --- a/plugins/smolblok_hostlist/corpus/apple.txt +++ /dev/null @@ -1 +0,0 @@ -127.0.0.1 localhost.localdomain diff --git a/plugins/smolblok_hostlist/corpus/banana.txt b/plugins/smolblok_hostlist/corpus/banana.txt deleted file mode 100644 index c30aa84..0000000 --- a/plugins/smolblok_hostlist/corpus/banana.txt +++ /dev/null @@ -1 +0,0 @@ -0.0.0.0 blockeddomain.com diff --git a/plugins/smolblok_hostlist/corpus/kiwi.txt b/plugins/smolblok_hostlist/corpus/kiwi.txt deleted file mode 100644 index 77c325c..0000000 --- a/plugins/smolblok_hostlist/corpus/kiwi.txt +++ /dev/null @@ -1 +0,0 @@ -# This is a comment, and after it comes a blank line diff --git a/plugins/smolblok_hostlist/corpus/orange.txt b/plugins/smolblok_hostlist/corpus/orange.txt deleted file mode 100644 index 583273d..0000000 --- a/plugins/smolblok_hostlist/corpus/orange.txt +++ /dev/null @@ -1 +0,0 @@ -0.0.0.0 blockeddomain.first blockeddomain.second diff --git a/plugins/smolblok_hostlist/filterlist.cpp b/plugins/smolblok_hostlist/filterlist.cpp deleted file mode 100644 index a0fd414..0000000 --- a/plugins/smolblok_hostlist/filterlist.cpp +++ /dev/null @@ -1,58 +0,0 @@ -/* - * This file is part of smolbote. It's copyrighted by the contributors recorded - * in the version control history of the file, available from its original - * location: https://library.iserlohn-fortress.net/aqua/smolbote.git - * - * SPDX-License-Identifier: GPL-3.0 - */ - -#include "filterlist.h" -#include <QIODevice> -#include <QTextStream> - -using namespace Hostlist; - -#ifdef FUZZER -extern "C" int LLVMFuzzerTestOneInput(const char *Data, long long Size) -{ - Filterlist::parseRule(QString::fromLatin1(Data, Size)); - return 0; -} -#endif - -std::map<Filterlist::DomainHash, Filterlist::Rule> Filterlist::parseRule(const QString &line) -{ - if(line.isEmpty() || line.at(0) == '#') { - return {}; - } - - auto parts = line.trimmed().split(' '); - if(parts.size() < 2) { - return {}; - } - - const auto redirect = (parts[0] == "0.0.0.0") ? QString() : parts[0]; - - std::map<DomainHash, Rule> r; - for(int i = 1; i < parts.size(); ++i) { - r.emplace(qHash(parts[i], 0), Filterlist::Rule{ parts[i], redirect }); - } - return r; -} - -bool Filterlist::load(QIODevice &from) -{ - if(!from.isReadable() || !from.isTextModeEnabled()) { - return false; - } - - while(from.bytesAvailable() > 0) { - const auto line = from.readLine(512).trimmed(); - auto r = parseRule(line); - if(!r.empty()) { - qDebug("merging in %lu rules", r.size()); - rules.merge(r); - } - } - return true; -} diff --git a/plugins/smolblok_hostlist/filterlist.h b/plugins/smolblok_hostlist/filterlist.h deleted file mode 100644 index 7301f20..0000000 --- a/plugins/smolblok_hostlist/filterlist.h +++ /dev/null @@ -1,58 +0,0 @@ -/* - * This file is part of smolbote. It's copyrighted by the contributors recorded - * in the version control history of the file, available from its original - * location: https://library.iserlohn-fortress.net/aqua/smolbote.git - * - * SPDX-License-Identifier: GPL-3.0 - */ - -#pragma once - -#include <map> -#include <smolbote/filterinterface.hpp> - -namespace Hostlist -{ - -class Filterlist final : public FilterList -{ -public: - typedef uint DomainHash; - struct Rule { - QString domain; - QString redirect; - }; - - Filterlist() = default; - ~Filterlist() = default; - - [[nodiscard]] bool findMatch(const QString &domain) const - { - const auto hash = qHash(domain, 0); - const auto found = rules.find(hash); - if(found != rules.end()) { - return true; - } - return false; - } - int count() const - { - return rules.size(); - } - - [[nodiscard]] bool filter(QWebEngineUrlRequestInfo &info) const - { - return false; - } - [[nodiscard]] bool isUpToDate() const - { - return true; - } - - bool load(QIODevice &device); - [[nodiscard]] static std::map<DomainHash, Rule> parseRule(const QString &line); - -private: - std::map<DomainHash, Rule> rules; -}; -} // namespace Hostlist diff --git a/plugins/smolblok_hostlist/meson.build b/plugins/smolblok_hostlist/meson.build deleted file mode 100644 index c9ff303..0000000 --- a/plugins/smolblok_hostlist/meson.build +++ /dev/null @@ -1,50 +0,0 @@ -lib_hostlistfilter = static_library('hostlistfilter', - [ 'filterlist.cpp' ], - include_directories: smolbote_interfaces, - dependencies: [dep_qt5] -) - -dep_hostlistfilter = declare_dependency( - include_directories: [ '.', smolbote_interfaces ], - link_with: lib_hostlistfilter -) - -# plugin -plugin = shared_library('smolblokHostlistPlugin', - [ 'plugin/plugin.cpp', - mod_qt5.preprocess(include_directories: smolbote_interfaces, moc_headers: 'plugin/plugin.h', dependencies: dep_qt5) ], - include_directories: smolbote_interfaces, - dependencies: [ dep_hostlistfilter, dep_qt5 ], - install: true, - install_dir: get_option('libdir')/'smolbote/plugins' -) - -# tests -test('rule', executable('rule', sources: 'test/rule.cpp', dependencies: [dep_qt5, dep_catch, dep_hostlistfilter]), suite: 'hostlist') - -test('filterlist', executable('filterlist', - sources: 'test/filterlist.cpp', - dependencies: [dep_qt5, dep_catch, dep_hostlistfilter]), - env: 'HOSTLIST_TXT='+meson.current_source_dir()/'test/hostlist.txt', - suite: 'hostlist' -) -test('plugin', executable('filterlist-plugin', - sources: [ 'test/plugin.cpp', 'plugin/plugin.cpp', - mod_qt5.preprocess(include_directories: smolbote_interfaces, moc_headers: 'plugin/plugin.h', dependencies: dep_qt5) ], - dependencies: [dep_qt5, dep_catch, dep_hostlistfilter]), - env: 'HOSTLIST_TXT='+meson.current_source_dir()/'test/hostlist.txt', - suite: 'hostlist' -) - -test('smolblok-load', smolblok_load, workdir: meson.build_root(), args: plugin.full_path(), suite: 'hostlist') - -# fuzzer -if meson.get_compiler('cpp').has_multi_arguments('-g', '-fsanitize=fuzzer') -executable('hostlist-fuzzer', - sources: 'filterlist.cpp', - include_directories: smolbote_interfaces, - dependencies: dep_qt5, - cpp_args: [ '-g', '-fsanitize=fuzzer', '-DFUZZER' ], - link_args: [ '-fsanitize=fuzzer' ] -) -endif diff --git a/plugins/smolblok_hostlist/plugin/plugin.cpp b/plugins/smolblok_hostlist/plugin/plugin.cpp deleted file mode 100644 index 28a7706..0000000 --- a/plugins/smolblok_hostlist/plugin/plugin.cpp +++ /dev/null @@ -1,32 +0,0 @@ -/* - * This file is part of smolbote. It's copyrighted by the contributors recorded - * in the version control history of the file, available from its original - * location: https://library.iserlohn-fortress.net/aqua/smolbote.git - * - * SPDX-License-Identifier: GPL-3.0 - */ - -#include "plugin.h" -#include "filterlist.h" - -FilterList* HostlistFilterPlugin::load(QIODevice &from) const -{ - if(!from.isOpen()) - return nullptr; - - auto *list = new Hostlist::Filterlist; - return list; -} - -bool HostlistFilterPlugin::parse(FilterList *list, QIODevice &from) const -{ - if(list == nullptr || !from.isOpen()) { - return false; - } - auto *l = dynamic_cast<Hostlist::Filterlist*>(list); - if(l == nullptr) { - return false; - } - return l->load(from); -} - diff --git a/plugins/smolblok_hostlist/plugin/plugin.h b/plugins/smolblok_hostlist/plugin/plugin.h deleted file mode 100644 index 53b5d36..0000000 --- a/plugins/smolblok_hostlist/plugin/plugin.h +++ /dev/null @@ -1,28 +0,0 @@ -/* - * This file is part of smolbote. It's copyrighted by the contributors recorded - * in the version control history of the file, available from its original - * location: https://library.iserlohn-fortress.net/aqua/smolbote.git - * - * SPDX-License-Identifier: GPL-3.0 - */ - -#ifndef SMOLBLOK_FILTER_PLUGIN_H -#define SMOLBLOK_FILTER_PLUGIN_H - -#include <smolbote/filterinterface.hpp> - -class HostlistFilterPlugin : public QObject, public FilterPlugin -{ - Q_OBJECT - Q_PLUGIN_METADATA(IID FilterPluginIid FILE "smolblokHostlistPlugin.json") - Q_INTERFACES(FilterPlugin) - -public: - ~HostlistFilterPlugin() = default; - - FilterList *load(QIODevice &from) const override; - bool parse(FilterList *list, QIODevice &from) const override; -}; - -#endif // SMOLBLOK_FILTER_PLUGIN_H - diff --git a/plugins/smolblok_hostlist/plugin/smolblokHostlistPlugin.json b/plugins/smolblok_hostlist/plugin/smolblokHostlistPlugin.json deleted file mode 100644 index aa53cdd..0000000 --- a/plugins/smolblok_hostlist/plugin/smolblokHostlistPlugin.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "name": "smolblok Hostlist filter plugin", - "author": "Aqua <aqua@iserlohn-fortress.net>" -} diff --git a/plugins/smolblok_hostlist/test/filterlist.cpp b/plugins/smolblok_hostlist/test/filterlist.cpp deleted file mode 100644 index 4aa532b..0000000 --- a/plugins/smolblok_hostlist/test/filterlist.cpp +++ /dev/null @@ -1,29 +0,0 @@ -#define CATCH_CONFIG_MAIN -#include "filterlist.h" -#include <QFile> -#include <catch2/catch.hpp> - -using namespace Hostlist; - -TEST_CASE("Hostlist") -{ - Filterlist list; - - const QString filename(qgetenv("HOSTLIST_TXT")); - REQUIRE(!filename.isEmpty()); - - QFile f(filename); - REQUIRE(f.open(QIODevice::ReadOnly | QIODevice::Text)); - - REQUIRE(list.load(f)); - f.close(); - - REQUIRE(list.count() == 4); - - REQUIRE(list.findMatch("blockeddomain.first")); - REQUIRE(list.findMatch("blockeddomain.second")); - - REQUIRE(list.findMatch("localhost.localdomain")); - - REQUIRE(!list.findMatch("other.domain")); -} diff --git a/plugins/smolblok_hostlist/test/hostlist.txt b/plugins/smolblok_hostlist/test/hostlist.txt deleted file mode 100644 index a0b4e5c..0000000 --- a/plugins/smolblok_hostlist/test/hostlist.txt +++ /dev/null @@ -1,6 +0,0 @@ -# This is a comment, and after it comes a blank line - -127.0.0.1 localhost.localdomain - -0.0.0.0 blockeddomain.com -0.0.0.0 blockeddomain.first blockeddomain.second diff --git a/plugins/smolblok_hostlist/test/plugin.cpp b/plugins/smolblok_hostlist/test/plugin.cpp deleted file mode 100644 index fad34f2..0000000 --- a/plugins/smolblok_hostlist/test/plugin.cpp +++ /dev/null @@ -1,27 +0,0 @@ -#define CATCH_CONFIG_MAIN -#include "plugin/plugin.h" -#include <QFile> -#include <catch2/catch.hpp> - -TEST_CASE("Hostlist") -{ - HostlistFilterPlugin plugin; - - const QString filename(qgetenv("HOSTLIST_TXT")); - REQUIRE(!filename.isEmpty()); - QFile f(filename); - - // shouldn't be able to load an unopened QIODevice - REQUIRE(plugin.load(f) == nullptr); - - REQUIRE(f.open(QIODevice::ReadOnly | QIODevice::Text)); - - auto *list = plugin.load(f); - REQUIRE(list != nullptr); - f.seek(0); - REQUIRE_FALSE(plugin.parse(nullptr, f)); - REQUIRE(plugin.parse(list, f)); - f.close(); - REQUIRE_FALSE(plugin.parse(list, f)); -} - diff --git a/plugins/smolblok_hostlist/test/rule.cpp b/plugins/smolblok_hostlist/test/rule.cpp deleted file mode 100644 index b5ba6e0..0000000 --- a/plugins/smolblok_hostlist/test/rule.cpp +++ /dev/null @@ -1,57 +0,0 @@ -#define CATCH_CONFIG_MAIN -#include "filterlist.h" -#include <catch2/catch.hpp> - -using namespace Hostlist; - -SCENARIO("Hostlist::Rule") -{ - GIVEN("an invalid rule") - { - const auto rule = Filterlist::parseRule("0.0.0.0 "); - REQUIRE(rule.empty()); - } - GIVEN("127.0.0.1 localhost.localdomain") - { - auto rule = Filterlist::parseRule("127.0.0.1 localhost.localdomain"); - - REQUIRE(!rule.empty()); - REQUIRE(rule.size() == 1); - - // note: you need to force it to hash a string, rather than the address itself - const auto index = qHash(QString("localhost.localdomain"), 0); - REQUIRE(rule[index].domain == "localhost.localdomain"); - REQUIRE(rule[index].redirect == "127.0.0.1"); - } - - GIVEN("0.0.0.0 blockeddomain.com") - { - auto rule = Filterlist::parseRule("0.0.0.0 blockeddomain.com"); - - REQUIRE(!rule.empty()); - REQUIRE(rule.size() == 1); - - const auto index = qHash(QString("blockeddomain.com"), 0); - REQUIRE(rule[index].domain == "blockeddomain.com"); - REQUIRE(rule[index].redirect.isEmpty()); - ; - } - - GIVEN("0.0.0.0 blockeddomain.first blockeddomain.second") - { - auto rule = Filterlist::parseRule("0.0.0.0 blockeddomain.first blockeddomain.second"); - - REQUIRE(!rule.empty()); - REQUIRE(rule.size() == 2); - { - const auto index = qHash(QString("blockeddomain.first"), 0); - REQUIRE(rule[index].domain == "blockeddomain.first"); - REQUIRE(rule[index].redirect.isEmpty()); - } - { - const auto index = qHash(QString("blockeddomain.second"), 0); - REQUIRE(rule[index].domain == "blockeddomain.second"); - REQUIRE(rule[index].redirect.isEmpty()); - } - } -} |