Back to list
cowwoc

get-session-id

by cowwoc

AI Agents that land on their feet

2🍴 0📅 Jan 25, 2026

SKILL.md


name: get-session-id description: Session ID is automatically available via ${CLAUDE_SESSION_ID} substitution allowed-tools: None (automatic substitution)

Get Session ID Skill

Purpose: The session ID is automatically available in skills and commands via ${CLAUDE_SESSION_ID}.

How It Works:

  • Claude Code substitutes ${CLAUDE_SESSION_ID} with the actual session ID when loading skills
  • No manual extraction or lookup required
  • The session ID is also visible in context via SessionStart hooks for user reference

When to Use This Skill:

  • Reference this documentation to understand how session IDs work
  • The session ID is already available - just use ${CLAUDE_SESSION_ID} in skill/command templates

How Session IDs Work

Claude Code assigns a unique session ID (UUID v4) to each conversation session. This ID is used for:

  • Naming conversation history files: /home/node/.config/projects/-workspace/{session-id}.jsonl
  • Session-specific TODO list tracking
  • Hook coordination across tools
  • Task ownership in multi-instance scenarios

Automatic Substitution in Skills

In skill and command markdown files, use ${CLAUDE_SESSION_ID} directly:

# This gets auto-substituted when the skill loads
SESSION_FILE="/home/node/.config/claude/projects/-workspace/${CLAUDE_SESSION_ID}.jsonl"
cat "$SESSION_FILE" | jq -s 'length'

Hooks and Scripts

Bash hooks receive the session ID via stdin JSON:

# Read stdin JSON and extract session_id
INPUT=$(cat)
SESSION_ID=$(echo "$INPUT" | jq -r '.session_id // empty')

# Use for session-specific operations
SESSION_FILE="/home/node/.config/claude/projects/-workspace/${SESSION_ID}.jsonl"

User Visibility

The session ID is injected into conversation context via two mechanisms:

  • echo-session-id.sh: Outputs session ID at SessionStart
  • inject-session-instructions.sh: Includes session ID in CAT instructions

Users see the session ID in system reminders at conversation start:

Session ID: b6933609-ab67-467e-af26-e48c3c8c129e

Usage Examples

Example 1: In Skill Templates

# Session ID is auto-substituted - no manual lookup needed
cat /home/node/.config/projects/-workspace/${CLAUDE_SESSION_ID}.jsonl | jq -s 'length'

Example 2: Access Session History

# The session ID is already substituted when this runs
jq -s '[.[] | select(.type == "message")]' \
  "/home/node/.config/projects/-workspace/${CLAUDE_SESSION_ID}.jsonl"

Example 3: In Hook Scripts (stdin JSON)

#!/bin/bash
INPUT=$(cat)
SESSION_ID=$(echo "$INPUT" | jq -r '.session_id // empty')
# Now use $SESSION_ID for session-specific operations
  • echo-session-id.sh: Hook that outputs session ID for user visibility
  • inject-session-instructions.sh: Hook that includes session ID in CAT instructions
  • get-history: Skill that uses session ID to access conversation

Score

Total Score

65/100

Based on repository quality metrics

SKILL.md

SKILL.mdファイルが含まれている

+20
LICENSE

ライセンスが設定されている

+10
説明文

100文字以上の説明がある

0/10
人気

GitHub Stars 100以上

0/15
最近の活動

1ヶ月以内に更新

+10
フォーク

10回以上フォークされている

0/5
Issue管理

オープンIssueが50未満

+5
言語

プログラミング言語が設定されている

+5
タグ

1つ以上のタグが設定されている

+5

Reviews

💬

Reviews coming soon