Merge branch '2309-0721' into 'yhkylin/v101'

fix(托盘): 开启热点后 WiFi列表内容未移除问题(bug181187)

See merge request kylinos-src/kylin-nm!235
This commit is contained in:
赵世旭 2023-07-28 08:48:56 +00:00
commit 6e07f5dabb
4 changed files with 51 additions and 27 deletions

View File

@ -457,8 +457,8 @@ NetworkManager::Connection::Ptr KyNetworkResourceManager::getConnect(const QStri
int index = 0;
NetworkManager::Connection::Ptr connectPtr = nullptr;
qDebug() <<"[KyNetworkResourceManager]" << "get connect with uuid" << connectUuid;
if (connectUuid.isEmpty()) {
qWarning() << "[KyNetworkResourceManager]" << "get connect with uuid is empty";
return nullptr;
}
@ -473,7 +473,7 @@ NetworkManager::Connection::Ptr KyNetworkResourceManager::getConnect(const QStri
}
}
qWarning()<<"[KyNetworkResourceManager]"<<"it can not find connect with uuid"<<connectUuid;
qWarning() << "[KyNetworkResourceManager]" << "it can not find connect with uuid" << connectUuid;
return nullptr;
}

View File

@ -416,18 +416,20 @@ void KyWirelessNetResource::onWifiNetworkAdded(QString devIfaceName, QString ssi
void KyWirelessNetResource::onWifiNetworkRemoved(QString devIfaceName, QString ssid)
{
if (m_WifiNetworkList.contains(devIfaceName)) {
int index = 0;
for ( ; index < m_WifiNetworkList.value(devIfaceName).size(); index++) {
if ( m_WifiNetworkList[devIfaceName].at(index).m_NetSsid == ssid) {
m_WifiNetworkList[devIfaceName].removeAt(index);
if (!m_WifiNetworkList.contains(devIfaceName)) {
return;
}
for (int index = 0; index < m_WifiNetworkList.value(devIfaceName).size(); ++index) {
if (m_WifiNetworkList[devIfaceName].at(index).m_NetSsid == ssid) {
m_WifiNetworkList[devIfaceName].removeAt(index);
//remove后为空则删除
if (m_WifiNetworkList.value(devIfaceName).isEmpty()) {
m_WifiNetworkList.remove(devIfaceName);
}
Q_EMIT wifiNetworkRemove(devIfaceName,ssid);
break;
}
//remove后为空则删除
if (m_WifiNetworkList.value(devIfaceName).isEmpty()) {
m_WifiNetworkList.remove(devIfaceName);
}
Q_EMIT wifiNetworkRemove(devIfaceName,ssid);
}
}
@ -846,8 +848,31 @@ void KyWirelessNetResource::onConnectionUpdate(QString uuid)
return;
}
m_WifiNetworkList.clear();
kyWirelessNetItemListInit();
QString ssid, dev;
getSsidByUuid(uuid, ssid);
getDeviceByUuid(uuid, dev);
NetworkManager::Device::Ptr devicePtr = m_networkResourceInstance->findDeviceInterface(dev);
if (devicePtr.isNull() || !m_WifiNetworkList.contains(dev)) {
return;
}
NetworkManager::WirelessNetwork::Ptr netPtr = m_networkResourceInstance->findWifiNetwork(ssid, devicePtr->uni());
if (netPtr.isNull()) {
return;
}
QList<KyWirelessNetItem> list = m_WifiNetworkList.value(dev);
for (int i = 0; i < list.count(); ++i) {
if (uuid == list.at(i).m_connectUuid) {
list.removeAt(i);
break;
}
}
list.append(KyWirelessNetItem(netPtr));
m_WifiNetworkList.insert(dev, list);
Q_EMIT wifiNetworkUpdate();
}

View File

@ -104,10 +104,7 @@ NetworkMode::NetworkMode(QObject *parent)
{
qRegisterMetaType<NetworkManager::Device::State>("NetworkManager::Device::State");
qRegisterMetaType<NetworkManager::Device::StateChangeReason>("NetworkManager::Device::StateChangeReason");
m_deviceResource = new KyNetworkDeviceResourse(this);
m_activatedConnectResource = new KyActiveConnectResourse(this);
m_connectResource = new KyConnectResourse(this);
m_wirelessNetResource = new KyWirelessNetResource(this);
connect(m_activatedConnectResource, &KyActiveConnectResourse::stateChangeReason,
this, &NetworkMode::onConnectionStateChanged);
}
@ -116,7 +113,8 @@ void NetworkMode::initWiredNetworkMode()
{
qDebug()<< LOG_FLAG << "initWiredNetworkMode";
QStringList wiredDevList;
m_deviceResource->getNetworkDeviceList(NetworkManager::Device::Type::Ethernet, wiredDevList);
KyNetworkDeviceResourse deviceResource;
deviceResource.getNetworkDeviceList(NetworkManager::Device::Type::Ethernet, wiredDevList);
if (wiredDevList.isEmpty()) {
return;
}
@ -148,14 +146,16 @@ void NetworkMode::initWirelessNetworkMode()
{
qDebug()<< LOG_FLAG << "initWirelessNetworkMode";
QStringList wirelessDevList;
m_deviceResource->getNetworkDeviceList(NetworkManager::Device::Type::Wifi, wirelessDevList);
KyNetworkDeviceResourse deviceResource;
deviceResource.getNetworkDeviceList(NetworkManager::Device::Type::Wifi, wirelessDevList);
if (wirelessDevList.isEmpty()) {
return;
}
for (auto devName : wirelessDevList) {
KyWirelessNetItem wirelessNetItem;
bool ret = m_wirelessNetResource->getActiveWirelessNetItem(devName, wirelessNetItem);
KyWirelessNetResource wirelessNetResource;
bool ret = wirelessNetResource.getActiveWirelessNetItem(devName, wirelessNetItem);
if (ret == true) {
int configType = NetworkModeConfig::getInstance()->getNetworkModeConfig(wirelessNetItem.m_connectUuid);
@ -205,9 +205,10 @@ void NetworkMode::onConnectionStateChanged(QString uuid,
QString ssid = "";
int configType = NetworkModeConfig::getInstance()->getNetworkModeConfig(uuid);
KyConnectResourse connectResource;
//有线网络连接
if (m_connectResource->isWiredConnection(uuid)) {
if (connectResource.isWiredConnection(uuid)) {
KyConnectItem *p_newItem = nullptr;
p_newItem = m_activatedConnectResource->getActiveConnectionByUuid(uuid);
if (nullptr == p_newItem) {
@ -229,9 +230,10 @@ void NetworkMode::onConnectionStateChanged(QString uuid,
}
}
//无线网络连接
if (m_connectResource->isWirelessConnection(uuid)) {
m_wirelessNetResource->getSsidByUuid(uuid, ssid);
m_wirelessNetResource->getDeviceByUuid(uuid, deviceName);
if (connectResource.isWirelessConnection(uuid)) {
KyWirelessNetResource wirelessNetResource;
wirelessNetResource.getSsidByUuid(uuid, ssid);
wirelessNetResource.getDeviceByUuid(uuid, deviceName);
if (ssid.isEmpty()) {
//忘记此网络
qDebug()<< LOG_FLAG << "forgrt wireless connect:" << uuid <<", call break_networkConnect";

View File

@ -64,10 +64,7 @@ public:
void initWirelessNetworkMode();
private:
KyNetworkDeviceResourse *m_deviceResource = nullptr;
KyActiveConnectResourse *m_activatedConnectResource = nullptr;
KyConnectResourse * m_connectResource = nullptr;
KyWirelessNetResource *m_wirelessNetResource = nullptr;
void setFirstConnectNetworkMode(QString uuid, QString deviceName, QString ssid);
private Q_SLOTS: