cc-safe-setup 29.6.7 → 29.6.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,43 @@
1
+ #!/bin/bash
2
+ # ================================================================
3
+ # markdown-link-check.sh — Verify local file links in markdown
4
+ # ================================================================
5
+ # PURPOSE:
6
+ # After Claude edits a markdown file, check that all local file
7
+ # references (relative paths) actually exist. Catches broken
8
+ # links to images, other docs, or code files.
9
+ #
10
+ # TRIGGER: PostToolUse
11
+ # MATCHER: "Edit|Write"
12
+ # ================================================================
13
+
14
+ INPUT=$(cat)
15
+ FILE=$(echo "$INPUT" | jq -r '.tool_input.file_path // empty' 2>/dev/null)
16
+
17
+ [ -z "$FILE" ] && exit 0
18
+ echo "$FILE" | grep -qiE '\.md$|\.mdx$' || exit 0
19
+ [ -f "$FILE" ] || exit 0
20
+
21
+ DIR=$(dirname "$FILE")
22
+ BROKEN=0
23
+
24
+ # Extract markdown links: [text](path) — skip URLs and anchors
25
+ while IFS= read -r link; do
26
+ # Skip URLs, anchors, and mailto
27
+ echo "$link" | grep -qE '^(https?://|#|mailto:)' && continue
28
+ # Remove anchor part
29
+ CLEAN=$(echo "$link" | sed 's/#.*//')
30
+ [ -z "$CLEAN" ] && continue
31
+ # Resolve relative path
32
+ TARGET="$DIR/$CLEAN"
33
+ if [ ! -e "$TARGET" ]; then
34
+ echo "⚠ Broken link in $FILE: $link" >&2
35
+ BROKEN=$((BROKEN + 1))
36
+ fi
37
+ done < <(grep -oE '\]\([^)]+\)' "$FILE" 2>/dev/null | sed 's/\](\(.*\))/\1/')
38
+
39
+ if [ "$BROKEN" -gt 0 ]; then
40
+ echo " $BROKEN broken link(s) found." >&2
41
+ fi
42
+
43
+ exit 0
@@ -0,0 +1,41 @@
1
+ #!/bin/bash
2
+ # ================================================================
3
+ # no-force-flag.sh — Block dangerous --force flags
4
+ # ================================================================
5
+ # PURPOSE:
6
+ # --force flags bypass safety checks in package managers and git.
7
+ # This hook blocks common dangerous --force patterns:
8
+ # - npm install --force (ignores peer dependency conflicts)
9
+ # - pip install --force-reinstall (skips cache, wastes time)
10
+ # - git push --force (overwrites remote history)
11
+ # - docker system prune --force (removes all unused data)
12
+ #
13
+ # TRIGGER: PreToolUse
14
+ # MATCHER: "Bash"
15
+ # ================================================================
16
+
17
+ INPUT=$(cat)
18
+ COMMAND=$(echo "$INPUT" | jq -r '.tool_input.command // empty' 2>/dev/null)
19
+ [ -z "$COMMAND" ] && exit 0
20
+
21
+ # npm install --force / --legacy-peer-deps
22
+ if echo "$COMMAND" | grep -qE 'npm\s+install.*--force|npm\s+i\s.*--force'; then
23
+ echo "BLOCKED: npm install --force bypasses peer dependency checks." >&2
24
+ echo "Fix the dependency conflict instead of forcing." >&2
25
+ exit 2
26
+ fi
27
+
28
+ # git push --force (not --force-with-lease)
29
+ if echo "$COMMAND" | grep -qE 'git\s+push.*--force($|\s)' && ! echo "$COMMAND" | grep -q 'force-with-lease'; then
30
+ echo "BLOCKED: git push --force can destroy remote history." >&2
31
+ echo "Use --force-with-lease for safer force-push." >&2
32
+ exit 2
33
+ fi
34
+
35
+ # docker system prune --force
36
+ if echo "$COMMAND" | grep -qE 'docker\s+(system\s+)?prune.*-f|docker\s+(system\s+)?prune.*--force'; then
37
+ echo "BLOCKED: docker prune --force removes all unused data without confirmation." >&2
38
+ exit 2
39
+ fi
40
+
41
+ exit 0
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "cc-safe-setup",
3
- "version": "29.6.7",
4
- "description": "One command to make Claude Code safe. 417 example hooks + 8 built-in. 52 CLI commands. 5639 tests. Works with Auto Mode.",
3
+ "version": "29.6.9",
4
+ "description": "One command to make Claude Code safe. 419 example hooks + 8 built-in. 52 CLI commands. 5655 tests. Works with Auto Mode.",
5
5
  "main": "index.mjs",
6
6
  "bin": {
7
7
  "cc-safe-setup": "index.mjs"