Merge pull request #2640 from csoler/v0.6-TorControl3

added control over received peers from FS
This commit is contained in:
csoler 2022-10-28 14:05:10 +02:00 committed by GitHub
commit 1474dfdd66
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 97 additions and 20 deletions

View File

@ -22,6 +22,7 @@
#include <QMovie> #include <QMovie>
#include <QMessageBox> #include <QMessageBox>
#include <QTcpSocket> #include <QTcpSocket>
#include <QMenu>
#include "retroshare/rsfriendserver.h" #include "retroshare/rsfriendserver.h"
#include "retroshare/rstor.h" #include "retroshare/rstor.h"
@ -78,13 +79,11 @@ FriendServerControl::FriendServerControl(QWidget *parent)
whileBlocking(autoAccept_CB)->setChecked(rsFriendServer->autoAddFriends()); whileBlocking(autoAccept_CB)->setChecked(rsFriendServer->autoAddFriends());
// init values // Init values
torServerFriendsToRequest_SB->setValue(rsFriendServer->friendsToRequest()); whileBlocking(torServerFriendsToRequest_SB)->setValue(rsFriendServer->friendsToRequest());
torServerAddress_LE->setText(QString::fromStdString(rsFriendServer->friendsServerAddress().c_str()));
torServerPort_SB->setValue(rsFriendServer->friendsServerPort());
// connect slignals/slots // Connect slignals/slots
QObject::connect(friendServerOnOff_CB,SIGNAL(toggled(bool)),this,SLOT(onOnOffClick(bool))); QObject::connect(friendServerOnOff_CB,SIGNAL(toggled(bool)),this,SLOT(onOnOffClick(bool)));
QObject::connect(torServerFriendsToRequest_SB,SIGNAL(valueChanged(int)),this,SLOT(onFriendsToRequestChanged(int))); QObject::connect(torServerFriendsToRequest_SB,SIGNAL(valueChanged(int)),this,SLOT(onFriendsToRequestChanged(int)));
@ -93,17 +92,33 @@ FriendServerControl::FriendServerControl(QWidget *parent)
QObject::connect(autoAccept_CB,SIGNAL(toggled(bool)),this,SLOT(onAutoAddFriends(bool))); QObject::connect(autoAccept_CB,SIGNAL(toggled(bool)),this,SLOT(onAutoAddFriends(bool)));
QObject::connect(mConnectionCheckTimer,SIGNAL(timeout()),this,SLOT(checkServerAddress())); QObject::connect(mConnectionCheckTimer,SIGNAL(timeout()),this,SLOT(checkServerAddress()));
QObject::connect(status_TW, SIGNAL(customContextMenuRequested(QPoint)), this, SLOT(launchStatusContextMenu(QPoint)));
mCheckingServerMovie = new QMovie(":/images/loader/circleball-16.gif"); mCheckingServerMovie = new QMovie(":/images/loader/circleball-16.gif");
// Do not block signal for these two, since we want to trigger a test to initialise the online status.
torServerAddress_LE->setText(QString::fromStdString(rsFriendServer->friendsServerAddress().c_str()));
torServerPort_SB->setValue(rsFriendServer->friendsServerPort());
updateFriendServerStatusIcon(false); updateFriendServerStatusIcon(false);
mEventHandlerId = 0; makeFriend_ACT = new QAction(tr("Make friend")); // makes SSL-only friend with the peer
QObject::connect(makeFriend_ACT,SIGNAL(triggered()),this,SLOT(makeFriend()));
mEventHandlerId_fs = 0;
rsEvents->registerEventsHandler( [this](std::shared_ptr<const RsEvent> event) rsEvents->registerEventsHandler( [this](std::shared_ptr<const RsEvent> event)
{ {
RsQThreadUtils::postToObject([=](){ handleEvent_main_thread(event); }, this ); RsQThreadUtils::postToObject([=](){ handleEvent_main_thread(event); }, this );
}, mEventHandlerId, RsEventType::FRIEND_SERVER ); }, mEventHandlerId_fs, RsEventType::FRIEND_SERVER );
mEventHandlerId_peer = 0;
rsEvents->registerEventsHandler( [this](std::shared_ptr<const RsEvent> event)
{
RsQThreadUtils::postToObject([=](){ handleEvent_main_thread(event); }, this );
}, mEventHandlerId_peer, RsEventType::PEER_CONNECTION );
} }
void FriendServerControl::onAutoAddFriends(bool b) void FriendServerControl::onAutoAddFriends(bool b)
@ -112,21 +127,37 @@ void FriendServerControl::onAutoAddFriends(bool b)
} }
void FriendServerControl::handleEvent_main_thread(std::shared_ptr<const RsEvent> event) void FriendServerControl::handleEvent_main_thread(std::shared_ptr<const RsEvent> event)
{ {
if(event->mType != RsEventType::FRIEND_SERVER) return; {
const RsFriendServerEvent *fe = dynamic_cast<const RsFriendServerEvent*>(event.get()); const RsFriendServerEvent *fe = dynamic_cast<const RsFriendServerEvent*>(event.get());
if(!fe)
return;
if(fe)
switch(fe->mFriendServerEventType) switch(fe->mFriendServerEventType)
{ {
case RsFriendServerEventCode::PEER_INFO_CHANGED: updateContactsStatus(); case RsFriendServerEventCode::PEER_INFO_CHANGED: updateContactsStatus();
break; break;
case RsFriendServerEventCode::FRIEND_SERVER_STATUS_CHANGED: updateFriendServerStatusIcon(fe->mFriendServerStatus == RsFriendServerStatus::ONLINE);
break;
default: default:
case RsFriendServerEventCode::UNKNOWN: break; case RsFriendServerEventCode::UNKNOWN: break;
} }
}
{
const RsConnectionEvent *pe = dynamic_cast<const RsConnectionEvent*>(event.get());
if(pe)
switch(pe->mConnectionInfoCode)
{
case RsConnectionEventCode::PEER_ADDED:
case RsConnectionEventCode::PEER_REMOVED:
case RsConnectionEventCode::PEER_CONNECTED: updateContactsStatus();
break;
default: ;
}
}
} }
FriendServerControl::~FriendServerControl() FriendServerControl::~FriendServerControl()
@ -134,9 +165,23 @@ FriendServerControl::~FriendServerControl()
delete mCheckingServerMovie; delete mCheckingServerMovie;
delete mConnectionCheckTimer; delete mConnectionCheckTimer;
rsEvents->unregisterEventsHandler(mEventHandlerId); rsEvents->unregisterEventsHandler(mEventHandlerId_fs);
rsEvents->unregisterEventsHandler(mEventHandlerId_peer);
} }
void FriendServerControl::launchStatusContextMenu(QPoint p)
{
RsPeerId peer_id = getCurrentPeer();
RsPeerDetails det;
if(rsPeers->getPeerDetails(peer_id,det) && det.accept_connection)
return;
QMenu contextMnu(this);
contextMnu.addAction(makeFriend_ACT);
contextMnu.exec(QCursor::pos());
}
void FriendServerControl::onOnOffClick(bool b) void FriendServerControl::onOnOffClick(bool b)
{ {
if(b) if(b)
@ -294,4 +339,24 @@ void FriendServerControl::updateContactsStatus()
} }
} }
RsPeerId FriendServerControl::getCurrentPeer()
{
QTableWidgetItem *item = status_TW->currentItem();
if(!item)
return RsPeerId();
return RsPeerId(status_TW->item(item->row(),NODE_COLUMN)->text().toStdString());
}
void FriendServerControl::makeFriend()
{
RsPeerId peer_id = getCurrentPeer();
rsFriendServer->allowPeer(peer_id);
}

