summaryrefslogtreecommitdiff
path: root/noncore/net/opieirc/ircconnection.cpp
Unidiff
Diffstat (limited to 'noncore/net/opieirc/ircconnection.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opieirc/ircconnection.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/noncore/net/opieirc/ircconnection.cpp b/noncore/net/opieirc/ircconnection.cpp
index 88e63f7..fb7e168 100644
--- a/noncore/net/opieirc/ircconnection.cpp
+++ b/noncore/net/opieirc/ircconnection.cpp
@@ -8,97 +8,98 @@
8 8
9IRCConnection::IRCConnection(IRCServer *server) { 9IRCConnection::IRCConnection(IRCServer *server) {
10 m_server = server; 10 m_server = server;
11 m_socket = new QSocket(this); 11 m_socket = new QSocket(this);
12 m_connected = FALSE; 12 m_connected = FALSE;
13 m_loggedIn = FALSE; 13 m_loggedIn = FALSE;
14 connect(m_socket, SIGNAL(connected()), this, SLOT(login())); 14 connect(m_socket, SIGNAL(connected()), this, SLOT(login()));
15 connect(m_socket, SIGNAL(readyRead()), this, SLOT(dataReady())); 15 connect(m_socket, SIGNAL(readyRead()), this, SLOT(dataReady()));
16 connect(m_socket, SIGNAL(error(int)), this, SLOT(error(int))); 16 connect(m_socket, SIGNAL(error(int)), this, SLOT(error(int)));
17 connect(m_socket, SIGNAL(connectionClosed()), this, SLOT(disconnect())); 17 connect(m_socket, SIGNAL(connectionClosed()), this, SLOT(disconnect()));
18 connect(m_socket, SIGNAL(delayedCloseFinished()), this, SLOT(disconnect())); 18 connect(m_socket, SIGNAL(delayedCloseFinished()), this, SLOT(disconnect()));
19} 19}
20 20
21/* Connect to the IRC server */ 21/* Connect to the IRC server */
22void IRCConnection::doConnect() { 22void IRCConnection::doConnect() {
23 ASSERT(!m_connected); 23 ASSERT(!m_connected);
24 m_socket->connectToHost(m_server->hostname(), m_server->port()); 24 m_socket->connectToHost(m_server->hostname(), m_server->port());
25} 25}
26 26
27/* Send commands to the IRC server */ 27/* Send commands to the IRC server */
28void IRCConnection::sendLine(QString line) { 28void IRCConnection::sendLine(QString line) {
29 while((line.right(1) == "\n") || (line.right(1) == "\r")) 29 while((line.right(1) == "\n") || (line.right(1) == "\r"))
30 line = line.left(line.length() - 1); 30 line = line.left(line.length() - 1);
31 line.append("\r\n"); 31 line.append("\r\n");
32 m_socket->writeBlock(line, line.length()); 32 QCString uline = line.utf8();
33 m_socket->writeBlock(uline, uline.length());
33} 34}
34 35
35void IRCConnection::sendCTCPReply(const QString &nickname, const QString &type, const QString &args) { 36void IRCConnection::sendCTCPReply(const QString &nickname, const QString &type, const QString &args) {
36 sendLine("NOTICE " + nickname + " :\001" + type + " " + args + "\001"); 37 sendLine("NOTICE " + nickname + " :\001" + type + " " + args + "\001");
37} 38}
38 39
39void IRCConnection::sendCTCPRequest(const QString &nickname, const QString &type, const QString &args) { 40void IRCConnection::sendCTCPRequest(const QString &nickname, const QString &type, const QString &args) {
40 sendLine("PRIVMSG " + nickname + " :\001" + type + " " + args + "\001"); 41 sendLine("PRIVMSG " + nickname + " :\001" + type + " " + args + "\001");
41} 42}
42 43
43void IRCConnection::sendCTCPPing(const QString &nickname) { 44void IRCConnection::sendCTCPPing(const QString &nickname) {
44 QDateTime tm; 45 QDateTime tm;
45 tm.setTime_t(0); 46 tm.setTime_t(0);
46 QString strtime = QString::number(tm.secsTo(QDateTime::currentDateTime())); 47 QString strtime = QString::number(tm.secsTo(QDateTime::currentDateTime()));
47 sendCTCPRequest(nickname, "PING", strtime); 48 sendCTCPRequest(nickname, "PING", strtime);
48} 49}
49 50
50void IRCConnection::whois(const QString &nickname) { 51void IRCConnection::whois(const QString &nickname) {
51 sendLine("WHOIS " + nickname); 52 sendLine("WHOIS " + nickname);
52} 53}
53 54
54/* 55/*
55 * login() is called right after the connection 56 * login() is called right after the connection
56 * to the IRC server has been established 57 * to the IRC server has been established
57 */ 58 */
58void IRCConnection::login() { 59void IRCConnection::login() {
59 char hostname[256]; 60 char hostname[256];
60 QString loginString; 61 QString loginString;
61 62
62 emit outputReady(IRCOutput(OUTPUT_CLIENTMESSAGE, tr("Connected, logging in .."))); 63 emit outputReady(IRCOutput(OUTPUT_CLIENTMESSAGE, tr("Connected, logging in ..")));
63 m_connected = TRUE; 64 m_connected = TRUE;
64 gethostname(hostname, sizeof(hostname)-1); 65 gethostname(hostname, sizeof(hostname)-1);
65 hostname[sizeof (hostname) - 1] = 0; 66 hostname[sizeof (hostname) - 1] = 0;
66 67
67 /* Create a logon string and send it */ 68 /* Create a logon string and send it */
68 if (m_server->password().length()>0) { 69 if (m_server->password().length()>0) {
69 loginString += "PASS " + m_server->password() + "\r\n"; 70 loginString += "PASS " + m_server->password() + "\r\n";
70 } 71 }
71 loginString += "NICK " + m_server->nick() + "\r\n" + 72 loginString += "NICK " + m_server->nick() + "\r\n" +
72 "USER " + m_server->username() + " " + hostname + 73 "USER " + m_server->username() + " " + hostname +
73 " " + m_server->hostname() + " :" + m_server->realname() + "\r\n"; 74 " " + m_server->hostname() + " :" + m_server->realname() + "\r\n";
74 sendLine(loginString); 75 sendLine(loginString);
75} 76}
76 77
77/* Called when data arrives on the socket */ 78/* Called when data arrives on the socket */
78void IRCConnection::dataReady() { 79void IRCConnection::dataReady() {
79 while(m_socket->canReadLine()) { 80 while(m_socket->canReadLine()) {
80 IRCMessage message(m_socket->readLine()); 81 IRCMessage message(QString::fromUtf8(m_socket->readLine()));
81 if (!m_loggedIn && message.isNumerical() && message.commandNumber() == 1) { 82 if (!m_loggedIn && message.isNumerical() && message.commandNumber() == 1) {
82 /* Now autojoin all channels specified inside the server profile */ 83 /* Now autojoin all channels specified inside the server profile */
83 QStringList channels = QStringList::split(QChar(','), m_server->channels()); 84 QStringList channels = QStringList::split(QChar(','), m_server->channels());
84 for (QStringList::Iterator it = channels.begin(); it != channels.end(); ++it) { 85 for (QStringList::Iterator it = channels.begin(); it != channels.end(); ++it) {
85 QString channelName = (*it).stripWhiteSpace(); 86 QString channelName = (*it).stripWhiteSpace();
86 if (channelName.startsWith("#") || channelName.startsWith("+")) { 87 if (channelName.startsWith("#") || channelName.startsWith("+")) {
87 sendLine("JOIN "+ channelName); 88 sendLine("JOIN "+ channelName);
88 } 89 }
89 } 90 }
90 m_loggedIn = TRUE; 91 m_loggedIn = TRUE;
91 emit outputReady(IRCOutput(OUTPUT_CLIENTMESSAGE, tr("Successfully logged in."))); 92 emit outputReady(IRCOutput(OUTPUT_CLIENTMESSAGE, tr("Successfully logged in.")));
92 } 93 }
93 emit messageArrived(&message); 94 emit messageArrived(&message);
94 } 95 }
95} 96}
96 97
97/* Called if any type of socket error occurs */ 98/* Called if any type of socket error occurs */
98void IRCConnection::error(int num) { 99void IRCConnection::error(int num) {
99 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Socket error : ") + strerror(num))); 100 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Socket error : ") + strerror(num)));
100} 101}
101 102
102void IRCConnection::disconnect() { 103void IRCConnection::disconnect() {
103 m_connected = FALSE; 104 m_connected = FALSE;
104 m_loggedIn = FALSE; 105 m_loggedIn = FALSE;