
* Add allowed DNS list for killswitch * Windows killswitch strict mode backend part * Killswitch strict mode for Linux and MacOS * Windows fixes * feature: Add Kill Switch settings page with strict mode option * fix windows build after merge * Refresh killswitch mode when it toggled * Use HLM to store strictMode flag * Some Linux updates * feat: Enhance VerticalRadioButton with improved styling and disabled states * Refresh killSwitch state update * Fix build * refactor: Modularize header components * Change kill switch radio button styling * Fix strict kill switch mode handling * Refactor: Replace HeaderType with new Types for headers in QML pages * Remove deprecated HeaderType QML component * Refresh strict mode killswitch after global toggle change * Implement model, controller and UI for killswitch dns exceptions * Connect backend part and UI * Change label text to DNS exceptions * Remove HeaderType from PageSettingsApiDevices * Some pretty fixes * Fix problem with definition sequence of PageSettingsKillSwitchExceptions.pml elements * Add exclusion method for Windows firewall * Change ubuntu version in deploy script * Update ubuntu version in GH actions * Add confirmation popup for strict killswitch mode * Add qt standard path for build script * Add method to killswitch for expanding strickt mode exceptions list and fix allowTrafficTo() for Windows. Also Added cache in KillSwitch class for exceptions * Add insertion of gateway address to strict killswitch exceptions * Review fixes * buildfix and naming --------- Co-authored-by: aiamnezia <ai@amnezia.org>
86 lines
1.9 KiB
C++
86 lines
1.9 KiB
C++
#include "allowed_dns_model.h"
|
|
|
|
AllowedDnsModel::AllowedDnsModel(std::shared_ptr<Settings> settings, QObject *parent)
|
|
: QAbstractListModel(parent), m_settings(settings)
|
|
{
|
|
fillDnsServers();
|
|
}
|
|
|
|
int AllowedDnsModel::rowCount(const QModelIndex &parent) const
|
|
{
|
|
Q_UNUSED(parent)
|
|
return m_dnsServers.size();
|
|
}
|
|
|
|
QVariant AllowedDnsModel::data(const QModelIndex &index, int role) const
|
|
{
|
|
if (!index.isValid() || index.row() < 0 || index.row() >= static_cast<int>(rowCount()))
|
|
return QVariant();
|
|
|
|
switch (role) {
|
|
case IpRole:
|
|
return m_dnsServers.at(index.row());
|
|
default:
|
|
return QVariant();
|
|
}
|
|
}
|
|
|
|
bool AllowedDnsModel::addDns(const QString &ip)
|
|
{
|
|
if (m_dnsServers.contains(ip)) {
|
|
return false;
|
|
}
|
|
|
|
beginInsertRows(QModelIndex(), rowCount(), rowCount());
|
|
m_dnsServers.append(ip);
|
|
m_settings->setAllowedDnsServers(m_dnsServers);
|
|
endInsertRows();
|
|
return true;
|
|
}
|
|
|
|
void AllowedDnsModel::addDnsList(const QStringList &dnsServers, bool replaceExisting)
|
|
{
|
|
beginResetModel();
|
|
|
|
if (replaceExisting) {
|
|
m_dnsServers.clear();
|
|
}
|
|
|
|
for (const QString &ip : dnsServers) {
|
|
if (!m_dnsServers.contains(ip)) {
|
|
m_dnsServers.append(ip);
|
|
}
|
|
}
|
|
|
|
m_settings->setAllowedDnsServers(m_dnsServers);
|
|
endResetModel();
|
|
}
|
|
|
|
void AllowedDnsModel::removeDns(QModelIndex index)
|
|
{
|
|
if (!index.isValid() || index.row() >= m_dnsServers.size()) {
|
|
return;
|
|
}
|
|
|
|
beginRemoveRows(QModelIndex(), index.row(), index.row());
|
|
m_dnsServers.removeAt(index.row());
|
|
m_settings->setAllowedDnsServers(m_dnsServers);
|
|
endRemoveRows();
|
|
}
|
|
|
|
QStringList AllowedDnsModel::getCurrentDnsServers()
|
|
{
|
|
return m_dnsServers;
|
|
}
|
|
|
|
QHash<int, QByteArray> AllowedDnsModel::roleNames() const
|
|
{
|
|
QHash<int, QByteArray> roles;
|
|
roles[IpRole] = "ip";
|
|
return roles;
|
|
}
|
|
|
|
void AllowedDnsModel::fillDnsServers()
|
|
{
|
|
m_dnsServers = m_settings->allowedDnsServers();
|
|
}
|