Stock Copilot Pro

v0.3.0

OpenClaw stock analysis skill for US/HK/CN markets. Combines QVeris data sources (THS, Caidazi, Alpha Vantage, Finnhub, X sentiment) for quote, fundamentals,...

6· 2.4k·16 current·18 all-time
bydxj@buxibuxi
Security Scan
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Benign
high confidence
Purpose & Capability
The skill is a multi-source stock analysis tool that routes queries through the QVeris gateway; requesting a single QVERIS_API_KEY is appropriate. The code files implement quote/fundamentals/technicals/sentiment logic and watchlist/brief/radar features consistent with the description. Minor note: metadata described the package as “instruction-only” but the package contains many code files and a local-skill-execution runtime — this is an implementation detail rather than a security mismatch.
Instruction Scope
SKILL.md and the code instruct the agent to call QVeris tools and to read/write only local skill files (watchlist and evolution state). Runtime behavior (tool discovery, executeTool, resolveToolPayload) is scoped to QVeris calls and content fetches are restricted to qveris.ai. The skill does not instruct reading unrelated system files or additional env vars.
Install Mechanism
No external installers or remote downloads are required; install mechanism is local-skill-execution and code is included in the package. This keeps install risk low. There are no extract-from-URL installs or third-party package downloads in the provided metadata.
Credentials
Only QVERIS_API_KEY is required and is the primary credential, which is proportional to a skill that calls the QVeris MCP/API gateway. The SKILL.md states the key is used in a read-only scope and the code indicates no other credentials are read/persisted. (You should treat the key as sensitive and restrict its scope if possible.)
Persistence & Privilege
The skill persists only to files inside its own directory (config/watchlist.json and .evolution/tool-evolution.json) and does not request always:true or system-wide changes. Auto-invocation is enabled by default but that is the platform default; the skill does include example cron jobs in the repo (informational) which could schedule recurring runs if the user configures them.
Assessment
This skill appears to do what it says: it routes multi-source market queries through QVeris and needs only the QVERIS_API_KEY. Before installing, confirm you trust QVeris (qveris.ai) because the skill will make outbound requests there and that service in turn may query other provider APIs on your behalf. Provide an API key with the minimum scope possible and monitor its use. Review the infra/qveris-client.mjs (included in the package) if you want to confirm which endpoints are contacted and how the key is attached. Be aware the skill stores a local watchlist and a small evolution state file inside the skill folder; these do not contain credentials per the README, but you may want to place the skill in an isolated environment if you plan to run scheduled/autonomous jobs. Finally, if you want maximum caution, run first-time executions interactively (not as an automated cron) and verify observed network requests match expectations.

Like a lobster shell, security has layers — review code before you run it.

Runtime requirements

EnvQVERIS_API_KEY
Primary envQVERIS_API_KEY
financevk975n7cc3gkwrgw2e2vkwp5rj981bax9latestvk979f694vjswawtpmxzcw9dcm5820bkpopenclawvk975n7cc3gkwrgw2e2vkwp5rj981bax9stocksvk975n7cc3gkwrgw2e2vkwp5rj981bax9
2.4kdownloads
6stars
14versions
Updated 1mo ago
v0.3.0
MIT-0

Stock Copilot Pro

Global Multi-Source Stock Analysis with QVeris.

SEO Keywords

OpenClaw, stock analysis skill, AI stock copilot, China A-shares, Hong Kong stocks, US stocks, quantitative analysis, fundamental analysis, technical analysis, sentiment analysis, industry radar, morning evening brief, watchlist, portfolio monitoring, QVeris API, THS iFinD, Caidazi, Alpha Vantage, Finnhub, X sentiment, investment research assistant

Supported Capabilities

  • Single-stock analysis (analyze): valuation, quality, technicals, sentiment, risk/timing
  • Multi-stock comparison (compare): cross-symbol ranking and portfolio-level view
  • Watchlist/holdings management (watch): list/add/remove for holdings and watchlist
  • Morning/Evening brief (brief): holdings-focused daily actionable briefing
  • Industry hot-topic radar (radar): multi-source topic aggregation for investable themes
  • Multi-format output: markdown, json, chat
  • OpenClaw LLM-ready flow: structured data in code + guided narrative in SKILL.md

