mirror of
https://github.com/qTox/qTox.git
synced 2024-03-22 14:00:36 +08:00
refactor(core): reimplement avatar transfers
In the process of this I used some ugly hacks, to finish this in time, they should be changed as soon as possible.
This commit is contained in:
parent
b647f9291e
commit
e5acc6726f
|
@ -235,8 +235,7 @@ ToxCorePtr Core::makeToxCore(const QByteArray &savedata, const ICoreSettings * c
|
||||||
|
|
||||||
void Core::onStarted()
|
void Core::onStarted()
|
||||||
{
|
{
|
||||||
// TODO(sudden6): this assert should hold?
|
assert(QThread::currentThread() == coreThread);
|
||||||
//assert(QThread::currentThread() == coreThread);
|
|
||||||
// One time initialization stuff
|
// One time initialization stuff
|
||||||
// set GUI with user and statusmsg
|
// set GUI with user and statusmsg
|
||||||
QString name = getUsername();
|
QString name = getUsername();
|
||||||
|
|
|
@ -139,44 +139,18 @@ signals:
|
||||||
void disconnected();
|
void disconnected();
|
||||||
|
|
||||||
void friendRequestReceived(const ToxPk& friendPk, const QString& message);
|
void friendRequestReceived(const ToxPk& friendPk, const QString& message);
|
||||||
void friendMessageReceived(uint32_t friendId, const QString& message, bool isAction);
|
void friendAvatarChanged(const ToxPk& friendPk, const QPixmap& pic);
|
||||||
|
void friendAvatarData(const ToxPk& friendPk, const QByteArray& data);
|
||||||
|
void friendAvatarRemoved(const ToxPk& friendPk);
|
||||||
|
|
||||||
void friendAdded(uint32_t friendId, const ToxPk& friendPk);
|
|
||||||
void requestSent(const ToxPk& friendPk, const QString& message);
|
void requestSent(const ToxPk& friendPk, const QString& message);
|
||||||
|
void failedToAddFriend(const ToxPk& friendPk, const QString& errorInfo = QString());
|
||||||
void friendStatusChanged(uint32_t friendId, Status status);
|
|
||||||
void friendStatusMessageChanged(uint32_t friendId, const QString& message);
|
|
||||||
void friendUsernameChanged(uint32_t friendId, const QString& username);
|
|
||||||
void friendTypingChanged(uint32_t friendId, bool isTyping);
|
|
||||||
void friendAvatarChanged(uint32_t friendId, const QPixmap& pic);
|
|
||||||
void friendAvatarRemoved(uint32_t friendId);
|
|
||||||
|
|
||||||
void friendRemoved(uint32_t friendId);
|
|
||||||
|
|
||||||
void friendLastSeenChanged(uint32_t friendId, const QDateTime& dateTime);
|
|
||||||
|
|
||||||
void emptyGroupCreated(int groupnumber);
|
|
||||||
void groupInviteReceived(const GroupInvite& inviteInfo);
|
|
||||||
void groupMessageReceived(int groupnumber, int peernumber, const QString& message, bool isAction);
|
|
||||||
void groupNamelistChanged(int groupnumber, int peernumber, uint8_t change);
|
|
||||||
void groupPeerlistChanged(int groupnumber);
|
|
||||||
void groupPeerNameChanged(int groupnumber, int peernumber, const QString& newName);
|
|
||||||
void groupTitleChanged(int groupnumber, const QString& author, const QString& title);
|
|
||||||
void groupPeerAudioPlaying(int groupnumber, int peernumber);
|
|
||||||
|
|
||||||
void usernameSet(const QString& username);
|
void usernameSet(const QString& username);
|
||||||
void statusMessageSet(const QString& message);
|
void statusMessageSet(const QString& message);
|
||||||
void statusSet(Status status);
|
void statusSet(Status status);
|
||||||
void idSet(const ToxId& id);
|
void idSet(const ToxId& id);
|
||||||
|
|
||||||
void messageSentResult(uint32_t friendId, const QString& message, int messageId);
|
|
||||||
void groupSentFailed(int groupId);
|
|
||||||
void actionSentResult(uint32_t friendId, const QString& action, int success);
|
|
||||||
|
|
||||||
void receiptRecieved(int friedId, int receipt);
|
|
||||||
|
|
||||||
void failedToAddFriend(const ToxPk& friendPk, const QString& errorInfo = QString());
|
|
||||||
void failedToRemoveFriend(uint32_t friendId);
|
|
||||||
void failedToSetUsername(const QString& username);
|
void failedToSetUsername(const QString& username);
|
||||||
void failedToSetStatusMessage(const QString& message);
|
void failedToSetStatusMessage(const QString& message);
|
||||||
void failedToSetStatus(Status status);
|
void failedToSetStatus(Status status);
|
||||||
|
@ -197,10 +171,45 @@ signals:
|
||||||
void fileTransferBrokenUnbroken(ToxFile file, bool broken);
|
void fileTransferBrokenUnbroken(ToxFile file, bool broken);
|
||||||
void fileNameChanged();
|
void fileNameChanged();
|
||||||
|
|
||||||
void fileSendFailed(uint32_t friendId, const QString& fname);
|
|
||||||
|
|
||||||
void saveRequest();
|
void saveRequest();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated prefer signals using ToxPk
|
||||||
|
*/
|
||||||
|
|
||||||
|
void fileAvatarOfferReceived(uint32_t friendId, uint32_t fileId, const QByteArray& avatarHash);
|
||||||
|
|
||||||
|
void friendMessageReceived(uint32_t friendId, const QString& message, bool isAction);
|
||||||
|
void friendAdded(uint32_t friendId, const ToxPk& friendPk);
|
||||||
|
|
||||||
|
void friendStatusChanged(uint32_t friendId, Status status);
|
||||||
|
void friendStatusMessageChanged(uint32_t friendId, const QString& message);
|
||||||
|
void friendUsernameChanged(uint32_t friendId, const QString& username);
|
||||||
|
void friendTypingChanged(uint32_t friendId, bool isTyping);
|
||||||
|
|
||||||
|
void friendAvatarChangedDeprecated(uint32_t friendId, const QPixmap& pic);
|
||||||
|
void friendRemoved(uint32_t friendId);
|
||||||
|
void friendLastSeenChanged(uint32_t friendId, const QDateTime& dateTime);
|
||||||
|
|
||||||
|
void emptyGroupCreated(int groupnumber);
|
||||||
|
void groupInviteReceived(const GroupInvite& inviteInfo);
|
||||||
|
void groupMessageReceived(int groupnumber, int peernumber, const QString& message, bool isAction);
|
||||||
|
void groupNamelistChanged(int groupnumber, int peernumber, uint8_t change);
|
||||||
|
void groupPeerlistChanged(int groupnumber);
|
||||||
|
void groupPeerNameChanged(int groupnumber, int peernumber, const QString& newName);
|
||||||
|
void groupTitleChanged(int groupnumber, const QString& author, const QString& title);
|
||||||
|
void groupPeerAudioPlaying(int groupnumber, int peernumber);
|
||||||
|
|
||||||
|
void messageSentResult(uint32_t friendId, const QString& message, int messageId);
|
||||||
|
void groupSentFailed(int groupId);
|
||||||
|
void actionSentResult(uint32_t friendId, const QString& action, int success);
|
||||||
|
|
||||||
|
void receiptRecieved(int friedId, int receipt);
|
||||||
|
|
||||||
|
void failedToRemoveFriend(uint32_t friendId);
|
||||||
|
|
||||||
|
void fileSendFailed(uint32_t friendId, const QString& fname);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Core(QThread* coreThread);
|
Core(QThread* coreThread);
|
||||||
|
|
||||||
|
|
|
@ -295,33 +295,17 @@ void CoreFile::onFileReceiveCallback(Tox*, uint32_t friendId, uint32_t fileId, u
|
||||||
if (!filesize) {
|
if (!filesize) {
|
||||||
qDebug() << QString("Received empty avatar request %1:%2").arg(friendId).arg(fileId);
|
qDebug() << QString("Received empty avatar request %1:%2").arg(friendId).arg(fileId);
|
||||||
// Avatars of size 0 means explicitely no avatar
|
// Avatars of size 0 means explicitely no avatar
|
||||||
emit core->friendAvatarRemoved(friendId);
|
emit core->friendAvatarRemoved(core->getFriendPublicKey(friendId));
|
||||||
// TODO(sudden6): use signal from above for that action
|
|
||||||
//core->profile.removeAvatar(friendPk);
|
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
static_assert(TOX_HASH_LENGTH <= TOX_FILE_ID_LENGTH,
|
static_assert(TOX_HASH_LENGTH <= TOX_FILE_ID_LENGTH,
|
||||||
"TOX_HASH_LENGTH > TOX_FILE_ID_LENGTH!");
|
"TOX_HASH_LENGTH > TOX_FILE_ID_LENGTH!");
|
||||||
uint8_t avatarHash[TOX_FILE_ID_LENGTH];
|
uint8_t avatarHash[TOX_FILE_ID_LENGTH];
|
||||||
tox_file_get_file_id(core->tox, friendId, fileId, avatarHash, nullptr);
|
tox_file_get_file_id(core->tox, friendId, fileId, avatarHash, nullptr);
|
||||||
// TODO(sudden6): fix that condition below
|
QByteArray avatarBytes{static_cast<const char*>(static_cast<const void*>(avatarHash)),
|
||||||
if (/*core->profile.getAvatarHash(friendPk)
|
TOX_HASH_LENGTH};
|
||||||
== QByteArray((char*)avatarHash, TOX_HASH_LENGTH)*/ false) {
|
emit core->fileAvatarOfferReceived(friendId, fileId, avatarBytes);
|
||||||
// If it's an avatar but we already have it cached, cancel
|
|
||||||
qDebug() << QString(
|
|
||||||
"Received avatar request %1:%2, reject, since we have it in cache.")
|
|
||||||
.arg(friendId)
|
|
||||||
.arg(fileId);
|
|
||||||
tox_file_control(core->tox, friendId, fileId, TOX_FILE_CONTROL_CANCEL, nullptr);
|
|
||||||
return;
|
return;
|
||||||
} else {
|
|
||||||
// It's an avatar and we don't have it, autoaccept the transfer
|
|
||||||
qDebug() << QString("Received avatar request %1:%2, accept, since we don't have it "
|
|
||||||
"in cache.")
|
|
||||||
.arg(friendId)
|
|
||||||
.arg(fileId);
|
|
||||||
tox_file_control(core->tox, friendId, fileId, TOX_FILE_CONTROL_RESUME, nullptr);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
const auto cleanFileName = CoreFile::getCleanFileName(filename.getQString());
|
const auto cleanFileName = CoreFile::getCleanFileName(filename.getQString());
|
||||||
|
@ -344,6 +328,37 @@ void CoreFile::onFileReceiveCallback(Tox*, uint32_t friendId, uint32_t fileId, u
|
||||||
if (kind != TOX_FILE_KIND_AVATAR)
|
if (kind != TOX_FILE_KIND_AVATAR)
|
||||||
emit core->fileReceiveRequested(file);
|
emit core->fileReceiveRequested(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO(sudden6): This whole method is a mess but needed to get stuff working for now
|
||||||
|
void CoreFile::handleAvatarOffer(uint32_t friendId, uint32_t fileId, bool accept)
|
||||||
|
{
|
||||||
|
// TODO(sudden6): evil evil evil
|
||||||
|
auto core = Core::getInstance();
|
||||||
|
if (!accept) {
|
||||||
|
// If it's an avatar but we already have it cached, cancel
|
||||||
|
qDebug() << QString(
|
||||||
|
"Received avatar request %1:%2, reject, since we have it in cache.")
|
||||||
|
.arg(friendId)
|
||||||
|
.arg(fileId);
|
||||||
|
tox_file_control(core->tox, friendId, fileId, TOX_FILE_CONTROL_CANCEL, nullptr);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// It's an avatar and we don't have it, autoaccept the transfer
|
||||||
|
qDebug() << QString("Received avatar request %1:%2, accept, since we don't have it "
|
||||||
|
"in cache.")
|
||||||
|
.arg(friendId)
|
||||||
|
.arg(fileId);
|
||||||
|
tox_file_control(core->tox, friendId, fileId, TOX_FILE_CONTROL_RESUME, nullptr);
|
||||||
|
|
||||||
|
ToxFile file{fileId, friendId, "<avatar>", "", ToxFile::RECEIVING};
|
||||||
|
file.filesize = 0;
|
||||||
|
file.fileKind = TOX_FILE_KIND_AVATAR;
|
||||||
|
file.resumeFileId.resize(TOX_FILE_ID_LENGTH);
|
||||||
|
tox_file_get_file_id(core->tox, friendId, fileId, (uint8_t*)file.resumeFileId.data(), nullptr);
|
||||||
|
addFile(friendId, fileId, file);
|
||||||
|
}
|
||||||
|
|
||||||
void CoreFile::onFileControlCallback(Tox*, uint32_t friendId, uint32_t fileId,
|
void CoreFile::onFileControlCallback(Tox*, uint32_t friendId, uint32_t fileId,
|
||||||
TOX_FILE_CONTROL control, void* core)
|
TOX_FILE_CONTROL control, void* core)
|
||||||
{
|
{
|
||||||
|
@ -448,11 +463,10 @@ void CoreFile::onFileRecvChunkCallback(Tox* tox, uint32_t friendId, uint32_t fil
|
||||||
pic.loadFromData(file->avatarData);
|
pic.loadFromData(file->avatarData);
|
||||||
if (!pic.isNull()) {
|
if (!pic.isNull()) {
|
||||||
qDebug() << "Got" << file->avatarData.size() << "bytes of avatar data from" << friendId;
|
qDebug() << "Got" << file->avatarData.size() << "bytes of avatar data from" << friendId;
|
||||||
// TODO(sudden6): handle the action below with the signal
|
emit core->friendAvatarData(core->getFriendPublicKey(friendId), file->avatarData);
|
||||||
/*
|
emit core->friendAvatarChanged(core->getFriendPublicKey(friendId), pic);
|
||||||
core->profile.saveAvatar(file->avatarData,
|
// TODO(sudden6): signal below is deprecated
|
||||||
core->getFriendPublicKey(friendId));*/
|
emit core->friendAvatarChangedDeprecated(friendId, pic);
|
||||||
emit core->friendAvatarChanged(friendId, pic);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
emit core->fileTransferFinished(*file);
|
emit core->fileTransferFinished(*file);
|
||||||
|
|
|
@ -39,6 +39,9 @@ class CoreFile
|
||||||
{
|
{
|
||||||
friend class Core;
|
friend class Core;
|
||||||
|
|
||||||
|
|
||||||
|
public:
|
||||||
|
static void handleAvatarOffer(uint32_t friendId, uint32_t fileId, bool accept);
|
||||||
private:
|
private:
|
||||||
CoreFile() = delete;
|
CoreFile() = delete;
|
||||||
|
|
||||||
|
|
|
@ -327,7 +327,7 @@ IProfileInfo::SetAvatarResult ProfileInfo::setAvatar(const QString &path)
|
||||||
return SetAvatarResult::TooLarge;
|
return SetAvatarResult::TooLarge;
|
||||||
}
|
}
|
||||||
|
|
||||||
profile->setAvatar(bytes, core->getSelfPublicKey());
|
profile->setAvatar(bytes);
|
||||||
return SetAvatarResult::OK;
|
return SetAvatarResult::OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -336,5 +336,5 @@ IProfileInfo::SetAvatarResult ProfileInfo::setAvatar(const QString &path)
|
||||||
*/
|
*/
|
||||||
void ProfileInfo::removeAvatar()
|
void ProfileInfo::removeAvatar()
|
||||||
{
|
{
|
||||||
profile->removeAvatar();
|
profile->removeSelfAvatar();
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
#include "profilelocker.h"
|
#include "profilelocker.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
#include "src/core/core.h"
|
#include "src/core/core.h"
|
||||||
|
#include "src/core/corefile.h"
|
||||||
#include "src/net/avatarbroadcaster.h"
|
#include "src/net/avatarbroadcaster.h"
|
||||||
#include "src/nexus.h"
|
#include "src/nexus.h"
|
||||||
#include "src/widget/gui.h"
|
#include "src/widget/gui.h"
|
||||||
|
@ -78,19 +79,16 @@ Profile::Profile(QString name, const QString& password, bool isNewProfile, const
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const ToxId& selfId = core->getSelfId();
|
|
||||||
loadDatabase(selfId, password);
|
|
||||||
const ToxPk& selfPk = selfId.getPublicKey();
|
|
||||||
QByteArray data = loadAvatarData(selfPk);
|
|
||||||
if (data.isEmpty()) {
|
|
||||||
qDebug() << "Self avatar not found, will broadcast empty avatar to friends";
|
|
||||||
}
|
|
||||||
|
|
||||||
// save tox file when Core requests it
|
// save tox file when Core requests it
|
||||||
connect(core.get(), &Core::saveRequest, this, &Profile::onSaveToxSave);
|
connect(core.get(), &Core::saveRequest, this, &Profile::onSaveToxSave);
|
||||||
|
// react to avatar changes
|
||||||
|
connect(core.get(), &Core::friendAvatarRemoved, this, &Profile::removeAvatar);
|
||||||
|
connect(core.get(), &Core::friendAvatarData, this, &Profile::saveAvatar);
|
||||||
|
connect(core.get(), &Core::fileAvatarOfferReceived, this, &Profile::onAvatarOfferReceived, Qt::ConnectionType::BlockingQueuedConnection);
|
||||||
|
|
||||||
|
const ToxId& selfId = core->getSelfId();
|
||||||
|
loadDatabase(selfId, password);
|
||||||
|
|
||||||
// TODO(sudden6): check if needed
|
|
||||||
//setAvatar(data, selfPk);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -298,6 +296,17 @@ QString Profile::getName() const
|
||||||
void Profile::startCore()
|
void Profile::startCore()
|
||||||
{
|
{
|
||||||
core->start();
|
core->start();
|
||||||
|
|
||||||
|
const ToxId& selfId = core->getSelfId();
|
||||||
|
const ToxPk& selfPk = selfId.getPublicKey();
|
||||||
|
QByteArray data = loadAvatarData(selfPk);
|
||||||
|
if (data.isEmpty()) {
|
||||||
|
qDebug() << "Self avatar not found, will broadcast empty avatar to friends";
|
||||||
|
}
|
||||||
|
// TODO(sudden6): moved here, because it crashes in the constructor
|
||||||
|
// reason: Core::getInstance() returns nullptr, because it's not yet initialized
|
||||||
|
// solution: kill Core::getInstance
|
||||||
|
setAvatar(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Profile::isNewProfile()
|
bool Profile::isNewProfile()
|
||||||
|
@ -317,6 +326,14 @@ void Profile::onSaveToxSave()
|
||||||
saveToxSave(data);
|
saveToxSave(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO(sudden6): handle this better maybe?
|
||||||
|
void Profile::onAvatarOfferReceived(uint32_t friendId, uint32_t fileId, const QByteArray &avatarHash)
|
||||||
|
{
|
||||||
|
// accept if we don't have it already
|
||||||
|
const bool accept = getAvatarHash(core->getFriendPublicKey(friendId)) != avatarHash;
|
||||||
|
CoreFile::handleAvatarOffer(friendId, fileId, accept);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Write the .tox save, encrypted if needed.
|
* @brief Write the .tox save, encrypted if needed.
|
||||||
* @param data Byte array of profile save.
|
* @param data Byte array of profile save.
|
||||||
|
@ -474,26 +491,31 @@ void Profile::loadDatabase(const ToxId& id, QString password)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Profile::setAvatar(QByteArray pic, const ToxPk& owner)
|
/**
|
||||||
|
* @brief Sets our own avatar
|
||||||
|
* @param pic Picture to use as avatar, if empty an Identicon will be used depending on settings
|
||||||
|
* @param owner
|
||||||
|
*/
|
||||||
|
void Profile::setAvatar(QByteArray pic)
|
||||||
{
|
{
|
||||||
QPixmap pixmap;
|
QPixmap pixmap;
|
||||||
QByteArray avatarData;
|
QByteArray avatarData;
|
||||||
|
const ToxPk& selfPk = core->getSelfPublicKey();
|
||||||
if (!pic.isEmpty()) {
|
if (!pic.isEmpty()) {
|
||||||
pixmap.loadFromData(pic);
|
pixmap.loadFromData(pic);
|
||||||
avatarData = pic;
|
avatarData = pic;
|
||||||
} else {
|
} else {
|
||||||
if (Settings::getInstance().getShowIdenticons()) {
|
if (Settings::getInstance().getShowIdenticons()) {
|
||||||
// with IDENTICON_ROWS=5 this gives a 160x160 image file
|
// with IDENTICON_ROWS=5 this gives a 160x160 image file
|
||||||
const QImage identicon = Identicon(owner.getKey()).toImage(32);
|
const QImage identicon = Identicon(selfPk.getKey()).toImage(32);
|
||||||
pixmap = QPixmap::fromImage(identicon);
|
pixmap = QPixmap::fromImage(identicon);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
pixmap.load(":/img/contact_dark.svg");
|
pixmap.load(":/img/contact_dark.svg");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
saveAvatar(avatarData, owner);
|
saveAvatar(selfPk, avatarData);
|
||||||
|
|
||||||
emit selfAvatarChanged(pixmap);
|
emit selfAvatarChanged(pixmap);
|
||||||
AvatarBroadcaster::setAvatar(avatarData);
|
AvatarBroadcaster::setAvatar(avatarData);
|
||||||
|
@ -523,7 +545,7 @@ void Profile::onRequestSent(const ToxPk& friendPk, const QString& message)
|
||||||
* @param pic Picture to save.
|
* @param pic Picture to save.
|
||||||
* @param owner PK of avatar owner.
|
* @param owner PK of avatar owner.
|
||||||
*/
|
*/
|
||||||
void Profile::saveAvatar(QByteArray pic, const ToxPk& owner)
|
void Profile::saveAvatar(const ToxPk& owner, QByteArray pic)
|
||||||
{
|
{
|
||||||
if (encrypted && !pic.isEmpty()) {
|
if (encrypted && !pic.isEmpty()) {
|
||||||
pic = passkey->encrypt(pic);
|
pic = passkey->encrypt(pic);
|
||||||
|
@ -560,7 +582,7 @@ QByteArray Profile::getAvatarHash(const ToxPk& owner)
|
||||||
/**
|
/**
|
||||||
* @brief Removes our own avatar.
|
* @brief Removes our own avatar.
|
||||||
*/
|
*/
|
||||||
void Profile::removeAvatar()
|
void Profile::removeSelfAvatar()
|
||||||
{
|
{
|
||||||
removeAvatar(core->getSelfId().getPublicKey());
|
removeAvatar(core->getSelfId().getPublicKey());
|
||||||
}
|
}
|
||||||
|
@ -592,7 +614,7 @@ void Profile::removeAvatar(const ToxPk& owner)
|
||||||
{
|
{
|
||||||
QFile::remove(avatarPath(owner));
|
QFile::remove(avatarPath(owner));
|
||||||
if (owner == core->getSelfId().getPublicKey()) {
|
if (owner == core->getSelfId().getPublicKey()) {
|
||||||
setAvatar({}, core->getSelfPublicKey());
|
setAvatar({});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -777,13 +799,13 @@ QString Profile::setPassword(const QString& newPassword)
|
||||||
Nexus::getDesktopGUI()->reloadHistory();
|
Nexus::getDesktopGUI()->reloadHistory();
|
||||||
|
|
||||||
QByteArray avatar = loadAvatarData(core->getSelfId().getPublicKey());
|
QByteArray avatar = loadAvatarData(core->getSelfId().getPublicKey());
|
||||||
saveAvatar(avatar, core->getSelfId().getPublicKey());
|
saveAvatar(core->getSelfId().getPublicKey(), avatar);
|
||||||
|
|
||||||
QVector<uint32_t> friendList = core->getFriendList();
|
QVector<uint32_t> friendList = core->getFriendList();
|
||||||
QVectorIterator<uint32_t> i(friendList);
|
QVectorIterator<uint32_t> i(friendList);
|
||||||
while (i.hasNext()) {
|
while (i.hasNext()) {
|
||||||
const ToxPk friendPublicKey = core->getFriendPublicKey(i.next());
|
const ToxPk friendPublicKey = core->getFriendPublicKey(i.next());
|
||||||
saveAvatar(loadAvatarData(friendPublicKey), friendPublicKey);
|
saveAvatar(friendPublicKey, loadAvatarData(friendPublicKey));
|
||||||
}
|
}
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,11 +56,9 @@ public:
|
||||||
QPixmap loadAvatar();
|
QPixmap loadAvatar();
|
||||||
QPixmap loadAvatar(const ToxPk& owner);
|
QPixmap loadAvatar(const ToxPk& owner);
|
||||||
QByteArray loadAvatarData(const ToxPk& owner);
|
QByteArray loadAvatarData(const ToxPk& owner);
|
||||||
void setAvatar(QByteArray pic, const ToxPk& owner);
|
void setAvatar(QByteArray pic);
|
||||||
void saveAvatar(QByteArray pic, const ToxPk& owner);
|
|
||||||
QByteArray getAvatarHash(const ToxPk& owner);
|
QByteArray getAvatarHash(const ToxPk& owner);
|
||||||
void removeAvatar(const ToxPk& owner);
|
void removeSelfAvatar();
|
||||||
void removeAvatar();
|
|
||||||
|
|
||||||
bool isHistoryEnabled();
|
bool isHistoryEnabled();
|
||||||
History* getHistory();
|
History* getHistory();
|
||||||
|
@ -88,7 +86,11 @@ public slots:
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void loadDatabase(const ToxId& id, QString password);
|
void loadDatabase(const ToxId& id, QString password);
|
||||||
|
void saveAvatar(const ToxPk& owner, QByteArray pic);
|
||||||
|
void removeAvatar(const ToxPk& owner);
|
||||||
void onSaveToxSave();
|
void onSaveToxSave();
|
||||||
|
// TODO(sudden6): use ToxPk instead of friendId
|
||||||
|
void onAvatarOfferReceived(uint32_t friendId, uint32_t fileId, const QByteArray& avatarHash);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Profile(QString name, const QString& password, bool newProfile, const QByteArray& toxsave);
|
Profile(QString name, const QString& password, bool newProfile, const QByteArray& toxsave);
|
||||||
|
|
|
@ -156,7 +156,7 @@ GroupNetCamView::GroupNetCamView(int group, QWidget* parent)
|
||||||
setActive();
|
setActive();
|
||||||
});
|
});
|
||||||
|
|
||||||
connect(Core::getInstance(), &Core::friendAvatarChanged, this,
|
connect(Core::getInstance(), &Core::friendAvatarChangedDeprecated, this,
|
||||||
&GroupNetCamView::friendAvatarChanged);
|
&GroupNetCamView::friendAvatarChanged);
|
||||||
|
|
||||||
selfVideoSurface->setText(Core::getInstance()->getUsername());
|
selfVideoSurface->setText(Core::getInstance()->getUsername());
|
||||||
|
|
|
@ -75,7 +75,7 @@ NetCamView::NetCamView(int friendId, QWidget* parent)
|
||||||
connections += connect(Nexus::getProfile(), &Profile::selfAvatarChanged,
|
connections += connect(Nexus::getProfile(), &Profile::selfAvatarChanged,
|
||||||
[this](const QPixmap& pixmap) { selfVideoSurface->setAvatar(pixmap); });
|
[this](const QPixmap& pixmap) { selfVideoSurface->setAvatar(pixmap); });
|
||||||
|
|
||||||
connections += connect(Core::getInstance(), &Core::friendAvatarChanged,
|
connections += connect(Core::getInstance(), &Core::friendAvatarChangedDeprecated,
|
||||||
[this](int FriendId, const QPixmap& pixmap) {
|
[this](int FriendId, const QPixmap& pixmap) {
|
||||||
if (this->friendId == FriendId)
|
if (this->friendId == FriendId)
|
||||||
videoSurface->setAvatar(pixmap);
|
videoSurface->setAvatar(pixmap);
|
||||||
|
|
|
@ -158,7 +158,8 @@ ChatForm::ChatForm(Friend* chatFriend, History* history)
|
||||||
|
|
||||||
const Core* core = Core::getInstance();
|
const Core* core = Core::getInstance();
|
||||||
connect(core, &Core::fileReceiveRequested, this, &ChatForm::onFileRecvRequest);
|
connect(core, &Core::fileReceiveRequested, this, &ChatForm::onFileRecvRequest);
|
||||||
connect(core, &Core::friendAvatarChanged, this, &ChatForm::onAvatarChange);
|
// TODO(sudden6): update slot to new API
|
||||||
|
connect(core, &Core::friendAvatarChangedDeprecated, this, &ChatForm::onAvatarChange);
|
||||||
connect(core, &Core::friendAvatarRemoved, this, &ChatForm::onAvatarRemoved);
|
connect(core, &Core::friendAvatarRemoved, this, &ChatForm::onAvatarRemoved);
|
||||||
connect(core, &Core::fileSendStarted, this, &ChatForm::startFileSend);
|
connect(core, &Core::fileSendStarted, this, &ChatForm::startFileSend);
|
||||||
connect(core, &Core::fileSendFailed, this, &ChatForm::onFileSendFailed);
|
connect(core, &Core::fileSendFailed, this, &ChatForm::onFileSendFailed);
|
||||||
|
@ -690,9 +691,9 @@ void ChatForm::dropEvent(QDropEvent* ev)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ChatForm::onAvatarRemoved(uint32_t friendId)
|
void ChatForm::onAvatarRemoved(const ToxPk& friendPk)
|
||||||
{
|
{
|
||||||
if (friendId != f->getId()) {
|
if (friendPk != f->getPublicKey()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -73,7 +73,7 @@ public slots:
|
||||||
void onAvStart(uint32_t friendId, bool video);
|
void onAvStart(uint32_t friendId, bool video);
|
||||||
void onAvEnd(uint32_t friendId, bool error);
|
void onAvEnd(uint32_t friendId, bool error);
|
||||||
void onAvatarChange(uint32_t friendId, const QPixmap& pic);
|
void onAvatarChange(uint32_t friendId, const QPixmap& pic);
|
||||||
void onAvatarRemoved(uint32_t friendId);
|
void onAvatarRemoved(const ToxPk &friendPk);
|
||||||
void onFileNameChanged();
|
void onFileNameChanged();
|
||||||
|
|
||||||
protected slots:
|
protected slots:
|
||||||
|
|
|
@ -418,9 +418,9 @@ void FriendWidget::resetEventFlags()
|
||||||
f->setEventFlag(false);
|
f->setEventFlag(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendWidget::onAvatarChange(uint32_t friendId, const QPixmap& pic)
|
void FriendWidget::onAvatarChange(const ToxPk& friendPk, const QPixmap& pic)
|
||||||
{
|
{
|
||||||
if (friendId != frnd->getId()) {
|
if (friendPk != frnd->getPublicKey()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -428,9 +428,9 @@ void FriendWidget::onAvatarChange(uint32_t friendId, const QPixmap& pic)
|
||||||
avatar->setPixmap(pic);
|
avatar->setPixmap(pic);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendWidget::onAvatarRemoved(uint32_t friendId)
|
void FriendWidget::onAvatarRemoved(const ToxPk& friendPk)
|
||||||
{
|
{
|
||||||
if (friendId != frnd->getId()) {
|
if (friendPk != frnd->getPublicKey()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#define FRIENDWIDGET_H
|
#define FRIENDWIDGET_H
|
||||||
|
|
||||||
#include "genericchatroomwidget.h"
|
#include "genericchatroomwidget.h"
|
||||||
|
#include "src/core/toxpk.h"
|
||||||
|
|
||||||
class QPixmap;
|
class QPixmap;
|
||||||
class MaskablePixmapWidget;
|
class MaskablePixmapWidget;
|
||||||
|
@ -45,8 +46,8 @@ signals:
|
||||||
void contextMenuCalled(QContextMenuEvent* event);
|
void contextMenuCalled(QContextMenuEvent* event);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void onAvatarChange(uint32_t friendId, const QPixmap& pic);
|
void onAvatarChange(const ToxPk &friendPk, const QPixmap& pic);
|
||||||
void onAvatarRemoved(uint32_t friendId);
|
void onAvatarRemoved(const ToxPk &friendPk);
|
||||||
void onContextMenuCalled(QContextMenuEvent* event);
|
void onContextMenuCalled(QContextMenuEvent* event);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
|
@ -1022,7 +1022,7 @@ void Widget::addFriend(uint32_t friendId, const ToxPk& friendPk)
|
||||||
QPixmap avatar = Nexus::getProfile()->loadAvatar(friendPk);
|
QPixmap avatar = Nexus::getProfile()->loadAvatar(friendPk);
|
||||||
if (!avatar.isNull()) {
|
if (!avatar.isNull()) {
|
||||||
friendForm->onAvatarChange(friendId, avatar);
|
friendForm->onAvatarChange(friendId, avatar);
|
||||||
widget->onAvatarChange(friendId, avatar);
|
widget->onAvatarChange(friendPk, avatar);
|
||||||
}
|
}
|
||||||
|
|
||||||
FilterCriteria filter = getFilterCriteria();
|
FilterCriteria filter = getFilterCriteria();
|
||||||
|
@ -1284,7 +1284,7 @@ void Widget::addFriendDialog(const Friend* frnd, ContentDialog* dialog)
|
||||||
|
|
||||||
QPixmap avatar = Nexus::getProfile()->loadAvatar(frnd->getPublicKey());
|
QPixmap avatar = Nexus::getProfile()->loadAvatar(frnd->getPublicKey());
|
||||||
if (!avatar.isNull()) {
|
if (!avatar.isNull()) {
|
||||||
friendWidget->onAvatarChange(friendId, avatar);
|
friendWidget->onAvatarChange(frnd->getPublicKey(), avatar);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user