update-hashes.sh 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. #!/usr/bin/env bash
  2. set -euo pipefail
  3. DUMMY="sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA="
  4. SYSTEM=${SYSTEM:-x86_64-linux}
  5. DEFAULT_HASH_FILE=${MODULES_HASH_FILE:-nix/hashes.json}
  6. HASH_FILE=${HASH_FILE:-$DEFAULT_HASH_FILE}
  7. if [ ! -f "$HASH_FILE" ]; then
  8. cat >"$HASH_FILE" <<EOF
  9. {
  10. "nodeModules": {}
  11. }
  12. EOF
  13. fi
  14. if git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
  15. if ! git ls-files --error-unmatch "$HASH_FILE" >/dev/null 2>&1; then
  16. git add -N "$HASH_FILE" >/dev/null 2>&1 || true
  17. fi
  18. fi
  19. export DUMMY
  20. export NIX_KEEP_OUTPUTS=1
  21. export NIX_KEEP_DERIVATIONS=1
  22. cleanup() {
  23. rm -f "${JSON_OUTPUT:-}" "${BUILD_LOG:-}" "${TMP_EXPR:-}"
  24. }
  25. trap cleanup EXIT
  26. write_node_modules_hash() {
  27. local value="$1"
  28. local system="${2:-$SYSTEM}"
  29. local temp
  30. temp=$(mktemp)
  31. if jq -e '.nodeModules | type == "object"' "$HASH_FILE" >/dev/null 2>&1; then
  32. jq --arg system "$system" --arg value "$value" '.nodeModules[$system] = $value' "$HASH_FILE" >"$temp"
  33. else
  34. jq --arg system "$system" --arg value "$value" '.nodeModules = {($system): $value}' "$HASH_FILE" >"$temp"
  35. fi
  36. mv "$temp" "$HASH_FILE"
  37. }
  38. TARGET="packages.${SYSTEM}.default"
  39. MODULES_ATTR=".#packages.${SYSTEM}.default.node_modules"
  40. CORRECT_HASH=""
  41. DRV_PATH="$(nix eval --raw "${MODULES_ATTR}.drvPath")"
  42. echo "Setting dummy node_modules outputHash for ${SYSTEM}..."
  43. write_node_modules_hash "$DUMMY"
  44. BUILD_LOG=$(mktemp)
  45. JSON_OUTPUT=$(mktemp)
  46. echo "Building node_modules for ${SYSTEM} to discover correct outputHash..."
  47. echo "Attempting to realize derivation: ${DRV_PATH}"
  48. REALISE_OUT=$(nix-store --realise "$DRV_PATH" --keep-failed 2>&1 | tee "$BUILD_LOG" || true)
  49. BUILD_PATH=$(echo "$REALISE_OUT" | grep "^/nix/store/" | head -n1 || true)
  50. if [ -n "$BUILD_PATH" ] && [ -d "$BUILD_PATH" ]; then
  51. echo "Realized node_modules output: $BUILD_PATH"
  52. CORRECT_HASH=$(nix hash path --sri "$BUILD_PATH" 2>/dev/null || true)
  53. fi
  54. if [ -z "$CORRECT_HASH" ]; then
  55. CORRECT_HASH="$(grep -E 'got:\s+sha256-[A-Za-z0-9+/=]+' "$BUILD_LOG" | awk '{print $2}' | head -n1 || true)"
  56. if [ -z "$CORRECT_HASH" ]; then
  57. CORRECT_HASH="$(grep -A2 'hash mismatch' "$BUILD_LOG" | grep 'got:' | awk '{print $2}' | sed 's/sha256:/sha256-/' || true)"
  58. fi
  59. if [ -z "$CORRECT_HASH" ]; then
  60. echo "Searching for kept failed build directory..."
  61. KEPT_DIR=$(grep -oE "build directory.*'[^']+'" "$BUILD_LOG" | grep -oE "'/[^']+'" | tr -d "'" | head -n1)
  62. if [ -z "$KEPT_DIR" ]; then
  63. KEPT_DIR=$(grep -oE '/nix/var/nix/builds/[^ ]+' "$BUILD_LOG" | head -n1)
  64. fi
  65. if [ -n "$KEPT_DIR" ] && [ -d "$KEPT_DIR" ]; then
  66. echo "Found kept build directory: $KEPT_DIR"
  67. if [ -d "$KEPT_DIR/build" ]; then
  68. HASH_PATH="$KEPT_DIR/build"
  69. else
  70. HASH_PATH="$KEPT_DIR"
  71. fi
  72. echo "Attempting to hash: $HASH_PATH"
  73. ls -la "$HASH_PATH" || true
  74. if [ -d "$HASH_PATH/node_modules" ]; then
  75. CORRECT_HASH=$(nix hash path --sri "$HASH_PATH" 2>/dev/null || true)
  76. echo "Computed hash from kept build: $CORRECT_HASH"
  77. fi
  78. fi
  79. fi
  80. fi
  81. if [ -z "$CORRECT_HASH" ]; then
  82. echo "Failed to determine correct node_modules hash for ${SYSTEM}."
  83. echo "Build log:"
  84. cat "$BUILD_LOG"
  85. exit 1
  86. fi
  87. write_node_modules_hash "$CORRECT_HASH"
  88. jq -e --arg system "$SYSTEM" --arg hash "$CORRECT_HASH" '.nodeModules[$system] == $hash' "$HASH_FILE" >/dev/null
  89. echo "node_modules hash updated for ${SYSTEM}: $CORRECT_HASH"
  90. rm -f "$BUILD_LOG"
  91. unset BUILD_LOG