Data Sources

  • Core MCP/API gateway: qveris.ai (QVERIS_API_KEY)
  • CN/HK quote and fundamentals:
    • ths_ifind.real_time_quotation
    • ths_ifind.financial_statements
    • ths_ifind.company_basics
    • ths_ifind.history_quotation
  • CN/HK news and research:
    • caidazi.news.query
    • caidazi.report.query
    • caidazi.search.hybrid.list
    • caidazi.search.hybrid_v2.query
  • Global news sentiment:
    • alpha_news_sentiment
    • finnhub.news
  • X/Twitter sentiment and hot topics:
    • qveris_social.x_domain_hot_topics
    • qveris_social.x_domain_hot_events
    • qveris_social.x_domain_new_posts
    • x_developer.2.tweets.search.recent

What This Skill Does

Stock Copilot Pro performs end-to-end stock analysis with five data domains:

  1. Market quote / trading context
  2. Fundamental metrics
  3. Technical signals (RSI/MACD/MA)
  4. News and sentiment
  5. X sentiment

It then generates a data-rich analyst report with:

  • value-investing scorecard
  • event-timing anti-chasing classification
  • safety-margin estimate
  • thesis-driven investment framework (drivers/risks/scenarios/KPIs)
  • multi-style playbooks (value/balanced/growth/trading)
  • event radar with candidate ideas from news and X
  • scenario-based recommendations
  • standard readable output (default) + optional full evidence trace (--evidence)

Key Advantages

  • Deterministic tool routing via references/tool-chains.json
  • Evolution v2 parameter-template memory to reduce recurring parameter errors
  • Strong fallback strategy across providers and markets
  • US/HK/CN market-aware symbol handling
  • Structured outputs for both analyst reading and machine ingestion
  • Safety-first handling of secrets and runtime state

Core Workflow

  1. Resolve user input to symbol + market (supports company-name aliases, e.g. Chinese name -> 600089.SH).

  2. Search tools by capability (quote, fundamentals, indicators, sentiment, X sentiment).

  3. Route by hardcoded tool chains first (market-aware), then fallback generic capability search.

    • For CN/HK sentiment, prioritize caidazi channels (report/news/wechat).
    • For CN/HK fundamentals, prioritize THS financial statements (income/balance sheet/cash flow), then fallback to company basics.
  4. Before execution, try evolution parameter templates; if unavailable, use default param builder.

  5. Run quality checks:

    • Missing key fields
    • Data recency
    • Cross-source inconsistency
  6. Produce analyst report with:

    • composite score
    • safety margin
    • event-driven vs pullback-risk timing classification
    • structured thesis (driver/risk/scenario/KPI)
    • event radar (timeline/theme) and candidate ideas
    • style-specific execution playbooks
    • market scenario suggestions
    • optional parsed/raw evidence sections when --evidence is enabled
  7. Preference routing (public audience default):

    • If no preference flags are provided, script returns a questionnaire first.
    • You can skip this with --skip-questionnaire.

Command Surface

Primary script: scripts/stock_copilot_pro.mjs

  • Analyze one symbol:
    • node scripts/stock_copilot_pro.mjs analyze --symbol AAPL --market US --mode comprehensive
    • node scripts/stock_copilot_pro.mjs analyze --symbol "<company-name>" --mode comprehensive
  • Compare multiple symbols:
    • node scripts/stock_copilot_pro.mjs compare --symbols AAPL,MSFT --market US --mode comprehensive
  • Manage watchlist:
    • node scripts/stock_copilot_pro.mjs watch --action list
    • node scripts/stock_copilot_pro.mjs watch --action add --bucket holdings --symbol AAPL --market US
    • node scripts/stock_copilot_pro.mjs watch --action remove --bucket watchlist --symbol 0700.HK --market HK
  • Generate brief:
    • node scripts/stock_copilot_pro.mjs brief --type morning --format chat
    • node scripts/stock_copilot_pro.mjs brief --type evening --format markdown
  • Run industry radar:
    • node scripts/stock_copilot_pro.mjs radar --market GLOBAL --limit 10

