add struct for MODE in hpp and add some of related JOIN error
This commit is contained in:
parent
be594154fc
commit
e74938f481
@ -6,7 +6,7 @@
|
||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* 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 <netinet/in.h> //struct socket
|
||||
#include <sys/epoll.h> //epoll ensemble
|
||||
#include <unistd.h> //close()
|
||||
#include <unistd.h> //close(0)
|
||||
#include <fcntl.h> //fcntl
|
||||
#include <vector>
|
||||
#include <algorithm>
|
||||
@ -39,6 +39,48 @@
|
||||
|
||||
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
|
||||
{
|
||||
bool registered;
|
||||
@ -54,6 +96,9 @@ struct clientData //each client have one
|
||||
|
||||
std::string cmdBuffer;
|
||||
std::vector<channelData *> joinedChan;
|
||||
|
||||
userMode mode;
|
||||
|
||||
int fd;
|
||||
int op;
|
||||
};
|
||||
@ -61,9 +106,16 @@ struct clientData //each client have one
|
||||
struct channelData //each chan have one
|
||||
{
|
||||
std::string name;
|
||||
|
||||
std::vector<clientData *> userList;
|
||||
std::vector<clientData *> banList;
|
||||
int op;
|
||||
std::vector<clientData *> opList;
|
||||
|
||||
chanMode mode;
|
||||
std::string password;
|
||||
int maxUser;
|
||||
//int banMask ???
|
||||
|
||||
int nbrUser;
|
||||
};
|
||||
|
||||
@ -73,15 +125,11 @@ struct fdList //&allFds in code | /!\ only one on the server | REFERENCE ONLY
|
||||
int epollFd;
|
||||
int serverFd;
|
||||
std::vector<int> userList;
|
||||
// std::vector<channelData> channelList;
|
||||
// std::vector<clientData> userData;
|
||||
|
||||
accessList<channelData> channelList;
|
||||
accessList<clientData> userData;
|
||||
|
||||
int alive;
|
||||
// std::map<int, channelData> channelList;
|
||||
// std::map<int, clientData> userData;
|
||||
|
||||
int nbrUser;
|
||||
functionTab parsingTab;
|
||||
|
||||
@ -6,7 +6,7 @@
|
||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* 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>
|
||||
//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)
|
||||
{
|
||||
if (allFds.userData[userNbr].registered == 1)
|
||||
|
||||
@ -6,43 +6,98 @@
|
||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* 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"
|
||||
|
||||
|
||||
// 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)
|
||||
{
|
||||
std::vector<std::string> splitBuff;
|
||||
int chanNbr;
|
||||
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;
|
||||
split(buffer, ' ', splitBuff);
|
||||
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 ;
|
||||
}
|
||||
|
||||
chanNbr = find_channel(allFds, splitBuff[1]);
|
||||
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.channelList[chanNbr].userList.push_back(&allFds.userData[userNbr]);//add user in chan data
|
||||
allFds.channelList[chanNbr].nbrUser++;
|
||||
std::cout << "join2 nickname " << 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;
|
||||
//std::cout << "join2 nickname " << allFds.channelList.back().userList[0]->nickname << std::endl;
|
||||
//std::cout << "join2 fd " << allFds.channelList.back().userList[0]->nickname << std::endl;
|
||||
//message nickname joined the channel?
|
||||
}
|
||||
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.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
|
||||
|
||||
|
||||
// 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";
|
||||
|
||||
//std::cout << "join nickname " << allFds.channelList[0].userList[0]->nickname << std::endl;
|
||||
//std::cout << "join fd " << allFds.channelList[0].userList[0]->fd << std::endl;
|
||||
//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;
|
||||
}
|
||||
@ -6,7 +6,7 @@
|
||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* 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 */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
|
||||
@ -6,7 +6,7 @@
|
||||
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* 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]
|
||||
//JOIN(allFds.userData[userNbr].cmdBuffer, allFds, userNbr);
|
||||
}
|
||||
if (splitBuff[0] != "QUIT")
|
||||
allFds.userData[userNbr].cmdBuffer.clear();
|
||||
}
|
||||
Loading…
Reference in New Issue
Block a user