Trading_skills ib-portfolio-action-report
Generate a comprehensive portfolio action report with earnings dates and risk assessment. Use when user asks for portfolio review, action items, earnings risk, or position management across IB accounts. Requires TWS or IB Gateway running locally.
git clone https://github.com/staskh/trading_skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/staskh/trading_skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/ib-portfolio-action-report" ~/.claude/skills/staskh-trading-skills-ib-portfolio-action-report && rm -rf "$T"
.claude/skills/ib-portfolio-action-report/SKILL.mdIB Portfolio Action Report
Generate a comprehensive portfolio action report that analyzes all positions across Interactive Brokers accounts, fetches earnings dates, and provides traffic-light risk indicators (🔴🟡🟢) for each position.
Prerequisites
User must have TWS or IB Gateway running locally with API enabled:
- Paper trading: port 7497
- Live trading: port 7496
Instructions
Step 1: Gather Data
Note: If
is not installed oruvis not found, replacepyproject.tomlwithuv run pythonin all commands below.python
uv run python scripts/report.py [--port PORT] [--account ACCOUNT]
The script returns JSON to stdout with analyzed portfolio data including risk levels, earnings dates, technical indicators, and spread groupings.
Step 2: Format Report
Read
templates/markdown-template.md for formatting instructions. Generate a markdown report from the JSON data and save to sandbox/.
Filename:
ib_portfolio_action_report_{ACCOUNT}_{YYYY-MM-DD}_{HHmm}.md
Step 3: Report Results
Present critical findings to the user: red/yellow items requiring attention, top priority actions, and the saved report path.
Arguments
- IB port (default: 7496 for live trading)--port
- Specific account ID to analyze (optional, defaults to all accounts)--account
JSON Output
The script returns structured JSON with:
- Timestampgenerated
- List of account IDsaccounts
- Red/yellow/green countssummary
- All positions grouped into spreads with risk level, urgency, and recommendationsspreads
- Technical indicators per symbol (RSI, trend, SMAs, MACD, ADX)technicals
- Earnings dates per symbolearnings
- Current prices per symbolprices
- Upcoming earnings with account/position infoearnings_calendar
- Position and risk counts per accountaccount_summary
Report Sections
- Critical Summary: Count of positions by risk level (🔴/🟡/🟢)
- Immediate Action Required: Positions expiring within 2 days
- Urgent - Expiring Within 1 Week: Short-term positions needing attention
- Critical Earnings Alert: Positions with earnings this week
- Earnings Next Week: Upcoming earnings exposure
- Expiring in 2 Weeks: Medium-term expirations
- Longer-Dated Positions: Core holdings with spread analysis
- Top Priority Actions: Numbered action items by urgency
- Position Size Summary: Account-level breakdown
- Earnings Calendar: Next 30 days of earnings dates
- Technical Analysis Summary: RSI, trend, SMAs, MACD, ADX for each underlying
Example Usage
# All accounts on live trading port uv run python scripts/report.py --port 7496 # Specific account uv run python scripts/report.py --port 7496 --account U790497
Dependencies
ib-asyncpandas-tayfinance