Files
nixpkgs/pkgs/by-name/um/umami/package.nix
Dark Steveneq 646b892680
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
push sheeet
2025-10-09 14:15:47 +02:00

202 lines
5.4 KiB
Nix

{
lib,
stdenvNoCC,
fetchFromGitHub,
fetchurl,
makeWrapper,
nixosTests,
nodejs,
pnpm_10,
prisma-engines,
openssl,
rustPlatform,
# build variables
databaseType ? "postgresql",
collectApiEndpoint ? "",
trackerScriptNames ? [ ],
basePath ? "",
}:
let
sources = lib.importJSON ./sources.json;
pnpm = pnpm_10;
geocities = stdenvNoCC.mkDerivation {
pname = "umami-geocities";
version = sources.geocities.date;
src = fetchurl {
url = "https://raw.githubusercontent.com/GitSquared/node-geolite2-redist/${sources.geocities.rev}/redist/GeoLite2-City.tar.gz";
inherit (sources.geocities) hash;
};
doBuild = false;
installPhase = ''
mkdir -p $out
cp ./GeoLite2-City.mmdb $out/GeoLite2-City.mmdb
'';
meta.license = lib.licenses.cc-by-40;
};
# Pin the specific version of prisma to the one used by upstream
# to guarantee compatibility.
prisma-engines' = prisma-engines.overrideAttrs (old: rec {
version = "6.7.0";
src = fetchFromGitHub {
owner = "prisma";
repo = "prisma-engines";
tag = version;
hash = "sha256-Ty8BqWjZluU6a5xhSAVb2VoTVY91UUj6zoVXMKeLO4o=";
};
cargoHash = "sha256-HjDoWa/JE6izUd+hmWVI1Yy3cTBlMcvD9ANsvqAoHBI=";
cargoDeps = rustPlatform.fetchCargoVendor {
inherit (old) pname;
inherit src version;
hash = cargoHash;
};
});
in
stdenvNoCC.mkDerivation (finalAttrs: {
pname = "umami";
version = "2.19.0";
nativeBuildInputs = [
makeWrapper
nodejs
pnpm.configHook
];
src = fetchFromGitHub {
owner = "umami-software";
repo = "umami";
tag = "v${finalAttrs.version}";
hash = "sha256-luiwGmCujbFGWANSCOiHIov56gsMQ6M+Bj0stcz9he8=";
};
# install dev dependencies as well, for rollup
pnpmInstallFlags = [ "--prod=false" ];
pnpmDeps = pnpm.fetchDeps {
inherit (finalAttrs)
pname
pnpmInstallFlags
version
src
;
fetcherVersion = 2;
hash = "sha256-2GiCeCt/mU5Dm5YHQgJF3127WPHq5QLX8JRcUv6B6lE=";
};
env.CYPRESS_INSTALL_BINARY = "0";
env.NODE_ENV = "production";
env.NEXT_TELEMETRY_DISABLED = "1";
# copy-db-files uses this variable to decide which Prisma schema to use
env.DATABASE_TYPE = databaseType;
env.COLLECT_API_ENDPOINT = collectApiEndpoint;
env.TRACKER_SCRIPT_NAME = lib.concatStringsSep "," trackerScriptNames;
env.BASE_PATH = basePath;
# Allow prisma-cli to find prisma-engines without having to download them
env.PRISMA_QUERY_ENGINE_LIBRARY = "${prisma-engines'}/lib/libquery_engine.node";
env.PRISMA_SCHEMA_ENGINE_BINARY = "${prisma-engines'}/bin/schema-engine";
buildPhase = ''
runHook preBuild
pnpm copy-db-files
pnpm build-db-client # prisma generate
pnpm build-tracker
pnpm build-app
runHook postBuild
'';
checkPhase = ''
runHook preCheck
pnpm test
runHook postCheck
'';
doCheck = true;
installPhase = ''
runHook preInstall
mv .next/standalone $out
mv .next/static $out/.next/static
# Include prisma cli in next standalone build.
# This is preferred to using the prisma in nixpkgs because it guarantees
# the version matches.
# See https://nextjs-forum.com/post/1280550687998083198
# and https://nextjs.org/docs/pages/api-reference/config/next-config-js/output#caveats
# Unfortunately, using outputFileTracingIncludes doesn't work because of pnpm's symlink structure,
# so we just copy the files manually.
mkdir -p $out/node_modules/.bin
cp node_modules/.bin/prisma $out/node_modules/.bin
cp -a node_modules/prisma $out/node_modules
cp -a node_modules/.pnpm/@prisma* $out/node_modules/.pnpm
cp -a node_modules/.pnpm/prisma* $out/node_modules/.pnpm
# remove broken symlinks (some dependencies that are not relevant for running migrations)
find "$out"/node_modules/.pnpm/@prisma* -xtype l -exec rm {} \;
find "$out"/node_modules/.pnpm/prisma* -xtype l -exec rm {} \;
cp -R public $out/public
cp -R prisma $out/prisma
ln -s ${geocities} $out/geo
mkdir -p $out/bin
# Run database migrations before starting umami.
# Add openssl to PATH since it is required for prisma to make SSL connections.
# Force working directory to $out because umami assumes many paths are relative to it (e.g., prisma and geolite).
makeWrapper ${nodejs}/bin/node $out/bin/umami-server \
--set NODE_ENV production \
--set NEXT_TELEMETRY_DISABLED 1 \
--set PRISMA_QUERY_ENGINE_LIBRARY "${prisma-engines'}/lib/libquery_engine.node" \
--set PRISMA_SCHEMA_ENGINE_BINARY "${prisma-engines'}/bin/schema-engine" \
--prefix PATH : ${
lib.makeBinPath [
openssl
nodejs
]
} \
--chdir $out \
--run "$out/node_modules/.bin/prisma migrate deploy" \
--add-flags "$out/server.js"
runHook postInstall
'';
passthru = {
tests = {
inherit (nixosTests) umami;
};
inherit
sources
geocities
;
prisma-engines = prisma-engines';
updateScript = ./update.sh;
};
meta = with lib; {
changelog = "https://github.com/umami-software/umami/releases/tag/v${finalAttrs.version}";
description = "Simple, easy to use, self-hosted web analytics solution";
homepage = "https://umami.is/";
license = with lib.licenses; [
mit
cc-by-40 # geocities
];
platforms = lib.platforms.linux;
mainProgram = "umami-server";
maintainers = with maintainers; [ diogotcorreia ];
};
})