#include "parse.h"
#include "modules.h"
#include "packet.h"
+#include "tgchange.h"
static int m_topic(struct Client *, struct Client *, int, const char **);
static int ms_topic(struct Client *, struct Client *, int, const char **);
if(MyClient(source_p) && !IsFloodDone(source_p))
flood_endgrace(source_p);
- if(!IsChannelName(name))
- {
- sendto_one_numeric(source_p, ERR_NOSUCHCHANNEL,
- form_str(ERR_NOSUCHCHANNEL), name);
- return 0;
- }
-
chptr = find_channel(name);
if(chptr == NULL)
return 0;
}
- if((chptr->mode.mode & MODE_TOPICLIMIT) == 0 || is_chanop(msptr))
+ if(MyClient(source_p) && !is_chanop_voiced(msptr) &&
+ !IsOper(source_p) &&
+ !add_channel_target(source_p, chptr))
+ {
+ sendto_one(source_p, form_str(ERR_TARGCHANGE),
+ me.name, source_p->name, chptr->chname);
+ return 0;
+ }
+
+ if(((chptr->mode.mode & MODE_TOPICLIMIT) == 0 ||
+ get_channel_access(source_p, msptr) >= CHFL_CHANOP) &&
+ (!MyClient(source_p) ||
+ can_send(chptr, source_p, msptr)))
{
char topic_info[USERHOST_REPLYLEN];
rb_sprintf(topic_info, "%s!%s@%s",
}
else
sendto_one(source_p, form_str(ERR_CHANOPRIVSNEEDED),
- me.name, source_p->name, name);
+ get_id(&me, source_p),
+ get_id(source_p, source_p), name);
}
else if(MyClient(source_p))
{
sendto_one(source_p, form_str(RPL_TOPICWHOTIME),
me.name, source_p->name, chptr->chname,
- chptr->topic_info, chptr->topic_time);
+ chptr->topic_info,
+ (unsigned long)chptr->topic_time);
}
}
{
struct Channel *chptr = NULL;
- if(IsChannelName(parv[1]))
- {
- if((chptr = find_channel(parv[1])) == NULL)
- return 0;
+ if((chptr = find_channel(parv[1])) == NULL)
+ return 0;
- set_channel_topic(chptr, parv[4], parv[2], atoi(parv[3]));
+ set_channel_topic(chptr, parv[4], parv[2], atoi(parv[3]));
- sendto_channel_local(ALL_MEMBERS, chptr, ":%s TOPIC %s :%s",
- source_p->name, parv[1],
- chptr->topic == NULL ? "" : chptr->topic);
- }
+ sendto_channel_local(ALL_MEMBERS, chptr, ":%s TOPIC %s :%s",
+ source_p->name, parv[1],
+ chptr->topic == NULL ? "" : chptr->topic);
return 0;
}