From: Michael Tremer Date: Wed, 17 Apr 2024 17:13:32 +0000 (+0000) Subject: misc-progs: Add wireguardctrl X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=f552e23da404adf4555299c887a0279016323df4;p=people%2Fstevee%2Fipfire-2.x.git misc-progs: Add wireguardctrl Signed-off-by: Michael Tremer --- diff --git a/src/misc-progs/Makefile b/src/misc-progs/Makefile index 1ae12b294..9d380c158 100644 --- a/src/misc-progs/Makefile +++ b/src/misc-progs/Makefile @@ -32,7 +32,7 @@ SUID_PROGS = squidctrl sshctrl ipfirereboot \ smartctrl clamavctrl addonctrl pakfire wlanapctrl \ setaliases urlfilterctrl updxlratorctrl fireinfoctrl rebuildroutes \ getconntracktable wirelessclient torctrl ddnsctrl unboundctrl \ - captivectrl + captivectrl wireguardctrl OBJS = $(patsubst %,%.o,$(PROGS) $(SUID_PROGS)) diff --git a/src/misc-progs/wireguardctrl.c b/src/misc-progs/wireguardctrl.c new file mode 100644 index 000000000..0c257646b --- /dev/null +++ b/src/misc-progs/wireguardctrl.c @@ -0,0 +1,44 @@ +/* This file is part of the IPFire Firewall. + * + * This program is distributed under the terms of the GNU General Public + * Licence. See the file COPYING for details. + * + */ + +#include +#include + +#include "setuid.h" + +int main(int argc, char** argv) { + // Become root + if (!initsetuid()) + exit(1); + + // Check if we have enough arguments + if (argc < 2) { + fprintf(stderr, "\nNot enough arguments.\n\n"); + exit(1); + } + + if (strcmp(argv[1], "start") == 0) { + return run("/etc/rc.d/init.d/wireguard", argv + 1); + + } else if (strcmp(argv[1], "stop") == 0) { + return run("/etc/rc.d/init.d/wireguard", argv + 1); + + } else if (strcmp(argv[1], "dump") == 0) { + const char* args[] = { + "show", + (argc > 2) ? argv[2] : "wg0", + "dump", + NULL, + }; + + return run("/usr/bin/wg", args); + + } + + fprintf(stderr, "Invalid command\n"); + exit(1); +}