/**************************************************************** * RetroShare is distributed under the following license: * * Copyright (C) 2013, Cyril Soler * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. ****************************************************************/ #include #include #include #include #include #include #include #include "RsAutoUpdatePage.h" #include "PopupDistantChatDialog.h" #define IMAGE_RED_LED ":/icons/bullet_red_64.png" #define IMAGE_YEL_LED ":/icons/bullet_yellow_64.png" #define IMAGE_GRN_LED ":/icons/bullet_green_64.png" #define IMAGE_GRY_LED ":/icons/bullet_grey_64.png" PopupDistantChatDialog::~PopupDistantChatDialog() { _update_timer->stop() ; delete _update_timer ; } PopupDistantChatDialog::PopupDistantChatDialog(const DistantChatPeerId& tunnel_id,QWidget *parent, Qt::WindowFlags flags) : PopupChatDialog(parent,flags) { _tunnel_id = tunnel_id ; _status_label = new QToolButton ; _update_timer = new QTimer ; _status_label->setAutoRaise(true); _status_label->setIconSize(QSize(24,24)); _update_timer->setInterval(1000) ; QObject::connect(_update_timer,SIGNAL(timeout()),this,SLOT(updateDisplay())) ; _update_timer->start() ; getChatWidget()->addChatBarWidget(_status_label) ; updateDisplay() ; } void PopupDistantChatDialog::init(const ChatId &chat_id, const QString &/*title*/) { if (!chat_id.isDistantChatId()) return; _tunnel_id = chat_id.toDistantChatId(); DistantChatPeerInfo tinfo; if(!rsMsgs->getDistantChatStatus(_tunnel_id,tinfo)) return ; RsIdentityDetails iddetails ; if(rsIdentity->getIdDetails(tinfo.to_id,iddetails)) PopupChatDialog::init(chat_id, QString::fromUtf8(iddetails.mNickname.c_str())) ; else PopupChatDialog::init(chat_id, QString::fromStdString(tinfo.to_id.toStdString())) ; // Do not use setOwnId, because we don't want the user to change the GXS avatar from the chat window // it will not be transmitted. ui.ownAvatarWidget->setOwnId() ; // sets the flag ui.ownAvatarWidget->setId(chat_id) ; // sets the actual Id } void PopupDistantChatDialog::updateDisplay() { if(RsAutoUpdatePage::eventsLocked()) // we need to do that by end, because it's not possible to derive from both PopupChatDialog and RsAutoUpdatePage return ; // which both derive from QObject. Signals-slot connexions won't work anymore. if(!isVisible()) return ; //std::cerr << "Checking tunnel..." ; // make sure about the tunnel status // DistantChatPeerInfo tinfo; rsMsgs->getDistantChatStatus(_tunnel_id,tinfo) ; ui.avatarWidget->setId(ChatId(_tunnel_id)); QString msg; switch(tinfo.status) { case RS_DISTANT_CHAT_STATUS_UNKNOWN: //std::cerr << "Unknown hash. Error!" << std::endl; _status_label->setIcon(QIcon(IMAGE_GRY_LED)); msg = tr("Remote status unknown."); _status_label->setToolTip(msg); getChatWidget()->updateStatusString("%1", msg, true); getChatWidget()->blockSending(tr( "Can't send message immediately, " "because there is no tunnel " "available." )); setPeerStatus(RS_STATUS_OFFLINE); break ; case RS_DISTANT_CHAT_STATUS_REMOTELY_CLOSED: std::cerr << "Chat remotely closed. " << std::endl; _status_label->setIcon(QIcon(IMAGE_RED_LED)); _status_label->setToolTip( QObject::tr("Distant peer has closed the chat") ); getChatWidget()->updateStatusString( "%1", tr( "The person you are talking to has deleted the" " secured chat tunnel." ), true ); getChatWidget()->blockSending(tr( "The chat partner deleted the secure" " tunnel, messages will be delivered" " as soon as possible")); setPeerStatus(RS_STATUS_OFFLINE) ; break ; case RS_DISTANT_CHAT_STATUS_TUNNEL_DN: //std::cerr << "Tunnel asked. Waiting for reponse. " << std::endl; _status_label->setIcon(QIcon(IMAGE_RED_LED)); msg = QObject::tr( "Tunnel is pending... Messages will be delivered as" " soon as possible" ); _status_label->setToolTip(msg); getChatWidget()->updateStatusString("%1", msg, true); getChatWidget()->blockSending(msg); setPeerStatus(RS_STATUS_OFFLINE); break; case RS_DISTANT_CHAT_STATUS_CAN_TALK: //std::cerr << "Tunnel is ok and data is transmitted." << std::endl; _status_label->setIcon(QIcon(IMAGE_GRN_LED)); msg = QObject::tr( "Secured tunnel is working. " "Messages are delivered immediately!" ); _status_label->setToolTip(msg); getChatWidget()->unblockSending(); setPeerStatus(RS_STATUS_ONLINE); break; } } void PopupDistantChatDialog::closeEvent(QCloseEvent *e) { //std::cerr << "Closing window => closing distant chat for hash " << _pid << std::endl; DistantChatPeerInfo tinfo ; rsMsgs->getDistantChatStatus(_tunnel_id,tinfo) ; if(tinfo.status != RS_DISTANT_CHAT_STATUS_REMOTELY_CLOSED) { QString msg = tr("Closing this window will end the conversation, notify the peer and remove the encrypted tunnel.") ; if(QMessageBox::Ok == QMessageBox::critical(NULL,tr("Kill the tunnel?"),msg, QMessageBox::Ok | QMessageBox::Cancel)) rsMsgs->closeDistantChatConnexion(_tunnel_id) ; else { e->ignore() ; return ; } } e->accept() ; PopupChatDialog::closeEvent(e) ; } QString PopupDistantChatDialog::getPeerName(const ChatId& /*id*/) const { DistantChatPeerInfo tinfo; rsMsgs->getDistantChatStatus(_tunnel_id,tinfo) ; RsIdentityDetails details ; if(rsIdentity->getIdDetails(tinfo.to_id,details)) return QString::fromUtf8( details.mNickname.c_str() ) ; else return QString::fromStdString(tinfo.to_id.toStdString()) ; } QString PopupDistantChatDialog::getOwnName() const { DistantChatPeerInfo tinfo; rsMsgs->getDistantChatStatus(_tunnel_id,tinfo) ; RsIdentityDetails details ; if(rsIdentity->getIdDetails(tinfo.own_id,details)) return QString::fromUtf8( details.mNickname.c_str() ) ; else return QString::fromStdString(tinfo.own_id.toStdString()) ; }