mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
Simplify IrcManager connection creation/disconnecting
reword some comments/add some comments about unfitting methods in IrcManager
This commit is contained in:
parent
bf5e619818
commit
b13b8a2ce6
2 changed files with 48 additions and 54 deletions
|
@ -13,7 +13,6 @@
|
||||||
#include "windowmanager.hpp"
|
#include "windowmanager.hpp"
|
||||||
|
|
||||||
#include <irccommand.h>
|
#include <irccommand.h>
|
||||||
#include <ircconnection.h>
|
|
||||||
#include <QJsonArray>
|
#include <QJsonArray>
|
||||||
#include <QJsonDocument>
|
#include <QJsonDocument>
|
||||||
#include <QJsonObject>
|
#include <QJsonObject>
|
||||||
|
@ -41,16 +40,32 @@ IrcManager::IrcManager(ChannelManager &_channelManager, Resources &_resources,
|
||||||
|
|
||||||
postToThread([this] { this->connect(); });
|
postToThread([this] { this->connect(); });
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Initialize the connections
|
||||||
|
this->writeConnection.reset(new Communi::IrcConnection);
|
||||||
|
this->writeConnection->moveToThread(QCoreApplication::instance()->thread());
|
||||||
|
|
||||||
|
this->readConnection.reset(new Communi::IrcConnection);
|
||||||
|
this->readConnection->moveToThread(QCoreApplication::instance()->thread());
|
||||||
|
|
||||||
|
// Listen to read connection message signals
|
||||||
|
QObject::connect(this->readConnection.get(), &Communi::IrcConnection::messageReceived, this,
|
||||||
|
&IrcManager::messageReceived);
|
||||||
|
QObject::connect(this->readConnection.get(), &Communi::IrcConnection::privateMessageReceived,
|
||||||
|
this, &IrcManager::privateMessageReceived);
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::setUser(std::shared_ptr<twitch::TwitchUser> account)
|
void IrcManager::setUser(std::shared_ptr<twitch::TwitchUser> newAccount)
|
||||||
{
|
{
|
||||||
this->account = account;
|
this->account = newAccount;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::connect()
|
void IrcManager::connect()
|
||||||
{
|
{
|
||||||
disconnect();
|
this->disconnect();
|
||||||
|
|
||||||
|
this->initializeConnection(this->writeConnection, false);
|
||||||
|
this->initializeConnection(this->readConnection, true);
|
||||||
|
|
||||||
// XXX(pajlada): Disabled the async_exec for now, because if we happen to run the
|
// XXX(pajlada): Disabled the async_exec for now, because if we happen to run the
|
||||||
// `beginConnecting` function in a different thread than last time, we won't be able to connect
|
// `beginConnecting` function in a different thread than last time, we won't be able to connect
|
||||||
|
@ -59,17 +74,10 @@ void IrcManager::connect()
|
||||||
this->beginConnecting();
|
this->beginConnecting();
|
||||||
}
|
}
|
||||||
|
|
||||||
Communi::IrcConnection *IrcManager::createConnection(bool doRead)
|
void IrcManager::initializeConnection(const std::unique_ptr<Communi::IrcConnection> &connection,
|
||||||
|
bool isReadConnection)
|
||||||
{
|
{
|
||||||
assert(this->account);
|
assert(this->account);
|
||||||
Communi::IrcConnection *connection = new Communi::IrcConnection;
|
|
||||||
|
|
||||||
if (doRead) {
|
|
||||||
QObject::connect(connection, &Communi::IrcConnection::messageReceived, this,
|
|
||||||
&IrcManager::messageReceived);
|
|
||||||
QObject::connect(connection, &Communi::IrcConnection::privateMessageReceived, this,
|
|
||||||
&IrcManager::privateMessageReceived);
|
|
||||||
}
|
|
||||||
|
|
||||||
QString username = this->account->getUserName();
|
QString username = this->account->getUserName();
|
||||||
QString oauthClient = this->account->getOAuthClient();
|
QString oauthClient = this->account->getOAuthClient();
|
||||||
|
@ -88,7 +96,7 @@ Communi::IrcConnection *IrcManager::createConnection(bool doRead)
|
||||||
this->refreshIgnoredUsers(username, oauthClient, oauthToken);
|
this->refreshIgnoredUsers(username, oauthClient, oauthToken);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (doRead) {
|
if (isReadConnection) {
|
||||||
connection->sendCommand(
|
connection->sendCommand(
|
||||||
Communi::IrcCommand::createCapability("REQ", "twitch.tv/membership"));
|
Communi::IrcCommand::createCapability("REQ", "twitch.tv/membership"));
|
||||||
connection->sendCommand(Communi::IrcCommand::createCapability("REQ", "twitch.tv/commands"));
|
connection->sendCommand(Communi::IrcCommand::createCapability("REQ", "twitch.tv/commands"));
|
||||||
|
@ -97,8 +105,6 @@ Communi::IrcConnection *IrcManager::createConnection(bool doRead)
|
||||||
|
|
||||||
connection->setHost("irc.chat.twitch.tv");
|
connection->setHost("irc.chat.twitch.tv");
|
||||||
connection->setPort(6667);
|
connection->setPort(6667);
|
||||||
|
|
||||||
return connection;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::refreshIgnoredUsers(const QString &username, const QString &oauthClient,
|
void IrcManager::refreshIgnoredUsers(const QString &username, const QString &oauthClient,
|
||||||
|
@ -139,43 +145,23 @@ void IrcManager::refreshIgnoredUsers(const QString &username, const QString &oau
|
||||||
|
|
||||||
void IrcManager::beginConnecting()
|
void IrcManager::beginConnecting()
|
||||||
{
|
{
|
||||||
uint32_t generation = ++this->connectionGeneration;
|
|
||||||
|
|
||||||
Communi::IrcConnection *_writeConnection = this->createConnection(false);
|
|
||||||
Communi::IrcConnection *_readConnection = this->createConnection(true);
|
|
||||||
|
|
||||||
std::lock_guard<std::mutex> locker(this->connectionMutex);
|
std::lock_guard<std::mutex> locker(this->connectionMutex);
|
||||||
|
|
||||||
if (generation == this->connectionGeneration) {
|
|
||||||
this->writeConnection = std::shared_ptr<Communi::IrcConnection>(_writeConnection);
|
|
||||||
this->readConnection = std::shared_ptr<Communi::IrcConnection>(_readConnection);
|
|
||||||
|
|
||||||
this->writeConnection->moveToThread(QCoreApplication::instance()->thread());
|
|
||||||
this->readConnection->moveToThread(QCoreApplication::instance()->thread());
|
|
||||||
|
|
||||||
for (auto &channel : this->channelManager.getItems()) {
|
for (auto &channel : this->channelManager.getItems()) {
|
||||||
this->writeConnection->sendRaw("JOIN #" + channel->name);
|
this->writeConnection->sendRaw("JOIN #" + channel->name);
|
||||||
this->readConnection->sendRaw("JOIN #" + channel->name);
|
this->readConnection->sendRaw("JOIN #" + channel->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
this->writeConnection->open();
|
this->writeConnection->open();
|
||||||
this->readConnection->open();
|
this->readConnection->open();
|
||||||
} else {
|
|
||||||
delete _writeConnection;
|
|
||||||
delete _readConnection;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::disconnect()
|
void IrcManager::disconnect()
|
||||||
{
|
{
|
||||||
this->connectionMutex.lock();
|
std::lock_guard<std::mutex> locker(this->connectionMutex);
|
||||||
|
|
||||||
auto _readConnection = this->readConnection;
|
this->readConnection->close();
|
||||||
auto _writeConnection = this->writeConnection;
|
this->writeConnection->close();
|
||||||
|
|
||||||
this->readConnection.reset();
|
|
||||||
this->writeConnection.reset();
|
|
||||||
|
|
||||||
this->connectionMutex.unlock();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::sendMessage(const QString &channelName, const QString &message)
|
void IrcManager::sendMessage(const QString &channelName, const QString &message)
|
||||||
|
@ -272,17 +258,17 @@ void IrcManager::handleRoomStateMessage(Communi::IrcMessage *message)
|
||||||
|
|
||||||
void IrcManager::handleClearChatMessage(Communi::IrcMessage *message)
|
void IrcManager::handleClearChatMessage(Communi::IrcMessage *message)
|
||||||
{
|
{
|
||||||
// do nothing
|
// TODO: Implement
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::handleUserStateMessage(Communi::IrcMessage *message)
|
void IrcManager::handleUserStateMessage(Communi::IrcMessage *message)
|
||||||
{
|
{
|
||||||
// do nothing
|
// TODO: Implement
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::handleWhisperMessage(Communi::IrcMessage *message)
|
void IrcManager::handleWhisperMessage(Communi::IrcMessage *message)
|
||||||
{
|
{
|
||||||
// do nothing
|
// TODO: Implement
|
||||||
}
|
}
|
||||||
|
|
||||||
void IrcManager::handleUserNoticeMessage(Communi::IrcMessage *message)
|
void IrcManager::handleUserNoticeMessage(Communi::IrcMessage *message)
|
||||||
|
@ -300,6 +286,7 @@ void IrcManager::handleModeMessage(Communi::IrcMessage *message)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// XXX: This does not fit in IrcManager
|
||||||
bool IrcManager::isTwitchBlockedUser(QString const &username)
|
bool IrcManager::isTwitchBlockedUser(QString const &username)
|
||||||
{
|
{
|
||||||
QMutexLocker locker(&this->twitchBlockedUsersMutex);
|
QMutexLocker locker(&this->twitchBlockedUsersMutex);
|
||||||
|
@ -309,6 +296,7 @@ bool IrcManager::isTwitchBlockedUser(QString const &username)
|
||||||
return iterator != this->twitchBlockedUsers.end();
|
return iterator != this->twitchBlockedUsers.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// XXX: This does not fit in IrcManager
|
||||||
bool IrcManager::tryAddIgnoredUser(QString const &username, QString &errorMessage)
|
bool IrcManager::tryAddIgnoredUser(QString const &username, QString &errorMessage)
|
||||||
{
|
{
|
||||||
assert(this->account);
|
assert(this->account);
|
||||||
|
@ -332,9 +320,11 @@ bool IrcManager::tryAddIgnoredUser(QString const &username, QString &errorMessag
|
||||||
reply->deleteLater();
|
reply->deleteLater();
|
||||||
|
|
||||||
errorMessage = "Error while ignoring user \"" + username + "\": " + reply->errorString();
|
errorMessage = "Error while ignoring user \"" + username + "\": " + reply->errorString();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// XXX: This does not fit in IrcManager
|
||||||
void IrcManager::addIgnoredUser(QString const &username)
|
void IrcManager::addIgnoredUser(QString const &username)
|
||||||
{
|
{
|
||||||
QString errorMessage;
|
QString errorMessage;
|
||||||
|
@ -343,9 +333,11 @@ void IrcManager::addIgnoredUser(QString const &username)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// XXX: This does not fit in IrcManager
|
||||||
bool IrcManager::tryRemoveIgnoredUser(QString const &username, QString &errorMessage)
|
bool IrcManager::tryRemoveIgnoredUser(QString const &username, QString &errorMessage)
|
||||||
{
|
{
|
||||||
assert(this->account);
|
assert(this->account);
|
||||||
|
|
||||||
QUrl url("https://api.twitch.tv/kraken/users/" + this->account->getUserName() + "/blocks/" +
|
QUrl url("https://api.twitch.tv/kraken/users/" + this->account->getUserName() + "/blocks/" +
|
||||||
username + "?oauth_token=" + this->account->getOAuthToken() +
|
username + "?oauth_token=" + this->account->getOAuthToken() +
|
||||||
"&client_id=" + this->account->getOAuthClient());
|
"&client_id=" + this->account->getOAuthClient());
|
||||||
|
@ -365,9 +357,11 @@ bool IrcManager::tryRemoveIgnoredUser(QString const &username, QString &errorMes
|
||||||
reply->deleteLater();
|
reply->deleteLater();
|
||||||
|
|
||||||
errorMessage = "Error while unignoring user \"" + username + "\": " + reply->errorString();
|
errorMessage = "Error while unignoring user \"" + username + "\": " + reply->errorString();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// XXX: This does not fit in IrcManager
|
||||||
void IrcManager::removeIgnoredUser(QString const &username)
|
void IrcManager::removeIgnoredUser(QString const &username)
|
||||||
{
|
{
|
||||||
QString errorMessage;
|
QString errorMessage;
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include "messages/message.hpp"
|
#include "messages/message.hpp"
|
||||||
#include "twitch/twitchuser.hpp"
|
#include "twitch/twitchuser.hpp"
|
||||||
|
|
||||||
|
#include <ircconnection.h>
|
||||||
#include <IrcMessage>
|
#include <IrcMessage>
|
||||||
#include <QMap>
|
#include <QMap>
|
||||||
#include <QMutex>
|
#include <QMutex>
|
||||||
|
@ -44,7 +45,7 @@ public:
|
||||||
void joinChannel(const QString &channelName);
|
void joinChannel(const QString &channelName);
|
||||||
void partChannel(const QString &channelName);
|
void partChannel(const QString &channelName);
|
||||||
|
|
||||||
void setUser(std::shared_ptr<twitch::TwitchUser> account);
|
void setUser(std::shared_ptr<twitch::TwitchUser> newAccount);
|
||||||
|
|
||||||
pajlada::Signals::Signal<Communi::IrcPrivateMessage *> onPrivateMessage;
|
pajlada::Signals::Signal<Communi::IrcPrivateMessage *> onPrivateMessage;
|
||||||
|
|
||||||
|
@ -57,19 +58,18 @@ private:
|
||||||
// variables
|
// variables
|
||||||
std::shared_ptr<twitch::TwitchUser> account = nullptr;
|
std::shared_ptr<twitch::TwitchUser> account = nullptr;
|
||||||
|
|
||||||
std::shared_ptr<Communi::IrcConnection> writeConnection = nullptr;
|
std::unique_ptr<Communi::IrcConnection> writeConnection = nullptr;
|
||||||
std::shared_ptr<Communi::IrcConnection> readConnection = nullptr;
|
std::unique_ptr<Communi::IrcConnection> readConnection = nullptr;
|
||||||
|
|
||||||
std::mutex connectionMutex;
|
std::mutex connectionMutex;
|
||||||
uint32_t connectionGeneration = 0;
|
|
||||||
|
|
||||||
QMap<QString, bool> twitchBlockedUsers;
|
QMap<QString, bool> twitchBlockedUsers;
|
||||||
QMutex twitchBlockedUsersMutex;
|
QMutex twitchBlockedUsersMutex;
|
||||||
|
|
||||||
QNetworkAccessManager networkAccessManager;
|
QNetworkAccessManager networkAccessManager;
|
||||||
|
|
||||||
// methods
|
void initializeConnection(const std::unique_ptr<Communi::IrcConnection> &connection,
|
||||||
Communi::IrcConnection *createConnection(bool doRead);
|
bool isReadConnection);
|
||||||
|
|
||||||
void refreshIgnoredUsers(const QString &username, const QString &oauthClient,
|
void refreshIgnoredUsers(const QString &username, const QString &oauthClient,
|
||||||
const QString &oauthToken);
|
const QString &oauthToken);
|
||||||
|
|
Loading…
Reference in a new issue