X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_spanningtree%2Faway.cpp;h=f14c8ac987937f735f488c4d12052f4d38cbd8ce;hb=bdc70892c647f0d7672aba413100730819a4b217;hp=cf0c87ce46a45d46c8b47cefff740f720988ed32;hpb=b14ebbccf08ec34a73e1ba271e67da80d9fe805c;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_spanningtree/away.cpp b/src/modules/m_spanningtree/away.cpp index cf0c87ce4..f14c8ac98 100644 --- a/src/modules/m_spanningtree/away.cpp +++ b/src/modules/m_spanningtree/away.cpp @@ -23,20 +23,18 @@ #include "utils.h" #include "commands.h" -CmdResult CommandAway::Handle(User* u, std::vector& params) +CmdResult CommandAway::HandleRemote(RemoteUser* u, std::vector& params) { - if (IS_SERVER(u)) - return CMD_INVALID; if (params.size()) { - FOREACH_MOD(OnSetAway, (u, params[params.size() - 1])); + FOREACH_MOD(OnSetAway, (u, params.back())); if (params.size() > 1) u->awaytime = ConvToInt(params[0]); else u->awaytime = ServerInstance->Time(); - u->awaymsg = params[params.size() - 1]; + u->awaymsg = params.back(); } else { @@ -45,3 +43,16 @@ CmdResult CommandAway::Handle(User* u, std::vector& params) } return CMD_SUCCESS; } + +CommandAway::Builder::Builder(User* user) + : CmdBuilder(user, "AWAY") +{ + push_int(user->awaytime).push_last(user->awaymsg); +} + +CommandAway::Builder::Builder(User* user, const std::string& msg) + : CmdBuilder(user, "AWAY") +{ + if (!msg.empty()) + push_int(ServerInstance->Time()).push_last(msg); +}