/* This file is part of the IPFire Firewall. * * This program is distributed under the terms of the GNU General Public * Licence. See the file COPYING for details. * */ #include #include #include #include #include #include #include "setuid.h" int main(int argc, char *argv[]) { if (!(initsetuid())) exit(1); if (argc < 2) { fprintf(stderr, "\nNo argument given.\n\nclamavctrl (start|stop|restart)\n\n"); exit(1); } if (strcmp(argv[1], "start") == 0) { safe_system("/etc/rc.d/init.d/clamav start"); } else if (strcmp(argv[1], "stop") == 0) { safe_system("/etc/rc.d/init.d/clamav stop"); } else if (strcmp(argv[1], "restart") == 0) { safe_system("/etc/rc.d/init.d/clamav restart"); } else if (strcmp(argv[1], "enable") == 0) { safe_system("ln -fs ../init.d/clamav /etc/rc.d/rc3.d/S33clamav >/dev/null 2>&1"); safe_system("ln -fs ../init.d/clamav /etc/rc.d/rc0.d/K67clamav >/dev/null 2>&1"); safe_system("ln -fs ../init.d/clamav /etc/rc.d/rc6.d/K67clamav >/dev/null 2>&1"); safe_system("/etc/rc.d/init.d/clamav start"); } else if (strcmp(argv[1], "disable") == 0) { safe_system("/etc/rc.d/init.d/clamav stop"); safe_system("rm -f /etc/rc.d/rc*.d/*clamav >/dev/null 2>&1"); } else { fprintf(stderr, "\nBad argument given.\n\nclamavctrl (start|stop|restart)\n\n"); exit(1); } return 0; }