blob: 185aee3ee0994f0cce24e33d9e24b326672d9a58 [file] [log] [blame]
paul718e3742002-12-13 20:15:29 +00001/* IP forward control by sysctl function.
2 * Copyright (C) 1997, 1999 Kunihiro Ishiguro
3 *
4 * This file is part of GNU Zebra.
5 *
6 * GNU Zebra is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
9 * later version.
10 *
11 * GNU Zebra is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with GNU Zebra; see the file COPYING. If not, write to the Free
18 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
19 * 02111-1307, USA.
20 */
21
22#include <zebra.h>
pauledd7c242003-06-04 13:59:38 +000023#include "privs.h"
paula1ac18c2005-06-28 17:17:12 +000024#include "zebra/ipforward.h"
paul718e3742002-12-13 20:15:29 +000025
26#ifdef NRL
27#include <netinet6/in6.h>
28#endif /* NRL */
29
30#include "log.h"
31
32#define MIB_SIZ 4
33
pauledd7c242003-06-04 13:59:38 +000034extern struct zebra_privs_t zserv_privs;
35
paul718e3742002-12-13 20:15:29 +000036/* IPv4 forwarding control MIB. */
37int mib[MIB_SIZ] =
38{
39 CTL_NET,
40 PF_INET,
41 IPPROTO_IP,
42 IPCTL_FORWARDING
43};
44
45int
paula1ac18c2005-06-28 17:17:12 +000046ipforward (void)
paul718e3742002-12-13 20:15:29 +000047{
gdta5ea6872004-08-26 13:24:00 +000048 size_t len;
paul718e3742002-12-13 20:15:29 +000049 int ipforwarding = 0;
50
51 len = sizeof ipforwarding;
52 if (sysctl (mib, MIB_SIZ, &ipforwarding, &len, 0, 0) < 0)
53 {
54 zlog_warn ("Can't get ipforwarding value");
55 return -1;
56 }
57 return ipforwarding;
58}
59
60int
paula1ac18c2005-06-28 17:17:12 +000061ipforward_on (void)
paul718e3742002-12-13 20:15:29 +000062{
gdta5ea6872004-08-26 13:24:00 +000063 size_t len;
paul718e3742002-12-13 20:15:29 +000064 int ipforwarding = 1;
65
66 len = sizeof ipforwarding;
pauledd7c242003-06-04 13:59:38 +000067 if (zserv_privs.change(ZPRIVS_RAISE))
68 zlog (NULL, LOG_ERR, "Can't raise privileges");
69 if (sysctl (mib, MIB_SIZ, NULL, NULL, &ipforwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +000070 {
pauledd7c242003-06-04 13:59:38 +000071 if (zserv_privs.change(ZPRIVS_LOWER))
72 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000073 zlog_warn ("Can't set ipforwarding on");
74 return -1;
75 }
pauledd7c242003-06-04 13:59:38 +000076 if (zserv_privs.change(ZPRIVS_LOWER))
77 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000078 return ipforwarding;
79}
80
81int
paula1ac18c2005-06-28 17:17:12 +000082ipforward_off (void)
paul718e3742002-12-13 20:15:29 +000083{
gdta5ea6872004-08-26 13:24:00 +000084 size_t len;
paul718e3742002-12-13 20:15:29 +000085 int ipforwarding = 0;
86
87 len = sizeof ipforwarding;
pauledd7c242003-06-04 13:59:38 +000088 if (zserv_privs.change(ZPRIVS_RAISE))
89 zlog (NULL, LOG_ERR, "Can't raise privileges");
90 if (sysctl (mib, MIB_SIZ, NULL, NULL, &ipforwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +000091 {
pauledd7c242003-06-04 13:59:38 +000092 if (zserv_privs.change(ZPRIVS_LOWER))
93 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000094 zlog_warn ("Can't set ipforwarding on");
95 return -1;
96 }
pauledd7c242003-06-04 13:59:38 +000097 if (zserv_privs.change(ZPRIVS_LOWER))
98 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000099 return ipforwarding;
100}
101
102#ifdef HAVE_IPV6
103
104/* IPv6 forwarding control MIB. */
105int mib_ipv6[MIB_SIZ] =
106{
107 CTL_NET,
108 PF_INET6,
109#if defined(KAME) || (defined(__bsdi__) && _BSDI_VERSION >= 199802 ) || defined(NRL)
110 IPPROTO_IPV6,
111 IPV6CTL_FORWARDING
112#else /* NOT KAME */
113 IPPROTO_IP,
114 IP6CTL_FORWARDING
115#endif /* KAME */
116};
117
118int
paula1ac18c2005-06-28 17:17:12 +0000119ipforward_ipv6 (void)
paul718e3742002-12-13 20:15:29 +0000120{
gdta5ea6872004-08-26 13:24:00 +0000121 size_t len;
paul718e3742002-12-13 20:15:29 +0000122 int ip6forwarding = 0;
123
124 len = sizeof ip6forwarding;
pauledd7c242003-06-04 13:59:38 +0000125 if (zserv_privs.change(ZPRIVS_RAISE))
126 zlog (NULL, LOG_ERR, "Can't raise privileges");
127 if (sysctl (mib_ipv6, MIB_SIZ, &ip6forwarding, &len, 0, 0) < 0)
paul718e3742002-12-13 20:15:29 +0000128 {
pauledd7c242003-06-04 13:59:38 +0000129 if (zserv_privs.change(ZPRIVS_LOWER))
130 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000131 zlog_warn ("can't get ip6forwarding value");
132 return -1;
133 }
pauledd7c242003-06-04 13:59:38 +0000134 if (zserv_privs.change(ZPRIVS_LOWER))
135 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000136 return ip6forwarding;
137}
138
139int
paula1ac18c2005-06-28 17:17:12 +0000140ipforward_ipv6_on (void)
paul718e3742002-12-13 20:15:29 +0000141{
gdta5ea6872004-08-26 13:24:00 +0000142 size_t len;
paul718e3742002-12-13 20:15:29 +0000143 int ip6forwarding = 1;
144
145 len = sizeof ip6forwarding;
pauledd7c242003-06-04 13:59:38 +0000146 if (zserv_privs.change(ZPRIVS_RAISE))
147 zlog (NULL, LOG_ERR, "Can't raise privileges");
148 if (sysctl (mib_ipv6, MIB_SIZ, NULL, NULL, &ip6forwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +0000149 {
pauledd7c242003-06-04 13:59:38 +0000150 if (zserv_privs.change(ZPRIVS_LOWER))
151 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000152 zlog_warn ("can't get ip6forwarding value");
153 return -1;
154 }
pauledd7c242003-06-04 13:59:38 +0000155 if (zserv_privs.change(ZPRIVS_LOWER))
156 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000157 return ip6forwarding;
158}
159
160int
paula1ac18c2005-06-28 17:17:12 +0000161ipforward_ipv6_off (void)
paul718e3742002-12-13 20:15:29 +0000162{
gdta5ea6872004-08-26 13:24:00 +0000163 size_t len;
paul718e3742002-12-13 20:15:29 +0000164 int ip6forwarding = 0;
165
166 len = sizeof ip6forwarding;
pauledd7c242003-06-04 13:59:38 +0000167 if (zserv_privs.change(ZPRIVS_RAISE))
168 zlog (NULL, LOG_ERR, "Can't raise privileges");
169 if (sysctl (mib_ipv6, MIB_SIZ, NULL, NULL, &ip6forwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +0000170 {
pauledd7c242003-06-04 13:59:38 +0000171 if (zserv_privs.change(ZPRIVS_LOWER))
172 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000173 zlog_warn ("can't get ip6forwarding value");
174 return -1;
175 }
pauledd7c242003-06-04 13:59:38 +0000176 if (zserv_privs.change(ZPRIVS_LOWER))
177 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000178 return ip6forwarding;
179}
180#endif /* HAVE_IPV6 */