summary refs log tree commit diff
path: root/pkgs/build-support/appimage
diff options
context:
space:
mode:
authorBignaux Ronan <ronan@aimao.org>2020-03-04 00:46:00 +0100
committerBignaux Ronan <ronan@aimao.org>2020-03-04 00:46:00 +0100
commit04037d1e03b9ee08f1b56ab3480e1ffdafd88155 (patch)
tree4e7d7e66e71adef2ca30360f2e40f53f35c7287e /pkgs/build-support/appimage
parentebaedb5377dcc5e6aca28ef666871e424dd39938 (diff)
downloadnixpkgs-04037d1e03b9ee08f1b56ab3480e1ffdafd88155.tar
nixpkgs-04037d1e03b9ee08f1b56ab3480e1ffdafd88155.tar.gz
nixpkgs-04037d1e03b9ee08f1b56ab3480e1ffdafd88155.tar.bz2
nixpkgs-04037d1e03b9ee08f1b56ab3480e1ffdafd88155.tar.lz
nixpkgs-04037d1e03b9ee08f1b56ab3480e1ffdafd88155.tar.xz
nixpkgs-04037d1e03b9ee08f1b56ab3480e1ffdafd88155.tar.zst
nixpkgs-04037d1e03b9ee08f1b56ab3480e1ffdafd88155.zip
appimage: unify extract functions
Diffstat (limited to 'pkgs/build-support/appimage')
-rw-r--r--pkgs/build-support/appimage/default.nix43
1 files changed, 22 insertions, 21 deletions
diff --git a/pkgs/build-support/appimage/default.nix b/pkgs/build-support/appimage/default.nix
index f4ccd038f76..f8e5206bbb5 100644
--- a/pkgs/build-support/appimage/default.nix
+++ b/pkgs/build-support/appimage/default.nix
@@ -1,39 +1,40 @@
 { stdenv, libarchive, radare2, jq, buildFHSUserEnv, squashfsTools, writeScript }:
 
 rec {
-  # Both extraction functions could be unified, but then
-  # it would depend on libmagic to correctly identify ISO 9660s
 
-  extractType1 = { name, src }: stdenv.mkDerivation {
+  extract = { name, src }: stdenv.mkDerivation {
     name = "${name}-extracted";
     inherit src;
-
-    nativeBuildInputs = [ libarchive ];
+    nativeBuildInputs = [ radare2 libarchive jq squashfsTools ];
     buildCommand = ''
-      mkdir $out
-      bsdtar -x -C $out -f $src
-    '';
-  };
+      # https://github.com/AppImage/libappimage/blob/ca8d4b53bed5cbc0f3d0398e30806e0d3adeaaab/src/libappimage/utils/MagicBytesChecker.cpp#L45-L63
+      appimageType=$(r2 $src -nn -Nqc "p8 3 @ 8")
+      case "$appimageType" in
+        414901)
+          mkdir $out
+          bsdtar -x -C $out -f $src;;
 
-  extractType2 = { name, src }: stdenv.mkDerivation {
-    name = "${name}-extracted";
-    inherit src;
+        414902)
+          install $src ./appimage
 
-    nativeBuildInputs = [ radare2 jq squashfsTools ];
-    buildCommand = ''
-      install $src ./appimage
+          # multiarch offset one-liner using same method as AppImage
+          # see https://gist.github.com/probonopd/a490ba3401b5ef7b881d5e603fa20c93
+          offset=$(r2 ./appimage -nn -Nqc "pfj.elf_header @ 0" |\
+            jq 'map({(.name): .value}) | add | .shoff + (.shnum * .shentsize)')
 
-      # multiarch offset one-liner using same method as AppImage
-      # see https://gist.github.com/probonopd/a490ba3401b5ef7b881d5e603fa20c93
-      offset=$(r2 ./appimage -nn -Nqc "pfj.elf_header @ 0" |\
-        jq 'map({(.name): .value}) | add | .shoff + (.shnum * .shentsize)')
+          unsquashfs -o $offset ./appimage
 
-      unsquashfs -o $offset ./appimage
+          cp -rv squashfs-root $out;;
 
-      cp -rv squashfs-root $out
+        # 414903) get prepared, https://github.com/TheAssassin/type3-runtime
+        *) echo "Unsupported AppImage Signature: $appimageType";;
+      esac
     '';
   };
 
+  extractType1 = extract;
+  extractType2 = extract;
+
   wrapAppImage = args@{ name, src, extraPkgs, ... }: buildFHSUserEnv (defaultFhsEnvArgs // {
     inherit name;