bouffon
This commit is contained in:
1
.gitignore
vendored
1
.gitignore
vendored
@@ -21,3 +21,4 @@ ircserv
|
|||||||
.vscode/
|
.vscode/
|
||||||
objs_bonus/
|
objs_bonus/
|
||||||
greg
|
greg
|
||||||
|
ft_irc-tester/
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
/* */
|
/* */
|
||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* Bot.hpp :+: :+: :+: */
|
/* bot.hpp :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/01/30 01:54:36 by vvaas #+# #+# */
|
/* Created: 2024/01/30 01:54:36 by vvaas #+# #+# */
|
||||||
/* Updated: 2024/01/30 02:39:52 by vvaas ### ########.fr */
|
/* Updated: 2024/01/30 16:56:57 by vvaas ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
@@ -24,6 +24,7 @@ class bot
|
|||||||
bot();
|
bot();
|
||||||
void init(void);
|
void init(void);
|
||||||
void connect_to_server(void);
|
void connect_to_server(void);
|
||||||
|
void handle_response(std::string buffer);
|
||||||
~bot();
|
~bot();
|
||||||
private :
|
private :
|
||||||
struct sockaddr_in _serv_addr;
|
struct sockaddr_in _serv_addr;
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/01/21 10:33:17 by maldavid #+# #+# */
|
/* Created: 2024/01/21 10:33:17 by maldavid #+# #+# */
|
||||||
/* Updated: 2024/01/30 01:45:23 by vvaas ### ########.fr */
|
/* Updated: 2024/01/30 17:06:21 by vvaas ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
@@ -17,6 +17,7 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <errorscode.hpp>
|
#include <errorscode.hpp>
|
||||||
|
#include <logs.hpp>
|
||||||
|
|
||||||
namespace irc
|
namespace irc
|
||||||
{
|
{
|
||||||
@@ -40,7 +41,7 @@ namespace irc
|
|||||||
|
|
||||||
inline void login() { _logged = true; }
|
inline void login() { _logged = true; }
|
||||||
inline void register_user() { _registered = true; }
|
inline void register_user() { _registered = true; }
|
||||||
inline void welcome() { if (isLogged() && !isWelcomed()) return ; _welcomed = true; sendCode(RPL_WELCOME, "Welcome to yipirc :), " + _nickname); }
|
inline void welcome() { if (!isLogged() || isWelcomed() || _nickname.empty()) return ; _welcomed = true; sendCode(RPL_WELCOME, "Welcome to yipirc :), " + _nickname); }
|
||||||
inline void requireDisconnect() { _disconnect_required = true; }
|
inline void requireDisconnect() { _disconnect_required = true; }
|
||||||
|
|
||||||
inline bool isLogged() const { return _logged; }
|
inline bool isLogged() const { return _logged; }
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
/* ************************************************************************** */
|
/******************************************************************************/
|
||||||
/* */
|
/* */
|
||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* logs.cpp :+: :+: :+: */
|
/* logs.cpp :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: maldavid <kbz_8.dev@akel-engine.com> +#+ +:+ +#+ */
|
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/01/21 09:17:47 by maldavid #+# #+# */
|
/* Created: 2024/01/21 09:17:47 by maldavid #+# #+# */
|
||||||
/* Updated: 2024/01/30 00:38:44 by maldavid ### ########.fr */
|
/* Updated: 2024/01/30 17:07:07 by vvaas ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/******************************************************************************/
|
||||||
|
|
||||||
#include <logs.hpp>
|
#include <logs.hpp>
|
||||||
#include <ansi.hpp>
|
#include <ansi.hpp>
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/01/21 09:31:17 by maldavid #+# #+# */
|
/* Created: 2024/01/21 09:31:17 by maldavid #+# #+# */
|
||||||
/* Updated: 2024/01/30 02:41:02 by vvaas ### ########.fr */
|
/* Updated: 2024/01/30 17:15:03 by vvaas ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
@@ -40,7 +40,7 @@ namespace irc
|
|||||||
_s_data.sin_addr.s_addr = INADDR_ANY;
|
_s_data.sin_addr.s_addr = INADDR_ANY;
|
||||||
_s_data.sin_port = htons(_port);
|
_s_data.sin_port = htons(_port);
|
||||||
_main_socket = socket(AF_INET, SOCK_STREAM, 0); // AF_INET == IPv4, SOCK_STREAM == TCP
|
_main_socket = socket(AF_INET, SOCK_STREAM, 0); // AF_INET == IPv4, SOCK_STREAM == TCP
|
||||||
if(_main_socket < 0)
|
if (_main_socket < 0)
|
||||||
logs::report(log_fatal_error, "socket error");
|
logs::report(log_fatal_error, "socket error");
|
||||||
logs::report(log_message, "socket succesfully started");
|
logs::report(log_message, "socket succesfully started");
|
||||||
}
|
}
|
||||||
@@ -50,14 +50,14 @@ namespace irc
|
|||||||
int opt = 1;
|
int opt = 1;
|
||||||
|
|
||||||
initSocketData();
|
initSocketData();
|
||||||
if(setsockopt(_main_socket, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt)) < 0) // SOL_SOCKET : modify socket only, SO_REUSEADDR : Reusable after program ends
|
if (setsockopt(_main_socket, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt)) < 0) // SOL_SOCKET : modify socket only, SO_REUSEADDR : Reusable after program ends
|
||||||
logs::report(log_fatal_error, "setsockopt() error (tout a pete)");
|
logs::report(log_fatal_error, "setsockopt() error (tout a pete)");
|
||||||
|
|
||||||
if(bind(_main_socket, reinterpret_cast<sockaddr*>(&_s_data), sizeof(_s_data)) != 0) // Bind _main_socket to localhost
|
if (bind(_main_socket, reinterpret_cast<sockaddr*>(&_s_data), sizeof(_s_data)) != 0) // Bind _main_socket to localhost
|
||||||
logs::report(log_fatal_error, "bind error");
|
logs::report(log_fatal_error, "bind error");
|
||||||
logs::report(log_message, "bind successful, starting listen loop");
|
logs::report(log_message, "bind successful, starting listen loop");
|
||||||
|
|
||||||
if(listen(_main_socket, MAX_USERS) != 0) // init the listen with MAX_USERS
|
if (listen(_main_socket, MAX_USERS) != 0) // init the listen with MAX_USERS
|
||||||
logs::report(log_fatal_error, "listen error");
|
logs::report(log_fatal_error, "listen error");
|
||||||
logs::report(log_message, "listen queue created successfully");
|
logs::report(log_message, "listen queue created successfully");
|
||||||
|
|
||||||
@@ -68,27 +68,27 @@ namespace irc
|
|||||||
{
|
{
|
||||||
char buffer[INPUT_SIZE] = { 0 };
|
char buffer[INPUT_SIZE] = { 0 };
|
||||||
ssize_t recv_size;
|
ssize_t recv_size;
|
||||||
for(std::vector<unstd::SharedPtr<Client> >::iterator it = _client.begin(); it != _client.end(); ++it)
|
for (std::vector<unstd::SharedPtr<Client> >::iterator it = _client.begin(); it != _client.end(); ++it)
|
||||||
{
|
{
|
||||||
if(!FD_ISSET((*it)->getFD(), &_fd_set))
|
if (!FD_ISSET((*it)->getFD(), &_fd_set))
|
||||||
continue;
|
continue;
|
||||||
while((recv_size = recv((*it)->getFD(), buffer, INPUT_SIZE, 0)) > 0) // read() but for socket fd
|
while ((recv_size = recv((*it)->getFD(), buffer, INPUT_SIZE, 0)) > 0) // read() but for socket fd
|
||||||
{
|
{
|
||||||
(*it)->newMsgInFlight(buffer);
|
(*it)->newMsgInFlight(buffer);
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
logs::report(log_message,"processing '%s'", buffer);
|
logs::report(log_message,"processing '%s'", buffer);
|
||||||
#endif
|
#endif
|
||||||
while(handleMessage(*it));
|
while (handleMessage(*it));
|
||||||
std::memset(buffer, 0, sizeof(buffer)); // clear the buffer to avoid trash remaining
|
std::memset(buffer, 0, sizeof(buffer)); // clear the buffer to avoid trash remaining
|
||||||
}
|
}
|
||||||
if(recv_size == 0 || (*it)->disconnectRequired()) // recv return 0 if an user disconnect
|
if (recv_size == 0 || (*it)->disconnectRequired()) // recv return 0 if an user disconnect
|
||||||
{
|
{
|
||||||
logs::report(log_message, "User %d disconnected", (*it)->getID());
|
logs::report(log_message, "User %d disconnected", (*it)->getID());
|
||||||
close((*it)->getFD());
|
close((*it)->getFD());
|
||||||
for(channel_it cit = _channels.begin(); cit != _channels.end();)
|
for (channel_it cit = _channels.begin(); cit != _channels.end();)
|
||||||
{
|
{
|
||||||
cit->removeClient(*it);
|
cit->removeClient(*it);
|
||||||
if(cit->getNumberOfClients() == 0)
|
if (cit->getNumberOfClients() == 0)
|
||||||
{
|
{
|
||||||
logs::report(log_message, "channel '%s' has been destroyed", cit->getName().c_str());
|
logs::report(log_message, "channel '%s' has been destroyed", cit->getName().c_str());
|
||||||
cit = _channels.erase(cit);
|
cit = _channels.erase(cit);
|
||||||
@@ -113,20 +113,20 @@ namespace irc
|
|||||||
FD_ZERO(&_fd_set);
|
FD_ZERO(&_fd_set);
|
||||||
FD_SET(_main_socket, &_fd_set);
|
FD_SET(_main_socket, &_fd_set);
|
||||||
|
|
||||||
for(std::vector<unstd::SharedPtr<Client> >::iterator it = _client.begin(); it != _client.end(); ++it)
|
for (std::vector<unstd::SharedPtr<Client> >::iterator it = _client.begin(); it != _client.end(); ++it)
|
||||||
FD_SET((*it)->getFD(), &_fd_set);
|
FD_SET((*it)->getFD(), &_fd_set);
|
||||||
|
|
||||||
tmp = select(MAX_USERS, &_fd_set, NULL, NULL, NULL); // SELECT blocks till a connection or message is received, and let only those in _fd_set
|
tmp = select(MAX_USERS, &_fd_set, NULL, NULL, NULL); // SELECT blocks till a connection or message is received, and let only those in _fd_set
|
||||||
if(tmp < 0 && _main_socket != NULL_SOCKET)
|
if (tmp < 0 && _main_socket != NULL_SOCKET)
|
||||||
logs::report(log_fatal_error, "select fd error");
|
logs::report(log_fatal_error, "select fd error");
|
||||||
|
|
||||||
if(FD_ISSET(_main_socket, &_fd_set)) // if it's a new connection
|
if (FD_ISSET(_main_socket, &_fd_set)) // if it's a new connection
|
||||||
{
|
{
|
||||||
sockaddr_in cli_sock;
|
sockaddr_in cli_sock;
|
||||||
fd = accept(_main_socket, reinterpret_cast<sockaddr*>(&cli_sock), &len); // adds the new connection
|
fd = accept(_main_socket, reinterpret_cast<sockaddr*>(&cli_sock), &len); // adds the new connection
|
||||||
if(fd < 0)
|
if (fd < 0)
|
||||||
logs::report(log_fatal_error, "accept() error");
|
logs::report(log_fatal_error, "accept() error");
|
||||||
if(fcntl(fd, F_SETFL, O_NONBLOCK) < 0)
|
if (fcntl(fd, F_SETFL, O_NONBLOCK) < 0)
|
||||||
logs::report(log_fatal_error, "fcntl() error");
|
logs::report(log_fatal_error, "fcntl() error");
|
||||||
|
|
||||||
unstd::SharedPtr<Client> new_client(new Client(fd, cli_sock, i++));
|
unstd::SharedPtr<Client> new_client(new Client(fd, cli_sock, i++));
|
||||||
@@ -140,50 +140,50 @@ namespace irc
|
|||||||
|
|
||||||
bool Server::handleMessage(unstd::SharedPtr<Client> client)
|
bool Server::handleMessage(unstd::SharedPtr<Client> client)
|
||||||
{
|
{
|
||||||
if(client->getMsgInFlight().empty()) // if there are no commands just return
|
if (client->getMsgInFlight().empty()) // if there are no commands just return
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
const Message msg(client, client->getNextMsg());
|
const Message msg(client, client->getNextMsg());
|
||||||
if(msg.getCmd() == "NICK")
|
if (msg.getCmd() == "NICK")
|
||||||
handleNick(client, msg);
|
handleNick(client, msg);
|
||||||
else if(msg.getCmd() == "USER")
|
else if (msg.getCmd() == "USER")
|
||||||
handleUser(client, msg);
|
handleUser(client, msg);
|
||||||
else if (msg.getCmd() == "PASS")
|
else if (msg.getCmd() == "PASS")
|
||||||
handlePass(client, msg);
|
handlePass(client, msg);
|
||||||
else if(!client->isLogged())
|
else if (!client->isLogged())
|
||||||
return true;
|
return true;
|
||||||
else if(msg.getCmd() == "QUIT")
|
else if (msg.getCmd() == "QUIT")
|
||||||
handleQuit(client, msg);
|
handleQuit(client, msg);
|
||||||
else if(msg.getCmd() == "WHO")
|
else if (msg.getCmd() == "WHO")
|
||||||
handleWho(client, msg);
|
handleWho(client, msg);
|
||||||
else if(msg.getCmd() == "PART")
|
else if (msg.getCmd() == "PART")
|
||||||
handlePart(client, msg);
|
handlePart(client, msg);
|
||||||
else if(msg.getCmd() == "JOIN")
|
else if (msg.getCmd() == "JOIN")
|
||||||
handleJoin(client, msg);
|
handleJoin(client, msg);
|
||||||
else if(msg.getCmd() == "INVITE")
|
else if (msg.getCmd() == "INVITE")
|
||||||
handleInvite(client, msg);
|
handleInvite(client, msg);
|
||||||
else if(msg.getCmd() == "PRIVMSG")
|
else if (msg.getCmd() == "PRIVMSG")
|
||||||
handlePrivMsg(client, msg);
|
handlePrivMsg(client, msg);
|
||||||
else if(msg.getCmd() == "NOTICE")
|
else if (msg.getCmd() == "NOTICE")
|
||||||
handleNotice(client, msg);
|
handleNotice(client, msg);
|
||||||
else if(msg.getCmd() == "KICK")
|
else if (msg.getCmd() == "KICK")
|
||||||
handleKick(client, msg);
|
handleKick(client, msg);
|
||||||
else if(msg.getCmd() == "TOPIC")
|
else if (msg.getCmd() == "TOPIC")
|
||||||
handleTopic(client, msg);
|
handleTopic(client, msg);
|
||||||
else if(msg.getCmd() == "PING")
|
else if (msg.getCmd() == "PING")
|
||||||
handlePing(client, msg);
|
handlePing(client, msg);
|
||||||
else if(msg.getCmd() == "MODE")
|
else if (msg.getCmd() == "MODE")
|
||||||
handleMode(client, msg);
|
handleMode(client, msg);
|
||||||
else if(msg.getCmd() == "imfeelinglucky")
|
else if (msg.getCmd() == "imfeelinglucky")
|
||||||
handleRussian(client);
|
handleRussian(client);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Server::isUserKnown(const std::string& user) const
|
bool Server::isUserKnown(const std::string& user) const
|
||||||
{
|
{
|
||||||
for(client_const_it it = _client.begin(); it < _client.end(); ++it)
|
for (client_const_it it = _client.begin(); it < _client.end(); ++it)
|
||||||
{
|
{
|
||||||
if(const_cast<unstd::SharedPtr<Client>&>(*it)->getNickName() == user)
|
if (const_cast<unstd::SharedPtr<Client>&>(*it)->getNickName() == user)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@@ -191,9 +191,9 @@ namespace irc
|
|||||||
|
|
||||||
bool Server::isChannelKnown(const std::string& channel) const
|
bool Server::isChannelKnown(const std::string& channel) const
|
||||||
{
|
{
|
||||||
for(channel_const_it it = _channels.begin(); it < _channels.end(); ++it)
|
for (channel_const_it it = _channels.begin(); it < _channels.end(); ++it)
|
||||||
{
|
{
|
||||||
if(it->getName() == channel)
|
if (it->getName() == channel)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@@ -201,9 +201,9 @@ namespace irc
|
|||||||
|
|
||||||
Channel* Server::getChannelByName(const std::string& name)
|
Channel* Server::getChannelByName(const std::string& name)
|
||||||
{
|
{
|
||||||
for(channel_it it = _channels.begin(); it < _channels.end(); ++it)
|
for (channel_it it = _channels.begin(); it < _channels.end(); ++it)
|
||||||
{
|
{
|
||||||
if(it->getName() == name)
|
if (it->getName() == name)
|
||||||
return &*it;
|
return &*it;
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
@@ -211,9 +211,9 @@ namespace irc
|
|||||||
|
|
||||||
unstd::SharedPtr<Client> Server::getClientByName(const std::string& name)
|
unstd::SharedPtr<Client> Server::getClientByName(const std::string& name)
|
||||||
{
|
{
|
||||||
for(client_it it = _client.begin(); it < _client.end(); ++it)
|
for (client_it it = _client.begin(); it < _client.end(); ++it)
|
||||||
{
|
{
|
||||||
if((*it)->getNickName() == name)
|
if ((*it)->getNickName() == name)
|
||||||
return *it;
|
return *it;
|
||||||
}
|
}
|
||||||
return unstd::SharedPtr<Client>(NULL);
|
return unstd::SharedPtr<Client>(NULL);
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/01/22 17:31:06 by maldavid #+# #+# */
|
/* Created: 2024/01/22 17:31:06 by maldavid #+# #+# */
|
||||||
/* Updated: 2024/01/30 02:32:17 by vvaas ### ########.fr */
|
/* Updated: 2024/01/30 16:59:42 by vvaas ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
@@ -62,7 +62,6 @@ namespace irc
|
|||||||
client->setNewNickName(msg.getTokens()[1]);
|
client->setNewNickName(msg.getTokens()[1]);
|
||||||
for (client_it it = _client.begin(); it != _client.end(); ++it)
|
for (client_it it = _client.begin(); it != _client.end(); ++it)
|
||||||
(*it)->sendMsg(oldNick, "NICK", msg.getTokens()[1]);
|
(*it)->sendMsg(oldNick, "NICK", msg.getTokens()[1]);
|
||||||
std::string welcome_msg = "Welcome to yipirc :), " + client->getNickName();
|
|
||||||
client->welcome();
|
client->welcome();
|
||||||
std::cout << "new nickname, " << client->getNickName() << std::endl;
|
std::cout << "new nickname, " << client->getNickName() << std::endl;
|
||||||
}
|
}
|
||||||
@@ -103,7 +102,6 @@ namespace irc
|
|||||||
|
|
||||||
void Server::handlePass(unstd::SharedPtr<class Client> client, const Message& msg)
|
void Server::handlePass(unstd::SharedPtr<class Client> client, const Message& msg)
|
||||||
{
|
{
|
||||||
std::string welcome_msg = "Welcome to yipirc :), " + client->getNickName();
|
|
||||||
if(client->isLogged())
|
if(client->isLogged())
|
||||||
return;
|
return;
|
||||||
if(msg.getTokens()[1] == _password)
|
if(msg.getTokens()[1] == _password)
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
/* By: vvaas <vvaas@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/01/30 01:54:56 by vvaas #+# #+# */
|
/* Created: 2024/01/30 01:54:56 by vvaas #+# #+# */
|
||||||
/* Updated: 2024/01/30 02:41:49 by vvaas ### ########.fr */
|
/* Updated: 2024/01/30 17:07:02 by vvaas ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
|
|
||||||
@@ -14,7 +14,9 @@
|
|||||||
#include <logs.hpp>
|
#include <logs.hpp>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <errno.h>
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
bot::bot() {}
|
bot::bot() {}
|
||||||
|
|
||||||
@@ -33,6 +35,14 @@ void bot::init()
|
|||||||
_serv_addr.sin_addr.s_addr = inet_addr(IP);
|
_serv_addr.sin_addr.s_addr = inet_addr(IP);
|
||||||
if (connect(_fd, (struct sockaddr*)&_serv_addr, sizeof(_serv_addr)) < 0)
|
if (connect(_fd, (struct sockaddr*)&_serv_addr, sizeof(_serv_addr)) < 0)
|
||||||
irc::logs::report(irc::log_fatal_error, "connect error");
|
irc::logs::report(irc::log_fatal_error, "connect error");
|
||||||
|
if(fcntl(_fd, F_SETFL, O_NONBLOCK) < 0)
|
||||||
|
irc::logs::report(irc::log_fatal_error, "fcntl() error");
|
||||||
|
}
|
||||||
|
|
||||||
|
void bot::handle_response(std::string buffer)
|
||||||
|
{
|
||||||
|
if (buffer == ":yipirc 001 greg :Welcome to yipirc :), greg\r\n")
|
||||||
|
return ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void bot::connect_to_server()
|
void bot::connect_to_server()
|
||||||
@@ -45,7 +55,8 @@ void bot::connect_to_server()
|
|||||||
}
|
}
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
while (recv(_fd, buffer, 1024, 0) < 0)
|
if (recv(_fd, buffer, 1024, 0) > 0)
|
||||||
std::cout << buffer << std::endl;
|
handle_response(buffer);
|
||||||
|
std::memset(buffer, 0, sizeof(buffer));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user