X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fcommands%2Fcmd_away.cpp;h=96da5cda5874c415852cfed466c5fc02ce3fd065;hb=33ce32eb8bfddfc1cb04668a03c9b795d33eb9c0;hp=c49813b52eefdd9c8ff5b5bc4b8e4695d3a3794c;hpb=e2f4bf3a135e6b23fea21b2628c2c830de29cdec;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/commands/cmd_away.cpp b/src/commands/cmd_away.cpp index c49813b52..96da5cda5 100644 --- a/src/commands/cmd_away.cpp +++ b/src/commands/cmd_away.cpp @@ -21,19 +21,21 @@ extern "C" DllExport Command* init_command(InspIRCd* Instance) /** Handle /AWAY */ -CmdResult CommandAway::Handle (const char* const* parameters, int pcnt, User *user) +CmdResult CommandAway::Handle (const std::vector& parameters, User *user) { int MOD_RESULT = 0; - if ((pcnt) && (*parameters[0])) + if ((parameters.size()) && (!parameters[0].empty())) { FOREACH_RESULT(I_OnSetAway, OnSetAway(user, parameters[0])); if (MOD_RESULT != 0 && !IS_LOCAL(user)) return CMD_FAILURE; - strlcpy(user->awaymsg,parameters[0],MAXAWAY); - user->WriteNumeric(306, "%s :You have been marked as being away",user->nick); + user->awaytime = ServerInstance->Time(); + user->awaymsg.assign(parameters[0], 0, ServerInstance->Config->Limits.MaxAway); + + user->WriteNumeric(RPL_NOWAWAY, "%s :You have been marked as being away",user->nick.c_str()); } else { @@ -42,8 +44,8 @@ CmdResult CommandAway::Handle (const char* const* parameters, int pcnt, User *us if (MOD_RESULT != 0 && !IS_LOCAL(user)) return CMD_FAILURE; - *user->awaymsg = 0; - user->WriteNumeric(305, "%s :You are no longer marked as being away",user->nick); + user->awaymsg.clear(); + user->WriteNumeric(RPL_UNAWAY, "%s :You are no longer marked as being away",user->nick.c_str()); } return CMD_SUCCESS;