#!/bin/bash # OpenClaw post-update patches # Run after every openclaw update to reapply source fixes # These should be removed once officially fixed upstream OC_DIR=$(npm -g root 2>/dev/null)/openclaw/dist PATCHED=0 # Patch 1: Preserve operator scopes with dangerouslyDisableDeviceAuth FILE="$OC_DIR/gateway-cli-DbznSfRg.js" if [ -f "$FILE" ] && grep -q 'if (scopes.length > 0) {' "$FILE" 2>/dev/null; then sed -i 's/if (scopes.length > 0) {/if (scopes.length > 0 \&\& !disableControlUiDeviceAuth) {/' "$FILE" echo "✅ Patch 1: Scope preservation applied" PATCHED=$((PATCHED + 1)) else echo "⏭️ Patch 1: Already applied or file changed" fi # Patch 2: Index deleted session transcripts in memory search FILE="$OC_DIR/sqlite-C54NeA1C.js" if [ -f "$FILE" ] && grep -q '\.filter((name) => name\.endsWith("\.jsonl"))' "$FILE" 2>/dev/null; then sed -i 's/\.filter((name) => name\.endsWith("\.jsonl"))/\.filter((name) => name.endsWith(".jsonl") || name.includes(".jsonl.deleted."))/' "$FILE" echo "✅ Patch 2: Deleted transcript indexing applied" PATCHED=$((PATCHED + 1)) else echo "⏭️ Patch 2: Already applied or file changed" fi echo "Patches applied: $PATCHED" # Note: After patching, gateway needs restart # The daily-updates.timer already restarts if OC changed