mirror of
https://github.com/anthropics/claude-code.git
synced 2026-04-26 06:52:41 +00:00
Compare commits
30 Commits
ashwin/loc
...
bcherny-pa
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1aaffa4e6d | ||
|
|
f5b24d5480 | ||
|
|
07e6bec5ff | ||
|
|
cf8c6fdf2d | ||
|
|
d720bf7aba | ||
|
|
dde41f6225 | ||
|
|
78e0785950 | ||
|
|
b3658880e5 | ||
|
|
9be8e07e92 | ||
|
|
c904f0f409 | ||
|
|
6418cacb0b | ||
|
|
4fd2c49e8b | ||
|
|
48ed55b459 | ||
|
|
8b2cbe3f86 | ||
|
|
40251280cc | ||
|
|
8f0379c698 | ||
|
|
10c1ec5391 | ||
|
|
6c7836e02f | ||
|
|
6f6fc43c73 | ||
|
|
944eb4eff6 | ||
|
|
21df74bb49 | ||
|
|
66ce673883 | ||
|
|
07b198b9de | ||
|
|
8ad36c459c | ||
|
|
b48dfb8e87 | ||
|
|
8e23e7d791 | ||
|
|
9285dfbf2f | ||
|
|
f91aed5440 | ||
|
|
46ca39c463 | ||
|
|
a6091b65c0 |
35
.claude/commands/dedupe.md
Normal file
35
.claude/commands/dedupe.md
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
---
|
||||||
|
allowed-tools: Bash(gh issue view:*), Bash(gh search:*), Bash(gh issue list:*), Bash(gh api:*), Bash(gh issue comment:*)
|
||||||
|
description: Find duplicate GitHub issues
|
||||||
|
---
|
||||||
|
|
||||||
|
Find up to 3 likely duplicate issues for a given GitHub issue.
|
||||||
|
|
||||||
|
To do this, follow these steps precisely:
|
||||||
|
|
||||||
|
1. Use an agent to check if the Github issue (a) is closed, (b) does not need to be deduped (eg. because it is broad product feedback without a specific solution, or positive feedback), or (c) already has a duplicates comment that you made earlier. If so, do not proceed.
|
||||||
|
2. Use an agent to view a Github issue, and ask the agent to return a summary of the issue
|
||||||
|
3. Then, launch 5 parallel agents to search Github for duplicates of this issue, using diverse keywords and search approaches, using the summary from #1
|
||||||
|
4. Next, feed the results from #1 and #2 into another agent, so that it can filter out false positives, that are likely not actually duplicates of the original issue. If there are no duplicates remaining, do not proceed.
|
||||||
|
5. Finally, comment back on the issue with a list of up to three duplicate issues (or zero, if there are no likely duplicates)
|
||||||
|
|
||||||
|
Notes (be sure to tell this to your agents, too):
|
||||||
|
|
||||||
|
- Use `gh` to interact with Github, rather than web fetch
|
||||||
|
- Do not use other tools, beyond `gh` (eg. don't use other MCP servers, file edit, etc.)
|
||||||
|
- Make a todo list first
|
||||||
|
- For your comment, follow the following format precisely (assuming for this example that you found 3 suspected duplicates):
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Found 3 possible duplicate issues:
|
||||||
|
|
||||||
|
1. <link to issue>
|
||||||
|
2. <link to issue>
|
||||||
|
3. <link to issue>
|
||||||
|
|
||||||
|
If your issue is a duplicate, please close it and 👍 the existing issue instead.
|
||||||
|
|
||||||
|
🤖 Generated with [Claude Code](https://claude.ai/code)
|
||||||
|
|
||||||
|
---
|
||||||
@@ -3,8 +3,11 @@ FROM node:20
|
|||||||
ARG TZ
|
ARG TZ
|
||||||
ENV TZ="$TZ"
|
ENV TZ="$TZ"
|
||||||
|
|
||||||
|
ARG CLAUDE_CODE_VERSION=latest
|
||||||
|
|
||||||
# Install basic development tools and iptables/ipset
|
# Install basic development tools and iptables/ipset
|
||||||
RUN apt update && apt install -y less \
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||||
|
less \
|
||||||
git \
|
git \
|
||||||
procps \
|
procps \
|
||||||
sudo \
|
sudo \
|
||||||
@@ -19,7 +22,10 @@ RUN apt update && apt install -y less \
|
|||||||
iproute2 \
|
iproute2 \
|
||||||
dnsutils \
|
dnsutils \
|
||||||
aggregate \
|
aggregate \
|
||||||
jq
|
jq \
|
||||||
|
nano \
|
||||||
|
vim \
|
||||||
|
&& apt-get clean && rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Ensure default node user has access to /usr/local/share
|
# Ensure default node user has access to /usr/local/share
|
||||||
RUN mkdir -p /usr/local/share/npm-global && \
|
RUN mkdir -p /usr/local/share/npm-global && \
|
||||||
@@ -42,10 +48,11 @@ RUN mkdir -p /workspace /home/node/.claude && \
|
|||||||
|
|
||||||
WORKDIR /workspace
|
WORKDIR /workspace
|
||||||
|
|
||||||
|
ARG GIT_DELTA_VERSION=0.18.2
|
||||||
RUN ARCH=$(dpkg --print-architecture) && \
|
RUN ARCH=$(dpkg --print-architecture) && \
|
||||||
wget "https://github.com/dandavison/delta/releases/download/0.18.2/git-delta_0.18.2_${ARCH}.deb" && \
|
wget "https://github.com/dandavison/delta/releases/download/${GIT_DELTA_VERSION}/git-delta_${GIT_DELTA_VERSION}_${ARCH}.deb" && \
|
||||||
sudo dpkg -i "git-delta_0.18.2_${ARCH}.deb" && \
|
sudo dpkg -i "git-delta_${GIT_DELTA_VERSION}_${ARCH}.deb" && \
|
||||||
rm "git-delta_0.18.2_${ARCH}.deb"
|
rm "git-delta_${GIT_DELTA_VERSION}_${ARCH}.deb"
|
||||||
|
|
||||||
# Set up non-root user
|
# Set up non-root user
|
||||||
USER node
|
USER node
|
||||||
@@ -57,8 +64,13 @@ ENV PATH=$PATH:/usr/local/share/npm-global/bin
|
|||||||
# Set the default shell to zsh rather than sh
|
# Set the default shell to zsh rather than sh
|
||||||
ENV SHELL=/bin/zsh
|
ENV SHELL=/bin/zsh
|
||||||
|
|
||||||
|
# Set the default editor and visual
|
||||||
|
ENV EDITOR nano
|
||||||
|
ENV VISUAL nano
|
||||||
|
|
||||||
# Default powerline10k theme
|
# Default powerline10k theme
|
||||||
RUN sh -c "$(wget -O- https://github.com/deluan/zsh-in-docker/releases/download/v1.2.0/zsh-in-docker.sh)" -- \
|
ARG ZSH_IN_DOCKER_VERSION=1.2.0
|
||||||
|
RUN sh -c "$(wget -O- https://github.com/deluan/zsh-in-docker/releases/download/v${ZSH_IN_DOCKER_VERSION}/zsh-in-docker.sh)" -- \
|
||||||
-p git \
|
-p git \
|
||||||
-p fzf \
|
-p fzf \
|
||||||
-a "source /usr/share/doc/fzf/examples/key-bindings.zsh" \
|
-a "source /usr/share/doc/fzf/examples/key-bindings.zsh" \
|
||||||
@@ -67,7 +79,8 @@ RUN sh -c "$(wget -O- https://github.com/deluan/zsh-in-docker/releases/download/
|
|||||||
-x
|
-x
|
||||||
|
|
||||||
# Install Claude
|
# Install Claude
|
||||||
RUN npm install -g @anthropic-ai/claude-code
|
RUN npm install -g @anthropic-ai/claude-code@${CLAUDE_CODE_VERSION}
|
||||||
|
|
||||||
|
|
||||||
# Copy and set up firewall script
|
# Copy and set up firewall script
|
||||||
COPY init-firewall.sh /usr/local/bin/
|
COPY init-firewall.sh /usr/local/bin/
|
||||||
|
|||||||
@@ -3,7 +3,10 @@
|
|||||||
"build": {
|
"build": {
|
||||||
"dockerfile": "Dockerfile",
|
"dockerfile": "Dockerfile",
|
||||||
"args": {
|
"args": {
|
||||||
"TZ": "${localEnv:TZ:America/Los_Angeles}"
|
"TZ": "${localEnv:TZ:America/Los_Angeles}",
|
||||||
|
"CLAUDE_CODE_VERSION": "latest",
|
||||||
|
"GIT_DELTA_VERSION": "0.18.2",
|
||||||
|
"ZSH_IN_DOCKER_VERSION": "1.2.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"runArgs": [
|
"runArgs": [
|
||||||
@@ -41,7 +44,7 @@
|
|||||||
"source=claude-code-bashhistory-${devcontainerId},target=/commandhistory,type=volume",
|
"source=claude-code-bashhistory-${devcontainerId},target=/commandhistory,type=volume",
|
||||||
"source=claude-code-config-${devcontainerId},target=/home/node/.claude,type=volume"
|
"source=claude-code-config-${devcontainerId},target=/home/node/.claude,type=volume"
|
||||||
],
|
],
|
||||||
"remoteEnv": {
|
"containerEnv": {
|
||||||
"NODE_OPTIONS": "--max-old-space-size=4096",
|
"NODE_OPTIONS": "--max-old-space-size=4096",
|
||||||
"CLAUDE_CONFIG_DIR": "/home/node/.claude",
|
"CLAUDE_CONFIG_DIR": "/home/node/.claude",
|
||||||
"POWERLEVEL9K_DISABLE_GITSTATUS": "true"
|
"POWERLEVEL9K_DISABLE_GITSTATUS": "true"
|
||||||
|
|||||||
@@ -2,6 +2,9 @@
|
|||||||
set -euo pipefail # Exit on error, undefined vars, and pipeline failures
|
set -euo pipefail # Exit on error, undefined vars, and pipeline failures
|
||||||
IFS=$'\n\t' # Stricter word splitting
|
IFS=$'\n\t' # Stricter word splitting
|
||||||
|
|
||||||
|
# 1. Extract Docker DNS info BEFORE any flushing
|
||||||
|
DOCKER_DNS_RULES=$(iptables-save -t nat | grep "127\.0\.0\.11" || true)
|
||||||
|
|
||||||
# Flush existing rules and delete existing ipsets
|
# Flush existing rules and delete existing ipsets
|
||||||
iptables -F
|
iptables -F
|
||||||
iptables -X
|
iptables -X
|
||||||
@@ -11,6 +14,16 @@ iptables -t mangle -F
|
|||||||
iptables -t mangle -X
|
iptables -t mangle -X
|
||||||
ipset destroy allowed-domains 2>/dev/null || true
|
ipset destroy allowed-domains 2>/dev/null || true
|
||||||
|
|
||||||
|
# 2. Selectively restore ONLY internal Docker DNS resolution
|
||||||
|
if [ -n "$DOCKER_DNS_RULES" ]; then
|
||||||
|
echo "Restoring Docker DNS rules..."
|
||||||
|
iptables -t nat -N DOCKER_OUTPUT 2>/dev/null || true
|
||||||
|
iptables -t nat -N DOCKER_POSTROUTING 2>/dev/null || true
|
||||||
|
echo "$DOCKER_DNS_RULES" | xargs -L 1 iptables -t nat
|
||||||
|
else
|
||||||
|
echo "No Docker DNS rules to restore"
|
||||||
|
fi
|
||||||
|
|
||||||
# First allow DNS and localhost before any restrictions
|
# First allow DNS and localhost before any restrictions
|
||||||
# Allow outbound DNS
|
# Allow outbound DNS
|
||||||
iptables -A OUTPUT -p udp --dport 53 -j ACCEPT
|
iptables -A OUTPUT -p udp --dport 53 -j ACCEPT
|
||||||
|
|||||||
25
.github/workflows/claude-dedupe-issues.yml
vendored
Normal file
25
.github/workflows/claude-dedupe-issues.yml
vendored
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
name: Claude Issue Dedupe
|
||||||
|
description: Automatically dedupe GitHub issues using Claude Code
|
||||||
|
on:
|
||||||
|
issues:
|
||||||
|
types: [opened]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
claude-dedupe-issues:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 10
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
issues: write
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Run Claude Code slash command
|
||||||
|
uses: anthropics/claude-code-base-action@beta
|
||||||
|
with:
|
||||||
|
prompt: "/dedupe ${{ github.repository }}/issues/${{ github.event.issue.number }}"
|
||||||
|
anthropic_api_key: ${{ secrets.ANTHROPIC_API_KEY }}
|
||||||
|
claude_env: |
|
||||||
|
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
28
.github/workflows/lock-closed-issues.yml
vendored
Normal file
28
.github/workflows/lock-closed-issues.yml
vendored
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
name: "Lock Stale Issues"
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
# 8am Pacific = 1pm UTC (2pm UTC during DST)
|
||||||
|
- cron: "0 14 * * *"
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
issues: write
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: lock-threads
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
lock-threads:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: dessant/lock-threads@1bf7ec25051fe7c00bdd17e6a7cf3d7bfb7dc771 # v5.0.1
|
||||||
|
with:
|
||||||
|
issue-inactive-days: "7"
|
||||||
|
process-only: "issues"
|
||||||
|
log-output: true
|
||||||
|
issue-comment: >
|
||||||
|
This issue has been automatically locked since it was
|
||||||
|
closed and has not had any activity for 7 days.
|
||||||
|
If you're experiencing a similar issue, please file a new issue
|
||||||
|
and reference this one if it's relevant.
|
||||||
29
CHANGELOG.md
29
CHANGELOG.md
@@ -1,8 +1,34 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## 1.0.64
|
||||||
|
|
||||||
|
- Agents: Added model customization support - you can now specify which model an agent should use
|
||||||
|
- Agents: Fixed unintended access to the recursive agent tool
|
||||||
|
- Hooks: Added systemMessage field to hook JSON output for displaying warnings and context
|
||||||
|
- SDK: Fixed user input tracking across multi-turn conversations
|
||||||
|
- Added hidden files to file search and @-mention suggestions
|
||||||
|
|
||||||
|
## 1.0.63
|
||||||
|
|
||||||
|
- Windows: Fixed file search, @agent mentions, and custom slash commands functionality
|
||||||
|
|
||||||
|
## 1.0.62
|
||||||
|
|
||||||
|
- Added @-mention support with typeahead for custom agents. @<your-custom-agent> to invoke it
|
||||||
|
- Hooks: Added SessionStart hook for new session initialization
|
||||||
|
- /add-dir command now supports typeahead for directory paths
|
||||||
|
- Improved network connectivity check reliability
|
||||||
|
|
||||||
## 1.0.61
|
## 1.0.61
|
||||||
|
|
||||||
- Added --settings flag to load settings from a JSON file
|
- Transcript mode (Ctrl+R): Changed Esc to exit transcript mode rather than interrupt
|
||||||
|
- Settings: Added `--settings` flag to load settings from a JSON file
|
||||||
|
- Settings: Fixed resolution of settings files paths that are symlinks
|
||||||
|
- OTEL: Fixed reporting of wrong organization after authentication changes
|
||||||
|
- Slash commands: Fixed permissions checking for allowed-tools with Bash
|
||||||
|
- IDE: Added support for pasting images in VSCode MacOS using ⌘+V
|
||||||
|
- IDE: Added `CLAUDE_CODE_AUTO_CONNECT_IDE=false` for disabling IDE auto-connection
|
||||||
|
- Added `CLAUDE_CODE_SHELL_PREFIX` for wrapping Claude and user-provided shell commands run by Claude Code
|
||||||
|
|
||||||
## 1.0.60
|
## 1.0.60
|
||||||
|
|
||||||
@@ -10,7 +36,6 @@
|
|||||||
|
|
||||||
## 1.0.59
|
## 1.0.59
|
||||||
|
|
||||||
- Rename CLAUDE_CODE_BASH_PREFIX to CLAUDE_CODE_SHELL_PREFIX
|
|
||||||
- SDK: Added tool confirmation support with canUseTool callback
|
- SDK: Added tool confirmation support with canUseTool callback
|
||||||
- SDK: Allow specifying env for spawned process
|
- SDK: Allow specifying env for spawned process
|
||||||
- Hooks: Exposed PermissionDecision to hooks (including "ask")
|
- Hooks: Exposed PermissionDecision to hooks (including "ask")
|
||||||
|
|||||||
@@ -37,6 +37,21 @@ param(
|
|||||||
Write-Host "--- DevContainer Startup & Connection Script ---"
|
Write-Host "--- DevContainer Startup & Connection Script ---"
|
||||||
Write-Host "Using backend: $($Backend)"
|
Write-Host "Using backend: $($Backend)"
|
||||||
|
|
||||||
|
# --- Prerequisite Check ---
|
||||||
|
Write-Host "Checking for required commands..."
|
||||||
|
try {
|
||||||
|
Get-Command $Backend -ErrorAction Stop | Out-Null
|
||||||
|
Write-Host "- $($Backend) command found."
|
||||||
|
Get-Command devcontainer -ErrorAction Stop | Out-Null
|
||||||
|
Write-Host "- devcontainer command found."
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
Write-Error "A required command is not installed or not in your PATH."
|
||||||
|
Write-Error "Please ensure '$($_.Exception.Message.Split(':')[0])' and 'devcontainer' are installed and accessible."
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
# --- Backend-Specific Initialization ---
|
# --- Backend-Specific Initialization ---
|
||||||
if ($Backend -eq 'podman') {
|
if ($Backend -eq 'podman') {
|
||||||
Write-Host "--- Podman Backend Initialization ---"
|
Write-Host "--- Podman Backend Initialization ---"
|
||||||
|
|||||||
Reference in New Issue
Block a user