12 Commits

Author SHA1 Message Date
6d6587dd87 update to 24.20.2 2025-08-30 12:26:27 +02:00
995033f526 update to 24.10 2025-03-15 12:16:24 +01:00
fb42ccefaa update to 23.05.5 2024-10-03 13:34:43 +02:00
08c00ac2a7 update to 23.05.3 2024-05-09 13:26:18 +00:00
1d5687bbae update to 23.05.2 2024-03-11 20:21:18 +00:00
f3f4cdeabc fix alias.sh 2023-04-23 11:21:01 +00:00
2d062dee87 update 22.03.4 2023-04-23 11:20:38 +00:00
stubbfelnewpc
12dc7b849c update to 22.03.2 2022-11-09 22:23:55 +01:00
stubbfelnewpc
38d9016792 ad mosquitto 2022-09-01 23:00:25 +02:00
stubbfelnewpc
3ea4574917 update deps 2022-09-01 22:36:08 +02:00
stubbfelnewpc
677e22d5e2 update to 21.02.3 2022-05-29 18:07:22 +02:00
stubbfelnewpc
2b96ab089c update to 21.02.2 2022-04-02 14:57:21 +02:00
11 changed files with 187 additions and 15 deletions

View File

@@ -0,0 +1,42 @@
// For format details, see https://aka.ms/devcontainer.json. For config options, see the
// README at: https://github.com/devcontainers/templates/tree/main/src/alpine
{
"name": "Alpine",
// Or use a Dockerfile or Docker Compose file. More info: https://containers.dev/guide/dockerfile
"image": "mcr.microsoft.com/devcontainers/base:alpine",
"features": {
"ghcr.io/devcontainers/features/nix:1": {
"packages": "nixpkgs-fmt",
"extraNixConfig": "experimental-features = nix-command flakes"
}
},
// Use 'forwardPorts' to make a list of ports inside the container available locally.
// "forwardPorts": [],
// Configure tool-specific properties.
"runArgs": ["--userns=keep-id"],
"containerUser": "vscode",
"customizations": {
"vscode": {
"extensions": [
"bbenoist.Nix"
]
}
},
// Features to add to the dev container. More info: https://containers.dev/features.
// "features": {},
// Use 'forwardPorts' to make a list of ports inside the container available locally.
// "forwardPorts": [],
// Use 'postCreateCommand' to run commands after the container is created.
// "postCreateCommand": "uname -a",
// Configure tool-specific properties.
// "customizations": {},
// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root.
// "remoteUser": "root"
}

1
.gitignore vendored
View File

@@ -1 +1,2 @@
_*
result

View File

@@ -1,4 +1,4 @@
MIT No Attribution Copyright 2020 stubbfel
MIT No Attribution Copyright 2024 stubbfel
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal

View File

