add struct for MODE in hpp and add some of related JOIN error

This commit is contained in:
kinou-p 2023-02-12 17:34:39 +01:00
parent be594154fc
commit e74938f481
5 changed files with 160 additions and 45 deletions

View File

@ -6,7 +6,7 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */ /* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2022/12/01 17:27:37 by apommier #+# #+# */ /* Created: 2022/12/01 17:27:37 by apommier #+# #+# */
/* Updated: 2023/02/12 15:48:37 by apommier ### ########.fr */ /* Updated: 2023/02/12 17:31:11 by apommier ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -19,7 +19,7 @@
#include <iostream> //std::cout | cerr #include <iostream> //std::cout | cerr
#include <netinet/in.h> //struct socket #include <netinet/in.h> //struct socket
#include <sys/epoll.h> //epoll ensemble #include <sys/epoll.h> //epoll ensemble
#include <unistd.h> //close() #include <unistd.h> //close(0)
#include <fcntl.h> //fcntl #include <fcntl.h> //fcntl
#include <vector> #include <vector>
#include <algorithm> #include <algorithm>
@ -39,6 +39,48 @@
struct channelData; struct channelData;
struct chanMode
{
bool o; //- donne/retire les privilèges d'opérateur de canal
bool p; //- drapeau de canal privé
bool s; //- drapeau de canal secret
bool i; //- drapeau de canal accessible uniquement sur invitation
bool t; //- drapeau de sujet de canal modifiable uniquement par les opérateurs
bool n; //- pas de messages dans un canal provenant de clients à l'extérieur du canal
bool m; //- canal modéré
bool l; //- définit le nombre maximal de personnes dans un canal
bool b; //- définit un masque de bannissement pour interdire l'accès à des utilisateurs
bool v; //- donne/retire la possibilité de parler dans un canal modéré
bool k; //- définit la clé du canal (mot de passe)
chanMode()
: o(0),
p(0),
s(0),
i(0),
t(0),
n(0),
m(0),
l(0),
b(0),
v(0),
k(0) {}
};
struct userMode
{
bool i; //- marque un utilisateur comme invisible ;
bool s; //- marque un utilisateur comme recevant les notifications du serveur ;
bool w; //- l'utilisateur reçoit les WALLOPs ;
bool o; //- drapeau d'opérateur.
userMode()
: i(0),
s(0),
w(0),
o(0) {}
};
struct clientData //each client have one struct clientData //each client have one
{ {
bool registered; bool registered;
@ -54,6 +96,9 @@ struct clientData //each client have one
std::string cmdBuffer; std::string cmdBuffer;
std::vector<channelData *> joinedChan; std::vector<channelData *> joinedChan;
userMode mode;
int fd; int fd;
int op; int op;
}; };
@ -61,9 +106,16 @@ struct clientData //each client have one
struct channelData //each chan have one struct channelData //each chan have one
{ {
std::string name; std::string name;
std::vector<clientData *> userList; std::vector<clientData *> userList;
std::vector<clientData *> banList; std::vector<clientData *> banList;
int op; std::vector<clientData *> opList;
chanMode mode;
std::string password;
int maxUser;
//int banMask ???
int nbrUser; int nbrUser;
}; };
@ -73,15 +125,11 @@ struct fdList //&allFds in code | /!\ only one on the server | REFERENCE ONLY
int epollFd; int epollFd;
int serverFd; int serverFd;
std::vector<int> userList; std::vector<int> userList;
// std::vector<channelData> channelList;
// std::vector<clientData> userData;
accessList<channelData> channelList; accessList<channelData> channelList;
accessList<clientData> userData; accessList<clientData> userData;
int alive; int alive;
// std::map<int, channelData> channelList;
// std::map<int, clientData> userData;
int nbrUser; int nbrUser;
functionTab parsingTab; functionTab parsingTab;

View File

@ -6,7 +6,7 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */ /* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/02/06 14:40:39 by apommier #+# #+# */ /* Created: 2023/02/06 14:40:39 by apommier #+# #+# */
/* Updated: 2023/02/12 13:36:30 by apommier ### ########.fr */ /* Updated: 2023/02/12 16:26:48 by apommier ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -16,6 +16,33 @@
//Paramètres: <nom d'utilisateur> <hôte> <nom de serveur> :<nom réel> //Paramètres: <nom d'utilisateur> <hôte> <nom de serveur> :<nom réel>
//ERR_NEEDMOREPARAMS ERR_ALREADYREGISTRED //ERR_NEEDMOREPARAMS ERR_ALREADYREGISTRED
struct modeChan
{
bool o;
bool p;
bool s;
bool i;
bool t;
bool n;
bool m;
bool l;
bool b;
bool v;
bool k;
};
struct modeUser
{
bool i;
bool s;
bool w;
bool o;
};
void USER(std::string buffer, fdList &allFds, int userNbr) void USER(std::string buffer, fdList &allFds, int userNbr)
{ {
if (allFds.userData[userNbr].registered == 1) if (allFds.userData[userNbr].registered == 1)

View File

@ -6,43 +6,98 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */ /* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/02/09 15:40:33 by apommier #+# #+# */ /* Created: 2023/02/09 15:40:33 by apommier #+# #+# */
/* Updated: 2023/02/11 14:55:28 by apommier ### ########.fr */ /* Updated: 2023/02/12 17:33:31 by apommier ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
#include "../../../includes/ft_irc.hpp" #include "../../../includes/ft_irc.hpp"
// Commande: JOIN
// Paramètres: <canal>{,<canal>} [<clé>{,<clé>}]
// 1459
// ERR_NEEDMOREPARAMS + ERR_BANNEDFROMCHAN
// ERR_INVITEONLYCHAN + ERR_BADCHANNELKEY
// ERR_CHANNELISFULL x ERR_BADCHANMASK ?
// ERR_NOSUCHCHANNEL x ERR_TOOMANYCHANNELS x
// RPL_TOPIC
// 2812
// ERR_NEEDMOREPARAMS ERR_BANNEDFROMCHAN
// ERR_INVITEONLYCHAN ERR_BADCHANNELKEY
// ERR_CHANNELISFULL ERR_BADCHANMASK
// ERR_NOSUCHCHANNEL ERR_TOOMANYCHANNELS
// ERR_TOOMANYTARGETS ERR_UNAVAILRESOURCE
// RPL_TOPIC
void leave_all(fdList &allFds, int userNbr)
{
(void)allFds;
(void)userNbr;
}
int chan_check(fdList &allFds, int userNbr, int chanNbr, std::vector<std::string> splitBuff)
{
std::string errorStr;
if (0/*banned*/)
{
errorStr = "474 * JOIN " + allFds.channelList[chanNbr].name + " :Cannot join channel (+b)\n";
cmd_error(allFds, allFds.userData[userNbr].fd, errorStr); //ERR_INVITEONLYCHAN
return (0);
}
if (allFds.channelList[chanNbr].mode.i)
{
errorStr = "461 * JOIN " + allFds.channelList[chanNbr].name + " :Cannot join channel (+i)\n";
cmd_error(allFds, allFds.userData[userNbr].fd, errorStr); //ERR_INVITEONLYCHAN
return (0);
}
if (allFds.channelList[chanNbr].mode.k)
{
if (splitBuff.size() < 3 || allFds.channelList[chanNbr].password != splitBuff[2])
{
errorStr = "475 * JOIN " + allFds.channelList[chanNbr].name + " :Cannot join channel (+k)\n";
cmd_error(allFds, allFds.userData[userNbr].fd, errorStr); //ERR_BADCHANNELKEY
}
return (0);
}
if (allFds.channelList[chanNbr].mode.l && allFds.channelList[chanNbr].nbrUser == allFds.channelList[chanNbr].maxUser)
{
errorStr = "471 * JOIN " + allFds.channelList[chanNbr].name + " :Cannot join channel (+l)\n";
cmd_error(allFds, allFds.userData[userNbr].fd, errorStr); //ERR_CHANNELISFULL
return (0);
}
return (1);
}
void JOIN(std::string buffer, fdList &allFds, int userNbr) void JOIN(std::string buffer, fdList &allFds, int userNbr)
{ {
std::vector<std::string> splitBuff; std::vector<std::string> splitBuff;
int chanNbr; int chanNbr;
std::cout << "==========join start========\n"; std::cout << "==========join start========\n";
if (allFds.channelList.size() == MAX_CHAN)
{
std::cout << "creation of channel refused, maximum number reached" << std::endl; // send msg to user?
return ;
}
std::cout << "userNbr= " << userNbr << std::endl; std::cout << "userNbr= " << userNbr << std::endl;
split(buffer, ' ', splitBuff); split(buffer, ' ', splitBuff);
if (splitBuff.size() < 2) if (splitBuff.size() < 2)
{ {
/*change error*/cmd_error(allFds, allFds.userData[userNbr].fd, "431 * NICK :No nickname given\n"); /*change error*/
cmd_error(allFds, allFds.userData[userNbr].fd, "461 * JOIN :Not enough parameters\n"); //ERR_NEEDMOREPARAMS
return ;
}
if (splitBuff[1] == "0")
{
leave_all(allFds, userNbr);
return ; return ;
} }
chanNbr = find_channel(allFds, splitBuff[1]); chanNbr = find_channel(allFds, splitBuff[1]);
if (chanNbr != -1) //chan already exist if (chanNbr != -1) //chan already exist
{ {
if (!chan_check(allFds, userNbr, chanNbr, splitBuff))
return ;
allFds.userData[userNbr].joinedChan.push_back(&allFds.channelList[chanNbr]); //add chan in user data allFds.userData[userNbr].joinedChan.push_back(&allFds.channelList[chanNbr]); //add chan in user data
allFds.channelList[chanNbr].userList.push_back(&allFds.userData[userNbr]);//add user in chan data allFds.channelList[chanNbr].userList.push_back(&allFds.userData[userNbr]);//add user in chan data
allFds.channelList[chanNbr].nbrUser++; allFds.channelList[chanNbr].nbrUser++;
std::cout << "join2 nickname " << allFds.channelList.back().userList[0]->nickname << std::endl; //std::cout << "join2 nickname " << allFds.channelList.back().userList[0]->nickname << std::endl;
std::cout << "join2 fd " << allFds.channelList.back().userList[0]->nickname << std::endl; //std::cout << "join2 fd " << allFds.channelList.back().userList[0]->nickname << std::endl;
//allFds.channelList.push_back(new_chan);
//std::cout << "nbruser in existent chan / persistence = " << allFds.channelList[chanNbr].nbrUser << std::endl;
//std::cout << "nbruser in existent user / persistence = " << allFds.userData[userNbr].joinedChan[0]->nbrUser << std::endl;
//message nickname joined the channel? //message nickname joined the channel?
} }
else //chan doesn't exist yet else //chan doesn't exist yet
@ -57,24 +112,8 @@ void JOIN(std::string buffer, fdList &allFds, int userNbr)
allFds.channelList.push_back(new_chan); allFds.channelList.push_back(new_chan);
allFds.userData[userNbr].joinedChan.push_back(&allFds.channelList.back());//add chan in user data allFds.userData[userNbr].joinedChan.push_back(&allFds.channelList.back());//add chan in user data
//allFds.channelList.back().userList.push_back(&allFds.userData[userNbr]);//add user in chan data //std::cout << "join nickname " << allFds.channelList[0].userList[0]->nickname << std::endl;
//std::cout << "join fd " << allFds.channelList[0].userList[0]->fd << std::endl;
// allFds.userData[userNbr].joinedChan.push_back(&allFds.channelList[chanNbr]); //add chan in user data
// allFds.channelList[chanNbr].userList.push_back(&allFds.userData[userNbr]);//add user in chan data
// allFds.channelList[chanNbr].nbrUser++;
std::cout << "join nickname " << allFds.channelList[0].userList[0]->nickname << std::endl;
std::cout << "join fd " << allFds.channelList[0].userList[0]->fd << std::endl;
//ft_putstr_fd(allFds.channelList[fd].userList[i]->fd, fullMsg);
//std::cout << "loop here\n";
//message nickname created the channel? //message nickname created the channel?
} }
// std::cout << "============persitence test============\n";
// std::cout << "odlname = " << allFds.userData[userNbr].joinedChan.back()->name << std::endl;
// allFds.channelList.back().name = "new name";
// std::cout << "newname = " << allFds.userData[userNbr].joinedChan.back()->name << std::endl;
// //allFds.channelList;
} }

View File

@ -6,7 +6,7 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */ /* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/02/09 22:04:11 by apommier #+# #+# */ /* Created: 2023/02/09 22:04:11 by apommier #+# #+# */
/* Updated: 2023/02/11 20:06:45 by apommier ### ########.fr */ /* Updated: 2023/02/12 17:30:37 by apommier ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */

View File

@ -6,7 +6,7 @@
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */ /* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2022/12/06 22:01:25 by apommier #+# #+# */ /* Created: 2022/12/06 22:01:25 by apommier #+# #+# */
/* Updated: 2023/02/12 14:21:56 by apommier ### ########.fr */ /* Updated: 2023/02/12 16:19:20 by apommier ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -45,5 +45,6 @@ void parse_commands(std::string buffer, fdList &allFds, int userNbr)
//allFds.parsingTab.cmdPtr[a] //allFds.parsingTab.cmdPtr[a]
//JOIN(allFds.userData[userNbr].cmdBuffer, allFds, userNbr); //JOIN(allFds.userData[userNbr].cmdBuffer, allFds, userNbr);
} }
if (splitBuff[0] != "QUIT")
allFds.userData[userNbr].cmdBuffer.clear(); allFds.userData[userNbr].cmdBuffer.clear();
} }