1 /* IP forward control by sysctl function.
2 * Copyright (C) 1997, 1999 Kunihiro Ishiguro
4 * This file is part of GNU Zebra.
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
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.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; see the file COPYING; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23 #include "zebra/ipforward.h"
29 extern struct zebra_privs_t zserv_privs
;
31 /* IPv4 forwarding control MIB. */
32 int mib
[MIB_SIZ
] = {CTL_NET
, PF_INET
, IPPROTO_IP
, IPCTL_FORWARDING
};
39 len
= sizeof ipforwarding
;
40 if (sysctl(mib
, MIB_SIZ
, &ipforwarding
, &len
, 0, 0) < 0) {
41 zlog_warn("Can't get ipforwarding value");
47 int ipforward_on(void)
52 len
= sizeof ipforwarding
;
53 if (zserv_privs
.change(ZPRIVS_RAISE
))
54 zlog_err("Can't raise privileges");
55 if (sysctl(mib
, MIB_SIZ
, NULL
, NULL
, &ipforwarding
, len
) < 0) {
56 if (zserv_privs
.change(ZPRIVS_LOWER
))
57 zlog_err("Can't lower privileges");
58 zlog_warn("Can't set ipforwarding on");
61 if (zserv_privs
.change(ZPRIVS_LOWER
))
62 zlog_err("Can't lower privileges");
66 int ipforward_off(void)
71 len
= sizeof ipforwarding
;
72 if (zserv_privs
.change(ZPRIVS_RAISE
))
73 zlog_err("Can't raise privileges");
74 if (sysctl(mib
, MIB_SIZ
, NULL
, NULL
, &ipforwarding
, len
) < 0) {
75 if (zserv_privs
.change(ZPRIVS_LOWER
))
76 zlog_err("Can't lower privileges");
77 zlog_warn("Can't set ipforwarding on");
80 if (zserv_privs
.change(ZPRIVS_LOWER
))
81 zlog_err("Can't lower privileges");
85 /* IPv6 forwarding control MIB. */
86 int mib_ipv6
[MIB_SIZ
] = {CTL_NET
, PF_INET6
,
88 IPPROTO_IPV6
, IPV6CTL_FORWARDING
90 IPPROTO_IP
, IP6CTL_FORWARDING
94 int ipforward_ipv6(void)
97 int ip6forwarding
= 0;
99 len
= sizeof ip6forwarding
;
100 if (zserv_privs
.change(ZPRIVS_RAISE
))
101 zlog_err("Can't raise privileges");
102 if (sysctl(mib_ipv6
, MIB_SIZ
, &ip6forwarding
, &len
, 0, 0) < 0) {
103 if (zserv_privs
.change(ZPRIVS_LOWER
))
104 zlog_err("Can't lower privileges");
105 zlog_warn("can't get ip6forwarding value");
108 if (zserv_privs
.change(ZPRIVS_LOWER
))
109 zlog_err("Can't lower privileges");
110 return ip6forwarding
;
113 int ipforward_ipv6_on(void)
116 int ip6forwarding
= 1;
118 len
= sizeof ip6forwarding
;
119 if (zserv_privs
.change(ZPRIVS_RAISE
))
120 zlog_err("Can't raise privileges");
121 if (sysctl(mib_ipv6
, MIB_SIZ
, NULL
, NULL
, &ip6forwarding
, len
) < 0) {
122 if (zserv_privs
.change(ZPRIVS_LOWER
))
123 zlog_err("Can't lower privileges");
124 zlog_warn("can't get ip6forwarding value");
127 if (zserv_privs
.change(ZPRIVS_LOWER
))
128 zlog_err("Can't lower privileges");
129 return ip6forwarding
;
132 int ipforward_ipv6_off(void)
135 int ip6forwarding
= 0;
137 len
= sizeof ip6forwarding
;
138 if (zserv_privs
.change(ZPRIVS_RAISE
))
139 zlog_err("Can't raise privileges");
140 if (sysctl(mib_ipv6
, MIB_SIZ
, NULL
, NULL
, &ip6forwarding
, len
) < 0) {
141 if (zserv_privs
.change(ZPRIVS_LOWER
))
142 zlog_err("Can't lower privileges");
143 zlog_warn("can't get ip6forwarding value");
146 if (zserv_privs
.change(ZPRIVS_LOWER
))
147 zlog_err("Can't lower privileges");
148 return ip6forwarding
;