OpenClaw scheduled tasks (morning/evening brief and radar)

To set up morning brief, evening brief, or daily radar in OpenClaw, use only the official OpenClaw cron format and create jobs via the CLI or Gateway cron tool. Do not edit ~/.openclaw/cron/jobs.json directly.

  • Reference: the jobs array in config/openclaw-cron.example.json; each item is one cron.add payload (fields: name, schedule: { kind, expr, tz }, sessionTarget: "isolated", payload: { kind: "agentTurn", message: "..." }, delivery).
  • Example (morning brief): openclaw cron add --name "Stock morning brief" --cron "0 9 * * 1-5" --tz Asia/Shanghai --session isolated --message "Use stock-copilot-pro to generate morning brief: run brief --type morning --max-items 8 --format chat" --announce. To deliver to Feishu, add --channel feishu --to <group-or-chat-id>.
  • Incorrect: using the legacy example format (e.g. schedule as string, command, delivery.channels array) or pasting the example into jobs.json will cause Gateway parse failure or crash.

CN/HK Coverage Details

  • Company-name input is supported and auto-resolved to market + symbol for common names.
  • Sentiment path prioritizes caidazi (research reports, news, wechat/public-account channels).
  • Fundamentals path prioritizes THS financial statements endpoints, and always calls THS company basics for profile backfill:
    • revenue
    • netProfit
    • totalAssets
    • totalLiabilities
    • operatingCashflow
    • industry
    • mainBusiness
    • tags

Output Modes

  • markdown (default): human-readable report
  • json: machine-readable merged payload
  • chat: segmented chat-friendly output for messaging apps
  • summary-first: compact output style via --summary-only

Preference & Event Options

  • Preference flags:

    • --horizon short|mid|long
    • --risk low|mid|high
    • --style value|balanced|growth|trading
    • --actionable (include execution-oriented rules)
    • --skip-questionnaire (force analysis without preference Q&A)
  • Event radar flags:

    • --event-window-days 7|14|30
    • --event-universe global|same_market
    • --event-view timeline|theme

Dynamic Evolution

  • Runtime learning state is stored in .evolution/tool-evolution.json.
  • One successful execution can update tool parameter templates.
  • Evolution stores param_templates and sample_successful_params for reuse.
  • Evolution does not decide tool priority; tool priority is controlled by tool-chains.json.
  • Use --no-evolution to disable loading/saving runtime learning state.

Safety and Disclosure

  • Uses only QVERIS_API_KEY.
  • Calls only QVeris APIs over HTTPS.
  • full_content_file_url fetching is kept enabled for data completeness, but only HTTPS URLs under qveris.ai are allowed.
  • Does not store API keys in logs, reports, or evolution state.
  • Runtime persistence is limited to .evolution/tool-evolution.json (metadata + parameter templates only).
  • Watchlist state is stored at config/watchlist.json (bootstrap from config/watchlist.example.json).
  • OpenClaw scheduled tasks: see config/openclaw-cron.example.json. Create jobs with the official format (schedule.kind, payload.kind, sessionTarget, etc.) via openclaw cron add or the Gateway cron tool; do not paste or merge the example JSON into ~/.openclaw/cron/jobs.json (schema mismatch can cause Gateway parse failure or crash). Set delivery.channel and delivery.to for your channel (e.g. feishu).
  • External source URLs remain hidden by default; only shown when --include-source-urls is explicitly enabled.
  • No package installation or arbitrary command execution is performed by this skill script.
  • Research-only output. Not investment advice.

Single Stock Analysis Guide

When analyzing analyze output, act as a senior buy-side analyst and deliver a professional but not overlong report.

