Skip to content
This repository has been archived by the owner on Sep 18, 2024. It is now read-only.

feat: use nix to build images #3

Merged
merged 1 commit into from
Jan 8, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
version: 2
updates:
- package-ecosystem: "github-actions"
directory: "/"
schedule:
interval: "weekly"
commit-message:
prefix: "deps(actions)"
31 changes: 0 additions & 31 deletions .github/workflows/check-commit.yml

This file was deleted.

63 changes: 0 additions & 63 deletions .github/workflows/docker-publish.yml

This file was deleted.

87 changes: 87 additions & 0 deletions .github/workflows/docker.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
name: Publish Docker Image

on:
push:
branches: [main]
pull_request:

jobs:
build:
name: Build image
runs-on: ubuntu-latest

strategy:
matrix:
arch: [x86_64, aarch64]

permissions:
contents: read

steps:
- uses: actions/checkout@v4

- name: Install Nix
uses: DeterminateSystems/nix-installer-action@v9

- name: Setup Nix cache
uses: DeterminateSystems/magic-nix-cache-action@v2

- name: Build Docker image
id: build
run: |
nix build -L .#container-${{ matrix.arch }}
[ ! -L result ] && exit 1
echo "path=$(realpath result)" >> "$GITHUB_OUTPUT"

- name: Upload image
uses: actions/upload-artifact@v4
with:
name: container-${{ matrix.arch }}
path: ${{ steps.build.outputs.path }}
if-no-files-found: error
retention-days: 12

push:
name: Push image
runs-on: ubuntu-latest
needs: build

permissions:
contents: read
packages: write

if: github.event_name == 'push'

steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Download images
uses: actions/download-artifact@v4
with:
path: images

- name: Login to registry
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_TOKEN }}

- name: Push to registry
env:
TAG: docker.io/getchoo/packwiz-serve:latest
run: |
set -euo pipefail

architectures=("x86_64" "aarch64")
for arch in "${architectures[@]}"; do
docker load < images/container-"$arch"/*.tar.gz
docker tag packwiz-serve:latest-"$arch" ${{ env.TAG }}-"$arch"
docker push ${{ env.TAG }}-"$arch"
done

docker manifest create ${{ env.TAG }} \
--amend ${{ env.TAG }}-x86_64 \
--amend ${{ env.TAG }}-aarch64

docker manifest push ${{ env.TAG }}
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# nix build artifacts
result*
repl-result-out*

21 changes: 0 additions & 21 deletions Dockerfile

This file was deleted.

51 changes: 51 additions & 0 deletions container.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
{
lib,
pkgs,
system,
...
}: arch: let
crossPkgs =
{
"x86_64-linux" = {
"x86_64" = pkgs.pkgsStatic;
"aarch64" = pkgs.pkgsCross.aarch64-multiplatform.pkgsStatic;
};

"aarch64-linux" = {
"x86_64" = pkgs.pkgsCross.musl64;
"aarch64" = pkgs.pkgsStatic;
};
}
.${system}
.${arch};

packwiz = crossPkgs.packwiz.overrideAttrs (oldAttrs: {
ldflags = [
"-linkmode external"
"-extldflags '-static -L${crossPkgs.musl}/lib'"
"-s -w -X github.com/packwiz/packwiz.version=${oldAttrs.version}"
];

postInstall = "";

CGO_ENABLED = 0;
});
in
pkgs.dockerTools.buildLayeredImage {
name = "packwiz-serve";
tag = "latest-${arch}";

contents = [packwiz];

config = {
Cmd = ["/bin/packwiz" "serve"];
Env = [
"HOME=/home" # why exactly does packwiz need a home dir? :shrug:
];
WorkingDir = "/data";
Volumes = {"/data" = {};};
ExposedPorts = {"8080" = {};};
};

architecture = crossPkgs.go.GOARCH;
}
1 change: 0 additions & 1 deletion current_commit.txt

This file was deleted.

26 changes: 26 additions & 0 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

34 changes: 34 additions & 0 deletions flake.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
{
description = "a docker image to serve packwiz modpacks";

inputs.nixpkgs.url = "nixpkgs/nixpkgs-unstable";

outputs = {
self,
nixpkgs,
...
}: let
systems = [
"x86_64-linux"
"aarch64-linux"
];

forAllSystems = fn: nixpkgs.lib.genAttrs systems (sys: fn nixpkgs.legacyPackages.${sys});
in {
formatter = forAllSystems (pkgs: pkgs.alejandra);

packages = forAllSystems ({
pkgs,
system,
...
}: let
containerFor = import ./container.nix pkgs;
arch = pkgs.stdenv.hostPlatform.uname.processor;
in {
container-x86_64 = containerFor "x86_64";
container-aarch64 = containerFor "aarch64";

default = self.packages.${system}."container-${arch}";
});
};
}