misc-progs: Add wireguardctrl

commit f552e23da404adf4555299c887a0279016323df4
    Author: Michael Tremer <michael.tremer@ipfire.org>
    Date:   Wed Apr 17 17:13:32 2024 +0000

        misc-progs: Add wireguardctrl

        Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>

Signed-off-by: Vincent Li <vincent.mc.li@gmail.com>
This commit is contained in:
Vincent Li
2025-07-03 20:11:03 +00:00
parent 3eb0ec8b1b
commit 3710ff2af7
3 changed files with 46 additions and 1 deletions

View File

@@ -35,6 +35,7 @@ usr/local/bin/updxlratorctrl
usr/local/bin/urlfilterctrl
#usr/local/bin/wiohelper
#usr/local/bin/wioscan
usr/local/bin/wireguardctrl
usr/local/bin/wirelessclient
usr/local/bin/wirelessctrl
#usr/local/bin/wlanapctrl

View File

@@ -32,7 +32,7 @@ SUID_PROGS = squidctrl sshctrl ipfirereboot \
smartctrl clamavctrl addonctrl pakfire mpfirectrl wlanapctrl \
setaliases urlfilterctrl updxlratorctrl fireinfoctrl rebuildroutes \
getconntracktable wirelessclient torctrl ddnsctrl unboundctrl \
captivectrl ddosctrl loxilbctrl keepalivedctrl haproxyctrl \
captivectrl wireguardctrl ddosctrl loxilbctrl keepalivedctrl haproxyctrl \
xdpdnsctrl xdpsnictrl xdpgeoipctrl
OBJS = $(patsubst %,%.o,$(PROGS) $(SUID_PROGS))

View File

@@ -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 <stdio.h>
#include <string.h>
#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) {
char* args[] = {
"show",
(argc > 2) ? argv[2] : "wg0",
"dump",
NULL,
};
return run("/usr/bin/wg", args);
}
fprintf(stderr, "Invalid command\n");
exit(1);
}