mirror of
https://github.com/Ladebeze66/ft_irc.git
synced 2025-12-16 05:58:09 +01:00
modifjoinchannel
This commit is contained in:
parent
fb982d0770
commit
b938c46c92
@ -6,7 +6,7 @@
|
|||||||
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/05/15 12:41:35 by fgras-ca #+# #+# */
|
/* Created: 2024/05/15 12:41:35 by fgras-ca #+# #+# */
|
||||||
/* Updated: 2024/05/21 19:26:51 by fgras-ca ### ########.fr */
|
/* Updated: 2024/05/28 11:13:12 by fgras-ca ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -17,6 +17,7 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include <ctime>
|
||||||
|
|
||||||
#include "RPL.hpp"
|
#include "RPL.hpp"
|
||||||
#include "Client.hpp"
|
#include "Client.hpp"
|
||||||
@ -38,13 +39,33 @@ public:
|
|||||||
const std::vector<Client *> &getClients() const;
|
const std::vector<Client *> &getClients() const;
|
||||||
void addOperator(Client *client);
|
void addOperator(Client *client);
|
||||||
bool isOperator(Client *client) const;
|
bool isOperator(Client *client) const;
|
||||||
bool hasClient(Client *client) const; // Ajouté
|
bool hasClient(Client *client) const;
|
||||||
void broadcast(const std::string &message, Client *_client, Server *_server); // Ajouté
|
void broadcast(const std::string &message, Client *_client, Server *_server);
|
||||||
|
|
||||||
|
// Ajouts
|
||||||
|
bool isBanned(Client *client) const;
|
||||||
|
bool isFull() const;
|
||||||
|
bool isInviteOnly() const;
|
||||||
|
bool isInvited(Client *client) const;
|
||||||
|
bool checkKey(const std::string &key) const;
|
||||||
|
const std::string &getTopic() const;
|
||||||
|
const std::string &getTopicSetter() const;
|
||||||
|
time_t getTopicTime() const;
|
||||||
|
void setTopic(const std::string &topic, const std::string &setter);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string _name;
|
std::string _name;
|
||||||
std::vector<Client *> _clients;
|
std::vector<Client *> _clients;
|
||||||
std::vector<Client *> _operators;
|
std::vector<Client *> _operators;
|
||||||
|
std::set<Client *> _bannedClients;
|
||||||
|
std::set<Client *> _invitedClients;
|
||||||
|
std::string _key;
|
||||||
|
std::string _topic;
|
||||||
|
std::string _topicSetter;
|
||||||
|
time_t _topicTime;
|
||||||
|
size_t _clientLimit;
|
||||||
|
bool _inviteOnly;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // CHANNEL_HPP
|
#endif // CHANNEL_HPP
|
||||||
|
|
||||||
|
|||||||
@ -6,28 +6,26 @@
|
|||||||
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/05/21 19:51:08 by fgras-ca #+# #+# */
|
/* Created: 2024/05/21 19:51:08 by fgras-ca #+# #+# */
|
||||||
/* Updated: 2024/05/21 20:13:15 by fgras-ca ### ########.fr */
|
/* Updated: 2024/05/28 11:09:22 by fgras-ca ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#ifndef JOIN_HPP
|
#ifndef JOIN_HPP
|
||||||
#define JOIN_HPP
|
#define JOIN_HPP
|
||||||
|
|
||||||
#include "Server.hpp"
|
#include <string>
|
||||||
#include "Client.hpp"
|
#include "Client.hpp"
|
||||||
|
#include "Server.hpp"
|
||||||
#include "Channel.hpp"
|
#include "Channel.hpp"
|
||||||
#include "RPL.hpp"
|
#include "RPL.hpp"
|
||||||
|
|
||||||
class Server;
|
|
||||||
class Client;
|
|
||||||
class Channel;
|
|
||||||
|
|
||||||
class JoinHandler
|
class JoinHandler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
void handleJoinCommand(Client *client, const std::string &channelName, Server *server);
|
void handleJoinCommand(Client *client, const std::string &channelName, Server *server);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void sendJoinSuccess(Client *client, Channel *channel, Server *server);
|
||||||
std::string getUsersList(Channel *channel);
|
std::string getUsersList(Channel *channel);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@ -6,13 +6,14 @@
|
|||||||
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/05/15 12:42:57 by fgras-ca #+# #+# */
|
/* Created: 2024/05/15 12:42:57 by fgras-ca #+# #+# */
|
||||||
/* Updated: 2024/05/21 19:27:42 by fgras-ca ### ########.fr */
|
/* Updated: 2024/05/28 13:06:02 by fgras-ca ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "Channel.hpp"
|
#include "Channel.hpp"
|
||||||
|
|
||||||
Channel::Channel(const std::string &name) : _name(name) {}
|
Channel::Channel(const std::string &name)
|
||||||
|
: _name(name), _clients(), _operators(), _bannedClients(), _invitedClients(), _key(""), _topic(""), _topicSetter(""), _topicTime(0), _clientLimit(50), _inviteOnly(false) {}
|
||||||
|
|
||||||
Channel::~Channel() {}
|
Channel::~Channel() {}
|
||||||
|
|
||||||
@ -56,14 +57,63 @@ bool Channel::hasClient(Client *client) const
|
|||||||
return std::find(_clients.begin(), _clients.end(), client) != _clients.end();
|
return std::find(_clients.begin(), _clients.end(), client) != _clients.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::broadcast(const std::string &message, Client *_client, Server *server)
|
void Channel::broadcast(const std::string &message, Client *_client, Server *_server)
|
||||||
{
|
{
|
||||||
for (std::vector<Client *>::iterator it = _clients.begin(); it != _clients.end(); ++it)
|
for (std::vector<Client *>::iterator it = _clients.begin(); it != _clients.end(); ++it)
|
||||||
{
|
{
|
||||||
if (*it != _client)
|
if (*it != _client)
|
||||||
{
|
{
|
||||||
// Send message to each client except the sender
|
// Send message to each client except the sender
|
||||||
server->sendToClient((*it)->getFd(), message);
|
_server->sendToClient((*it)->getFd(), message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Channel::isBanned(Client *client) const
|
||||||
|
{
|
||||||
|
return _bannedClients.find(client) != _bannedClients.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Channel::isFull() const
|
||||||
|
{
|
||||||
|
return _clients.size() >= _clientLimit;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Channel::isInviteOnly() const
|
||||||
|
{
|
||||||
|
return _inviteOnly;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Channel::isInvited(Client *client) const
|
||||||
|
{
|
||||||
|
return _invitedClients.find(client) != _invitedClients.end();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Channel::checkKey(const std::string &key) const
|
||||||
|
{
|
||||||
|
return _key.empty() || _key == key;
|
||||||
|
}
|
||||||
|
|
||||||
|
const std::string &Channel::getTopic() const
|
||||||
|
{
|
||||||
|
return _topic;
|
||||||
|
}
|
||||||
|
|
||||||
|
const std::string &Channel::getTopicSetter() const
|
||||||
|
{
|
||||||
|
return _topicSetter;
|
||||||
|
}
|
||||||
|
|
||||||
|
time_t Channel::getTopicTime() const
|
||||||
|
{
|
||||||
|
return _topicTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Channel::setTopic(const std::string &topic, const std::string &setter)
|
||||||
|
{
|
||||||
|
_topic = topic;
|
||||||
|
_topicSetter = setter;
|
||||||
|
_topicTime = std::time(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/05/15 18:26:34 by fgras-ca #+# #+# */
|
/* Created: 2024/05/15 18:26:34 by fgras-ca #+# #+# */
|
||||||
/* Updated: 2024/05/21 20:24:52 by fgras-ca ### ########.fr */
|
/* Updated: 2024/05/28 13:07:17 by fgras-ca ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/05/21 19:51:31 by fgras-ca #+# #+# */
|
/* Created: 2024/05/21 19:51:31 by fgras-ca #+# #+# */
|
||||||
/* Updated: 2024/05/21 20:13:30 by fgras-ca ### ########.fr */
|
/* Updated: 2024/05/28 13:07:53 by fgras-ca ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -14,34 +14,66 @@
|
|||||||
|
|
||||||
void JoinHandler::handleJoinCommand(Client *client, const std::string &channelName, Server *server)
|
void JoinHandler::handleJoinCommand(Client *client, const std::string &channelName, Server *server)
|
||||||
{
|
{
|
||||||
|
if (channelName.empty()) {
|
||||||
|
server->sendToClient(client->getFd(), ERR_NEEDMOREPARAMS(client, "JOIN"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
std::map<std::string, Channel *> &channels = server->getChannels();
|
std::map<std::string, Channel *> &channels = server->getChannels();
|
||||||
Channel *channel;
|
Channel *channel;
|
||||||
if (channels.find(channelName) == channels.end())
|
|
||||||
{
|
if (channels.find(channelName) == channels.end()) {
|
||||||
channel = new Channel(channelName);
|
channel = new Channel(channelName);
|
||||||
channels[channelName] = channel;
|
channels[channelName] = channel;
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
{
|
|
||||||
channel = channels[channelName];
|
channel = channels[channelName];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (channel->isBanned(client)) {
|
||||||
|
server->sendToClient(client->getFd(), ERR_BANNEDFROMCHAN(client, channelName));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (channel->isFull()) {
|
||||||
|
server->sendToClient(client->getFd(), ERR_CHANNELISFULL(client, channelName));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (channel->isInviteOnly() && !channel->isInvited(client)) {
|
||||||
|
server->sendToClient(client->getFd(), ERR_INVITEONLYCHAN(client, channelName));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
channel->addClient(client);
|
channel->addClient(client);
|
||||||
std::string joinMessage = ":" + client->getNickname() + " JOIN " + channelName + "\r\n";
|
sendJoinSuccess(client, channel, server);
|
||||||
|
}
|
||||||
|
|
||||||
|
void JoinHandler::sendJoinSuccess(Client *client, Channel *channel, Server *server)
|
||||||
|
{
|
||||||
|
std::string joinMessage = ":" + client->getNickname() + " JOIN " + channel->getName() + "\r\n";
|
||||||
server->sendToClient(client->getFd(), joinMessage);
|
server->sendToClient(client->getFd(), joinMessage);
|
||||||
|
|
||||||
|
if (!channel->getTopic().empty()) {
|
||||||
|
server->sendToClient(client->getFd(), RPL_TOPIC(client, channel->getName(), channel->getTopic()));
|
||||||
|
server->sendToClient(client->getFd(), RPL_TOPICWHOTIME(client, channel->getName(), channel->getTopicSetter(), channel->getTopicTime()));
|
||||||
|
}
|
||||||
|
|
||||||
std::string usersList = getUsersList(channel);
|
std::string usersList = getUsersList(channel);
|
||||||
server->sendToClient(client->getFd(), usersList);
|
server->sendToClient(client->getFd(), usersList);
|
||||||
|
|
||||||
|
channel->broadcast(joinMessage, client, server);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string JoinHandler::getUsersList(Channel *channel)
|
std::string JoinHandler::getUsersList(Channel *channel)
|
||||||
{
|
{
|
||||||
std::vector<Client *> clients = channel->getClients();
|
std::vector<Client *> clients = channel->getClients();
|
||||||
std::string usersList = ":server 353 " + clients[0]->getNickname() + " = " + channel->getName() + " :";
|
std::string users;
|
||||||
for (std::vector<Client *>::iterator it = clients.begin(); it != clients.end(); ++it)
|
for (std::vector<Client *>::iterator it = clients.begin(); it != clients.end(); ++it) {
|
||||||
{
|
users += (*it)->getNickname() + " ";
|
||||||
usersList += (*it)->getNickname() + " ";
|
|
||||||
}
|
}
|
||||||
usersList += "\r\n:server 366 " + clients[0]->getNickname() + " " + channel->getName() + " :End of /NAMES list.\r\n";
|
|
||||||
return usersList;
|
std::ostringstream oss;
|
||||||
|
oss << RPL_NAMREPLY(clients[0], channel->getName(), users);
|
||||||
|
oss << RPL_ENDOFNAMES(clients[0], channel->getName());
|
||||||
|
return oss.str();
|
||||||
}
|
}
|
||||||
|
|||||||
@ -6,7 +6,7 @@
|
|||||||
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
/* By: fgras-ca <fgras-ca@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2024/05/17 16:09:20 by fgras-ca #+# #+# */
|
/* Created: 2024/05/17 16:09:20 by fgras-ca #+# #+# */
|
||||||
/* Updated: 2024/05/21 18:03:56 by fgras-ca ### ########.fr */
|
/* Updated: 2024/05/28 13:08:30 by fgras-ca ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user