diff --git a/net/netbird/Makefile b/net/netbird/Makefile new file mode 100644 index 000000000..ab3854bc9 --- /dev/null +++ b/net/netbird/Makefile @@ -0,0 +1,9 @@ +PLUGIN_NAME= netbird +PLUGIN_VERSION= 0.1 +PLUGIN_DEPENDS= netbird +PLUGIN_COMMENT= Peer-to-peer VPN that seamlessly connects your devices +PLUGIN_MAINTAINER= opn-netbird@sun-ri.se +PLUGIN_WWW= https://netbird.io +PLUGIN_DEVEL= yes + +.include "../../Mk/plugins.mk" \ No newline at end of file diff --git a/net/netbird/pkg-descr b/net/netbird/pkg-descr new file mode 100644 index 000000000..2bd140887 --- /dev/null +++ b/net/netbird/pkg-descr @@ -0,0 +1,18 @@ +NetBird is an open-source WireGuard-based overlay network combined with +Zero Trust Network Access, providing secure and reliable connectivity +to internal resources. + +Key features: +- Zero-config VPN: Easily create secure connections between devices without +manual network setup. +- Built on WireGuard: Leverages WireGuard's high-performance encryption for +fast and secure communication. +- Self-hosted or Cloud-managed: Users can deploy their own NetBird management +server or use NetBird Cloud for centralized control. +- Access Control & Routing: Fine-grained access control policies and automatic +network routing simplify connectivity. +- This FreeBSD port provides the NetBird client daemon and CLI tools, allowing +FreeBSD systems to join a NetBird mesh network and securely communicate with +other peers. + +For more details, visit: https://netbird.io \ No newline at end of file diff --git a/net/netbird/src/etc/inc/plugins.inc.d/netbird.inc b/net/netbird/src/etc/inc/plugins.inc.d/netbird.inc new file mode 100644 index 000000000..fb8b4fdce --- /dev/null +++ b/net/netbird/src/etc/inc/plugins.inc.d/netbird.inc @@ -0,0 +1,57 @@ +general->Enabled->isEmpty(); +} + +function netbird_services() +{ + $services = array(); + + if (!netbird_enabled()) { + return $services; + } + + $services[] = array( + 'description' => gettext('Netbird'), + 'configd' => array( + 'restart' => array('netbird restart'), + 'start' => array('netbird start'), + 'stop' => array('netbird stop'), + ), + 'name' => 'netbird', + 'pidfile' => '/var/run/netbird.pid', + ); + + return $services; +} + diff --git a/net/netbird/src/etc/rc.syshook.d/carp/30-netbird b/net/netbird/src/etc/rc.syshook.d/carp/30-netbird new file mode 100755 index 000000000..824d74f3b --- /dev/null +++ b/net/netbird/src/etc/rc.syshook.d/carp/30-netbird @@ -0,0 +1,78 @@ +#!/usr/local/bin/php + + * Copyright (C) 2025 Ralph Moser, PJ Monitoring GmbH + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, + * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + * AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + */ + +require_once('config.inc'); +require_once('util.inc'); +require_once('interfaces.inc'); + + +$model = new \OPNsense\netbird\Netbird(); +$enabled = $model->general->Enabled->__toString(); + + +if(!$enabled) { + exit(0); +} + +$carpif = $model->general->CarpIf->__toString(); + +if($carpif == '') { + exit(0); +} + +$target_vhid = $model->general->VHID; +$subsystem = !empty($argv[1]) ? $argv[1] : ''; +$type = !empty($argv[2]) ? $argv[2] : ''; + +if ($type != 'MASTER' && $type != 'BACKUP') { + exit(1); +} + +if (!strstr($subsystem, '@')) { + exit(1); +} + +list ($vhid, $iface) = explode('@', $subsystem); +$friendly = convert_real_interface_to_friendly_interface_name($iface); + + +if ($carpif != $friendly || $vhid != $target_vhid) { + exit(0); +} + +switch ($type) { + case 'MASTER': + shell_exec('/usr/local/bin/netbird up'); + break; + case 'BACKUP': + shell_exec('/usr/local/bin/netbird down'); + break; +} + diff --git a/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/Api/InitialController.php b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/Api/InitialController.php new file mode 100644 index 000000000..e74610aa9 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/Api/InitialController.php @@ -0,0 +1,44 @@ +configdRun("netbird con-status"); + if ($bckResult !== null) { + return nl2br(htmlspecialchars($bckResult)); + } + return "Error retrieving connection status"; + } + + public function searchFilter($array, $value): bool + { + foreach ($array as $val) { + if (str_contains(strval($val), strtolower($value))) { + return true; + } + } + return false; + } + + public function upDownStatusAction(): string + { + $backend = new Backend(); + $bckResult = $backend->configdRun("netbird status"); + if (!str_contains($bckResult, "is running")) { + return json_encode(array('updown' => "NOT RUNNING", 'status' => "Netbird is not running")); + } + $bckResult = $backend->configdRun("netbird short-con-status"); + $txtStatus = nl2br(htmlspecialchars($bckResult)); + $bckResult = $backend->configdRun("netbird con-status-json"); + $status = json_decode($bckResult, true); + if (!$status['publicKey']) { + return json_encode(array('updown' => "DOWN", 'status' => $txtStatus)); + } + return json_encode(array('updown' => "UP", 'status' => $txtStatus)); + } + + public function searchAction(): string + { + $request = $this->request; + $backend = new Backend(); + $bckResult = $backend->configdRun("netbird status"); + if (!str_contains($bckResult, "is running")) { + return json_encode(array('current' => 1, 'rowCount' => 0, 'total' => 0, 'rows' => array())); + } + $bckResult = $backend->configdRun("netbird con-status-json"); + $status = json_decode($bckResult, true); + $itemsPerPage = $request->get('rowCount', 'int', -1); + $currentPage = $request->get('current', 'int', 1); + $sortBy = array('status'); + $sortDescending = false; + + + $searchPhrase = strtolower($request->get('searchPhrase', 'string', '')); + if (!$status['peers']['details']) { + return json_encode(array('current' => 1, 'rowCount' => 0, 'total' => 0, 'rows' => array())); + } + $details = $status['peers']['details']; + $details = array_filter($details, function ($item) use ($searchPhrase) { + return $this->searchFilter($item, $searchPhrase); + }); + $detailsFlat = array(); + foreach ($details as $detail) { + $detailsFlat[] = $this->flattenOneLevel($detail); + } + if ($request->hasPost('sort') && is_array($request->get("sort")) && !empty($request->get("sort"))) { + $sortBy = array_keys($request->get("sort")); + if (!empty($sortBy) && $request->get("sort")[$sortBy[0]] == "desc") { + $sortDescending = true; + } + + } + $sortValues = array(); + foreach ($detailsFlat as $detail) { + $sortValues[] = $detail[$sortBy[0]]; + } + array_multisort($sortValues, $sortDescending ? SORT_DESC : SORT_ASC, $detailsFlat); + $page = array_slice($detailsFlat, ($currentPage - 1) * $itemsPerPage, $itemsPerPage); + $page = $this->convertFieldsToDisplay($page); + $result = array('current' => $currentPage, 'rowCount' => count($page), 'total' => count($detailsFlat), 'rows' => $page); + return json_encode($result); + } + + private function flattenOneLevel($array): array + { + $result = array(); + foreach ($array as $key => $value) { + if (is_array($value)) { + foreach ($value as $subkey => $subvalue) { + if ($key == "routes") { + $result[$key] = implode("
", $value); + } + else { + $result[$key . "." . $subkey] = $subvalue; + } + } + } else { + $result[$key] = $value; + } + } + return $result; + } + + public function setUpAction(): string + { + $backend = new Backend(); + try { + return $backend->configdRun("netbird set-up"); + } catch (\Exception $e) { + return "Error running netbird up" . "\n" . $e->getMessage(); + } + } + + public function initialUpAction(): string + { + $backend = new Backend(); + $mdlInitial = new Initial(); + $key = $mdlInitial->initial->setupkey->__toString(); + $api = $mdlInitial->initial->mgmtservice->__toString(); + $hostname = $mdlInitial->initial->hostname->__toString(); + if ($hostname == "") { + $hostname = gethostname(); + if(!$hostname){ + $hostname = "OPNsense"; + }else{ + if(str_contains($hostname, ".")){ + $hostname = explode(".", $hostname)[0]; + } + } + + $mdlInitial->initial->hostname = $hostname; + } + $mdlInitial->initial->setupkey = "00000000-0000-0000-0000-000000000000"; + $mdlInitial->initial->initsure = 0; + + $mdlInitial->serializeToConfig(); + $cnf = Config::getInstance(); + $cnf->save(); + + $bckresult = $backend->configdRun("netbird set-up-initial " . escapeshellarg($api) . " " . escapeshellarg($key) . " " . escapeshellarg($hostname)); + return nl2br(htmlspecialchars($bckresult)); + } + + public function setDownAction(): string + { + $backend = new Backend(); + try { + return $backend->configdRun("netbird set-down"); + } catch (\Exception $e) { + return "Error running netbird down" . "\n" . $e->getMessage(); + } + } + + public function reloadAction() + { + $status = "failed"; + if ($this->request->isPost()) { + try { + $mdlNetbird = new Netbird(); + $backend = new Backend(); + if (trim($backend->configdRun('template reload OPNsense/netbird')) == "OK") { + $status = "ok"; + } + + $enabled = $mdlNetbird->general->Enabled->__toString() == 1; + $carpEnabled = $mdlNetbird->general->CarpIf->__toString() != ''; + $disableClientRoutes = $mdlNetbird->general->DisableClientRoutes->__toString() == 1; + $disableServerRoutes = $mdlNetbird->general->DisableServerRoutes->__toString() == 1; + $disableDNS = $mdlNetbird->general->DisableDNS->__toString() == 1; + $rpEnabled = $mdlNetbird->general->QuantumEnabled->__toString() == 1; + $rpPermissive = $mdlNetbird->general->QuantumPermissive->__toString() == 1; + $wgPort = $mdlNetbird->general->WgPort->__toString(); + $netbirdConfigJson = file_get_contents(self::NETBIRD_CONFIG_JSON); + $netbirdConfig = json_decode($netbirdConfigJson, true); + $netbirdConfig["DisableAutoConnect"] = $carpEnabled; + $netbirdConfig["DisableClientRoutes"] = $disableClientRoutes; + $netbirdConfig["DisableServerRoutes"] = $disableServerRoutes; + $netbirdConfig["DisableDNS"] = $disableDNS; + $netbirdConfig["RosenpassEnabled"] = $rpEnabled; + $netbirdConfig["RosenpassPermissive"] = $rpPermissive; + $netbirdConfig["WgPort"] = intval($wgPort); + $netbirdConfigJson = json_encode($netbirdConfig); + file_put_contents(self::NETBIRD_CONFIG_JSON, $netbirdConfigJson); + $action = $enabled ? "restart" : "stop"; + $backend->configdRun("netbird $action"); + } catch (\Exception $e) { + $status = "failed"; + syslog(LOG_ERR, "netbird: failed to reload configuration: " . $e->getMessage()); + } + } + return array("status" => $status); + } + + /** + * @param array $page + * @return array + */ + public function convertFieldsToDisplay(array $page): array + { + for ($i = 0; $i < count($page); $i++) { + $page[$i]['latency'] = round($page[$i]['latency'] / 1000000, 2) . " ms"; + $received = $page[$i]['transferReceived']; + $rcvUnit = "KiB"; + $received /= 1024; + if ($received > 1024) { + $received /= 1024; + $rcvUnit = "MiB"; + } + if ($received > 1024) { + $received /= 1024; + $rcvUnit = "GiB"; + } + + $sent = $page[$i]['transferSent']; + $sentUnit = "KiB"; + $sent /= 1024; + if ($sent > 1024) { + $sent /= 1024; + $sentUnit = "MiB"; + } + if ($sent > 1024) { + $sent /= 1024; + $sentUnit = "GiB"; + } + $page[$i]['transferReceived'] = round($received, 2) . " " . $rcvUnit; + $page[$i]['transferSent'] = round($sent, 2) . " " . $sentUnit; + $page[$i]['lastStatusUpdate'] = date("Y-m-d H:i:s", strtotime($page[$i]['lastStatusUpdate'])); + $page[$i]['lastWireguardHandshake'] = date("Y-m-d H:i:s", strtotime($page[$i]['lastWireguardHandshake'])); + foreach ($page[$i] as $key => $value) { + if ($value == "true") { + $page[$i][$key] = 1; + } elseif ($value == "false") { + $page[$i][$key] = 0; + } + + } + } + return $page; + } +} diff --git a/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/Api/SettingsController.php b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/Api/SettingsController.php new file mode 100644 index 000000000..8f880f942 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/Api/SettingsController.php @@ -0,0 +1,43 @@ +view->pick('OPNsense/netbird/constatus'); + } +} diff --git a/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/IndexController.php b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/IndexController.php new file mode 100644 index 000000000..f17874e21 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/IndexController.php @@ -0,0 +1,45 @@ +view->generalForm = $this->getForm("general"); + $this->view->initialUpForm = $this->getForm("initialup"); + $this->view->pick('OPNsense/netbird/index'); + } +} diff --git a/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/forms/general.xml b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/forms/general.xml new file mode 100644 index 000000000..94513a0cd --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/forms/general.xml @@ -0,0 +1,56 @@ +
+ + netbird.general.Enabled + + checkbox + Enable Netbird + + + netbird.general.WgPort + + text + + + netbird.general.DisableDNS + + checkbox + Disables DNS lookups for the Netbird network. + + + netbird.general.DisableServerRoutes + + checkbox + Prevents Netbird from being a routing peer for other Netbird peers. + + + netbird.general.DisableClientRoutes + + checkbox + Prevents Netbird from setting client routes to other remote peers. + + + netbird.general.QuantumEnabled + + checkbox + Enable Rosenpass + + + netbird.general.QuantumPermissive + + checkbox + Enable Rosenpass permissive mode + + + netbird.general.CarpIf + + dropdown + If set to none Netbird up is executed and auto connect is enabled. If an interface is selected auto + connect is disabled. Please trigger a CARP event or execute Netbird up manually on the MASTER node. + + + + netbird.general.VHID + + text + +
diff --git a/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/forms/initialup.xml b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/forms/initialup.xml new file mode 100644 index 000000000..eb4db002f --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/controllers/OPNsense/netbird/forms/initialup.xml @@ -0,0 +1,25 @@ +
+ + netbird.initial.mgmtservice + + text + + + netbird.initial.setupkey + + text + + + netbird.initial.hostname + + text + If empty the system hostname excluding the domain part will be used. + + + netbird.initial.initsure + + checkbox + If you enable this checkbox and submit the form your old netbird config will be deleted. In case of an error it will get restored. Should something go terribly wrong you can find the backups + in the configuration folder. (/usr/local/etc/netbird) + +
diff --git a/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/ACL/ACL.xml b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/ACL/ACL.xml new file mode 100644 index 000000000..d5e38af31 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/ACL/ACL.xml @@ -0,0 +1,9 @@ + + + VPN: Netbird + + ui/netbird/* + api/netbird/* + + + diff --git a/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Initial.php b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Initial.php new file mode 100644 index 000000000..e629015fe --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Initial.php @@ -0,0 +1,37 @@ + + //OPNsense/netbird-initial + + Netbird initial setup + + + + + + + /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i + Please specify a valid setup key. + + + Y + https://api.netbird.io:443 + + + N + N + N + N + N + Please specify a valid hostname. + + + 0 + Y + + + + diff --git a/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Menu/Menu.xml b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Menu/Menu.xml new file mode 100644 index 000000000..b499dd889 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Menu/Menu.xml @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Netbird.php b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Netbird.php new file mode 100644 index 000000000..76dbf4784 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/models/OPNsense/netbird/Netbird.php @@ -0,0 +1,37 @@ + + //OPNsense/netbird + 0.8.1 + Netbird plugin + + + + + + 0 + Y + + + Y + 51820 + + + 0 + Y + + + 1 + Y + + + 1 + Y + + + 1 + Y + + + 0 + Y + + + N + + + N + 1 + + + + diff --git a/net/netbird/src/opnsense/mvc/app/views/OPNsense/netbird/constatus.volt b/net/netbird/src/opnsense/mvc/app/views/OPNsense/netbird/constatus.volt new file mode 100644 index 000000000..4d12f6127 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/views/OPNsense/netbird/constatus.volt @@ -0,0 +1,164 @@ +{# + # Copyright (C) 2025 Ralph Moser, PJ Monitoring GmbH + # Copyright (C) 2025 squared GmbH + # Copyright (C) 2025 Christopher Linn, BackendMedia IT-Services GmbH + # All rights reserved. + # + # Redistribution and use in source and binary forms, with or without modification, + # are permitted provided that the following conditions are met: + # + # 1. Redistributions of source code must retain the above copyright notice, + # this list of conditions and the following disclaimer. + # + # 2. Redistributions in binary form must reproduce the above copyright notice, + # this list of conditions and the following disclaimer in the documentation + # and/or other materials provided with the distribution. + # + # THIS SOFTWARE IS PROVIDED “AS IS” AND ANY EXPRESS OR IMPLIED WARRANTIES, + # INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + # AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + # AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + # OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + # POSSIBILITY OF SUCH DAMAGE. + #} + + +
+

Netbird Connection

+ +
+
+ + +
+ +
+

Peers

+ + + + + + + + + + + + + + + + + + + + + + + +
{{ lang._('FQDN') }}{{ lang._('Routes') }}{{ lang._('IP') }}{{ lang._('Direct') }}{{ lang._('Status') }}{{ lang._('Last Handshake') }}{{ lang._('Last Status Update') }}{{ lang._('Received') }}{{ lang._('Sent') }}{{ lang._('Latency') }}{{ lang._('Connection Type') }}{{ lang._('QR') }}{{ lang._('ICE TL') }}{{ lang._('ICE TR') }}{{ lang._('ICE EP Local') }}{{ lang._('ICE EP Remote') }}
+
+
+

{{ lang._('Status Output') }}

+
+
+
+ +
+ +
diff --git a/net/netbird/src/opnsense/mvc/app/views/OPNsense/netbird/index.volt b/net/netbird/src/opnsense/mvc/app/views/OPNsense/netbird/index.volt new file mode 100644 index 000000000..e3225bba8 --- /dev/null +++ b/net/netbird/src/opnsense/mvc/app/views/OPNsense/netbird/index.volt @@ -0,0 +1,107 @@ +{# + # Copyright (C) 2025 Ralph Moser, PJ Monitoring GmbH + # Copyright (C) 2025 squared GmbH + # Copyright (C) 2025 Christopher Linn, BackendMedia IT-Services GmbH + # All rights reserved. + # + # Redistribution and use in source and binary forms, with or without modification, + # are permitted provided that the following conditions are met: + # + # 1. Redistributions of source code must retain the above copyright notice, + # this list of conditions and the following disclaimer. + # + # 2. Redistributions in binary form must reproduce the above copyright notice, + # this list of conditions and the following disclaimer in the documentation + # and/or other materials provided with the distribution. + # + # THIS SOFTWARE IS PROVIDED “AS IS” AND ANY EXPRESS OR IMPLIED WARRANTIES, + # INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + # AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + # AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + # OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + # POSSIBILITY OF SUCH DAMAGE. + #} + + + + + +
+ {{ partial("layout_partials/base_form",['fields':generalForm,'id':'frm_GeneralSettings']) }} +
+ +
+ +
+ +
+ {{ partial("layout_partials/base_form",['fields':initialUpForm,'id':'frm_InitialUp']) }} +
+ +
+ +
+ + diff --git a/net/netbird/src/opnsense/scripts/OPNsense/netbird/initialup.sh b/net/netbird/src/opnsense/scripts/OPNsense/netbird/initialup.sh new file mode 100755 index 000000000..e338ef405 --- /dev/null +++ b/net/netbird/src/opnsense/scripts/OPNsense/netbird/initialup.sh @@ -0,0 +1,16 @@ +#!/bin/sh +timestamp=$(date +%s) +/usr/local/etc/rc.d/netbird stop +echo "Deleting old configuration file" +mv /usr/local/etc/netbird/config.json /usr/local/etc/netbird/config.json.$timestamp +/usr/local/etc/rc.d/netbird start +/usr/local/bin/netbird up $@ 2>&1 +if [ $? -ne 0 ]; then + /usr/local/etc/rc.d/netbird stop + echo "Failed to bring up netbird" + echo "Restoring old configuration file" + mv /usr/local/etc/netbird/config.json /usr/local/etc/netbird/config.json.$timestamp.fail + mv /usr/local/etc/netbird/config.json.$timestamp /usr/local/etc/netbird/config.json + /usr/local/etc/rc.d/netbird start +fi +exit 0 \ No newline at end of file diff --git a/net/netbird/src/opnsense/service/conf/actions.d/actions_netbird.conf b/net/netbird/src/opnsense/service/conf/actions.d/actions_netbird.conf new file mode 100644 index 000000000..65711c67c --- /dev/null +++ b/net/netbird/src/opnsense/service/conf/actions.d/actions_netbird.conf @@ -0,0 +1,57 @@ +[start] +command:/usr/local/etc/rc.d/netbird start +parameters: +type:script +message:starting netbird + +[stop] +command:/usr/local/etc/rc.d/netbird stop +parameters: +type:script +message:stopping netbird + +[restart] +command:/usr/local/etc/rc.d/netbird restart +parameters: +type:script +message:restarting netbird + +[status] +command:/usr/local/etc/rc.d/netbird status +errors:no +type:script_output +message:get netbird status + +[con-status] +command:/usr/local/bin/netbird status -d +errors:no +type:script_output +message:get netbird connection status + +[set-up] +command:/usr/local/bin/netbird up +type:script +message:set netbird up + +[set-up-initial] +command:/usr/local/opnsense/scripts/OPNsense/netbird/initialup.sh +parameters: -m %s -k %s -n %s +type:script_output +message:setup netbird + +[set-down] +command:/usr/local/bin/netbird down +type:script +message:set netbird down + +[short-con-status] +command:/usr/local/bin/netbird status +errors:no +type:script_output +message:get short netbird connection status + +[con-status-json] +command:/usr/local/bin/netbird status --json +errors:no +type:script_output +message:get netbird connection status \ No newline at end of file diff --git a/net/netbird/src/opnsense/service/templates/OPNsense/Syslog/local/netbird.conf b/net/netbird/src/opnsense/service/templates/OPNsense/Syslog/local/netbird.conf new file mode 100644 index 000000000..c16a43df7 --- /dev/null +++ b/net/netbird/src/opnsense/service/templates/OPNsense/Syslog/local/netbird.conf @@ -0,0 +1,6 @@ +################################################################### +# Local syslog-ng configuration filter definition [netbird]. +################################################################### +filter f_local_netbird { + program("netbird"); +}; diff --git a/net/netbird/src/opnsense/service/templates/OPNsense/netbird/+TARGETS b/net/netbird/src/opnsense/service/templates/OPNsense/netbird/+TARGETS new file mode 100644 index 000000000..123637703 --- /dev/null +++ b/net/netbird/src/opnsense/service/templates/OPNsense/netbird/+TARGETS @@ -0,0 +1 @@ +netbird:/etc/rc.conf.d/netbird \ No newline at end of file diff --git a/net/netbird/src/opnsense/service/templates/OPNsense/netbird/netbird b/net/netbird/src/opnsense/service/templates/OPNsense/netbird/netbird new file mode 100644 index 000000000..fba7bdb83 --- /dev/null +++ b/net/netbird/src/opnsense/service/templates/OPNsense/netbird/netbird @@ -0,0 +1,5 @@ +{% if helpers.exists('OPNsense.netbird.general.Enabled') and OPNsense.netbird.general.Enabled|default("0") == '1' %} +netbird_enable="YES" +{% else %} +netbird_enable="NO" +{% endif %}