Merge branch '2309-0721' into 'yhkylin/v101'
fix(托盘): 开启热点后 WiFi列表内容未移除问题(bug181187) See merge request kylinos-src/kylin-nm!235
This commit is contained in:
commit
6e07f5dabb
|
@ -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;
|
||||
}
|
||||
|
|
|
@ -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();
|
||||
}
|
||||
|
||||
|
|
|
@ -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";
|
||||
|
|
|
@ -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:
|
||||
|
|
Loading…
Reference in New Issue