registersearchterm(reg_whowassearch, "ident",ident_parse, 0, "User's current ident");
registersearchterm(reg_nicksearch, "host",host_parse, 0, "User's host, allow \"host real\" to match real host");
registersearchterm(reg_whowassearch, "host",host_parse, 0, "User's host, allow \"host real\" to match real host");
- registersearchterm(reg_nicksearch, "channel",channel_parse, 0, "Valid Channel Name to match users against"); /* nick only */
+ registersearchterm(reg_nicksearch, "channel",channel_parse, 0, "Valid Channel Name to match users against");
+ registersearchterm(reg_whowassearch, "channel",channel_parse, 0, "Valid Channel Name to match users against");
registersearchterm(reg_nicksearch, "timestamp",timestamp_parse, 0, "User's Timestamp");
registersearchterm(reg_whowassearch, "timestamp",timestamp_parse, 0, "User's Timestamp");
registersearchterm(reg_nicksearch, "country",country_parse, 0, "2 letter country code (data source is geoip)");
struct searchNode *channel_parse(searchCtx *ctx, int argc, char **argv) {
struct searchNode *thenode, *convsn;
- channel *cp;
+ chanindex *cip;
char *p;
if (argc<1) {
if (!(convsn=argtoconststr("channel", ctx, argv[0], &p)))
return NULL;
- cp=findchannel(p);
+ cip=findorcreatechanindex(p);
convsn->free(ctx, convsn);
- if (!cp) {
- parseError = "channel: unknown channel";
- return NULL;
- }
if (!(thenode=(struct searchNode *)malloc(sizeof (struct searchNode)))) {
parseError = "malloc: could not allocate memory for this search.";
}
thenode->returntype = RETURNTYPE_BOOL;
- thenode->localdata = cp;
+ thenode->localdata = cip;
thenode->exe = channel_exe;
thenode->free = channel_free;
void *channel_exe(searchCtx *ctx, struct searchNode *thenode, void *theinput) {
nick *np = (nick *)theinput;
- channel *cp = thenode->localdata;
+ chanindex *cip = thenode->localdata;
+ channel *cp;
+ whowas *ww;
+ int i;
- if (getnumerichandlefromchanhash(cp->users, np->numeric)) {
- return (void *)1;
+ if (ctx->searchcmd == reg_nicksearch) {
+ cp = cip->channel;
+
+ if (!cp)
+ return (void *)0;
+
+ if (getnumerichandlefromchanhash(cp->users, np->numeric))
+ return (void *)1;
} else {
- return (void *)0;
+ ww = (whowas *)np->next; /* Eww. */
+
+ for (i = 0; i < WW_MAXCHANNELS; i++)
+ if (ww->channels[i] == cip)
+ return (void *)1;
}
+
+ return (void *)0;
}
void channel_free(searchCtx *ctx, struct searchNode *thenode) {
+ releasechanindex(thenode->localdata);
free(thenode);
}