diff --git a/content/posts/microsocks-on-netbsd.md b/content/posts/microsocks-on-netbsd.md new file mode 100644 index 0000000..68537f7 --- /dev/null +++ b/content/posts/microsocks-on-netbsd.md @@ -0,0 +1,81 @@ ++++ +title = 'Microsocks on NetBSD' +date = 2024-10-28T07:44:51+02:00 +draft = false ++++ + +Have you ever wanted a proxy server that you can run on a toaster (literally)? Well, enter today's setup, Microsocks on NetBSD. Microsocks is a simple, fast and efficient SOCKS5 server. NetBSD is a highly portable UNIX system that you can literally run on a toaster. +
+ +
+ +## Prerequisites +* Something running NetBSD +* Internet connection + +## Getting microsocks +Microsocks is not in the NetBSD repositories as far as i can tell, so we'll just compile it. +``` +git clone https://github.com/rofl0r/microsocks +cd microsocks +make +make install +``` +And now we have installed Microsocks. Yay! You could just run it in a `screen` or something, but that's not very practical and actually pretty lame, so we'll setup an rc script. + +## Setting up the rc script +Firstly, open /etc/rc.d/microsocks with your preferred editor (I use `Vim` BTW) and add the script below +```sh +#!/bin/sh +# +# PROVIDE: microsocks +# REQUIRE: DAEMON + +. /etc/rc.subr + +name="microsocks" +rcvar=$name +command="/usr/local/bin/microsocks" +pidfile="/var/run/${name}.pid" +start_cmd="microsocks_start" +stop_cmd="microsocks_stop" + +microsocks_start() { + if [ -f "$pidfile" ] && kill -0 $(cat "$pidfile") 2>/dev/null; then + echo "$name is already running." + else + echo "Starting $name..." + ${command} & + echo $! > "$pidfile" + echo "$name started with PID $(cat "$pidfile")." + fi +} + +microsocks_stop() { + if [ -f "$pidfile" ]; then + echo "Stopping $name..." + kill -TERM $(cat "$pidfile") && rm -f "$pidfile" + echo "$name stopped." + else + echo "$name is not running." + fi +} + +load_rc_config $name +run_rc_command "$1" +``` + +Direct your attention towards line 10. There we have the command that starts Microsocks. It doesn't necesarrily need arguments, as such, we can leave it as such, but that's not reccomended. Consult [this page](https://github.com/rofl0r/microsocks/blob/master/README.md#command-line-options) for more information on what arguments you can use. + +Now to test everything is working, you can use this command: +``` +service microsocks onestart +``` +If you're able to connect to your proxy, you've configured it properly. We can now enable it in `/etc/rc.conf`, where we'll append: +``` +microsocks=YES +``` +And now we can restart and you'll see that our proxy is still alive. + +## Conclusion +NetBSD is pretty cool. \ No newline at end of file diff --git a/static/pictures/netbsd-toaster.jpeg b/static/pictures/netbsd-toaster.jpeg new file mode 100644 index 0000000..5e600ba Binary files /dev/null and b/static/pictures/netbsd-toaster.jpeg differ