{ lib, stdenv, fetchzip, rustPlatform, fetchFromGitHub, protobuf, # nativeBuildInputs cmake, perl, pkg-config, darwin, # buildInputs openssl, rdkafka, versionCheckHook, nix-update-script, }: let fetchNpmPackage = { name, version, hash, js_prod_file, js_dev_file, ... }@args: let package = fetchzip { url = "https://registry.npmjs.org/${name}/-/${baseNameOf name}-${version}.tgz"; inherit hash; }; files = with args; [ { src = js_prod_file; dst = "./src/environmentd/src/http/static/js/vendor/${name}.js"; } { src = js_prod_file; dst = "./src/prof-http/src/http/static/js/vendor/${name}.js"; } { src = js_dev_file; dst = "./src/environmentd/src/http/static-dev/js/vendor/${name}.js"; } { src = js_dev_file; dst = "./src/prof-http/src/http/static-dev/js/vendor/${name}.js"; } ] ++ lib.optionals (args ? css_file) [ { src = css_file; dst = "./src/environmentd/src/http/static/css/vendor/${name}.css"; } { src = css_file; dst = "./src/prof-http/src/http/static/css/vendor/${name}.css"; } ] ++ lib.optionals (args ? extra_file) [ { src = extra_file.src; dst = "./src/environmentd/src/http/static/${extra_file.dst}"; } { src = extra_file.src; dst = "./src/prof-http/src/http/static/${extra_file.dst}"; } ]; in lib.concatStringsSep "\n" ( lib.forEach files ( { src, dst }: '' mkdir -p "${dirOf dst}" cp "${package}/${src}" "${dst}" '' ) ); npmPackages = import ./npm_deps.nix; in rustPlatform.buildRustPackage rec { pname = "materialize"; version = "0.87.2"; MZ_DEV_BUILD_SHA = "000000000000000000000000000000000000000000000000000"; src = fetchFromGitHub { owner = "MaterializeInc"; repo = "materialize"; tag = "v${version}"; hash = "sha256-EHhN+avUxzwKU48MubiMM40W9J93yZlNqV+xeP44dl0="; fetchSubmodules = true; }; postPatch = '' ${lib.concatStringsSep "\n" (map fetchNpmPackage npmPackages)} substituteInPlace ./misc/dist/materialized.service \ --replace-fail /usr/bin $out/bin \ --replace-fail _Materialize root substituteInPlace ./src/catalog/build.rs \ --replace-fail '&[ ' '&["."' ''; env = { # needed for internal protobuf c wrapper library PROTOC = lib.getExe protobuf; PROTOC_INCLUDE = "${protobuf}/include"; # needed to dynamically link rdkafka CARGO_FEATURE_DYNAMIC_LINKING = 1; }; cargoHash = "sha256-+OREisZ/vw3Oi5MNCYn7u06pZKtf+2trlGyn//uAGws="; nativeBuildInputs = [ cmake perl pkg-config rustPlatform.bindgenHook ] # Provides the mig command used by the krb5-src build script ++ lib.optional stdenv.hostPlatform.isDarwin darwin.bootstrap_cmds; # Needed to get openssl-sys to use pkg-config. OPENSSL_NO_VENDOR = 1; buildInputs = [ openssl rdkafka ]; # the check phase requires linking with rocksdb which can be a problem since # the rust rocksdb crate is not updated very often. doCheck = false; # Skip tests that use the network checkFlags = [ "--exact" "--skip=test_client" "--skip=test_client_errors" "--skip=test_client_all_subjects" "--skip=test_client_subject_and_references" "--skip=test_no_block" "--skip=test_safe_mode" "--skip=test_tls" ]; cargoBuildFlags = [ "--bin=clusterd" "--bin=environmentd" ]; postInstall = '' install --mode=444 -D ./misc/dist/materialized.service $out/etc/systemd/system/materialized.service ''; nativeInstallCheckInputs = [ versionCheckHook ]; versionCheckProgram = "${placeholder "out"}/bin/environmentd"; versionCheckProgramArg = "--version"; doInstallCheck = true; passthru = { updateScript = nix-update-script { }; }; meta = { homepage = "https://materialize.com"; description = "Streaming SQL materialized view engine for real-time applications"; license = lib.licenses.bsl11; platforms = lib.platforms.unix; maintainers = with lib.maintainers; [ petrosagg ]; mainProgram = "environmentd"; }; }