Required Output (7 Sections)

  1. Data Snapshot (required)
    • Start with a compact metrics table built from data fields.
    • Include at least: price/change, marketCap, PE/PB, profitMargin, revenue, netProfit, RSI, 52W range.
    • Example format:
| Metric | Value |
|--------|-------|
| Price | $264.58 (+1.54%) |
| Market Cap | $3.89T |
| P/E | 33.45 |
| P/B | 57.97 |
| Profit Margin | 27% |
| Revenue (TTM) | $394B |
| Net Profit | $99.8B |
| RSI | 58.3 |
| 52W Range | $164 - $270 |
  1. Key view (30 seconds)

    • One-line conclusion: buy/hold/avoid + key reason.
  2. Investment thesis

    • Bull case: 2 points (growth driver, moat/catalyst)
    • Bear case: 2 points (valuation/risk/timing)
    • Final balance: what dominates now.
  3. Valuation and key levels

    • PE/PB vs peer or history percentile (cheap/fair/expensive)
    • Key levels: current price, support, resistance, stop-loss reference
  4. Recommendation (required)

    • Different advice by position status:
      • No position
      • Light position
      • Heavy position / underwater
    • Each suggestion must include concrete trigger/price/condition.
  5. Risk monitor

    • Top 2-3 risks + invalidation condition (what proves thesis wrong).
  6. Data Sources (required)

    • End with a source disclosure line showing QVeris attribution and data channels actually used.
    • Include generation timestamp and list of source/tool names from payload metadata such as dataSources, meta.sourceStats, or data.*.selectedTool.
    • Example format:
> Data powered by [QVeris](https://qveris.ai) | Sources: Alpha Vantage (quote/fundamentals), Finnhub (news sentiment), X/Twitter (social sentiment) | Generated at 2026-02-22T13:00:00Z

Quality Bar

  • Avoid data dumping; each key number must include interpretation.
  • Every numeric claim must be grounded in actual payload values; do not fabricate numbers.
  • Keep concise but complete (target 250-500 characters for narrative).
  • Must include actionable guidance and time window.
  • Ticker and technical terms in English.

Daily Brief Analysis Guide

When analyzing brief output, generate an actionable morning/evening briefing for OpenClaw conversation.

Morning Brief

  1. Market overview: risk-on/off + key overnight move + today's tone, plus an index snapshot table from marketOverview.indices (index name, price, % change, timestamp)
  2. Holdings check: holdings that need action first, with per-holding price/% change/grade when available
  3. Radar relevance: which radar themes impact holdings
  4. Today's plan (required): specific watch levels / event / execution plan
  5. Data Sources (required): one-line QVeris attribution and channels used in this brief

Evening Brief

  1. Session recap: index + sector + portfolio one-line recap, with key index close/% change
  2. Holdings change: biggest winners/losers and why, with quantized move (%) where available
  3. Thesis check: whether thesis changed
  4. Tomorrow's plan (required): explicit conditions and actions
  5. Data Sources (required): one-line QVeris attribution and channels used in this brief

Quality Bar

  • Prioritize user holdings, not generic market commentary.
  • Quantify changes when possible (%, levels, counts).
  • Keep concise and decision-oriented.
  • Include a short source disclosure line at the end to improve traceability and credibility.

Hot Topic Analysis Guide

When analyzing radar output, cluster signals into investable themes and provide concise actionable conclusions.

Required Output (per theme)

  • Theme: clear, investable label
  • Driver: what changed and why now
  • Impact: beneficiaries/losers + magnitude + duration
  • Recommendation (required): concrete trigger or level
  • Risk note: key invalidation or monitoring signal
  • Source tag (required): include source label for each theme (for example: caidazi_report, alpha_news_sentiment, x_hot_topics)

Execution Rules

  • Cluster into 3-5 themes max.
  • Cross-verify sources; lower confidence for social-only signals.
  • Distinguish short-term trade vs mid-term allocation.
  • Keep each theme concise (<200 characters preferred).
  • End with a QVeris source disclosure line listing channels that contributed to this radar run.

Comments

Loading comments...