add sysbox
This commit is contained in:
@@ -39,6 +39,10 @@
|
|||||||
./hardware-configuration.nix
|
./hardware-configuration.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
|
nixpkgs.overlays = [
|
||||||
|
(import ./utils/overlays/packages.nix)
|
||||||
|
];
|
||||||
|
|
||||||
nixpkgs.config.permittedInsecurePackages = [
|
nixpkgs.config.permittedInsecurePackages = [
|
||||||
"openssl-1.1.1w"
|
"openssl-1.1.1w"
|
||||||
];
|
];
|
||||||
@@ -57,6 +61,7 @@
|
|||||||
ethtool # manage NIC settings (offload, NIC feeatures, ...)
|
ethtool # manage NIC settings (offload, NIC feeatures, ...)
|
||||||
tcpdump # view network traffic
|
tcpdump # view network traffic
|
||||||
conntrack-tools # view network connection states
|
conntrack-tools # view network connection states
|
||||||
|
sysbox
|
||||||
];
|
];
|
||||||
|
|
||||||
nix.gc = {
|
nix.gc = {
|
||||||
|
|||||||
@@ -69,8 +69,6 @@ in
|
|||||||
"/var/lib/gitea:/data"
|
"/var/lib/gitea:/data"
|
||||||
"/etc/gitea/app.ini:/data/custom/conf/app.ini:ro"
|
"/etc/gitea/app.ini:/data/custom/conf/app.ini:ro"
|
||||||
"/var/lib/acme/git.cloonar.com:/ssl:ro"
|
"/var/lib/acme/git.cloonar.com:/ssl:ro"
|
||||||
"/etc/timezone:/etc/timezone:ro"
|
|
||||||
"/etc/localtime:/etc/localtime:ro"
|
|
||||||
];
|
];
|
||||||
environment = {
|
environment = {
|
||||||
USER_UID = builtins.toString config.users.users.gitea.uid;
|
USER_UID = builtins.toString config.users.users.gitea.uid;
|
||||||
|
|||||||
@@ -29,11 +29,5 @@
|
|||||||
proxy_set_header Connection $connection_upgrade;
|
proxy_set_header Connection $connection_upgrade;
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
# networking.firewall = {
|
|
||||||
# allowedUDPPorts = [
|
|
||||||
# 5683 # shelly coiot
|
|
||||||
# ];
|
|
||||||
# };
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -26,8 +26,7 @@
|
|||||||
Restart = "always";
|
Restart = "always";
|
||||||
ExecStartPre= ''
|
ExecStartPre= ''
|
||||||
-${pkgs.docker}/bin/docker stop %n \
|
-${pkgs.docker}/bin/docker stop %n \
|
||||||
-${pkgs.docker}/bin/docker rm %n \
|
${pkgs.docker}/bin/docker rm %n
|
||||||
${pkgs.docker}/bin/docker pull drone/drone:2.20.0
|
|
||||||
'';
|
'';
|
||||||
ExecStart= ''
|
ExecStart= ''
|
||||||
${pkgs.docker}/bin/docker run --rm --name %n \
|
${pkgs.docker}/bin/docker run --rm --name %n \
|
||||||
|
|||||||
@@ -26,8 +26,7 @@
|
|||||||
Restart = "always";
|
Restart = "always";
|
||||||
ExecStartPre= ''
|
ExecStartPre= ''
|
||||||
-${pkgs.docker}/bin/docker stop %n \
|
-${pkgs.docker}/bin/docker stop %n \
|
||||||
-${pkgs.docker}/bin/docker rm %n \
|
${pkgs.docker}/bin/docker rm %n
|
||||||
${pkgs.docker}/bin/docker pull drone/drone:2.20.0
|
|
||||||
'';
|
'';
|
||||||
ExecStart= ''
|
ExecStart= ''
|
||||||
${pkgs.docker}/bin/docker run --rm --name %n \
|
${pkgs.docker}/bin/docker run --rm --name %n \
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
self: super: {
|
self: super: {
|
||||||
bento = (super.callPackage ../pkgs/bento { });
|
bento = (super.callPackage ../pkgs/bento { });
|
||||||
ykfde = (super.callPackage ../pkgs/ykfde { });
|
ykfde = (super.callPackage ../pkgs/ykfde { });
|
||||||
|
sysbox = (super.callPackage ../pkgs/sysbox { });
|
||||||
wow-addon-manager = (super.callPackage ../pkgs/wow-addon-manager { });
|
wow-addon-manager = (super.callPackage ../pkgs/wow-addon-manager { });
|
||||||
}
|
}
|
||||||
|
|||||||
82
utils/pkgs/sysbox.nix
Normal file
82
utils/pkgs/sysbox.nix
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
{ lib
|
||||||
|
, stdenv
|
||||||
|
, buildGoModule
|
||||||
|
, fetchurl
|
||||||
|
, makeWrapper
|
||||||
|
, git
|
||||||
|
, bash
|
||||||
|
, coreutils
|
||||||
|
, gitea
|
||||||
|
, gzip
|
||||||
|
, openssh
|
||||||
|
, pam
|
||||||
|
, sqliteSupport ? true
|
||||||
|
, pamSupport ? true
|
||||||
|
, runCommand
|
||||||
|
, brotli
|
||||||
|
, xorg
|
||||||
|
, nixosTests
|
||||||
|
}:
|
||||||
|
|
||||||
|
buildGoModule rec {
|
||||||
|
pname = "sysbox";
|
||||||
|
version = "0.6.2";
|
||||||
|
|
||||||
|
# not fetching directly from the git repo, because that lacks several vendor files for the web UI
|
||||||
|
src = fetchurl {
|
||||||
|
url = "https://github.com/nestybox/sysbox/archive/refs/tags/v${version}.tar.gz";
|
||||||
|
hash = "sha256-cH/AHsFXOdvfSfj9AZUd3l/RlYE06o1ByZu0vvGQuXw=";
|
||||||
|
};
|
||||||
|
|
||||||
|
vendorHash = null;
|
||||||
|
|
||||||
|
# subPackages = [ "." ];
|
||||||
|
|
||||||
|
nativeBuildInputs = [ makeWrapper ];
|
||||||
|
|
||||||
|
# buildInputs = lib.optional pamSupport pam;
|
||||||
|
|
||||||
|
# tags = lib.optional pamSupport "pam"
|
||||||
|
# ++ lib.optionals sqliteSupport [ "sqlite" "sqlite_unlock_notify" ];
|
||||||
|
|
||||||
|
# ldflags = [
|
||||||
|
# "-s"
|
||||||
|
# "-w"
|
||||||
|
# "-X main.Version=${version}"
|
||||||
|
# "-X 'main.Tags=${lib.concatStringsSep " " tags}'"
|
||||||
|
# ];
|
||||||
|
|
||||||
|
outputs = [ "out" ];
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
mkdir -p $out
|
||||||
|
# cp -R ./options/locale $out/locale
|
||||||
|
|
||||||
|
wrapProgram $out/bin/gitea \
|
||||||
|
--prefix PATH : ${lib.makeBinPath [ ]}
|
||||||
|
'';
|
||||||
|
|
||||||
|
# passthru = {
|
||||||
|
# data-compressed = runCommand "gitea-data-compressed" {
|
||||||
|
# nativeBuildInputs = [ brotli xorg.lndir ];
|
||||||
|
# } ''
|
||||||
|
# mkdir $out
|
||||||
|
# lndir ${gitea.data}/ $out/
|
||||||
|
#
|
||||||
|
# # Create static gzip and brotli files
|
||||||
|
# find -L $out -type f -regextype posix-extended -iregex '.*\.(css|html|js|svg|ttf|txt)' \
|
||||||
|
# -exec gzip --best --keep --force {} ';' \
|
||||||
|
# -exec brotli --best --keep --no-copy-stat {} ';'
|
||||||
|
# '';
|
||||||
|
#
|
||||||
|
# tests = nixosTests.gitea;
|
||||||
|
# };
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "Improves container isolation";
|
||||||
|
homepage = "https://github.com/nestybox/sysbox";
|
||||||
|
license = licenses.apache;
|
||||||
|
broken = stdenv.isDarwin;
|
||||||
|
mainProgram = "sysbox-runc";
|
||||||
|
};
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user