mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-04 12:21:04 -05:00
working gui version for peers dialog
git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@2013 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
1ae1c9a98b
commit
bb45fa3db5
@ -198,7 +198,7 @@ AuthGPG::AuthGPG()
|
|||||||
*
|
*
|
||||||
* returns false if GnuPG is not available.
|
* returns false if GnuPG is not available.
|
||||||
*/
|
*/
|
||||||
bool AuthGPG::availablePGPCertificates(std::list<std::string> &ids)
|
bool AuthGPG::availablePGPCertificatesWithPrivateKeys(std::list<std::string> &ids)
|
||||||
{
|
{
|
||||||
//RsStackMutex stack(pgpMtx); /******* LOCKED ******/
|
//RsStackMutex stack(pgpMtx); /******* LOCKED ******/
|
||||||
|
|
||||||
@ -225,9 +225,9 @@ bool AuthGPG::availablePGPCertificates(std::list<std::string> &ids)
|
|||||||
/* Loop until end of key */
|
/* Loop until end of key */
|
||||||
for(i = 0;(GPG_ERR_NO_ERROR == (ERR = gpgme_op_keylist_next (CTX, &KEY))); i++)
|
for(i = 0;(GPG_ERR_NO_ERROR == (ERR = gpgme_op_keylist_next (CTX, &KEY))); i++)
|
||||||
{
|
{
|
||||||
if (KEY->subkeys)
|
if (KEY->subkeys)
|
||||||
{
|
{
|
||||||
ids.push_back(KEY->subkeys->keyid);
|
ids.push_back(KEY->subkeys->keyid);
|
||||||
std::cerr << "AuthGPG::availablePGPCertificates() Added: "
|
std::cerr << "AuthGPG::availablePGPCertificates() Added: "
|
||||||
<< KEY->subkeys->keyid << std::endl;
|
<< KEY->subkeys->keyid << std::endl;
|
||||||
}
|
}
|
||||||
@ -971,6 +971,14 @@ bool AuthGPG::encryptText(gpgme_data_t PLAIN, gpgme_data_t CIPHER) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool AuthGPG::getPGPAcceptedList(std::list<std::string> &ids)
|
||||||
|
{
|
||||||
|
//RsStackMutex stack(pgpMtx); /******* LOCKED ******/
|
||||||
|
//TODO : implement a list in config file of accepted GPG key to connect with
|
||||||
|
|
||||||
|
return getPGPSignedList(ids);
|
||||||
|
}
|
||||||
|
|
||||||
bool AuthGPG::getPGPSignedList(std::list<std::string> &ids)
|
bool AuthGPG::getPGPSignedList(std::list<std::string> &ids)
|
||||||
{
|
{
|
||||||
//RsStackMutex stack(pgpMtx); /******* LOCKED ******/
|
//RsStackMutex stack(pgpMtx); /******* LOCKED ******/
|
||||||
|
@ -104,7 +104,7 @@ class AuthGPG
|
|||||||
AuthGPG();
|
AuthGPG();
|
||||||
~AuthGPG();
|
~AuthGPG();
|
||||||
|
|
||||||
bool availablePGPCertificates(std::list<std::string> &ids);
|
bool availablePGPCertificatesWithPrivateKeys(std::list<std::string> &ids);
|
||||||
|
|
||||||
int GPGInit(std::string ownId);
|
int GPGInit(std::string ownId);
|
||||||
|
|
||||||
@ -150,10 +150,11 @@ class AuthGPG
|
|||||||
|
|
||||||
/* PGP web of trust management */
|
/* PGP web of trust management */
|
||||||
GPG_id PGPOwnId();
|
GPG_id PGPOwnId();
|
||||||
bool getPGPAllList(std::list<std::string> &ids);
|
|
||||||
bool getPGPDetails(std::string id, RsPeerDetails &d);
|
bool getPGPDetails(std::string id, RsPeerDetails &d);
|
||||||
bool getPGPSignedList(std::list<std::string> &ids);
|
bool getPGPAllList(std::list<std::string> &ids);
|
||||||
bool getPGPValidList(std::list<std::string> &ids);
|
bool getPGPValidList(std::list<std::string> &ids);
|
||||||
|
bool getPGPAcceptedList(std::list<std::string> &ids);
|
||||||
|
bool getPGPSignedList(std::list<std::string> &ids);
|
||||||
bool isPGPValid(std::string id);
|
bool isPGPValid(std::string id);
|
||||||
bool isPGPSigned(std::string id);
|
bool isPGPSigned(std::string id);
|
||||||
|
|
||||||
|
@ -604,16 +604,6 @@ int AuthSSL::setConfigDirectories(std::string configfile, std::string neighd
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* no trust in SSL certs */
|
|
||||||
bool AuthSSL::isTrustingMe(std::string id)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
void AuthSSL::addTrustingPeer(std::string id)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string AuthSSL::OwnId()
|
std::string AuthSSL::OwnId()
|
||||||
{
|
{
|
||||||
#ifdef AUTHSSL_DEBUG
|
#ifdef AUTHSSL_DEBUG
|
||||||
@ -697,30 +687,30 @@ bool AuthSSL::getUnknownList(std::list<std::string> &ids)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* silly question really - only valid certs get saved to map
|
bool AuthSSL::getSSLChildListOfGPGId(std::string gpg_id, std::list<std::string> &ids)
|
||||||
* so if in map its okay
|
|
||||||
*/
|
|
||||||
bool AuthSSL::isValid(std::string id)
|
|
||||||
{
|
{
|
||||||
#ifdef AUTHSSL_DEBUG
|
#ifdef AUTHSSL_DEBUG
|
||||||
std::cerr << "AuthSSL::isValid() " << id;
|
std::cerr << "AuthSSL::getChildListOfGPGId() called for gpg id : " << gpg_id << std::endl;
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
#endif
|
||||||
sslMtx.lock(); /***** LOCK *****/
|
sslMtx.lock(); /***** LOCK *****/
|
||||||
bool valid = false;
|
|
||||||
|
|
||||||
if (id == mOwnId)
|
/* iterate through both lists */
|
||||||
{
|
std::map<std::string, sslcert *>::iterator it;
|
||||||
valid = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
valid = (mCerts.end() != mCerts.find(id));
|
|
||||||
}
|
|
||||||
|
|
||||||
sslMtx.unlock(); /**** UNLOCK ****/
|
for(it = mCerts.begin(); it != mCerts.end(); it++)
|
||||||
|
{
|
||||||
|
#ifdef AUTHSSL_DEBUG
|
||||||
|
std::cerr << "AuthSSL::getChildListOfGPGId() it->second->authed : " << it->second->authed << "; it->second->issuer : " << it->second->issuer << std::endl;
|
||||||
|
#endif
|
||||||
|
if (it->second->authed && it->second->issuer == gpg_id)
|
||||||
|
{
|
||||||
|
ids.push_back(it->first);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return valid;
|
sslMtx.unlock(); /**** UNLOCK ****/
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AuthSSL::isAuthenticated(std::string id)
|
bool AuthSSL::isAuthenticated(std::string id)
|
||||||
@ -1019,73 +1009,6 @@ bool AuthSSL::SaveCertificateToBinary(std::string id, uint8_t **ptr, uint32_t *
|
|||||||
return valid;
|
return valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Signatures */
|
|
||||||
/* NO Signatures in SSL Certificates */
|
|
||||||
|
|
||||||
bool AuthSSL::SignCertificate(std::string id)
|
|
||||||
{
|
|
||||||
#ifdef AUTHSSL_DEBUG
|
|
||||||
std::cerr << "AuthSSL::SignCertificate() NULL " << id;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
bool valid = false;
|
|
||||||
return valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool AuthSSL::TrustCertificate(std::string id, bool totrust)
|
|
||||||
{
|
|
||||||
#ifdef AUTHSSL_DEBUG
|
|
||||||
std::cerr << "AuthSSL::TrustCertificate() NULL " << id;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
bool valid = false;
|
|
||||||
return valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool AuthSSL::RevokeCertificate(std::string id)
|
|
||||||
{
|
|
||||||
#ifdef AUTHSSL_DEBUG
|
|
||||||
std::cerr << "AuthSSL::RevokeCertificate() NULL " << id;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
sslMtx.lock(); /***** LOCK *****/
|
|
||||||
sslMtx.unlock(); /**** UNLOCK ****/
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool AuthSSL::AuthCertificate(std::string id)
|
|
||||||
{
|
|
||||||
|
|
||||||
#ifdef AUTHSSL_DEBUG
|
|
||||||
std::cerr << "AuthSSL::AuthCertificate() " << id;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
sslMtx.lock(); /***** LOCK *****/
|
|
||||||
|
|
||||||
/* get the cert first */
|
|
||||||
sslcert *cert = NULL;
|
|
||||||
sslcert *own = mOwnCert;
|
|
||||||
bool valid = false;
|
|
||||||
|
|
||||||
if (locked_FindCert(id, &cert))
|
|
||||||
{
|
|
||||||
/* ensuring this function can do nothing in PGP mode */
|
|
||||||
#ifdef PQI_USE_SSLONLY
|
|
||||||
cert->authed=true;
|
|
||||||
mToSaveCerts = true;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
sslMtx.unlock(); /**** UNLOCK ****/
|
|
||||||
return valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Sign / Encrypt / Verify Data (TODO) */
|
/* Sign / Encrypt / Verify Data (TODO) */
|
||||||
|
|
||||||
bool AuthSSL::SignData(std::string input, std::string &sign)
|
bool AuthSSL::SignData(std::string input, std::string &sign)
|
||||||
@ -1577,13 +1500,7 @@ bool AuthSSL::ProcessX509(X509 *x509, std::string &id)
|
|||||||
{
|
{
|
||||||
#ifdef AUTHSSL_DEBUG
|
#ifdef AUTHSSL_DEBUG
|
||||||
std::cerr << "AuthSSL::ProcessX509() ValidateCertificate FAILED";
|
std::cerr << "AuthSSL::ProcessX509() ValidateCertificate FAILED";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef PQI_USE_SSLONLY
|
|
||||||
/* bad ( or unknown pgp issuer ) certificate */
|
|
||||||
X509_free(x509);
|
|
||||||
return false;
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1681,7 +1598,7 @@ bool AuthSSL::ProcessX509(X509 *x509, std::string &id)
|
|||||||
|
|
||||||
sslMtx.lock(); /***** LOCK *****/
|
sslMtx.lock(); /***** LOCK *****/
|
||||||
|
|
||||||
mCerts[xid] = cert;
|
mCerts[xid] = cert;
|
||||||
|
|
||||||
/* resave if new certificate */
|
/* resave if new certificate */
|
||||||
mToSaveCerts = true;
|
mToSaveCerts = true;
|
||||||
@ -1707,8 +1624,7 @@ bool AuthSSL::ProcessX509(X509 *x509, std::string &id)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool getX509id(X509 *x509, std::string &xid)
|
bool getX509id(X509 *x509, std::string &xid) {
|
||||||
{
|
|
||||||
#ifdef AUTHSSL_DEBUG
|
#ifdef AUTHSSL_DEBUG
|
||||||
std::cerr << "AuthSSL::getX509id()";
|
std::cerr << "AuthSSL::getX509id()";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
@ -1986,8 +1902,6 @@ bool AuthSSL::AuthX509(X509 *x509)
|
|||||||
int sigoutl=0,sigoutll=0;
|
int sigoutl=0,sigoutll=0;
|
||||||
X509_ALGOR *a;
|
X509_ALGOR *a;
|
||||||
|
|
||||||
fprintf(stderr, "AuthSSL::AuthX509()\n");
|
|
||||||
|
|
||||||
EVP_MD_CTX_init(&ctx);
|
EVP_MD_CTX_init(&ctx);
|
||||||
|
|
||||||
/* input buffer */
|
/* input buffer */
|
||||||
@ -2038,6 +1952,8 @@ bool AuthSSL::AuthX509(X509 *x509)
|
|||||||
sigoutl = 0;
|
sigoutl = 0;
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
//TODO implement a way to check that the sign KEY is the same as the issuer id in the ssl cert
|
||||||
|
|
||||||
std::cerr << "AuthSSL::AuthX509() X509 authenticated" << std::endl;
|
std::cerr << "AuthSSL::AuthX509() X509 authenticated" << std::endl;
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
@ -2049,22 +1965,20 @@ bool AuthSSL::AuthX509(X509 *x509)
|
|||||||
bool AuthSSL::ValidateCertificate(X509 *x509, std::string &peerId)
|
bool AuthSSL::ValidateCertificate(X509 *x509, std::string &peerId)
|
||||||
{
|
{
|
||||||
/* check self signed */
|
/* check self signed */
|
||||||
#warning "ValidateCertificate Not Finished"
|
if (!AuthX509(x509) || !getX509id(x509, peerId)) {
|
||||||
|
#ifdef AUTHSSL_DEBUG
|
||||||
#if 0
|
std::cerr << "AuthSSL::ValidateCertificate() bad certificate.";
|
||||||
if (!X509_check_valid_certificate(x509))
|
std::cerr << std::endl;
|
||||||
{
|
|
||||||
/* bad certificate */
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef AUTHSSL_DEBUG
|
#ifdef AUTHSSL_DEBUG
|
||||||
std::cerr << "AuthSSL::ValidateCertificate() Not Finished!";
|
std::cerr << "AuthSSL::ValidateCertificate() good certificate.";
|
||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return getX509id(x509, peerId);
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* store for discovery */
|
/* store for discovery */
|
||||||
@ -2136,8 +2050,6 @@ bool AuthSSL::CheckCertificate(std::string x509Id, X509 *x509)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/********************************************************************************/
|
/********************************************************************************/
|
||||||
/********************************************************************************/
|
/********************************************************************************/
|
||||||
/********************************************************************************/
|
/********************************************************************************/
|
||||||
|
@ -101,26 +101,19 @@ virtual int setConfigDirectories(std::string confFile, std::string neighDir)
|
|||||||
/*********** Overloaded Functions from p3AuthMgr **********/
|
/*********** Overloaded Functions from p3AuthMgr **********/
|
||||||
|
|
||||||
/* get Certificate Ids */
|
/* get Certificate Ids */
|
||||||
|
|
||||||
virtual std::string OwnId();
|
virtual std::string OwnId();
|
||||||
virtual bool getAllList(std::list<std::string> &ids);
|
virtual bool getAllList(std::list<std::string> &ids);
|
||||||
virtual bool getAuthenticatedList(std::list<std::string> &ids);
|
virtual bool getAuthenticatedList(std::list<std::string> &ids);
|
||||||
virtual bool getUnknownList(std::list<std::string> &ids);
|
virtual bool getUnknownList(std::list<std::string> &ids);
|
||||||
|
virtual bool getSSLChildListOfGPGId(std::string gpg_id, std::list<std::string> &ids);
|
||||||
|
|
||||||
/* get Details from the Certificates */
|
/* get Details from the Certificates */
|
||||||
|
|
||||||
virtual bool isValid(std::string id);
|
|
||||||
virtual bool isAuthenticated(std::string id);
|
virtual bool isAuthenticated(std::string id);
|
||||||
virtual std::string getName(std::string id);
|
virtual std::string getName(std::string id);
|
||||||
virtual std::string getIssuerName(std::string id);
|
virtual std::string getIssuerName(std::string id);
|
||||||
virtual std::string getGPGId(SSL_id id);
|
virtual std::string getGPGId(SSL_id id);
|
||||||
virtual bool getCertDetails(std::string id, sslcert &cert);
|
virtual bool getCertDetails(std::string id, sslcert &cert);
|
||||||
|
|
||||||
/* first party trust info (dummy) */
|
|
||||||
virtual bool isTrustingMe(std::string id) ;
|
|
||||||
virtual void addTrustingPeer(std::string id) ;
|
|
||||||
|
|
||||||
|
|
||||||
/* High Level Load/Save Configuration */
|
/* High Level Load/Save Configuration */
|
||||||
virtual bool FinalSaveCertificates();
|
virtual bool FinalSaveCertificates();
|
||||||
virtual bool CheckSaveCertificates();
|
virtual bool CheckSaveCertificates();
|
||||||
@ -132,19 +125,11 @@ virtual bool LoadCertificateFromString(std::string pem, std::string &id);
|
|||||||
virtual std::string SaveCertificateToString(std::string id);
|
virtual std::string SaveCertificateToString(std::string id);
|
||||||
virtual bool LoadCertificateFromFile(std::string filename, std::string &id);
|
virtual bool LoadCertificateFromFile(std::string filename, std::string &id);
|
||||||
virtual bool SaveCertificateToFile(std::string id, std::string filename);
|
virtual bool SaveCertificateToFile(std::string id, std::string filename);
|
||||||
|
bool ProcessX509(X509 *x509, std::string &id);
|
||||||
|
|
||||||
virtual bool LoadCertificateFromBinary(const uint8_t *ptr, uint32_t len, std::string &id);
|
virtual bool LoadCertificateFromBinary(const uint8_t *ptr, uint32_t len, std::string &id);
|
||||||
virtual bool SaveCertificateToBinary(std::string id, uint8_t **ptr, uint32_t *len);
|
virtual bool SaveCertificateToBinary(std::string id, uint8_t **ptr, uint32_t *len);
|
||||||
|
|
||||||
/* Signatures */
|
|
||||||
|
|
||||||
virtual bool AuthCertificate(std::string uid);
|
|
||||||
|
|
||||||
/* These are dummy functions */
|
|
||||||
virtual bool SignCertificate(std::string id);
|
|
||||||
virtual bool RevokeCertificate(std::string id);
|
|
||||||
virtual bool TrustCertificate(std::string id, bool trust);
|
|
||||||
|
|
||||||
/* Sign / Encrypt / Verify Data (TODO) */
|
/* Sign / Encrypt / Verify Data (TODO) */
|
||||||
virtual bool SignData(std::string input, std::string &sign);
|
virtual bool SignData(std::string input, std::string &sign);
|
||||||
virtual bool SignData(const void *data, const uint32_t len, std::string &sign);
|
virtual bool SignData(const void *data, const uint32_t len, std::string &sign);
|
||||||
@ -153,10 +138,10 @@ virtual bool SignDataBin(const void*, uint32_t, unsigned char*, unsigned int*
|
|||||||
virtual bool VerifySignBin(std::string, const void*, uint32_t, unsigned char*, unsigned int);
|
virtual bool VerifySignBin(std::string, const void*, uint32_t, unsigned char*, unsigned int);
|
||||||
|
|
||||||
// return : false if encrypt failed
|
// return : false if encrypt failed
|
||||||
bool encrypt(void *&out, int &outlen, const void *in, int inlen, std::string peerId); //return the encrypted length
|
bool encrypt(void *&out, int &outlen, const void *in, int inlen, std::string peerId);
|
||||||
|
|
||||||
// return : false if decrypt fails
|
// return : false if decrypt fails
|
||||||
bool decrypt(void *&out, int &outlen, const void *in, int inlen); //return the encrypted length
|
bool decrypt(void *&out, int &outlen, const void *in, int inlen);
|
||||||
|
|
||||||
|
|
||||||
/*********** Overloaded Functions from p3AuthMgr **********/
|
/*********** Overloaded Functions from p3AuthMgr **********/
|
||||||
@ -191,8 +176,6 @@ bool loadCertificates(bool &oldFormat, std::map<std::string, std::string> &key
|
|||||||
static AuthSSL *instance_ssl;
|
static AuthSSL *instance_ssl;
|
||||||
|
|
||||||
/* Helper Functions */
|
/* Helper Functions */
|
||||||
bool ProcessX509(X509 *x509, std::string &id);
|
|
||||||
|
|
||||||
X509 * loadX509FromPEM(std::string pem);
|
X509 * loadX509FromPEM(std::string pem);
|
||||||
X509 * loadX509FromFile(std::string fname, std::string hash);
|
X509 * loadX509FromFile(std::string fname, std::string hash);
|
||||||
bool saveX509ToFile(X509 *x509, std::string fname, std::string &hash);
|
bool saveX509ToFile(X509 *x509, std::string fname, std::string &hash);
|
||||||
|
@ -2170,7 +2170,7 @@ bool p3ConnectMgr::addNeighbour(std::string id)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* check with the AuthMgr if its valid */
|
/* check with the AuthMgr if its valid */
|
||||||
if (!AuthSSL::getAuthSSL()->isValid(id))
|
if (!AuthSSL::getAuthSSL()->isAuthenticated(id))
|
||||||
{
|
{
|
||||||
/* no auth */
|
/* no auth */
|
||||||
return false;
|
return false;
|
||||||
@ -2912,7 +2912,7 @@ bool p3ConnectMgr::loadList(std::list<RsItem *> load)
|
|||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#endif
|
#endif
|
||||||
/* add ownConfig */
|
/* add ownConfig */
|
||||||
setOwnNetConfig(pitem->netMode, pitem->visState);
|
setOwnNetConfig(pitem->netMode, pitem->visState);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -130,37 +130,36 @@ virtual bool OthersChanged() = 0;
|
|||||||
/* Peer Details (Net & Auth) */
|
/* Peer Details (Net & Auth) */
|
||||||
virtual std::string getOwnId() = 0;
|
virtual std::string getOwnId() = 0;
|
||||||
|
|
||||||
virtual bool getOnlineList(std::list<std::string> &ids) = 0;
|
virtual bool getOnlineList(std::list<std::string> &ssl_ids) = 0;
|
||||||
virtual bool getFriendList(std::list<std::string> &ids) = 0;
|
virtual bool getFriendList(std::list<std::string> &ssl_ids) = 0;
|
||||||
virtual bool getOthersList(std::list<std::string> &ids) = 0;
|
virtual bool getOthersList(std::list<std::string> &ssl_ids) = 0;
|
||||||
|
|
||||||
virtual bool isOnline(std::string id) = 0;
|
virtual bool isOnline(std::string ssl_id) = 0;
|
||||||
virtual bool isFriend(std::string id) = 0;
|
virtual bool isFriend(std::string ssl_id) = 0;
|
||||||
virtual std::string getPeerName(std::string id) = 0;
|
virtual std::string getPeerName(std::string ssl_id) = 0;
|
||||||
virtual std::string getPeerPGPName(std::string pgp_id) = 0;
|
virtual std::string getPeerPGPName(std::string ssl_id) = 0;
|
||||||
virtual bool getPeerDetails(std::string id, RsPeerDetails &d) = 0; //get Peer detail accept SSL and PGP certs
|
virtual bool getPeerDetails(std::string ssl_or_gpg_id, RsPeerDetails &d) = 0; //get Peer detail accept SSL and PGP certs
|
||||||
|
|
||||||
/* Using PGP Ids */
|
/* Using PGP Ids */
|
||||||
virtual std::string getPGPOwnId() = 0;
|
virtual std::string getPGPOwnId() = 0;
|
||||||
virtual std::string getPGPId(std::string ssl_id) = 0;
|
virtual std::string getPGPId(std::string ssl_id) = 0;
|
||||||
virtual bool getPGPAcceptedList(std::list<std::string> &ids) = 0;
|
virtual bool getPGPAcceptedList(std::list<std::string> &gpg_ids) = 0;
|
||||||
virtual bool getPGPSignedList(std::list<std::string> &ids) = 0;//friends that we accpet to connect with but we don't want to sign their gpg key
|
virtual bool getPGPSignedList(std::list<std::string> &gpg_ids) = 0;//friends that we accpet to connect with but we don't want to sign their gpg key
|
||||||
virtual bool getPGPValidList(std::list<std::string> &ids) = 0;
|
virtual bool getPGPValidList(std::list<std::string> &gpg_ids) = 0;
|
||||||
virtual bool getPGPAllList(std::list<std::string> &ids) = 0;
|
virtual bool getPGPAllList(std::list<std::string> &gpg_ids) = 0;
|
||||||
virtual bool getPGPDetails(std::string id, RsPeerDetails &d) = 0;
|
virtual bool getPGPDetails(std::string gpg_id, RsPeerDetails &d) = 0;
|
||||||
|
virtual bool getSSLChildListOfGPGId(std::string gpg_id, std::list<std::string> &ids) = 0;
|
||||||
virtual bool getPGPFriendList(std::list<std::string> &ids) = 0;
|
|
||||||
|
|
||||||
/* Add/Remove Friends */
|
/* Add/Remove Friends */
|
||||||
virtual bool addFriend(std::string id) = 0;
|
virtual bool addFriend(std::string id) = 0;
|
||||||
virtual bool removeFriend(std::string id) = 0;
|
virtual bool removeFriend(std::string id) = 0;
|
||||||
|
|
||||||
/* Network Stuff */
|
/* Network Stuff */
|
||||||
virtual bool connectAttempt(std::string id) = 0;
|
virtual bool connectAttempt(std::string ssl_id) = 0;
|
||||||
virtual bool setLocalAddress(std::string id, std::string addr, uint16_t port) = 0;
|
virtual bool setLocalAddress(std::string ssl_id, std::string addr, uint16_t port) = 0;
|
||||||
virtual bool setExtAddress( std::string id, std::string addr, uint16_t port) = 0;
|
virtual bool setExtAddress( std::string ssl_id, std::string addr, uint16_t port) = 0;
|
||||||
virtual bool setNetworkMode(std::string id, uint32_t netMode) = 0;
|
virtual bool setNetworkMode(std::string ssl_id, uint32_t netMode) = 0;
|
||||||
virtual bool setVisState(std::string id, uint32_t vis) = 0;
|
virtual bool setVisState(std::string ssl_id, uint32_t vis) = 0;
|
||||||
|
|
||||||
virtual void getIPServersList(std::list<std::string>& ip_servers) = 0;
|
virtual void getIPServersList(std::list<std::string>& ip_servers) = 0;
|
||||||
virtual void allowServerIPDetermination(bool) = 0;
|
virtual void allowServerIPDetermination(bool) = 0;
|
||||||
@ -176,8 +175,8 @@ virtual bool LoadCertificateFromString(std::string cert, std::string &id) = 0;
|
|||||||
virtual bool SaveCertificateToFile(std::string id, std::string fname) = 0;
|
virtual bool SaveCertificateToFile(std::string id, std::string fname) = 0;
|
||||||
virtual std::string SaveCertificateToString(std::string id) = 0;
|
virtual std::string SaveCertificateToString(std::string id) = 0;
|
||||||
|
|
||||||
virtual bool SignGPGCertificate(std::string id) = 0;
|
virtual bool SignGPGCertificate(std::string gpg_id) = 0;
|
||||||
virtual bool TrustGPGCertificate(std::string id, uint32_t trustlvl) = 0;
|
virtual bool TrustGPGCertificate(std::string gpg_id, uint32_t trustlvl) = 0;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -291,16 +291,21 @@ static struct sockaddr_in getPreferredAddress( const struct sockaddr_in& addr1,t
|
|||||||
|
|
||||||
bool p3Peers::getPeerDetails(std::string id, RsPeerDetails &d)
|
bool p3Peers::getPeerDetails(std::string id, RsPeerDetails &d)
|
||||||
{
|
{
|
||||||
#ifdef P3PEERS_DEBUG
|
#ifdef P3PEERS_DEBUG
|
||||||
std::cerr << "p3Peers::getPeerDetails() " << id;
|
std::cerr << "p3Peers::getPeerDetails() called for id : " << id << std::endl;
|
||||||
std::cerr << std::endl;
|
#endif
|
||||||
#endif
|
|
||||||
//first, check if it's a gpg or a ssl id.
|
//first, check if it's a gpg or a ssl id.
|
||||||
if (AuthSSL::getAuthSSL()->getGPGId(id) == "") {
|
if (AuthSSL::getAuthSSL()->getGPGId(id) == "") {
|
||||||
//assume is not SSL, because every ssl_id has got a pgp_id
|
//assume is not SSL, because every ssl_id has got a pgp_id
|
||||||
|
#ifdef P3PEERS_DEBUG
|
||||||
|
std::cerr << "p3Peers::getPeerDetails() got a gpg id and is returning GPG details only for id : " << id << std::endl;
|
||||||
|
#endif
|
||||||
d.isOnlyGPGdetail = true;
|
d.isOnlyGPGdetail = true;
|
||||||
return this->getPGPDetails(id, d);
|
return this->getPGPDetails(id, d);
|
||||||
}
|
}
|
||||||
|
#ifdef P3PEERS_DEBUG
|
||||||
|
std::cerr << "p3Peers::getPeerDetails() got a SSL id and is returning SSL and GPG details for id : " << id << std::endl;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* get from gpg (first), to fill in the sign and trust details */
|
/* get from gpg (first), to fill in the sign and trust details */
|
||||||
/* don't retrun now, we've got fill in the ssl and connection info */
|
/* don't retrun now, we've got fill in the ssl and connection info */
|
||||||
@ -309,9 +314,11 @@ bool p3Peers::getPeerDetails(std::string id, RsPeerDetails &d)
|
|||||||
|
|
||||||
//get the ssl details
|
//get the ssl details
|
||||||
sslcert authDetail;
|
sslcert authDetail;
|
||||||
if (!AuthSSL::getAuthSSL()->getCertDetails(id, authDetail))
|
if (!AuthSSL::getAuthSSL()->getCertDetails(id, authDetail)) {
|
||||||
{
|
#ifdef P3PEERS_DEBUG
|
||||||
return false;
|
std::cerr << "p3Peers::getPeerDetails() got no SSL details, is returning." << std::endl;
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
d.fpr = authDetail.fpr;
|
d.fpr = authDetail.fpr;
|
||||||
@ -486,56 +493,6 @@ std::string p3Peers::getPeerName(std::string id)
|
|||||||
return AuthSSL::getAuthSSL()->getName(id);
|
return AuthSSL::getAuthSSL()->getName(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool p3Peers::getPGPFriendList(std::list<std::string> &ids)
|
|
||||||
{
|
|
||||||
#ifdef P3PEERS_DEBUG
|
|
||||||
std::cerr << "p3Peers::getPGPFriendList()";
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
std::list<std::string> certids;
|
|
||||||
std::list<std::string>::iterator it;
|
|
||||||
|
|
||||||
mConnMgr->getFriendList(certids);
|
|
||||||
|
|
||||||
/* get from mAuthMgr (first) */
|
|
||||||
for(it = certids.begin(); it != certids.end(); it++)
|
|
||||||
{
|
|
||||||
sslcert detail;
|
|
||||||
if (!AuthSSL::getAuthSSL()->getCertDetails(*it, detail))
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef P3PEERS_DEBUG
|
|
||||||
std::cerr << "p3Peers::getPGPFriendList() Cert Id: " << *it;
|
|
||||||
std::cerr << " Issuer: " << detail.issuer;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
if (!mAuthMgr->isPGPvalid(detail.issuer))
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (ids.end() == std::find(ids.begin(),ids.end(),detail.issuer))
|
|
||||||
{
|
|
||||||
|
|
||||||
#ifdef P3PEERS_DEBUG
|
|
||||||
std::cerr << "p3Peers::getPGPFriendList() Adding Friend: ";
|
|
||||||
std::cerr << detail.issuer;
|
|
||||||
std::cerr << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ids.push_back(detail.issuer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool p3Peers::getPGPAllList(std::list<std::string> &ids)
|
bool p3Peers::getPGPAllList(std::list<std::string> &ids)
|
||||||
{
|
{
|
||||||
#ifdef P3PEERS_DEBUG
|
#ifdef P3PEERS_DEBUG
|
||||||
@ -579,11 +536,21 @@ bool p3Peers::getPGPAcceptedList(std::list<std::string> &ids)
|
|||||||
std::cerr << std::endl;
|
std::cerr << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* get from mAuthMgr */
|
//TODO implement an additional list of GPG keys that are accepted even if not signed
|
||||||
AuthGPG::getAuthGPG()->getPGPSignedList(ids);
|
AuthGPG::getAuthGPG()->getPGPSignedList(ids);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool p3Peers::getSSLChildListOfGPGId(std::string gpg_id, std::list<std::string> &ids)
|
||||||
|
{
|
||||||
|
#ifdef P3PEERS_DEBUG
|
||||||
|
std::cerr << "p3Peers::getSSLChildListOfGPGId() for id : " << gpg_id;
|
||||||
|
std::cerr << std::endl;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return AuthSSL::getAuthSSL()->getSSLChildListOfGPGId(gpg_id, ids);;
|
||||||
|
}
|
||||||
|
|
||||||
bool p3Peers::getPGPDetails(std::string id, RsPeerDetails &d)
|
bool p3Peers::getPGPDetails(std::string id, RsPeerDetails &d)
|
||||||
{
|
{
|
||||||
#ifdef P3PEERS_DEBUG
|
#ifdef P3PEERS_DEBUG
|
||||||
|
@ -61,9 +61,7 @@ virtual bool getPGPSignedList(std::list<std::string> &ids);
|
|||||||
virtual bool getPGPValidList(std::list<std::string> &ids);
|
virtual bool getPGPValidList(std::list<std::string> &ids);
|
||||||
virtual bool getPGPAllList(std::list<std::string> &ids);
|
virtual bool getPGPAllList(std::list<std::string> &ids);
|
||||||
virtual bool getPGPDetails(std::string id, RsPeerDetails &d);
|
virtual bool getPGPDetails(std::string id, RsPeerDetails &d);
|
||||||
|
virtual bool getSSLChildListOfGPGId(std::string gpg_id, std::list<std::string> &ids);
|
||||||
virtual bool getPGPFriendList(std::list<std::string> &ids);
|
|
||||||
|
|
||||||
|
|
||||||
/* Add/Remove Friends */
|
/* Add/Remove Friends */
|
||||||
virtual bool addFriend(std::string id);
|
virtual bool addFriend(std::string id);
|
||||||
|
@ -765,7 +765,7 @@ static bool checkAccount(std::string accountdir, accountId &id)
|
|||||||
|
|
||||||
/* Generating GPGme Account */
|
/* Generating GPGme Account */
|
||||||
int RsInit::GetPGPLogins(std::list<std::string> &pgpIds) {
|
int RsInit::GetPGPLogins(std::list<std::string> &pgpIds) {
|
||||||
AuthGPG::getAuthGPG()->availablePGPCertificates(pgpIds);
|
AuthGPG::getAuthGPG()->availablePGPCertificatesWithPrivateKeys(pgpIds);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1886,6 +1886,12 @@ int RsServer::StartupRetroShare()
|
|||||||
rsNotify = new p3Notify();
|
rsNotify = new p3Notify();
|
||||||
|
|
||||||
mConnMgr = new p3ConnectMgr();
|
mConnMgr = new p3ConnectMgr();
|
||||||
|
//load all the SSL certs as friends
|
||||||
|
std::list<std::string> sslIds;
|
||||||
|
AuthSSL::getAuthSSL()->getAuthenticatedList(sslIds);
|
||||||
|
for (std::list<std::string>::iterator sslIdsIt = sslIds.begin(); sslIdsIt != sslIds.end(); sslIdsIt++) {
|
||||||
|
mConnMgr->addFriend(*sslIdsIt);
|
||||||
|
}
|
||||||
pqiNetAssistFirewall *mUpnpMgr = new upnphandler();
|
pqiNetAssistFirewall *mUpnpMgr = new upnphandler();
|
||||||
//p3DhtMgr *mDhtMgr = new OpenDHTMgr(ownId, mConnMgr, RsInitConfig::configDir);
|
//p3DhtMgr *mDhtMgr = new OpenDHTMgr(ownId, mConnMgr, RsInitConfig::configDir);
|
||||||
|
|
||||||
|
@ -729,7 +729,6 @@ void p3disc::recvPeerFriendMsg(RsDiscReply *item)
|
|||||||
{
|
{
|
||||||
std::cerr << " Found a peer that trust me: " << peerId << " (" << rsPeers->getPeerName(peerId) << ")" << std::endl ;
|
std::cerr << " Found a peer that trust me: " << peerId << " (" << rsPeers->getPeerName(peerId) << ")" << std::endl ;
|
||||||
flags |= RS_NET_FLAGS_TRUSTS_ME;
|
flags |= RS_NET_FLAGS_TRUSTS_ME;
|
||||||
AuthSSL::getAuthSSL()->addTrustingPeer(peerId) ;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* generate type */
|
/* generate type */
|
||||||
|
@ -156,7 +156,7 @@ void NetworkView::insertPeers()
|
|||||||
|
|
||||||
/* get the list of friends' issuers, as we flag them specially */
|
/* get the list of friends' issuers, as we flag them specially */
|
||||||
std::list<std::string> fids;
|
std::list<std::string> fids;
|
||||||
rsPeers->getPGPFriendList(fids);
|
//rsPeers->getPGPFriendList(fids);
|
||||||
|
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
@ -252,7 +252,7 @@ void NetworkView::insertConnections()
|
|||||||
|
|
||||||
//std::string ownId = rsPeers->getGPGOwnId();
|
//std::string ownId = rsPeers->getGPGOwnId();
|
||||||
//rsPeers->getPGPAllList(ids);
|
//rsPeers->getPGPAllList(ids);
|
||||||
rsPeers->getPGPFriendList(fids);
|
//rsPeers->getPGPFriendList(fids);
|
||||||
|
|
||||||
std::cerr << "NetworkView::insertConnections()" << std::endl;
|
std::cerr << "NetworkView::insertConnections()" << std::endl;
|
||||||
|
|
||||||
|
@ -101,31 +101,27 @@ PeersDialog::PeersDialog(QWidget *parent)
|
|||||||
connect( ui.avatartoolButton, SIGNAL(clicked()), SLOT(getAvatar()));
|
connect( ui.avatartoolButton, SIGNAL(clicked()), SLOT(getAvatar()));
|
||||||
connect( ui.mypersonalstatuslabel, SIGNAL(clicked()), SLOT(statusmessage()));
|
connect( ui.mypersonalstatuslabel, SIGNAL(clicked()), SLOT(statusmessage()));
|
||||||
|
|
||||||
/* hide the Tree +/- */
|
|
||||||
ui.peertreeWidget -> setRootIsDecorated( false );
|
|
||||||
|
|
||||||
ui.peertabWidget->addTab(new ProfileWidget(),QString(tr("Profile")));
|
ui.peertabWidget->addTab(new ProfileWidget(),QString(tr("Profile")));
|
||||||
|
|
||||||
ui.peertreeWidget->setColumnCount(4);
|
ui.peertreeWidget->setColumnCount(4);
|
||||||
ui.peertreeWidget->setColumnHidden ( 3, true);
|
ui.peertreeWidget->setColumnHidden ( 3, true);
|
||||||
|
ui.peertreeWidget->setColumnHidden ( 2, true);
|
||||||
ui.peertreeWidget->sortItems( 2, Qt::AscendingOrder );
|
ui.peertreeWidget->sortItems( 2, Qt::AscendingOrder );
|
||||||
|
|
||||||
/* Set header resize modes and initial section sizes */
|
/* Set header resize modes and initial section sizes */
|
||||||
QHeaderView * _header = ui.peertreeWidget->header () ;
|
// QHeaderView * _header = ui.peertreeWidget->header () ;
|
||||||
_header->setResizeMode (0, QHeaderView::Custom);
|
// _header->setResizeMode (0, QHeaderView::Custom);
|
||||||
_header->setResizeMode (1, QHeaderView::Interactive);
|
// _header->setResizeMode (1, QHeaderView::Interactive);
|
||||||
_header->setResizeMode (2, QHeaderView::Interactive);
|
// _header->setResizeMode (2, QHeaderView::Interactive);
|
||||||
|
//
|
||||||
|
// _header->resizeSection ( 0, 100 );
|
||||||
|
// _header->resizeSection ( 1, 100 );
|
||||||
|
// _header->resizeSection ( 2, 100 );
|
||||||
|
|
||||||
|
// set header text aligment
|
||||||
_header->resizeSection ( 0, 25 );
|
|
||||||
_header->resizeSection ( 1, 150 );
|
|
||||||
_header->resizeSection ( 2, 150 );
|
|
||||||
|
|
||||||
|
|
||||||
// set header text aligment
|
|
||||||
QTreeWidgetItem * headerItem = ui.peertreeWidget->headerItem();
|
QTreeWidgetItem * headerItem = ui.peertreeWidget->headerItem();
|
||||||
headerItem->setTextAlignment(0, Qt::AlignHCenter | Qt::AlignVCenter);
|
headerItem->setTextAlignment(0, Qt::AlignHCenter | Qt::AlignVCenter);
|
||||||
headerItem->setTextAlignment(1, Qt::AlignHCenter | Qt::AlignVCenter);
|
headerItem->setTextAlignment(1, Qt::AlignLeft | Qt::AlignVCenter);
|
||||||
headerItem->setTextAlignment(2, Qt::AlignHCenter | Qt::AlignVCenter);
|
headerItem->setTextAlignment(2, Qt::AlignHCenter | Qt::AlignVCenter);
|
||||||
|
|
||||||
|
|
||||||
@ -268,7 +264,7 @@ void PeersDialog::updateDisplay()
|
|||||||
/* get the list of peers from the RsIface. */
|
/* get the list of peers from the RsIface. */
|
||||||
void PeersDialog::insertPeers()
|
void PeersDialog::insertPeers()
|
||||||
{
|
{
|
||||||
std::list<std::string> peers;
|
std::list<std::string> gpgFriends;
|
||||||
std::list<std::string>::iterator it;
|
std::list<std::string>::iterator it;
|
||||||
|
|
||||||
if (!rsPeers) {
|
if (!rsPeers) {
|
||||||
@ -276,7 +272,7 @@ void PeersDialog::insertPeers()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
rsPeers->getFriendList(peers);
|
rsPeers->getPGPAcceptedList(gpgFriends);
|
||||||
|
|
||||||
/* get a link to the table */
|
/* get a link to the table */
|
||||||
QTreeWidget *peerWidget = ui.peertreeWidget;
|
QTreeWidget *peerWidget = ui.peertreeWidget;
|
||||||
@ -289,7 +285,8 @@ void PeersDialog::insertPeers()
|
|||||||
ui.nicklabel->setText(titleStr.arg(QString::fromStdString(pd.name) + tr(" (me)"))) ;
|
ui.nicklabel->setText(titleStr.arg(QString::fromStdString(pd.name) + tr(" (me)"))) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
for(it = peers.begin(); it != peers.end(); it++) {
|
//add the gpg friends
|
||||||
|
for(it = gpgFriends.begin(); it != gpgFriends.end(); it++) {
|
||||||
RsPeerDetails detail;
|
RsPeerDetails detail;
|
||||||
if (!rsPeers->getPeerDetails(*it, detail)) {
|
if (!rsPeers->getPeerDetails(*it, detail)) {
|
||||||
continue; /* BAD */
|
continue; /* BAD */
|
||||||
@ -301,71 +298,110 @@ void PeersDialog::insertPeers()
|
|||||||
if (list.size() == 1) {
|
if (list.size() == 1) {
|
||||||
item = list.front();
|
item = list.front();
|
||||||
} else {
|
} else {
|
||||||
item = new QTreeWidgetItem((QTreeWidget*)0);
|
item = new QTreeWidgetItem(0);
|
||||||
|
item->setChildIndicatorPolicy(QTreeWidgetItem::DontShowIndicatorWhenChildless);
|
||||||
}
|
}
|
||||||
|
|
||||||
item -> setText(0, "");
|
item -> setText(0, QString::fromStdString(detail.name));
|
||||||
|
|
||||||
item -> setText(1, QString::fromStdString(detail.autoconnect));
|
item -> setTextAlignment(0, Qt::AlignLeft | Qt::AlignVCenter );
|
||||||
item -> setTextAlignment(1, Qt::AlignCenter | Qt::AlignVCenter );
|
|
||||||
|
|
||||||
if (rsMsgs->getCustomStateString(detail.id) != "") {
|
//item -> setText( 1, QString::fromStdString(detail.name));
|
||||||
item -> setText( 2, QString::fromStdString(detail.name) + tr(" - ") +
|
|
||||||
QString::fromStdString(rsMsgs->getCustomStateString(detail.id)));
|
|
||||||
item -> setToolTip( 2, QString::fromStdString(detail.name) + tr(" - ") +
|
|
||||||
QString::fromStdString(rsMsgs->getCustomStateString(detail.id)));
|
|
||||||
} else {
|
|
||||||
item -> setText( 2, QString::fromStdString(detail.name));
|
|
||||||
item -> setToolTip( 2, QString::fromStdString(detail.name));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* not displayed, used to find back the item */
|
/* not displayed, used to find back the item */
|
||||||
item -> setText(3, QString::fromStdString(detail.id));
|
item -> setText(3, QString::fromStdString(detail.id));
|
||||||
|
|
||||||
/* change color and icon */
|
|
||||||
int i;
|
|
||||||
if (detail.state & RS_PEER_STATE_CONNECTED) {
|
|
||||||
item -> setIcon(0,(QIcon(IMAGE_ONLINE)));
|
|
||||||
QFont font;
|
|
||||||
font.setBold(true);
|
|
||||||
for(i = 1; i < 3; i++) {
|
|
||||||
item -> setTextColor(i,(Qt::darkBlue));
|
|
||||||
item -> setFont(i,font);
|
|
||||||
}
|
|
||||||
} else if (detail.state & RS_PEER_STATE_UNREACHABLE) {
|
|
||||||
item -> setIcon(0,(QIcon(IMAGE_UNREACHABLE)));
|
|
||||||
QFont font;
|
|
||||||
font.setBold(false);
|
|
||||||
for(i = 1; i < 3; i++) {
|
|
||||||
item -> setTextColor(i,(Qt::darkRed));
|
|
||||||
item -> setFont(i,font);
|
|
||||||
}
|
|
||||||
} else if (detail.state & RS_PEER_STATE_ONLINE) {
|
|
||||||
/* bright green */
|
|
||||||
item -> setIcon(0,(QIcon(IMAGE_AVAIBLE)));
|
|
||||||
QFont font;
|
|
||||||
font.setBold(true);
|
|
||||||
for(i = 1; i < 3; i++) {
|
|
||||||
item -> setTextColor(i,(Qt::darkCyan));
|
|
||||||
item -> setFont(i,font);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (time(NULL) - detail.lastConnect < 3600) {
|
|
||||||
item -> setIcon(0,(QIcon(IMAGE_OFFLINE)));
|
|
||||||
} else {
|
|
||||||
item -> setIcon(0,(QIcon(IMAGE_OFFLINE2)));
|
|
||||||
}
|
|
||||||
QFont font;
|
|
||||||
font.setBold(false);
|
|
||||||
for(i = 1; i < 3; i++) {
|
|
||||||
item -> setTextColor(i,(Qt::black));
|
|
||||||
item -> setFont(i,font);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* add to the list. If item is already in the list, it won't be duplicated thanks to Qt */
|
/* add to the list. If item is already in the list, it won't be duplicated thanks to Qt */
|
||||||
peerWidget->addTopLevelItem(item);
|
peerWidget->addTopLevelItem(item);
|
||||||
}
|
|
||||||
|
//add the childs (ssl certs)
|
||||||
|
//item->takeChildren();
|
||||||
|
|
||||||
|
std::list<std::string> sslContacts;
|
||||||
|
rsPeers->getSSLChildListOfGPGId(detail.id, sslContacts);
|
||||||
|
for(std::list<std::string>::iterator sslIt = sslContacts.begin(); sslIt != sslContacts.end(); sslIt++) {
|
||||||
|
RsPeerDetails sslDetail;
|
||||||
|
if (!rsPeers->getPeerDetails(*sslIt, sslDetail)) {
|
||||||
|
continue; /* BAD */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* find the sslItem */
|
||||||
|
QTreeWidgetItem *sslItem = new QTreeWidgetItem(1);
|
||||||
|
bool gotToExpandBecauseNewChild = true;
|
||||||
|
for (int childIndex = 0; childIndex < item->childCount(); childIndex++) {
|
||||||
|
if (item->child(childIndex)->text(3).toStdString() == sslDetail.id) {
|
||||||
|
sslItem = item->child(childIndex);
|
||||||
|
gotToExpandBecauseNewChild = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* not displayed, used to find back the item */
|
||||||
|
sslItem -> setText(3, QString::fromStdString(sslDetail.id));
|
||||||
|
|
||||||
|
if (rsMsgs->getCustomStateString(sslDetail.id) != "") {
|
||||||
|
sslItem -> setText( 0, tr("location : ") + QString::fromStdString(sslDetail.location) + tr(" - ") + QString::fromStdString(rsMsgs->getCustomStateString(sslDetail.id)));
|
||||||
|
sslItem -> setToolTip( 0, tr("location : ") + QString::fromStdString(sslDetail.location) + tr(" - ") + QString::fromStdString(rsMsgs->getCustomStateString(sslDetail.id)));
|
||||||
|
} else {
|
||||||
|
sslItem -> setText( 0, tr("location : ") + QString::fromStdString(sslDetail.location));
|
||||||
|
sslItem -> setToolTip( 0, tr("location : ") + QString::fromStdString(sslDetail.location));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* not displayed, used to find back the item */
|
||||||
|
sslItem -> setText(1, QString::fromStdString(sslDetail.autoconnect));
|
||||||
|
|
||||||
|
/* change color and icon */
|
||||||
|
int i;
|
||||||
|
if (sslDetail.state & RS_PEER_STATE_CONNECTED) {
|
||||||
|
sslItem -> setIcon(0,(QIcon(IMAGE_ONLINE)));
|
||||||
|
QFont font;
|
||||||
|
font.setBold(true);
|
||||||
|
for(i = 1; i < 3; i++) {
|
||||||
|
sslItem -> setTextColor(i,(Qt::darkBlue));
|
||||||
|
sslItem -> setFont(i,font);
|
||||||
|
}
|
||||||
|
} else if (sslDetail.state & RS_PEER_STATE_UNREACHABLE) {
|
||||||
|
sslItem -> setIcon(0,(QIcon(IMAGE_UNREACHABLE)));
|
||||||
|
QFont font;
|
||||||
|
font.setBold(false);
|
||||||
|
for(i = 1; i < 3; i++) {
|
||||||
|
sslItem -> setTextColor(i,(Qt::darkRed));
|
||||||
|
sslItem -> setFont(i,font);
|
||||||
|
}
|
||||||
|
} else if (sslDetail.state & RS_PEER_STATE_ONLINE) {
|
||||||
|
/* bright green */
|
||||||
|
sslItem -> setIcon(0,(QIcon(IMAGE_AVAIBLE)));
|
||||||
|
QFont font;
|
||||||
|
font.setBold(true);
|
||||||
|
for(i = 1; i < 3; i++) {
|
||||||
|
sslItem -> setTextColor(i,(Qt::darkCyan));
|
||||||
|
sslItem -> setFont(i,font);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (time(NULL) - sslDetail.lastConnect < 3600) {
|
||||||
|
sslItem -> setIcon(0,(QIcon(IMAGE_OFFLINE)));
|
||||||
|
} else {
|
||||||
|
sslItem -> setIcon(0,(QIcon(IMAGE_OFFLINE2)));
|
||||||
|
}
|
||||||
|
QFont font;
|
||||||
|
font.setBold(false);
|
||||||
|
for(i = 1; i < 3; i++) {
|
||||||
|
sslItem -> setTextColor(i,(Qt::black));
|
||||||
|
sslItem -> setFont(i,font);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef PEERS_DEBUG
|
||||||
|
std::cerr << "PeersDialog::insertPeers() inserting sslItem." << std::endl;
|
||||||
|
#endif
|
||||||
|
/* add to the list. If item is already in the list, it won't be duplicated thanks to Qt */
|
||||||
|
item->addChild(sslItem);
|
||||||
|
if (gotToExpandBecauseNewChild) {
|
||||||
|
item->setExpanded(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Utility Fns */
|
/* Utility Fns */
|
||||||
@ -386,7 +422,7 @@ void PeersDialog::exportfriend()
|
|||||||
if (!c)
|
if (!c)
|
||||||
{
|
{
|
||||||
#ifdef PEERS_DEBUG
|
#ifdef PEERS_DEBUG
|
||||||
std::cerr << "PeersDialog::exportfriend() Noone Selected -- sorry" << std::endl;
|
std::cerr << "PeersDialog::exportfriend() None Selected -- sorry" << std::endl;
|
||||||
#endif
|
#endif
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -640,15 +640,33 @@ background: white;}</string>
|
|||||||
<height>24</height>
|
<height>24</height>
|
||||||
</size>
|
</size>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="autoExpandDelay">
|
||||||
|
<number>1</number>
|
||||||
|
</property>
|
||||||
|
<property name="indentation">
|
||||||
|
<number>20</number>
|
||||||
|
</property>
|
||||||
<property name="itemsExpandable">
|
<property name="itemsExpandable">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
<property name="sortingEnabled">
|
<property name="sortingEnabled">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="wordWrap">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
<property name="expandsOnDoubleClick">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
<attribute name="headerDefaultSectionSize">
|
||||||
|
<number>200</number>
|
||||||
|
</attribute>
|
||||||
|
<attribute name="headerDefaultSectionSize">
|
||||||
|
<number>200</number>
|
||||||
|
</attribute>
|
||||||
<column>
|
<column>
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>#</string>
|
<string>Person</string>
|
||||||
</property>
|
</property>
|
||||||
</column>
|
</column>
|
||||||
<column>
|
<column>
|
||||||
@ -656,11 +674,6 @@ background: white;}</string>
|
|||||||
<string>Status</string>
|
<string>Status</string>
|
||||||
</property>
|
</property>
|
||||||
</column>
|
</column>
|
||||||
<column>
|
|
||||||
<property name="text">
|
|
||||||
<string>Person</string>
|
|
||||||
</property>
|
|
||||||
</column>
|
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
@ -1140,8 +1153,6 @@ background: white;}</string>
|
|||||||
</widget>
|
</widget>
|
||||||
<resources>
|
<resources>
|
||||||
<include location="images.qrc"/>
|
<include location="images.qrc"/>
|
||||||
<include location="images.qrc"/>
|
|
||||||
<include location="images.qrc"/>
|
|
||||||
</resources>
|
</resources>
|
||||||
<connections/>
|
<connections/>
|
||||||
</ui>
|
</ui>
|
||||||
|
Loading…
Reference in New Issue
Block a user