Attempt 3 at fixing disconnections :)

* Added limit of 10kB for Certificate size. If it is bigger - discard certificate.
 * Remove certificates for slow / trickle connections (for Relay connections).



git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@4822 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
drbob 2012-01-20 14:41:45 +00:00
parent 761bca8678
commit 611db96fb9
2 changed files with 41 additions and 3 deletions

View File

@ -434,11 +434,33 @@ void AuthGPGimpl::processServices()
#endif #endif
/* save the certificate to string */ /* save the certificate to string */
#define DISABLE_CERTIFICATE_SEND 1 /*****
* #define DISABLE_CERTIFICATE_SEND 1
****/
#define LIMIT_CERTIFICATE_SIZE 1
#define MAX_CERTIFICATE_SIZE 10000
#ifdef DISABLE_CERTIFICATE_SEND #ifdef DISABLE_CERTIFICATE_SEND
std::cerr << "AuthGPGimpl::processServices() Certificates Disabled" << std::endl;
loadOrSave->m_certGpg = ""; loadOrSave->m_certGpg = "";
#else #else
loadOrSave->m_certGpg = SaveCertificateToString(loadOrSave->m_certGpgId,true); loadOrSave->m_certGpg = SaveCertificateToString(loadOrSave->m_certGpgId,true);
std::cerr << "AuthGPGimpl::processServices() Cert for: " << loadOrSave->m_certGpgId;
std::cerr << " is " << loadOrSave->m_certGpg.size() << " bytes";
std::cerr << std::endl;
#ifdef LIMIT_CERTIFICATE_SIZE
if (loadOrSave->m_certGpg.size() > MAX_CERTIFICATE_SIZE)
{
std::cerr << "AuthGPGimpl::processServices() Cert for: " << loadOrSave->m_certGpgId;
std::cerr << " is over size limit - removing";
std::cerr << std::endl;
loadOrSave->m_certGpg = "";
}
#endif
#endif #endif
} }

View File

@ -975,14 +975,30 @@ void p3disc::setGPGOperation(AuthGPGOperation *operation)
} }
#endif #endif
// Send off message /* for Relay Connections (and other slow ones) we don't want to
item->certGPG = loadOrSave->m_certGpg; * to waste bandwidth sending certificates. So don't add it.
*/
uint32_t linkType = mLinkMgr->getLinkType(item->PeerId());
if ((linkType & RS_NET_CONN_SPEED_TRICKLE) ||
(linkType & RS_NET_CONN_SPEED_LOW))
{
std::cerr << "p3disc::setGPGOperation() Send DiscReply Packet to: ";
std::cerr << item->PeerId();
std::cerr << " without Certificate (low bandwidth)" << std::endl;
}
else
{
// Attaching Certificate.
item->certGPG = loadOrSave->m_certGpg;
}
#ifdef P3DISC_DEBUG #ifdef P3DISC_DEBUG
std::cerr << "p3disc::setGPGOperation() About to Send Message:" << std::endl; std::cerr << "p3disc::setGPGOperation() About to Send Message:" << std::endl;
item->print(std::cerr, 5); item->print(std::cerr, 5);
#endif #endif
// Send off message
sendItem(item); sendItem(item);
#ifdef P3DISC_DEBUG #ifdef P3DISC_DEBUG