View File

@ -42,8 +42,11 @@ protected slots:
void onNbFriendsToRequestsChanged(int n); void onNbFriendsToRequestsChanged(int n);
void checkServerAddress(); void checkServerAddress();
void onAutoAddFriends(bool b); void onAutoAddFriends(bool b);
void launchStatusContextMenu(QPoint p);
void makeFriend();
private: private:
RsPeerId getCurrentPeer();
void updateContactsStatus(); void updateContactsStatus();
void updateFriendServerStatusIcon(bool ok); void updateFriendServerStatusIcon(bool ok);
void handleEvent_main_thread(std::shared_ptr<const RsEvent> event); void handleEvent_main_thread(std::shared_ptr<const RsEvent> event);
@ -52,5 +55,11 @@ private:
QMovie *mCheckingServerMovie; QMovie *mCheckingServerMovie;
bool mCurrentlyCheckingServerAddress; bool mCurrentlyCheckingServerAddress;
RsEventsHandlerId_t mEventHandlerId; RsEventsHandlerId_t mEventHandlerId_fs;
RsEventsHandlerId_t mEventHandlerId_peer;
QAction *makeFriend_ACT;
QAction *unmakeFriend_ACT;
QAction *removePeer_ACT;
QAction *removePeerPermanently_ACT;
}; };

View File

@ -194,6 +194,9 @@
</item> </item>
<item> <item>
<widget class="QTableWidget" name="status_TW"> <widget class="QTableWidget" name="status_TW">
<property name="contextMenuPolicy">
<enum>Qt::CustomContextMenu</enum>
</property>
<column> <column>
<property name="text"> <property name="text">
<string>Name</string> <string>Name</string>