blob: 57ed18578559ff275be2b39697073523e76a1e76 [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
paul718e3742002-12-13 20:15:29 +000026#include "log.h"
27
28#define MIB_SIZ 4
29
pauledd7c242003-06-04 13:59:38 +000030extern struct zebra_privs_t zserv_privs;
31
paul718e3742002-12-13 20:15:29 +000032/* IPv4 forwarding control MIB. */
33int mib[MIB_SIZ] =
34{
35 CTL_NET,
36 PF_INET,
37 IPPROTO_IP,
38 IPCTL_FORWARDING
39};
40
41int
paula1ac18c2005-06-28 17:17:12 +000042ipforward (void)
paul718e3742002-12-13 20:15:29 +000043{
gdta5ea6872004-08-26 13:24:00 +000044 size_t len;
paul718e3742002-12-13 20:15:29 +000045 int ipforwarding = 0;
46
47 len = sizeof ipforwarding;
48 if (sysctl (mib, MIB_SIZ, &ipforwarding, &len, 0, 0) < 0)
49 {
50 zlog_warn ("Can't get ipforwarding value");
51 return -1;
52 }
53 return ipforwarding;
54}
55
56int
paula1ac18c2005-06-28 17:17:12 +000057ipforward_on (void)
paul718e3742002-12-13 20:15:29 +000058{
gdta5ea6872004-08-26 13:24:00 +000059 size_t len;
paul718e3742002-12-13 20:15:29 +000060 int ipforwarding = 1;
61
62 len = sizeof ipforwarding;
pauledd7c242003-06-04 13:59:38 +000063 if (zserv_privs.change(ZPRIVS_RAISE))
64 zlog (NULL, LOG_ERR, "Can't raise privileges");
65 if (sysctl (mib, MIB_SIZ, NULL, NULL, &ipforwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +000066 {
pauledd7c242003-06-04 13:59:38 +000067 if (zserv_privs.change(ZPRIVS_LOWER))
68 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000069 zlog_warn ("Can't set ipforwarding on");
70 return -1;
71 }
pauledd7c242003-06-04 13:59:38 +000072 if (zserv_privs.change(ZPRIVS_LOWER))
73 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000074 return ipforwarding;
75}
76
77int
paula1ac18c2005-06-28 17:17:12 +000078ipforward_off (void)
paul718e3742002-12-13 20:15:29 +000079{
gdta5ea6872004-08-26 13:24:00 +000080 size_t len;
paul718e3742002-12-13 20:15:29 +000081 int ipforwarding = 0;
82
83 len = sizeof ipforwarding;
pauledd7c242003-06-04 13:59:38 +000084 if (zserv_privs.change(ZPRIVS_RAISE))
85 zlog (NULL, LOG_ERR, "Can't raise privileges");
86 if (sysctl (mib, MIB_SIZ, NULL, NULL, &ipforwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +000087 {
pauledd7c242003-06-04 13:59:38 +000088 if (zserv_privs.change(ZPRIVS_LOWER))
89 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000090 zlog_warn ("Can't set ipforwarding on");
91 return -1;
92 }
pauledd7c242003-06-04 13:59:38 +000093 if (zserv_privs.change(ZPRIVS_LOWER))
94 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +000095 return ipforwarding;
96}
97
98#ifdef HAVE_IPV6
99
100/* IPv6 forwarding control MIB. */
101int mib_ipv6[MIB_SIZ] =
102{
103 CTL_NET,
104 PF_INET6,
David Lamparter6d6df302014-06-28 21:12:37 +0200105#if defined(KAME)
paul718e3742002-12-13 20:15:29 +0000106 IPPROTO_IPV6,
107 IPV6CTL_FORWARDING
108#else /* NOT KAME */
109 IPPROTO_IP,
110 IP6CTL_FORWARDING
111#endif /* KAME */
112};
113
114int
paula1ac18c2005-06-28 17:17:12 +0000115ipforward_ipv6 (void)
paul718e3742002-12-13 20:15:29 +0000116{
gdta5ea6872004-08-26 13:24:00 +0000117 size_t len;
paul718e3742002-12-13 20:15:29 +0000118 int ip6forwarding = 0;
119
120 len = sizeof ip6forwarding;
pauledd7c242003-06-04 13:59:38 +0000121 if (zserv_privs.change(ZPRIVS_RAISE))
122 zlog (NULL, LOG_ERR, "Can't raise privileges");
123 if (sysctl (mib_ipv6, MIB_SIZ, &ip6forwarding, &len, 0, 0) < 0)
paul718e3742002-12-13 20:15:29 +0000124 {
pauledd7c242003-06-04 13:59:38 +0000125 if (zserv_privs.change(ZPRIVS_LOWER))
126 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000127 zlog_warn ("can't get ip6forwarding value");
128 return -1;
129 }
pauledd7c242003-06-04 13:59:38 +0000130 if (zserv_privs.change(ZPRIVS_LOWER))
131 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000132 return ip6forwarding;
133}
134
135int
paula1ac18c2005-06-28 17:17:12 +0000136ipforward_ipv6_on (void)
paul718e3742002-12-13 20:15:29 +0000137{
gdta5ea6872004-08-26 13:24:00 +0000138 size_t len;
paul718e3742002-12-13 20:15:29 +0000139 int ip6forwarding = 1;
140
141 len = sizeof ip6forwarding;
pauledd7c242003-06-04 13:59:38 +0000142 if (zserv_privs.change(ZPRIVS_RAISE))
143 zlog (NULL, LOG_ERR, "Can't raise privileges");
144 if (sysctl (mib_ipv6, MIB_SIZ, NULL, NULL, &ip6forwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +0000145 {
pauledd7c242003-06-04 13:59:38 +0000146 if (zserv_privs.change(ZPRIVS_LOWER))
147 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000148 zlog_warn ("can't get ip6forwarding value");
149 return -1;
150 }
pauledd7c242003-06-04 13:59:38 +0000151 if (zserv_privs.change(ZPRIVS_LOWER))
152 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000153 return ip6forwarding;
154}
155
156int
paula1ac18c2005-06-28 17:17:12 +0000157ipforward_ipv6_off (void)
paul718e3742002-12-13 20:15:29 +0000158{
gdta5ea6872004-08-26 13:24:00 +0000159 size_t len;
paul718e3742002-12-13 20:15:29 +0000160 int ip6forwarding = 0;
161
162 len = sizeof ip6forwarding;
pauledd7c242003-06-04 13:59:38 +0000163 if (zserv_privs.change(ZPRIVS_RAISE))
164 zlog (NULL, LOG_ERR, "Can't raise privileges");
165 if (sysctl (mib_ipv6, MIB_SIZ, NULL, NULL, &ip6forwarding, len) < 0)
paul718e3742002-12-13 20:15:29 +0000166 {
pauledd7c242003-06-04 13:59:38 +0000167 if (zserv_privs.change(ZPRIVS_LOWER))
168 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000169 zlog_warn ("can't get ip6forwarding value");
170 return -1;
171 }
pauledd7c242003-06-04 13:59:38 +0000172 if (zserv_privs.change(ZPRIVS_LOWER))
173 zlog (NULL, LOG_ERR, "Can't lower privileges");
paul718e3742002-12-13 20:15:29 +0000174 return ip6forwarding;
175}
176#endif /* HAVE_IPV6 */