partpos = sprintf(part, "%s", ((user->flags & USERFLAG_ISAUTHED) ? user->auth : ""));
} else if(!strcmp(argv[i], "access")) {
if(chan)
- partpos = sprintf(part, "%d", getChannelAccess(user, chan, 0));
+ partpos = sprintf(part, "%d", getChannelAccess(user, chan));
}
} else {
partpos = sprintf(part, "%s", argv[i]);
}
command[commandpos] = '\0';
//we should now have a valid command
- FILE *fp;
- fp = popen(command, "r");
- if (fp) {
- char *a;
- while (fgets(command, 1024, fp) != NULL) {
- if((a = strchr(command, '\n')))
- *a = '\0';
- if(answere_channel) {
- putsock(client, "PRIVMSG %s :%s", chan->name, command);
- } else
- reply(getTextBot(), user, "%s", command);
+ struct ClientSocket *textbot = getTextBot();
+ #ifndef WIN32
+ pid_t pID = fork();
+ if (pID == 0) { //We're the child process :D
+ pID = fork();
+ if(pID < 0) exit(EXIT_FAILURE);
+ if(pID != 0) exit(EXIT_SUCCESS);
+ #endif
+ FILE *fp;
+ fp = popen(command, "r");
+ if (fp) {
+ char *a;
+ while (fgets(command, 1024, fp) != NULL) {
+ if((a = strchr(command, '\n')))
+ *a = '\0';
+ if(answere_channel)
+ putsock(client, "PRIVMSG %s :%s", chan->name, command);
+ else
+ reply(textbot, user, "%s", command);
+ }
+ pclose(fp);
+ } else {
+ reply(getTextBot(), user, "internal bot error - please contact an administrator!");
}
- pclose(fp);
- } else {
- //error
+ #ifndef WIN32
+ exit(EXIT_FAILURE);
+ } else if (pID < 0) {
reply(getTextBot(), user, "internal bot error - please contact an administrator!");
- return;
+ } else {
+ //parent bot - continue program
+ wait(NULL);
}
+ #endif
}