📄 tncfg.c
字号:
/* * IPSEC interface configuration * Copyright (C) 1996 John Ioannidis. * Copyright (C) 1998, 1999, 2000, 2001 Richard Guy Briggs. * * 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. See <http://www.fsf.org/copyleft/gpl.txt>. * * 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. */char tncfg_c_version[] = "RCSID $Id: tncfg.c,v 1.1 2005/03/20 02:59:24 mcr Exp $";#include <stdio.h>#include <string.h>#include <stdlib.h> /* system(), strtoul() */#include <unistd.h> /* getuid() */#include <linux/types.h>#include <sys/ioctl.h> /* ioctl() */#include <openswan.h>#ifdef NET_21 /* from openswan.h */#include <linux/sockios.h>#include <sys/socket.h>#endif /* NET_21 */ /* from openswan.h */#if 0#include <linux/if.h>#else#include <net/if.h>#endif#include <sys/types.h>#include <errno.h>#include <getopt.h>#include "openswan/ipsec_tunnel.h"static voidusage(char *name){ fprintf(stdout,"%s <virtual-device>\n", name); exit(1);}intmain(int argc, char *argv[]){ struct ifreq ifr; memset(&ifr, 0, sizeof(ifr)); program_name = argv[0]; s=socket(AF_INET, SOCK_DGRAM,0); if(s==-1) { fprintf(stderr, "%s: Socket creation failed:%s " , program_name, strerror(errno)); exit(1); } if (ioctl(fd, SIOCDEVPRIVATE, &ifr) >= 0) { new_i if(ioctl(s, shc->cf_cmd, &ifr)==-1) { if(shc->cf_cmd == IPSEC_SET_DEV) { fprintf(stderr, "%s: Socket ioctl failed on attach -- ", program_name); switch(errno) { case EINVAL: fprintf(stderr, "Invalid argument, check kernel log messages for specifics.\n"); break; case ENODEV: fprintf(stderr, "No such device. Is the virtual device valid? Is the ipsec module linked into the kernel or loaded as a module?\n"); break; case ENXIO: fprintf(stderr, "No such device. Is the physical device valid?\n"); break; case EBUSY: fprintf(stderr, "Device busy. Virtual device %s is already attached to a physical device -- Use detach first.\n", ifr.ifr_name); break; default: fprintf(stderr, "Unknown socket error %d.\n", errno); } exit(1); } if(shc->cf_cmd == IPSEC_DEL_DEV) { fprintf(stderr, "%s: Socket ioctl failed on detach -- ", program_name); switch(errno) { case EINVAL: fprintf(stderr, "Invalid argument, check kernel log messages for specifics.\n"); break; case ENODEV: fprintf(stderr, "No such device. Is the virtual device valid? The ipsec module may not be linked into the kernel or loaded as a module.\n"); break; case ENXIO: fprintf(stderr, "Device requested is not linked to any physical device.\n"); break; default: fprintf(stderr, "Unknown socket error %d.\n", errno); } exit(1); } if(shc->cf_cmd == IPSEC_CLR_DEV) { fprintf(stderr, "%s: Socket ioctl failed on clear -- ", program_name); switch(errno) { case EINVAL: fprintf(stderr, "Invalid argument, check kernel log messages for specifics.\n"); break; case ENODEV: fprintf(stderr, "Failed. Is the ipsec module linked into the kernel or loaded as a module?.\n"); break; default: fprintf(stderr, "Unknown socket error %d.\n", errno); } exit(1); } } exit(0);} /* * $Log: tncfg.c,v $ * Revision 1.1 2005/03/20 02:59:24 mcr * code to test bad SIOCPRIVATE call (never finished) * * Revision 1.32 2004/04/06 03:05:06 mcr * freeswan->openswan changes. * * Revision 1.31 2004/04/04 01:53:50 ken * Use openswan includes * * Revision 1.30 2002/04/24 07:55:32 mcr * #include patches and Makefiles for post-reorg compilation. * * Revision 1.29 2002/04/24 07:35:41 mcr * Moved from ./klips/utils/tncfg.c,v * * Revision 1.28 2002/03/08 21:44:05 rgb * Update for all GNU-compliant --version strings. * * Revision 1.27 2001/06/14 19:35:15 rgb * Update copyright date. * * Revision 1.26 2001/05/21 02:02:55 rgb * Eliminate 1-letter options. * * Revision 1.25 2001/05/16 05:07:20 rgb * Fixed --label option in KLIPS manual utils to add the label to the * command name rather than replace it in error text. * Fix 'print table' non-option in KLIPS manual utils to deal with --label * and --debug options. * * Revision 1.24 2000/09/12 13:09:05 rgb * Fixed real/physical discrepancy between tncfg.8 and tncfg.c. * * Revision 1.23 2000/08/27 01:48:30 rgb * Update copyright. * * Revision 1.22 2000/07/26 03:41:46 rgb * Changed all printf's to fprintf's. Fixed tncfg's usage to stderr. * * Revision 1.21 2000/06/21 16:51:27 rgb * Added no additional argument option to usage text. * * Revision 1.20 2000/01/21 06:26:31 rgb * Added --debug switch to command line. * * Revision 1.19 1999/12/08 20:32:41 rgb * Cleaned out unused cruft. * Changed include file, limiting scope, to avoid conflicts in 2.0.xx * kernels. * * Revision 1.18 1999/12/07 18:27:10 rgb * Added headers to silence fussy compilers. * Converted local functions to static to limit scope. * * Revision 1.17 1999/11/18 04:09:21 rgb * Replaced all kernel version macros to shorter, readable form. * * Revision 1.16 1999/05/25 01:45:36 rgb * Fix version macros for 2.0.x as a module. * * Revision 1.15 1999/05/05 22:02:34 rgb * Add a quick and dirty port to 2.2 kernels by Marc Boucher <marc@mbsi.ca>. * * Revision 1.14 1999/04/15 15:37:28 rgb * Forward check changes from POST1_00 branch. * * Revision 1.10.6.2 1999/04/13 20:58:10 rgb * Add argc==1 --> /proc/net/ipsec_*. * * Revision 1.10.6.1 1999/03/30 17:01:36 rgb * Make main() return type explicit. * * Revision 1.13 1999/04/11 00:12:09 henry * GPL boilerplate * * Revision 1.12 1999/04/06 04:54:39 rgb * Fix/Add RCSID Id: and Log: bits to make PHMDs happy. This includes * patch shell fixes. * * Revision 1.11 1999/03/17 15:40:54 rgb * Make explicit main() return type of int. * * Revision 1.10 1998/11/12 21:08:04 rgb * Add --label option to identify caller from scripts. * * Revision 1.9 1998/10/09 18:47:30 rgb * Add 'optionfrom' to get more options from a named file. * * Revision 1.8 1998/10/09 04:36:55 rgb * Changed help output from stderr to stdout. * Deleted old commented out cruft. * * Revision 1.7 1998/08/28 03:15:14 rgb * Add some manual long options to the usage text. * * Revision 1.6 1998/08/05 22:29:00 rgb * Change includes to accomodate RH5.x. * Force long option names. * Add ENXIO error return code to narrow down error reporting. * * Revision 1.5 1998/07/29 21:45:28 rgb * Convert to long option names. * * Revision 1.4 1998/07/09 18:14:11 rgb * Added error checking to IP's and keys. * Made most error messages more specific rather than spamming usage text. * Added more descriptive kernel error return codes and messages. * Converted all spi translations to unsigned. * Removed all invocations of perror. * * Revision 1.3 1998/05/27 18:48:20 rgb * Adding --help and --version directives. * * Revision 1.2 1998/04/23 21:11:39 rgb * Fixed 0 argument usage case to prevent sigsegv. * * Revision 1.1.1.1 1998/04/08 05:35:09 henry * RGB's ipsec-0.8pre2.tar.gz ipsec-0.8 * * Revision 0.5 1997/06/03 04:31:55 ji * New file. * */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -