#include "wireguardConfigModel.h" #include "protocols/protocols_defs.h" WireGuardConfigModel::WireGuardConfigModel(QObject *parent) : QAbstractListModel(parent) { } int WireGuardConfigModel::rowCount(const QModelIndex &parent) const { Q_UNUSED(parent); return 1; } bool WireGuardConfigModel::setData(const QModelIndex &index, const QVariant &value, int role) { if (!index.isValid() || index.row() < 0 || index.row() >= ContainerProps::allContainers().size()) { return false; } switch (role) { case Roles::PortRole: m_protocolConfig.insert(config_key::port, value.toString()); break; case Roles::CipherRole: m_protocolConfig.insert(config_key::cipher, value.toString()); break; } emit dataChanged(index, index, QList { role }); return true; } QVariant WireGuardConfigModel::data(const QModelIndex &index, int role) const { if (!index.isValid() || index.row() < 0 || index.row() >= rowCount()) { return false; } switch (role) { case Roles::PortRole: return m_protocolConfig.value(config_key::port).toString(protocols::shadowsocks::defaultPort); case Roles::CipherRole: return m_protocolConfig.value(config_key::cipher).toString(protocols::shadowsocks::defaultCipher); } return QVariant(); } void WireGuardConfigModel::updateModel(const QJsonObject &config) { beginResetModel(); m_container = ContainerProps::containerFromString(config.value(config_key::container).toString()); m_fullConfig = config; QJsonObject protocolConfig = config.value(config_key::wireguard).toObject(); endResetModel(); } QJsonObject WireGuardConfigModel::getConfig() { m_fullConfig.insert(config_key::wireguard, m_protocolConfig); return m_fullConfig; } QHash WireGuardConfigModel::roleNames() const { QHash roles; roles[PortRole] = "port"; roles[CipherRole] = "cipher"; return roles; }