@@ -24,32 +24,37 @@ This file setup the nix shell with all necessary dependencies and shell environm
### Commands
loadBuilder -> load device specific image builder and manifest ("default") packages list:
```sh
# nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="<target_name>"; arch="<arch_name"; version="<openwrt_release_version>"; profile="<profile_name>"; packages=[<list_of_user_packages>];}' --pure --run loadBuilder
nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="brcm2708"; arch="bcm2708"; version="19.07.4"; profile="rpi"; packages=["luci-ssl"];}' --pure --run loadBuilder
```
makeImage -> create image by image builder
```sh
# nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="<target_name>"; arch="<arch_name"; version="<openwrt_release_version>"; profile="<profile_name>"; packages=[<list_of_user_packages>];}' --pure --run makeCmakeImageleanImage
nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="brcm2708"; arch="bcm2708"; version="19.07.4"; profile="rpi"; packages=["luci-ssl"];}' --pure --run makeImage
```
removeBuilder -> remove image builder
```sh
# nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="<target_name>"; arch="<arch_name"; version="<openwrt_release_version>"; profile="<profile_name>"; packages=[<list_of_user_packages>];}' --pure --run removeBuilder
nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="brcm2708"; arch="bcm2708"; version="19.07.4"; profile="rpi"; packages=["luci-ssl"];}' --pure --run removeBuilder
```
makeCleanImage -> remove old image builder, load new image builder and create image
```sh
# nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="<target_name>"; arch="<arch_name"; version="<openwrt_release_version>"; profile="<profile_name>"; packages=[<list_of_user_packages>];}' --pure --run makeCleanImage
nix-shell --expr 'with import <nixpkgs> {}; callPackage ./buildOpenwrt.nix {target="brcm2708"; arch="bcm2708"; version="19.07.4"; profile="rpi"; packages=["luci-ssl"];}' --pure --run makeCleanImage
```
created image can be found:
```sh
${workingFolder}/openwrt-imagebuilder-${version}-${target}-$arch}.Linux-x86_64/bin/targets/${target}/${arch}
${workingFolder}/openwrt-imagebuilder-${version}-${target}-${arch}.Linux-x86_64/bin/targets/${target}/${arch}
```
## Device File
@@ -68,6 +73,7 @@ pkgs.callPackage <path_to_repo>/buildOpenwrt.nix {
```
pi example
```nix
{ pkgs ? import <nixpkgs> {}}:
pkgs.callPackage ../buildOpenwrt.nix {
@@ -86,8 +92,11 @@ pkgs.callPackage ../buildOpenwrt.nix {
build an image with:
```sh
# nix-shell <path_to_device_file>.nix --run makeCleanImage
nix-shell devices/pi-img.nix --run makeCleanImage
# load nixe alias for `nix --experimental-features "nix-command flakes"`
. alias.sh
# nix run <path_to_device_file>.nix
nixe run . devices/pi-img.nix
```
For more example see `devices` folder.

3
alias.sh Normal file
View File

@@ -0,0 +1,3 @@
#!/bin/env sh
alias nixe='nix --experimental-features "nix-command flakes"'

View File

@@ -7,7 +7,8 @@
packages ? [],
manifestPkgs ? "$(cat manifest_packages)",
workingFolder ? "$PWD/_builder",
builderVersion ? version
builderVersion ? version,
moreBuildInputs ? []
}:
pkgs.mkShell {
name = "openwrt-build-${target}-${arch}-${profile}";
@@ -22,7 +23,7 @@ pkgs.mkShell {
git
python3Full
rsync
man_db
man-db
gawk
gettext
unzip
@@ -38,13 +39,13 @@ pkgs.mkShell {
gnutar
curl
cacert
];
] ++ moreBuildInputs;
shellHook =
''
export WORKING_FOLDER=$(realpath ${workingFolder})
mkdir -p $WORKING_FOLDER
function loadBuilder() {
curl -s https://downloads.openwrt.org/releases/${builderVersion}/targets/${target}/${arch}/openwrt-imagebuilder-${builderVersion}-${target}-${arch}.Linux-x86_64.tar.xz | tar xvJ -C $WORKING_FOLDER
curl -s https://downloads.openwrt.org/releases/${builderVersion}/targets/${target}/${arch}/openwrt-imagebuilder-${builderVersion}-${target}-${arch}.Linux-x86_64.tar.zst | tar -I zstd -xv -C $WORKING_FOLDER
curl -s https://downloads.openwrt.org/releases/${version}/targets/${target}/${arch}/openwrt-${version}-${target}-${arch}.manifest | cut -f 1 -d ' ' | tr '\n' ' ' > $WORKING_FOLDER/openwrt-imagebuilder-${builderVersion}-${target}-${arch}.Linux-x86_64/manifest_packages
}

View File

@@ -2,13 +2,17 @@
pkgs.callPackage ../buildOpenwrt.nix {
target = "ar71xx";
arch = "generic";
version= "19.07.8";
version= "19.07.10";
profile = "gl-inet-6416A-v1";
packages = [
"luci-ssl"
"luci-proto-wireguard"
"luci-app-wireguard"
"luci-app-mosquitto"
"kmod-ath9k-htc"
"ath9k-htc-firmware"
];
moreBuildInputs = with pkgs; [
python2Full
];
}

View File

@@ -2,16 +2,17 @@
pkgs.callPackage ../buildOpenwrt.nix {
target = "mvebu";
arch = "cortexa9";
version= "21.02.1";
version= "24.10.2";
profile = "linksys_wrt1200ac";
packages = [
"adblock"
"luci-ssl"
"luci-proto-wireguard"
"luci-app-wireguard"
"luci-app-adblock"
"luci-app-openvpn"
"openvpn-openssl"
"tcpdump-mini"
"usteer"
"luci-app-usteer"
];
}

View File

@@ -2,7 +2,7 @@
pkgs.callPackage ../buildOpenwrt.nix {
target = "bcm27xx";
arch = "bcm2708";
version= "21.02.1";
version= "24.10.2";
profile = "rpi";
packages = ["luci-ssl"];
}

26
flake.lock generated Normal file
View File

@@ -0,0 +1,26 @@
{
"nodes": {
"nixpkgs": {
"locked": {
"lastModified": 1741862977,
"narHash": "sha256-prZ0M8vE/ghRGGZcflvxCu40ObKaB+ikn74/xQoNrGQ=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "cdd2ef009676ac92b715ff26630164bb88fec4e0",
"type": "github"
},
"original": {
"id": "nixpkgs",
"ref": "nixos-24.11",
"type": "indirect"
}
},
"root": {
"inputs": {
"nixpkgs": "nixpkgs"
}
}
},
"root": "root",
"version": 7
}

85
flake.nix Normal file
View File

@@ -0,0 +1,85 @@
{
description = "NOIBW - Nix-Openwrt-ImageBuilder-Wrapper";
inputs.nixpkgs.url = "nixpkgs/nixos-25.05";
outputs = { self, nixpkgs }:
let
name = "NOIBW";
version = "1.7.0";
supportedSystems = [ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" ];
forAllSystems = nixpkgs.lib.genAttrs supportedSystems;
nixpkgsFor = forAllSystems (system: import nixpkgs { inherit system; });
devTaskScripts = forAllSystems (system:
{
autoTag = nixpkgsFor.${system}.writeScript "auto_tag.sh" ''
git tag --force v${version}
git push origin v${version}
'';
});
appScripts = forAllSystems (system:
{
makeCleanImageScript = nixpkgsFor.${system}.writers.writeBash "makeCleanImage.sh" ''
nix-shell "$1" --run makeCleanImage
'';
});
in
rec {
packages = forAllSystems (system:
{
default = appScripts.${system}.makeCleanImageScript;
});
apps = forAllSystems (system:
let
updateLockScript = nixpkgsFor.${system}.writeShellScriptBin "update_flake_lock.sh" ''
nix --experimental-features 'nix-command flakes' flake update
nix --experimental-features 'nix-command flakes' build
'';
in
{
default = { type = "app"; program = "${packages.${system}.default}"; };
devTasks = {
updateFlakeLock = { type = "app"; program = "${updateLockScript}/bin/update_flake_lock.sh"; };
autoTag = { type = "app"; program = "${devTaskScripts.${system}.autoTag}"; };
};
});
devShells = forAllSystems (system:
{
default = nixpkgsFor.${system}.mkShell {
name = "dev-shell";
packages = with nixpkgsFor.${system}; [
perl
quilt
ccache
libxslt
gcc
gengetopt
subversion
git
python3Full
rsync
man-db
gawk
gettext
unzip
file
wget
ncurses5.dev
zlib.static
gnumake
which
bash
coreutils
wget
gnutar
curl
cacert
];
shellHook = ''
alias nixe="nix --experimental-features 'nix-command flakes'"
'';
};
});
};
}