/* * Author: Paul.Russell@rustcorp.com.au and mneuling@radlogic.com.au * * Based on the ipchains code by Paul Russell and Michael Neuling * * (C) 2000-2002 by the netfilter coreteam : * Paul 'Rusty' Russell * Marc Boucher * James Morris * Harald Welte * Jozsef Kadlecsik * * iptables -- IP firewall administration for kernels with * firewall table (aimed for the 2.3 kernels) * * See the accompanying manual page iptables(8) for information * about proper usage of this program. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include #include #include #include #define LOCK_FILE "/var/lock/iptables_cmd_lock" #ifdef IPTABLES_MULTI int iptables_blocking(int argc, char *argv[]) #else int main(int argc, char *argv[]) #endif { int fd; int ret; char *table = "filter"; iptc_handle_t handle = NULL; program_name = "iptables"; program_version = IPTABLES_VERSION; lib_dir = getenv("IPTABLES_LIB_DIR"); if (!lib_dir) lib_dir = IPT_LIB_DIR; #ifdef NO_SHARED_LIBS init_extensions(); #endif fd = open(LOCK_FILE, O_CREAT|O_WRONLY|O_TRUNC); if (fd < 0) { fprintf(stderr, "iptables: Cannot open lock file %s (strerr:%s)\n", LOCK_FILE, strerror(errno)); exit(errno); } flock(fd, LOCK_EX); ret = do_command(argc, argv, &table, &handle); if (ret) { ret = iptc_commit(&handle); if (errno == EAGAIN) { fprintf(stderr, "iptc_commit: %s\n", strerror(errno)); exit(RESOURCE_PROBLEM); } } flock(fd, LOCK_UN); if (!ret) { fprintf(stderr, "fall-through(errno:%d) iptables: %s\n", errno, iptc_strerror(errno)); /* Test: Try to get the errno... */ /* exit(errno); */ } exit(!ret); }