Browse Source

fixed #1387

pull/1421/head
kote 5 years ago
parent
commit
f7a084969a
  1. 7
      daemon/UPnP.cpp
  2. 1
      daemon/UPnP.h
  3. 4
      qt/i2pd_qt/i2pd_qt.pro

7
daemon/UPnP.cpp

@ -110,6 +110,7 @@ namespace transport @@ -110,6 +110,7 @@ namespace transport
}
err = UPNP_GetValidIGD (m_Devlist, &m_upnpUrls, &m_upnpData, m_NetworkAddr, sizeof (m_NetworkAddr));
m_upnpUrlsInitialized=err!=0;
if (err == UPNP_IGD_VALID_CONNECTED)
{
err = UPNP_GetExternalIPAddress (m_upnpUrls.controlURL, m_upnpData.first.servicetype, m_externalIPAddress);
@ -218,6 +219,9 @@ namespace transport @@ -218,6 +219,9 @@ namespace transport
void UPnP::CloseMapping (std::shared_ptr<i2p::data::RouterInfo::Address> address)
{
if(!m_upnpUrlsInitialized) {
return;
}
std::string strType (GetProto (address)), strPort (std::to_string (address->port));
int err = UPNPCOMMAND_SUCCESS;
@ -233,7 +237,10 @@ namespace transport @@ -233,7 +237,10 @@ namespace transport
{
freeUPNPDevlist (m_Devlist);
m_Devlist = 0;
if(m_upnpUrlsInitialized){
FreeUPNPUrls (&m_upnpUrls);
m_upnpUrlsInitialized=false;
}
}
std::string UPnP::GetProto (std::shared_ptr<i2p::data::RouterInfo::Address> address)

1
daemon/UPnP.h

@ -60,6 +60,7 @@ namespace transport @@ -60,6 +60,7 @@ namespace transport
std::mutex m_StartedMutex;
boost::asio::io_service m_Service;
boost::asio::deadline_timer m_Timer;
bool m_upnpUrlsInitialized=false;
struct UPNPUrls m_upnpUrls;
struct IGDdatas m_upnpData;

4
qt/i2pd_qt/i2pd_qt.pro

@ -6,9 +6,7 @@ TARGET = i2pd_qt @@ -6,9 +6,7 @@ TARGET = i2pd_qt
TEMPLATE = app
QMAKE_CXXFLAGS *= -std=c++11 -Wno-unused-parameter -Wno-maybe-uninitialized
# For now, disable UPnP which currently crashes in UPnP::Stop() -- https://github.com/PurpleI2P/i2pd/issues/1387
#DEFINES += USE_UPNP
DEFINES -= USE_UPNP
DEFINES += USE_UPNP
CONFIG(debug, debug|release) {
message(Debug build)

Loading…
Cancel
Save