message error

This commit is contained in:
PrStein 2023-03-10 21:55:31 +01:00
parent 4517fa302f
commit 6502a5f303

View File

@ -3,10 +3,10 @@
/* ::: :::::::: */ /* ::: :::::::: */
/* mode.cpp :+: :+: :+: */ /* mode.cpp :+: :+: :+: */
/* +:+ +:+ +:+ */ /* +:+ +:+ +:+ */
/* By: apommier <apommier@student.42.fr> +#+ +:+ +#+ */ /* By: sadjigui <sadjigui@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/02/11 19:19:30 by apommier #+# #+# */ /* Created: 2023/02/11 19:19:30 by apommier #+# #+# */
/* Updated: 2023/03/09 05:44:57 by apommier ### ########.fr */ /* Updated: 2023/03/10 21:50:12 by sadjigui ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -27,6 +27,7 @@ void chan_opt_o(fdList &allFds, int userNbr, std::vector<std::string> opt, int c
if ((find_user(allFds, opt[3]) == -1)) if ((find_user(allFds, opt[3]) == -1))
{ {
std::cout << "User :" << opt[3] << " not found" << std::endl; std::cout << "User :" << opt[3] << " not found" << std::endl;
cmd_error(allFds, allFds.userData[userNbr].fd, "401 *" + opt[1] + " :No such nick/channel\n");
return ; return ;
} }
@ -65,7 +66,7 @@ void chan_opt_v(fdList &allFds, int userNbr, std::vector<std::string> opt, int c
int target = find_user(allFds, opt[3]); int target = find_user(allFds, opt[3]);
if (target == -1) if (target == -1)
{ {
std::cout << "no user found " << std::endl; cmd_error(allFds, allFds.userData[userNbr].fd, "401 *" + opt[3] + " :No such nick/channel\n");
return ; return ;
} }
@ -93,10 +94,12 @@ void chan_opt_b(fdList &allFds, int userNbr, std::vector<std::string> opt, int c
std::cout << "Nobody was banned on this channel" << std::endl; std::cout << "Nobody was banned on this channel" << std::endl;
return ; return ;
} }
for (long unsigned int i = 0; i < ban.size(); ++i) for (long unsigned int i = 0; i < ban.size(); i++)
{ {
std::cout << ban[i]->userName << std::endl; std::cout << ban[i]->nickname << std::endl;
} }
ban_reply(allFds.channelList[chanNbr], allFds.userData[userNbr]);
} }
if (opt.size() >= 4) if (opt.size() >= 4)
{ {
@ -130,6 +133,11 @@ void do_chan_opt(fdList &allFds, int userNbr, std::vector<std::string> opt, int
(void)allFds; (void)allFds;
(void)userNbr; (void)userNbr;
bool sign = true; bool sign = true;
// if (allFds.userData[userNbr].mode.o == false)
// {
// return ;
// }
if (opt[2][0] == '-') if (opt[2][0] == '-')
sign = false; sign = false;
for (int i = 1; opt[2][i]; i++) for (int i = 1; opt[2][i]; i++)
@ -178,19 +186,16 @@ void do_user_opt(fdList &allFds, int userNbr, std::vector<std::string> opt, int
(void)new_target; (void)new_target;
//char opts[4] = {'i', 's', 'w', 'o'}; //char opts[4] = {'i', 's', 'w', 'o'};
bool sign = true; bool sign = true;
if (opt[2][0] == '-')
sign = false;
if (allFds.userData[userNbr].nickname != opt[1]) if (allFds.userData[userNbr].nickname != opt[1])
{ {
std::cout << "not the same user ! don't try to change someone else MODE you stupid bitch\n"; std::cout << "not the same user ! don't try to change someone else MODE you stupid bitch\n";
//cmd_error(allFds, allFds.userData[userNbr].fd, "401 *" + opt[1] + " :No such nick/channel\n"); cmd_error(allFds, allFds.userData[userNbr].fd, "502 *" + opt[1] + " :Cant change mode for other users\n");
return ; return ;
} }
if (opt[2][0] == '-')
sign = false;
for (int i = 1; opt[2][i]; i++) for (int i = 1; opt[2][i]; i++)
{ {
//int j = 0;
//while (opts[j] && opts[j] != opt[2][i])
// j++;
switch(opt[2][i]) switch(opt[2][i])
{ {
case 'i': allFds.userData[new_target].mode.i = (sign = true) ? true : false; case 'i': allFds.userData[new_target].mode.i = (sign = true) ? true : false;
@ -200,9 +205,11 @@ void do_user_opt(fdList &allFds, int userNbr, std::vector<std::string> opt, int
case 'w': allFds.userData[new_target].mode.w = (sign = true) ? true : false; case 'w': allFds.userData[new_target].mode.w = (sign = true) ? true : false;
break ; break ;
case 'o': case 'o':
if (sign == true)
return ;
if (allFds.userData[userNbr].mode.o == false) if (allFds.userData[userNbr].mode.o == false)
{ {
cmd_error(allFds, allFds.userData[userNbr].fd, "482 *" + opt[1] + " :You're not channel\n"); cmd_error(allFds, allFds.userData[userNbr].fd, "482 *" + opt[1] + " :You're not channel operator\n");
return ; return ;
} }
allFds.userData[new_target].mode.o = (sign = true) ? true : false; allFds.userData[new_target].mode.o = (sign = true) ? true : false;
@ -222,7 +229,7 @@ void MODE(std::string buffer, fdList &allFds, int userNbr)
split(buffer, ' ', splitBuff); split(buffer, ' ', splitBuff);
if (splitBuff.size() < 3) if (splitBuff.size() < 3)
{ {
std::cout << "ERR_NEEDMOREPARAMS" << std::endl; cmd_error(allFds, allFds.userData[userNbr].fd, "461 *" + splitBuff[0] + " :Not enough parameters\n");
return ; return ;
} }
if (splitBuff[1][0] == '#' || splitBuff[1][0] == '&') //splitbuff[1] always equal to <channel> or <nickname> if (splitBuff[1][0] == '#' || splitBuff[1][0] == '&') //splitbuff[1] always equal to <channel> or <nickname>
@ -230,22 +237,22 @@ void MODE(std::string buffer, fdList &allFds, int userNbr)
if ((pos = find_channel(allFds, splitBuff[1])) == -1) //if true chan doesn't exist if ((pos = find_channel(allFds, splitBuff[1])) == -1) //if true chan doesn't exist
{ {
std::cout << splitBuff[1] << ": No such channel" << std::endl; std::cout << splitBuff[1] << ": No such channel" << std::endl;
// 403 ERR_NOSUCHCHANNEL cmd_error(allFds, allFds.userData[userNbr].fd, "403 *" + splitBuff[1] + " :No such channel\n");
// "<nom de canal> :No such channel"
return ; return ;
}//else }//else
//verify_option(allFds, str, i); //needed? //verify_option(allFds, str, i); //needed?
std::cout << "splitbuff[2] = " << splitBuff[2] << std::endl; // std::cout << "splitbuff[2] = " << splitBuff[2] << std::endl;
search_and_erase(splitBuff[2], "opsitnmlbvk"); search_and_erase(splitBuff[2], "opsitnmlbvk");
std::cout << "splitbuff[2] after = " << splitBuff[2] << std::endl; // std::cout << "splitbuff[2] after = " << splitBuff[2] << std::endl;
if ((splitBuff[2].size() < 2) || (splitBuff[2][0] != '-' && splitBuff[2][0] != '+')) if ((splitBuff[2].size() < 2) || (splitBuff[2][0] != '-' && splitBuff[2][0] != '+'))
{ {
std::cout << "Bad params" << std::endl; std::cout << "Bad params" << std::endl;
return ; return ;
} }
do_chan_opt(allFds, userNbr, splitBuff, pos); do_chan_opt(allFds, userNbr, splitBuff, pos);
chan_reply(allFds.channelList[pos], allFds.userData[userNbr]);
//do_option one by one here (do_chan_opt)? //do_option one by one here (do_chan_opt)?
return ; return ;
} }
@ -253,8 +260,7 @@ void MODE(std::string buffer, fdList &allFds, int userNbr)
else if ((pos = find_user(allFds, splitBuff[1])) == -1) else if ((pos = find_user(allFds, splitBuff[1])) == -1)
{ {
std::cout << "user doesn't exist" << std::endl; std::cout << "user doesn't exist" << std::endl;
// 401 ERR_NOSUCHNICK cmd_error(allFds, allFds.userData[userNbr].fd, "401 *" + splitBuff[1] + " :No such nick/channel\n");
// "<pseudonyme> :No such nick/channel"
return ; return ;
} }
else else
@ -262,10 +268,11 @@ void MODE(std::string buffer, fdList &allFds, int userNbr)
search_and_erase(splitBuff[2], "iswo"); search_and_erase(splitBuff[2], "iswo");
if ((splitBuff[2].size() < 2) && (splitBuff[2][0] != '-' || splitBuff[2][0] != '+')) if ((splitBuff[2].size() < 2) && (splitBuff[2][0] != '-' || splitBuff[2][0] != '+'))
{ {
std::cout << "Bad params" << std::endl; cmd_error(allFds, allFds.userData[userNbr].fd, "461 *" + splitBuff[0] + " :Not enough parameters\n");
return ; return ;
} }
do_user_opt(allFds, userNbr, splitBuff, pos); do_user_opt(allFds, userNbr, splitBuff, pos);
user_reply(allFds.userData[userNbr]);
} }
//do_option one by one here (do_user_opt)? //do_option one by one here (do_user_opt)?