diff --git a/libretroshare/src/pqi/authgpg.cc b/libretroshare/src/pqi/authgpg.cc index 4f4333520..6efc129f9 100644 --- a/libretroshare/src/pqi/authgpg.cc +++ b/libretroshare/src/pqi/authgpg.cc @@ -198,7 +198,7 @@ AuthGPG::AuthGPG() * * returns false if GnuPG is not available. */ -bool AuthGPG::availablePGPCertificates(std::list &ids) +bool AuthGPG::availablePGPCertificatesWithPrivateKeys(std::list &ids) { //RsStackMutex stack(pgpMtx); /******* LOCKED ******/ @@ -225,9 +225,9 @@ bool AuthGPG::availablePGPCertificates(std::list &ids) /* Loop until end of key */ 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: " << KEY->subkeys->keyid << std::endl; } @@ -971,6 +971,14 @@ bool AuthGPG::encryptText(gpgme_data_t PLAIN, gpgme_data_t CIPHER) { return true; } +bool AuthGPG::getPGPAcceptedList(std::list &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 &ids) { //RsStackMutex stack(pgpMtx); /******* LOCKED ******/ diff --git a/libretroshare/src/pqi/authgpg.h b/libretroshare/src/pqi/authgpg.h index 414466a2b..a0861807e 100644 --- a/libretroshare/src/pqi/authgpg.h +++ b/libretroshare/src/pqi/authgpg.h @@ -104,7 +104,7 @@ class AuthGPG AuthGPG(); ~AuthGPG(); - bool availablePGPCertificates(std::list &ids); + bool availablePGPCertificatesWithPrivateKeys(std::list &ids); int GPGInit(std::string ownId); @@ -150,10 +150,11 @@ class AuthGPG /* PGP web of trust management */ GPG_id PGPOwnId(); - bool getPGPAllList(std::list &ids); bool getPGPDetails(std::string id, RsPeerDetails &d); - bool getPGPSignedList(std::list &ids); + bool getPGPAllList(std::list &ids); bool getPGPValidList(std::list &ids); + bool getPGPAcceptedList(std::list &ids); + bool getPGPSignedList(std::list &ids); bool isPGPValid(std::string id); bool isPGPSigned(std::string id); diff --git a/libretroshare/src/pqi/authssl.cc b/libretroshare/src/pqi/authssl.cc index 8dcd58f26..d068808de 100644 --- a/libretroshare/src/pqi/authssl.cc +++ b/libretroshare/src/pqi/authssl.cc @@ -604,16 +604,6 @@ int AuthSSL::setConfigDirectories(std::string configfile, std::string neighd 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() { #ifdef AUTHSSL_DEBUG @@ -697,30 +687,30 @@ bool AuthSSL::getUnknownList(std::list &ids) return true; } - /* silly question really - only valid certs get saved to map - * so if in map its okay - */ -bool AuthSSL::isValid(std::string id) +bool AuthSSL::getSSLChildListOfGPGId(std::string gpg_id, std::list &ids) { #ifdef AUTHSSL_DEBUG - std::cerr << "AuthSSL::isValid() " << id; - std::cerr << std::endl; + std::cerr << "AuthSSL::getChildListOfGPGId() called for gpg id : " << gpg_id << std::endl; #endif - sslMtx.lock(); /***** LOCK *****/ - bool valid = false; + sslMtx.lock(); /***** LOCK *****/ - if (id == mOwnId) - { - valid = true; - } - else - { - valid = (mCerts.end() != mCerts.find(id)); - } + /* iterate through both lists */ + std::map::iterator it; - 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) @@ -1019,73 +1009,6 @@ bool AuthSSL::SaveCertificateToBinary(std::string id, uint8_t **ptr, uint32_t * 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) */ bool AuthSSL::SignData(std::string input, std::string &sign) @@ -1577,13 +1500,7 @@ bool AuthSSL::ProcessX509(X509 *x509, std::string &id) { #ifdef AUTHSSL_DEBUG std::cerr << "AuthSSL::ProcessX509() ValidateCertificate FAILED"; - std::cerr << std::endl; -#endif - -#ifdef PQI_USE_SSLONLY - /* bad ( or unknown pgp issuer ) certificate */ - X509_free(x509); - return false; + std::cerr << std::endl; #endif } @@ -1681,7 +1598,7 @@ bool AuthSSL::ProcessX509(X509 *x509, std::string &id) sslMtx.lock(); /***** LOCK *****/ - mCerts[xid] = cert; + mCerts[xid] = cert; /* resave if new certificate */ 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 std::cerr << "AuthSSL::getX509id()"; std::cerr << std::endl; @@ -1986,8 +1902,6 @@ bool AuthSSL::AuthX509(X509 *x509) int sigoutl=0,sigoutll=0; X509_ALGOR *a; - fprintf(stderr, "AuthSSL::AuthX509()\n"); - EVP_MD_CTX_init(&ctx); /* input buffer */ @@ -2038,6 +1952,8 @@ bool AuthSSL::AuthX509(X509 *x509) sigoutl = 0; 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; return true; @@ -2049,22 +1965,20 @@ bool AuthSSL::AuthX509(X509 *x509) bool AuthSSL::ValidateCertificate(X509 *x509, std::string &peerId) { /* check self signed */ -#warning "ValidateCertificate Not Finished" - -#if 0 - if (!X509_check_valid_certificate(x509)) - { - /* bad certificate */ - return false; - } + if (!AuthX509(x509) || !getX509id(x509, peerId)) { +#ifdef AUTHSSL_DEBUG + std::cerr << "AuthSSL::ValidateCertificate() bad certificate."; + std::cerr << std::endl; #endif + return false; + } #ifdef AUTHSSL_DEBUG - std::cerr << "AuthSSL::ValidateCertificate() Not Finished!"; + std::cerr << "AuthSSL::ValidateCertificate() good certificate."; std::cerr << std::endl; #endif - return getX509id(x509, peerId); + return true; } /* store for discovery */ @@ -2136,8 +2050,6 @@ bool AuthSSL::CheckCertificate(std::string x509Id, X509 *x509) } - - /********************************************************************************/ /********************************************************************************/ /********************************************************************************/ diff --git a/libretroshare/src/pqi/authssl.h b/libretroshare/src/pqi/authssl.h index 97830c310..8a286db44 100644 --- a/libretroshare/src/pqi/authssl.h +++ b/libretroshare/src/pqi/authssl.h @@ -101,26 +101,19 @@ virtual int setConfigDirectories(std::string confFile, std::string neighDir) /*********** Overloaded Functions from p3AuthMgr **********/ /* get Certificate Ids */ - virtual std::string OwnId(); virtual bool getAllList(std::list &ids); virtual bool getAuthenticatedList(std::list &ids); virtual bool getUnknownList(std::list &ids); - +virtual bool getSSLChildListOfGPGId(std::string gpg_id, std::list &ids); + /* get Details from the Certificates */ - -virtual bool isValid(std::string id); virtual bool isAuthenticated(std::string id); virtual std::string getName(std::string id); virtual std::string getIssuerName(std::string id); virtual std::string getGPGId(SSL_id id); 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 */ virtual bool FinalSaveCertificates(); virtual bool CheckSaveCertificates(); @@ -132,19 +125,11 @@ virtual bool LoadCertificateFromString(std::string pem, std::string &id); virtual std::string SaveCertificateToString(std::string id); virtual bool LoadCertificateFromFile(std::string filename, std::string &id); 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 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) */ virtual bool SignData(std::string input, 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); // 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 -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 **********/ @@ -191,8 +176,6 @@ bool loadCertificates(bool &oldFormat, std::map &key static AuthSSL *instance_ssl; /* Helper Functions */ -bool ProcessX509(X509 *x509, std::string &id); - X509 * loadX509FromPEM(std::string pem); X509 * loadX509FromFile(std::string fname, std::string hash); bool saveX509ToFile(X509 *x509, std::string fname, std::string &hash); diff --git a/libretroshare/src/pqi/p3connmgr.cc b/libretroshare/src/pqi/p3connmgr.cc index 6829fbacb..1109a9bec 100644 --- a/libretroshare/src/pqi/p3connmgr.cc +++ b/libretroshare/src/pqi/p3connmgr.cc @@ -2170,7 +2170,7 @@ bool p3ConnectMgr::addNeighbour(std::string id) } /* check with the AuthMgr if its valid */ - if (!AuthSSL::getAuthSSL()->isValid(id)) + if (!AuthSSL::getAuthSSL()->isAuthenticated(id)) { /* no auth */ return false; @@ -2912,7 +2912,7 @@ bool p3ConnectMgr::loadList(std::list load) std::cerr << std::endl; #endif /* add ownConfig */ - setOwnNetConfig(pitem->netMode, pitem->visState); + setOwnNetConfig(pitem->netMode, pitem->visState); } else { diff --git a/libretroshare/src/rsiface/rspeers.h b/libretroshare/src/rsiface/rspeers.h index 697a9ebcd..aa7c52e02 100644 --- a/libretroshare/src/rsiface/rspeers.h +++ b/libretroshare/src/rsiface/rspeers.h @@ -130,37 +130,36 @@ virtual bool OthersChanged() = 0; /* Peer Details (Net & Auth) */ virtual std::string getOwnId() = 0; -virtual bool getOnlineList(std::list &ids) = 0; -virtual bool getFriendList(std::list &ids) = 0; -virtual bool getOthersList(std::list &ids) = 0; +virtual bool getOnlineList(std::list &ssl_ids) = 0; +virtual bool getFriendList(std::list &ssl_ids) = 0; +virtual bool getOthersList(std::list &ssl_ids) = 0; -virtual bool isOnline(std::string id) = 0; -virtual bool isFriend(std::string id) = 0; -virtual std::string getPeerName(std::string id) = 0; -virtual std::string getPeerPGPName(std::string pgp_id) = 0; -virtual bool getPeerDetails(std::string id, RsPeerDetails &d) = 0; //get Peer detail accept SSL and PGP certs +virtual bool isOnline(std::string ssl_id) = 0; +virtual bool isFriend(std::string ssl_id) = 0; +virtual std::string getPeerName(std::string ssl_id) = 0; +virtual std::string getPeerPGPName(std::string ssl_id) = 0; +virtual bool getPeerDetails(std::string ssl_or_gpg_id, RsPeerDetails &d) = 0; //get Peer detail accept SSL and PGP certs /* Using PGP Ids */ virtual std::string getPGPOwnId() = 0; virtual std::string getPGPId(std::string ssl_id) = 0; -virtual bool getPGPAcceptedList(std::list &ids) = 0; -virtual bool getPGPSignedList(std::list &ids) = 0;//friends that we accpet to connect with but we don't want to sign their gpg key -virtual bool getPGPValidList(std::list &ids) = 0; -virtual bool getPGPAllList(std::list &ids) = 0; -virtual bool getPGPDetails(std::string id, RsPeerDetails &d) = 0; - -virtual bool getPGPFriendList(std::list &ids) = 0; +virtual bool getPGPAcceptedList(std::list &gpg_ids) = 0; +virtual bool getPGPSignedList(std::list &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 &gpg_ids) = 0; +virtual bool getPGPAllList(std::list &gpg_ids) = 0; +virtual bool getPGPDetails(std::string gpg_id, RsPeerDetails &d) = 0; +virtual bool getSSLChildListOfGPGId(std::string gpg_id, std::list &ids) = 0; /* Add/Remove Friends */ virtual bool addFriend(std::string id) = 0; virtual bool removeFriend(std::string id) = 0; /* Network Stuff */ -virtual bool connectAttempt(std::string id) = 0; -virtual bool setLocalAddress(std::string id, std::string addr, uint16_t port) = 0; -virtual bool setExtAddress( std::string id, std::string addr, uint16_t port) = 0; -virtual bool setNetworkMode(std::string id, uint32_t netMode) = 0; -virtual bool setVisState(std::string id, uint32_t vis) = 0; +virtual bool connectAttempt(std::string ssl_id) = 0; +virtual bool setLocalAddress(std::string ssl_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 ssl_id, uint32_t netMode) = 0; +virtual bool setVisState(std::string ssl_id, uint32_t vis) = 0; virtual void getIPServersList(std::list& ip_servers) = 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 std::string SaveCertificateToString(std::string id) = 0; -virtual bool SignGPGCertificate(std::string id) = 0; -virtual bool TrustGPGCertificate(std::string id, uint32_t trustlvl) = 0; +virtual bool SignGPGCertificate(std::string gpg_id) = 0; +virtual bool TrustGPGCertificate(std::string gpg_id, uint32_t trustlvl) = 0; }; diff --git a/libretroshare/src/rsserver/p3peers.cc b/libretroshare/src/rsserver/p3peers.cc index 22cefe2c3..fa4f4bc41 100644 --- a/libretroshare/src/rsserver/p3peers.cc +++ b/libretroshare/src/rsserver/p3peers.cc @@ -291,16 +291,21 @@ static struct sockaddr_in getPreferredAddress( const struct sockaddr_in& addr1,t bool p3Peers::getPeerDetails(std::string id, RsPeerDetails &d) { -#ifdef P3PEERS_DEBUG - std::cerr << "p3Peers::getPeerDetails() " << id; - std::cerr << std::endl; -#endif + #ifdef P3PEERS_DEBUG + std::cerr << "p3Peers::getPeerDetails() called for id : " << id << std::endl; + #endif //first, check if it's a gpg or a ssl id. if (AuthSSL::getAuthSSL()->getGPGId(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; 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 */ /* 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 sslcert authDetail; - if (!AuthSSL::getAuthSSL()->getCertDetails(id, authDetail)) - { - return false; + if (!AuthSSL::getAuthSSL()->getCertDetails(id, authDetail)) { + #ifdef P3PEERS_DEBUG + std::cerr << "p3Peers::getPeerDetails() got no SSL details, is returning." << std::endl; + #endif + return false; } d.fpr = authDetail.fpr; @@ -486,56 +493,6 @@ std::string p3Peers::getPeerName(std::string id) return AuthSSL::getAuthSSL()->getName(id); } - -bool p3Peers::getPGPFriendList(std::list &ids) -{ -#ifdef P3PEERS_DEBUG - std::cerr << "p3Peers::getPGPFriendList()"; - std::cerr << std::endl; -#endif - - std::list certids; - std::list::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 &ids) { #ifdef P3PEERS_DEBUG @@ -579,11 +536,21 @@ bool p3Peers::getPGPAcceptedList(std::list &ids) std::cerr << std::endl; #endif - /* get from mAuthMgr */ + //TODO implement an additional list of GPG keys that are accepted even if not signed AuthGPG::getAuthGPG()->getPGPSignedList(ids); return true; } +bool p3Peers::getSSLChildListOfGPGId(std::string gpg_id, std::list &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) { #ifdef P3PEERS_DEBUG diff --git a/libretroshare/src/rsserver/p3peers.h b/libretroshare/src/rsserver/p3peers.h index f980089b8..45545a355 100644 --- a/libretroshare/src/rsserver/p3peers.h +++ b/libretroshare/src/rsserver/p3peers.h @@ -61,9 +61,7 @@ virtual bool getPGPSignedList(std::list &ids); virtual bool getPGPValidList(std::list &ids); virtual bool getPGPAllList(std::list &ids); virtual bool getPGPDetails(std::string id, RsPeerDetails &d); - -virtual bool getPGPFriendList(std::list &ids); - +virtual bool getSSLChildListOfGPGId(std::string gpg_id, std::list &ids); /* Add/Remove Friends */ virtual bool addFriend(std::string id); diff --git a/libretroshare/src/rsserver/rsinit.cc b/libretroshare/src/rsserver/rsinit.cc index d8b0f2f8b..c8c837b75 100644 --- a/libretroshare/src/rsserver/rsinit.cc +++ b/libretroshare/src/rsserver/rsinit.cc @@ -765,7 +765,7 @@ static bool checkAccount(std::string accountdir, accountId &id) /* Generating GPGme Account */ int RsInit::GetPGPLogins(std::list &pgpIds) { - AuthGPG::getAuthGPG()->availablePGPCertificates(pgpIds); + AuthGPG::getAuthGPG()->availablePGPCertificatesWithPrivateKeys(pgpIds); return 1; } @@ -1886,6 +1886,12 @@ int RsServer::StartupRetroShare() rsNotify = new p3Notify(); mConnMgr = new p3ConnectMgr(); + //load all the SSL certs as friends + std::list sslIds; + AuthSSL::getAuthSSL()->getAuthenticatedList(sslIds); + for (std::list::iterator sslIdsIt = sslIds.begin(); sslIdsIt != sslIds.end(); sslIdsIt++) { + mConnMgr->addFriend(*sslIdsIt); + } pqiNetAssistFirewall *mUpnpMgr = new upnphandler(); //p3DhtMgr *mDhtMgr = new OpenDHTMgr(ownId, mConnMgr, RsInitConfig::configDir); diff --git a/libretroshare/src/services/p3disc.cc b/libretroshare/src/services/p3disc.cc index 3eed8efef..4aae467c4 100644 --- a/libretroshare/src/services/p3disc.cc +++ b/libretroshare/src/services/p3disc.cc @@ -729,7 +729,6 @@ void p3disc::recvPeerFriendMsg(RsDiscReply *item) { std::cerr << " Found a peer that trust me: " << peerId << " (" << rsPeers->getPeerName(peerId) << ")" << std::endl ; flags |= RS_NET_FLAGS_TRUSTS_ME; - AuthSSL::getAuthSSL()->addTrustingPeer(peerId) ; } /* generate type */ diff --git a/retroshare-gui/src/gui/NetworkView.cpp b/retroshare-gui/src/gui/NetworkView.cpp index 82bcd95e2..b4dfb5a7b 100644 --- a/retroshare-gui/src/gui/NetworkView.cpp +++ b/retroshare-gui/src/gui/NetworkView.cpp @@ -156,7 +156,7 @@ void NetworkView::insertPeers() /* get the list of friends' issuers, as we flag them specially */ std::list fids; - rsPeers->getPGPFriendList(fids); + //rsPeers->getPGPFriendList(fids); int i = 0; @@ -252,7 +252,7 @@ void NetworkView::insertConnections() //std::string ownId = rsPeers->getGPGOwnId(); //rsPeers->getPGPAllList(ids); - rsPeers->getPGPFriendList(fids); + //rsPeers->getPGPFriendList(fids); std::cerr << "NetworkView::insertConnections()" << std::endl; diff --git a/retroshare-gui/src/gui/PeersDialog.cpp b/retroshare-gui/src/gui/PeersDialog.cpp index e3a24a57c..798fc6b19 100644 --- a/retroshare-gui/src/gui/PeersDialog.cpp +++ b/retroshare-gui/src/gui/PeersDialog.cpp @@ -100,32 +100,28 @@ PeersDialog::PeersDialog(QWidget *parent) connect( ui.avatartoolButton, SIGNAL(clicked()), SLOT(getAvatar())); connect( ui.mypersonalstatuslabel, SIGNAL(clicked()), SLOT(statusmessage())); - - /* hide the Tree +/- */ - ui.peertreeWidget -> setRootIsDecorated( false ); ui.peertabWidget->addTab(new ProfileWidget(),QString(tr("Profile"))); ui.peertreeWidget->setColumnCount(4); ui.peertreeWidget->setColumnHidden ( 3, true); + ui.peertreeWidget->setColumnHidden ( 2, true); ui.peertreeWidget->sortItems( 2, Qt::AscendingOrder ); /* Set header resize modes and initial section sizes */ - QHeaderView * _header = ui.peertreeWidget->header () ; - _header->setResizeMode (0, QHeaderView::Custom); - _header->setResizeMode (1, QHeaderView::Interactive); - _header->setResizeMode (2, QHeaderView::Interactive); +// QHeaderView * _header = ui.peertreeWidget->header () ; +// _header->setResizeMode (0, QHeaderView::Custom); +// _header->setResizeMode (1, QHeaderView::Interactive); +// _header->setResizeMode (2, QHeaderView::Interactive); +// +// _header->resizeSection ( 0, 100 ); +// _header->resizeSection ( 1, 100 ); +// _header->resizeSection ( 2, 100 ); - - _header->resizeSection ( 0, 25 ); - _header->resizeSection ( 1, 150 ); - _header->resizeSection ( 2, 150 ); - - - // set header text aligment +// set header text aligment QTreeWidgetItem * headerItem = ui.peertreeWidget->headerItem(); - headerItem->setTextAlignment(0, Qt::AlignHCenter | Qt::AlignVCenter); - headerItem->setTextAlignment(1, Qt::AlignHCenter | Qt::AlignVCenter); + headerItem->setTextAlignment(0, Qt::AlignHCenter | Qt::AlignVCenter); + headerItem->setTextAlignment(1, Qt::AlignLeft | Qt::AlignVCenter); headerItem->setTextAlignment(2, Qt::AlignHCenter | Qt::AlignVCenter); @@ -268,7 +264,7 @@ void PeersDialog::updateDisplay() /* get the list of peers from the RsIface. */ void PeersDialog::insertPeers() { - std::list peers; + std::list gpgFriends; std::list::iterator it; if (!rsPeers) { @@ -276,7 +272,7 @@ void PeersDialog::insertPeers() return; } - rsPeers->getFriendList(peers); + rsPeers->getPGPAcceptedList(gpgFriends); /* get a link to the table */ QTreeWidget *peerWidget = ui.peertreeWidget; @@ -289,7 +285,8 @@ void PeersDialog::insertPeers() 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; if (!rsPeers->getPeerDetails(*it, detail)) { continue; /* BAD */ @@ -301,71 +298,110 @@ void PeersDialog::insertPeers() if (list.size() == 1) { item = list.front(); } 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(1, Qt::AlignCenter | Qt::AlignVCenter ); + item -> setTextAlignment(0, Qt::AlignLeft | Qt::AlignVCenter ); - if (rsMsgs->getCustomStateString(detail.id) != "") { - 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)); - } + //item -> setText( 1, QString::fromStdString(detail.name)); /* not displayed, used to find back the item */ 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 */ peerWidget->addTopLevelItem(item); - } + + //add the childs (ssl certs) + //item->takeChildren(); + + std::list sslContacts; + rsPeers->getSSLChildListOfGPGId(detail.id, sslContacts); + for(std::list::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 */ @@ -386,7 +422,7 @@ void PeersDialog::exportfriend() if (!c) { #ifdef PEERS_DEBUG - std::cerr << "PeersDialog::exportfriend() Noone Selected -- sorry" << std::endl; + std::cerr << "PeersDialog::exportfriend() None Selected -- sorry" << std::endl; #endif return; } diff --git a/retroshare-gui/src/gui/PeersDialog.ui b/retroshare-gui/src/gui/PeersDialog.ui index 494706a1e..678ba49c1 100644 --- a/retroshare-gui/src/gui/PeersDialog.ui +++ b/retroshare-gui/src/gui/PeersDialog.ui @@ -640,15 +640,33 @@ background: white;} 24 + + 1 + + + 20 + true true + + false + + + false + + + 200 + + + 200 + - # + Person @@ -656,11 +674,6 @@ background: white;} Status - - - Person - - @@ -1140,8 +1153,6 @@ background: white;} - -