diff options
Diffstat (limited to 'pkgs/misc/vencord/default.nix')
-rw-r--r-- | pkgs/misc/vencord/default.nix | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/pkgs/misc/vencord/default.nix b/pkgs/misc/vencord/default.nix new file mode 100644 index 0000000000000..4f663e534c4ba --- /dev/null +++ b/pkgs/misc/vencord/default.nix @@ -0,0 +1,63 @@ +{ buildNpmPackage +, fetchFromGitHub +, lib +, substituteAll +, esbuild +, buildGoModule +, buildWebExtension ? false +}: +buildNpmPackage rec { + pname = "vencord"; + version = "1.1.6"; + + src = fetchFromGitHub { + owner = "Vendicated"; + repo = "Vencord"; + rev = "v${version}"; + sha256 = "sha256-V9fzSoRqVlk9QqpzzR2x+aOwGHhQhQiSjXZWMC0uLnQ="; + }; + + ESBUILD_BINARY_PATH = lib.getExe (esbuild.override { + buildGoModule = args: buildGoModule (args // rec { + version = "0.15.18"; + src = fetchFromGitHub { + owner = "evanw"; + repo = "esbuild"; + rev = "v${version}"; + hash = "sha256-b9R1ML+pgRg9j2yrkQmBulPuLHYLUQvW+WTyR/Cq6zE="; + }; + vendorHash = "sha256-+BfxCyg0KkDQpHt/wycy/8CTG6YBA/VJvJFhhzUnSiQ="; + }); + }); + + # Supresses an error about esbuild's version. + npmRebuildFlags = [ "|| true" ]; + + npmDepsHash = "sha256-jKSdeyQ8oHw7ZGby0XzDg4O8mtH276ykVuBcw7dU/Ls="; + npmFlags = [ "--legacy-peer-deps" ]; + npmBuildScript = if buildWebExtension then "buildWeb" else "build"; + + prePatch = '' + cp ${./package-lock.json} ./package-lock.json + ''; + + patches = [ + (substituteAll { + src = ./replace-git.patch; + inherit version; + }) + ]; + + installPhase = if buildWebExtension then '' + cp -r dist/extension-unpacked/ $out + '' else '' + cp -r dist/ $out + ''; + + meta = with lib; { + description = "Vencord web extension"; + homepage = "https://github.com/Vendicated/Vencord"; + license = licenses.gpl3Only; + maintainers = with maintainers; [ FlafyDev NotAShelf Scrumplex ]; + }; +} |