1 /*************************************************************************** 2 * Copyright (C) 2005-2020 by the Quassel Project * 3 * devel@quassel-irc.org * 4 * * 5 * This program is free software; you can redistribute it and/or modify * 6 * it under the terms of the GNU General Public License as published by * 7 * the Free Software Foundation; either version 2 of the License, or * 8 * (at your option) version 3. * 9 * * 10 * This program is distributed in the hope that it will be useful, * 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * 13 * GNU General Public License for more details. * 14 * * 15 * You should have received a copy of the GNU General Public License * 16 * along with this program; if not, write to the * 17 * Free Software Foundation, Inc., * 18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * 19 ***************************************************************************/ 20 21 #pragma once 22 23 #include "client-export.h" 24 25 #include <QMap> 26 27 #include "ignorelistmanager.h" 28 29 class CLIENT_EXPORT ClientIgnoreListManager : public IgnoreListManager 30 { 31 Q_OBJECT 32 33 public: 34 explicit ClientIgnoreListManager(QObject* parent = nullptr); 35 36 //! Fetch all matching ignore rules for a given hostmask 37 /** \param hostmask The hostmask of the user 38 * \param network The network name 39 * \param channel The channel name 40 * \return Returns a QMap with the rule as key and a bool, representing if the rule is enabled or not, as value 41 */ 42 QMap<QString, bool> matchingRulesForHostmask(const QString& hostmask, const QString& network, const QString& channel) const; 43 44 signals: 45 void ignoreListChanged(); 46 47 private: 48 // matches an ignore rule against a given string 49 bool pureMatch(const IgnoreListItem& item, const QString& string) const; 50 }; 51