[pve-devel] [PATCH container 1/2] fix #2044: add openwrt support
Oguz Bektas
o.bektas at proxmox.com
Mon Nov 8 14:43:59 CET 2021
---
src/PVE/LXC/Setup.pm | 4 ++
src/PVE/LXC/Setup/Makefile | 1 +
src/PVE/LXC/Setup/OpenWrt.pm | 82 ++++++++++++++++++++++++++++++++++++
3 files changed, 87 insertions(+)
create mode 100644 src/PVE/LXC/Setup/OpenWrt.pm
diff --git a/src/PVE/LXC/Setup.pm b/src/PVE/LXC/Setup.pm
index 5cc56af..e89886f 100644
--- a/src/PVE/LXC/Setup.pm
+++ b/src/PVE/LXC/Setup.pm
@@ -17,6 +17,7 @@ use PVE::LXC::Setup::Fedora;
use PVE::LXC::Setup::Gentoo;
use PVE::LXC::Setup::SUSE;
use PVE::LXC::Setup::Ubuntu;
+use PVE::LXC::Setup::OpenWrt;
use PVE::LXC::Setup::Unmanaged;
my $plugins = {
@@ -28,6 +29,7 @@ my $plugins = {
fedora => 'PVE::LXC::Setup::Fedora',
gentoo => 'PVE::LXC::Setup::Gentoo',
opensuse => 'PVE::LXC::Setup::SUSE',
+ openwrt => 'PVE::LXC::Setup::OpenWrt',
ubuntu => 'PVE::LXC::Setup::Ubuntu',
unmanaged => 'PVE::LXC::Setup::Unmanaged',
};
@@ -75,6 +77,8 @@ my $autodetect_type = sub {
return "alpine";
} elsif (-f "$rootdir/etc/gentoo-release") {
return "gentoo";
+ } elsif (-f "$rootdir/etc/openwrt_release") {
+ return "openwrt";
} elsif (-f "$rootdir/etc/os-release") {
die "unable to detect OS distribution\n";
} else {
diff --git a/src/PVE/LXC/Setup/Makefile b/src/PVE/LXC/Setup/Makefile
index 04ee2e4..22702ca 100644
--- a/src/PVE/LXC/Setup/Makefile
+++ b/src/PVE/LXC/Setup/Makefile
@@ -9,6 +9,7 @@ SOURCES=\
Fedora.pm \
Gentoo.pm \
SUSE.pm \
+ OpenWrt.pm \
Ubuntu.pm \
Unmanaged.pm \
diff --git a/src/PVE/LXC/Setup/OpenWrt.pm b/src/PVE/LXC/Setup/OpenWrt.pm
new file mode 100644
index 0000000..89ea740
--- /dev/null
+++ b/src/PVE/LXC/Setup/OpenWrt.pm
@@ -0,0 +1,82 @@
+package PVE::LXC::Setup::OpenWrt;
+
+use strict;
+use warnings;
+
+use PVE::LXC;
+use PVE::Network;
+use File::Path;
+
+use PVE::LXC::Setup::Base;
+use base qw(PVE::LXC::Setup::Base);
+
+my $known_versions = {
+ '21.02.1' => 1,
+};
+
+sub new {
+ my ($class, $conf, $rootdir) = @_;
+
+ my $version;
+ my $release = PVE::Tools::file_get_contents("$rootdir/etc/openwrt_release");
+ if ($release =~ m/^DISTRIB_RELEASE=\'(\d+\.\d+\.\d+)\'$/mi) {
+ $version = $1;
+ }
+ die "unsupported OpenWrt version '$version'\n"
+ if !$known_versions->{$version};
+
+ my $self = { conf => $conf, rootdir => $rootdir, version => $version };
+
+ $conf->{ostype} = "openwrt";
+
+ return bless $self, $class;
+}
+
+sub template_fixup {
+ my ($self, $conf) = @_;
+}
+
+sub setup_init {
+ my ($self, $conf) = @_;
+}
+
+sub setup_network {
+ my ($self, $conf) = @_;
+
+ my $d;
+ foreach my $k (keys %$conf) {
+ next if $k !~ m/^net(\d+)$/;
+ $d = PVE::LXC::Config->parse_lxc_network($conf->{$k});
+ next if !$d->{name};
+ }
+
+ my $proto = ($d->{ip} eq 'dhcp') ? 'dhcp' : 'static';
+ my $ip = "";
+ if ($proto eq 'static') {
+ $ip = $d->{ip};
+ }
+
+ my $data = <<"DATA";
+config interface 'loopback'
+ option proto 'static'
+ option ipaddr '127.0.0.1'
+ option netmask '255.0.0.0'
+ option device 'lo'
+
+config interface 'wan'
+ option proto '$proto'
+ option device '$d->{name}'
+ option ipaddr '$ip'
+ option netmask '255.255.255.0'
+DATA
+ $self->ct_file_set_contents("/etc/config/network", $data);
+}
+
+# non systemd based containers work with pure cgroupv2
+sub unified_cgroupv2_support {
+ my ($self) = @_;
+
+ return 1;
+}
+
+1
--
2.30.2
More information about the pve-devel
mailing list