Crawler Summary

call-analysis-workflow answer-first brief

Build call analysis dashboards from CallRail data. Downloads calls, transcribes with AssemblyAI, classifies by category, and generates a professional React dashboard. --- name: call-analysis-workflow description: Build call analysis dashboards from CallRail data. Downloads calls, transcribes with AssemblyAI, classifies by category, and generates a professional React dashboard. --- Call Analysis Workflow Build professional call analysis dashboards for businesses using CallRail. Overview This workflow transforms raw CallRail data into an insightful dashboard showing: - Call categori Capability contract not published. No trust telemetry is available yet. Last updated 4/14/2026.

Freshness

Last checked 4/14/2026

Best For

call-analysis-workflow is best for general automation workflows where OpenClaw compatibility matters.

Not Ideal For

Contract metadata is missing or unavailable for deterministic execution.

Evidence Sources Checked

editorial-content, GITHUB OPENCLEW, runtime-metrics, public facts pack

Claim this agent
Agent DossierGitHubSafety: 94/100

call-analysis-workflow

Build call analysis dashboards from CallRail data. Downloads calls, transcribes with AssemblyAI, classifies by category, and generates a professional React dashboard. --- name: call-analysis-workflow description: Build call analysis dashboards from CallRail data. Downloads calls, transcribes with AssemblyAI, classifies by category, and generates a professional React dashboard. --- Call Analysis Workflow Build professional call analysis dashboards for businesses using CallRail. Overview This workflow transforms raw CallRail data into an insightful dashboard showing: - Call categori

OpenClawself-declared

Public facts

4

Change events

1

Artifacts

0

Freshness

Apr 14, 2026

Verifiededitorial-contentNo verified compatibility signals

Capability contract not published. No trust telemetry is available yet. Last updated 4/14/2026.

Trust evidence available

Trust score

Unknown

Compatibility

OpenClaw

Freshness

Apr 14, 2026

Vendor

Robertnitzan

Artifacts

0

Benchmarks

0

Last release

Unpublished

Executive Summary

Key links, install path, and a quick operational read before the deeper crawl record.

Verifiededitorial-content

Summary

Capability contract not published. No trust telemetry is available yet. Last updated 4/14/2026.

Setup snapshot

git clone https://github.com/Robertnitzan/call-analysis-workflow.git
  1. 1

    Setup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.

  2. 2

    Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.

Evidence Ledger

Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.

Verifiededitorial-content
Vendor (1)

Vendor

Robertnitzan

profilemedium
Observed Apr 14, 2026Source linkProvenance
Compatibility (1)

Protocol compatibility

OpenClaw

contractmedium
Observed Apr 14, 2026Source linkProvenance
Security (1)

Handshake status

UNKNOWN

trustmedium
Observed unknownSource linkProvenance
Integration (1)

Crawlable docs

6 indexed pages on the official domain

search_documentmedium
Observed Apr 15, 2026Source linkProvenance

Release & Crawl Timeline

Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.

Self-declaredagent-index

Artifacts Archive

Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.

Self-declaredGITHUB OPENCLEW

Extracted files

0

Examples

6

Snippets

0

Languages

typescript

Parameters

Executable Examples

text

GET https://api.callrail.com/v3/a/{account_id}/calls.json
Authorization: Token token={api_key}

json

{
  "speaker_labels": true,
  "sentiment_analysis": true,
  "language_detection": true
}

text

├── Tabs: Call List | Missed Opportunities | Methodology
├── Stats Grid: Total, Customers, Spam, Operations, Answered, Missed
├── Filters: Category, Status, Date Range, Search
├── Call Table: Date, Status, Duration, Category, Confidence, Sentiment, Recording
└── Call Detail Modal: Full transcript, speaker labels, sentiment breakdown

css

--bg-base: #0a0a0b
--bg-surface-1: #111113
--text-primary: #fafafa
--text-muted: #71717a
--color-customer: #22c55e
--color-spam: #ef4444

bash

npm run build
cp -r public/data dist/
vercel --prod --yes

json

{
  "id": "CAL...",
  "direction": "inbound|outbound",
  "duration": 120,
  "recording_duration": 110,
  "start_time": "2026-01-15T10:30:00-08:00",
  "customer_phone": "+1234567890",
  "customer_city": "San Francisco",
  "answered": true,
  "voicemail": false,
  "has_recording": true,
  "has_assemblyai": true,
  "confidence": 0.95,
  "assemblyai_text": "Full transcript...",
  "utterances": [...],
  "sentiment_results": [...]
}

Docs & README

Full documentation captured from public sources, including the complete README when available.

Self-declaredGITHUB OPENCLEW

Docs source

GITHUB OPENCLEW

Editorial quality

ready

Build call analysis dashboards from CallRail data. Downloads calls, transcribes with AssemblyAI, classifies by category, and generates a professional React dashboard. --- name: call-analysis-workflow description: Build call analysis dashboards from CallRail data. Downloads calls, transcribes with AssemblyAI, classifies by category, and generates a professional React dashboard. --- Call Analysis Workflow Build professional call analysis dashboards for businesses using CallRail. Overview This workflow transforms raw CallRail data into an insightful dashboard showing: - Call categori

Full README

name: call-analysis-workflow description: Build call analysis dashboards from CallRail data. Downloads calls, transcribes with AssemblyAI, classifies by category, and generates a professional React dashboard.

Call Analysis Workflow

Build professional call analysis dashboards for businesses using CallRail.

Overview

This workflow transforms raw CallRail data into an insightful dashboard showing:

  • Call categories (Customer, Spam, Operations, Incomplete)
  • Missed opportunities (customer voicemails that need follow-up)
  • Sentiment analysis per call
  • Transcripts with speaker diarization
  • Weekly breakdowns and methodology explanations

Required Skills

This workflow uses two existing skills:

1. assemblyai-transcribe

Location: /root/clawd/skills/assemblyai-transcribe/SKILL.md Purpose: Transcribe call recordings with speaker labels and sentiment analysis Required: ASSEMBLYAI_API_KEY in environment

2. interface-design

Location: /root/clawd/skills/interface-design/SKILL.md Purpose: Design consistent, professional dashboard UI Key principles: Dark mode, borders-only depth, 4px spacing, monospace for data

Workflow Steps

Step 1: Fetch Calls from CallRail

See: references/1-fetch-calls.md

Required credentials:

  • CallRail API Key (Settings → API → API Keys)
  • Account ID (from CallRail URL)

API endpoint:

GET https://api.callrail.com/v3/a/{account_id}/calls.json
Authorization: Token token={api_key}

Key fields to extract:

  • id, direction, duration, start_time
  • customer_phone_number, customer_city, customer_state
  • answered, voicemail
  • recording (URL to get audio)
  • transcription (CallRail's basic transcript)

Step 2: Download Recordings

See: references/2-download-recordings.md

For each call with a recording:

  1. GET {recording_url}.json with auth header
  2. Follow redirect URL to download MP3
  3. Save to audio/{call_id}.mp3

Note: Only calls with recording field have audio. Outbound calls and missed calls without voicemail have no recording.

Step 3: Transcribe with AssemblyAI

See: references/3-transcribe.md

Use the assemblyai-transcribe skill with these options:

{
  "speaker_labels": true,
  "sentiment_analysis": true,
  "language_detection": true
}

Output per call:

  • text - Full transcript
  • confidence - Transcription accuracy (0-1)
  • utterances - Array of {speaker, text, start, end}
  • sentiment_analysis_results - Array of {text, sentiment, confidence}

Step 4: Classify Calls

See: references/4-classify.md

Categories: | Category | Description | Patterns | |----------|-------------|----------| | customer | Real customer inquiries | quote, estimate, price, schedule, project | | spam | Robocalls, solicitation | warranty, medicare, press 1, insurance |

| operations | Internal/employee calls | delivery, materials, job site | | incomplete | Can't classify | No recording, too short, unclear |

Classification logic:

  1. No transcript → incomplete

  2. Check spam patterns → spam if matched

  3. Check customer patterns → customer if matched

  4. Check operations patterns → operations if matched

  5. Fallback by direction: outbound → operations, inbound → customer or incomplete

See patterns/ directory for full pattern lists.

Step 5: Build Dashboard

See: references/5-build-dashboard.md

Tech stack:

  • React 18 + Vite
  • Tailwind-style CSS (custom tokens)
  • No external UI libraries

Dashboard structure:

├── Tabs: Call List | Missed Opportunities | Methodology
├── Stats Grid: Total, Customers, Spam, Operations, Answered, Missed
├── Filters: Category, Status, Date Range, Search
├── Call Table: Date, Status, Duration, Category, Confidence, Sentiment, Recording
└── Call Detail Modal: Full transcript, speaker labels, sentiment breakdown

Design tokens (dark mode):

--bg-base: #0a0a0b
--bg-surface-1: #111113
--text-primary: #fafafa
--text-muted: #71717a
--color-customer: #22c55e
--color-spam: #ef4444

Step 6: Deploy to Vercel

See: references/6-deploy.md

npm run build
cp -r public/data dist/
vercel --prod --yes

Data Structure

calls-merged.json

{
  "id": "CAL...",
  "direction": "inbound|outbound",
  "duration": 120,
  "recording_duration": 110,
  "start_time": "2026-01-15T10:30:00-08:00",
  "customer_phone": "+1234567890",
  "customer_city": "San Francisco",
  "answered": true,
  "voicemail": false,
  "has_recording": true,
  "has_assemblyai": true,
  "confidence": 0.95,
  "assemblyai_text": "Full transcript...",
  "utterances": [...],
  "sentiment_results": [...]
}

results.json

{
  "generated_at": "2026-02-03T...",
  "stats": {
    "total": 415,
    "inbound": 333,
    "outbound": 82,
    "inbound_answered": 228,
    "inbound_missed": 105,
    "with_recording": 249,
    "voicemail": 38,
    "by_category": { "customer": 34, "spam": 133, "operations": 12, "incomplete": 236 },
    "inbound_answered_by_category": { "customer": 29, "spam": 111, "operations": 9, "incomplete": 79 }
  },
  "calls": [
    {
      "...merged fields...",
      "category": "customer",
      "confidence_classification": 0.85,
      "reasoning": ["Customer patterns detected"],
      "sentiment_summary": { "positive": 40, "negative": 10, "neutral": 50 },
      "incomplete_reason": null
    }
  ]
}

Key Insights

Why calls have no recording

  • Outbound calls: CallRail doesn't record by default
  • Missed without voicemail: Nothing to record
  • Softphone calls: May not route through tracking number

Duration vs Recording Duration

  • Duration: Total call time (includes ringing)
  • Recording Duration: Only recorded portion (starts after answer)
  • Average difference: ~9 seconds (ringing time)

Missed Opportunities

Customer voicemails = leads that weren't answered. Filter by:

calls.filter(c => c.voicemail && c.category === 'customer')

Example Project

See: examples/rhino-concrete/

Live dashboard: https://rhino-call-analyzer.vercel.app

Stats (Jan 2026):

  • 415 total calls (333 inbound + 82 outbound)
  • 333 inbound breakdown: 228 answered + 38 voicemail + 67 missed
  • 249 with recording (all inbound), 166 without

Classification of 228 Inbound Answered:

  • 111 spam (49%) - cold calls, robocalls, sales pitches
  • 29 customers (13%) - real inquiries about concrete work
  • 9 operations (4%) - suppliers, insurance, accounting
  • 79 incomplete (35%) - too short/unclear to classify

Missed Opportunities (6 customer voicemails): Real leads that went to voicemail and need follow-up.

Why 166 calls have no recording:

  • 82 outbound (not recorded by CallRail)
  • 70 inbound missed without voicemail (nothing to record)
  • 14 inbound answered without recording (CallRail config issue)

Contract & API

Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.

MissingGITHUB OPENCLEW

Contract coverage

Status

missing

Auth

None

Streaming

No

Data region

Unspecified

Protocol support

OpenClaw: self-declared

Requires: none

Forbidden: none

Guardrails

Operational confidence: low

No positive guardrails captured.
Invocation examples
curl -s "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/snapshot"
curl -s "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/contract"
curl -s "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/trust"

Reliability & Benchmarks

Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.

Missingruntime-metrics

Trust signals

Handshake

UNKNOWN

Confidence

unknown

Attempts 30d

unknown

Fallback rate

unknown

Runtime metrics

Observed P50

unknown

Observed P95

unknown

Rate limit

unknown

Estimated cost

unknown

Do not use if

Contract metadata is missing or unavailable for deterministic execution.
No benchmark suites or observed failure patterns are available.

Media & Demo

Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.

Missingno-media
No screenshots, media assets, or demo links are available.

Related Agents

Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.

Self-declaredprotocol-neighbors
GITHUB_REPOSactivepieces

Rank

70

AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents

Traction

No public download signal

Freshness

Updated 2d ago

OPENCLAW
GITHUB_REPOScherry-studio

Rank

70

AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs

Traction

No public download signal

Freshness

Updated 6d ago

MCPOPENCLAW
GITHUB_REPOSAionUi

Rank

70

Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!

Traction

No public download signal

Freshness

Updated 6d ago

MCPOPENCLAW
GITHUB_REPOSCopilotKit

Rank

70

The Frontend for Agents & Generative UI. React + Angular

Traction

No public download signal

Freshness

Updated 23d ago

OPENCLAW
Machine Appendix

Contract JSON

{
  "contractStatus": "missing",
  "authModes": [],
  "requires": [],
  "forbidden": [],
  "supportsMcp": false,
  "supportsA2a": false,
  "supportsStreaming": false,
  "inputSchemaRef": null,
  "outputSchemaRef": null,
  "dataRegion": null,
  "contractUpdatedAt": null,
  "sourceUpdatedAt": null,
  "freshnessSeconds": null
}

Invocation Guide

{
  "preferredApi": {
    "snapshotUrl": "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/snapshot",
    "contractUrl": "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/contract",
    "trustUrl": "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/trust"
  },
  "curlExamples": [
    "curl -s \"https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/snapshot\"",
    "curl -s \"https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/contract\"",
    "curl -s \"https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/trust\""
  ],
  "jsonRequestTemplate": {
    "query": "summarize this repo",
    "constraints": {
      "maxLatencyMs": 2000,
      "protocolPreference": [
        "OPENCLEW"
      ]
    }
  },
  "jsonResponseTemplate": {
    "ok": true,
    "result": {
      "summary": "...",
      "confidence": 0.9
    },
    "meta": {
      "source": "GITHUB_OPENCLEW",
      "generatedAt": "2026-04-17T05:35:22.981Z"
    }
  },
  "retryPolicy": {
    "maxAttempts": 3,
    "backoffMs": [
      500,
      1500,
      3500
    ],
    "retryableConditions": [
      "HTTP_429",
      "HTTP_503",
      "NETWORK_TIMEOUT"
    ]
  }
}

Trust JSON

{
  "status": "unavailable",
  "handshakeStatus": "UNKNOWN",
  "verificationFreshnessHours": null,
  "reputationScore": null,
  "p95LatencyMs": null,
  "successRate30d": null,
  "fallbackRate": null,
  "attempts30d": null,
  "trustUpdatedAt": null,
  "trustConfidence": "unknown",
  "sourceUpdatedAt": null,
  "freshnessSeconds": null
}

Capability Matrix

{
  "rows": [
    {
      "key": "OPENCLEW",
      "type": "protocol",
      "support": "unknown",
      "confidenceSource": "profile",
      "notes": "Listed on profile"
    }
  ],
  "flattenedTokens": "protocol:OPENCLEW|unknown|profile"
}

Facts JSON

[
  {
    "factKey": "docs_crawl",
    "category": "integration",
    "label": "Crawlable docs",
    "value": "6 indexed pages on the official domain",
    "href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceType": "search_document",
    "confidence": "medium",
    "observedAt": "2026-04-15T05:03:46.393Z",
    "isPublic": true
  },
  {
    "factKey": "vendor",
    "category": "vendor",
    "label": "Vendor",
    "value": "Robertnitzan",
    "href": "https://github.com/Robertnitzan/call-analysis-workflow",
    "sourceUrl": "https://github.com/Robertnitzan/call-analysis-workflow",
    "sourceType": "profile",
    "confidence": "medium",
    "observedAt": "2026-04-14T22:24:56.759Z",
    "isPublic": true
  },
  {
    "factKey": "protocols",
    "category": "compatibility",
    "label": "Protocol compatibility",
    "value": "OpenClaw",
    "href": "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/contract",
    "sourceUrl": "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/contract",
    "sourceType": "contract",
    "confidence": "medium",
    "observedAt": "2026-04-14T22:24:56.759Z",
    "isPublic": true
  },
  {
    "factKey": "handshake_status",
    "category": "security",
    "label": "Handshake status",
    "value": "UNKNOWN",
    "href": "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/trust",
    "sourceUrl": "https://xpersona.co/api/v1/agents/robertnitzan-call-analysis-workflow/trust",
    "sourceType": "trust",
    "confidence": "medium",
    "observedAt": null,
    "isPublic": true
  }
]

Change Events JSON

[
  {
    "eventType": "docs_update",
    "title": "Docs refreshed: Sign in to GitHub · GitHub",
    "description": "Fresh crawlable documentation was indexed for the official domain.",
    "href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
    "sourceType": "search_document",
    "confidence": "medium",
    "observedAt": "2026-04-15T05:03:46.393Z",
    "isPublic": true
  }
]

Sponsored

Ads related to call-analysis-workflow and adjacent AI workflows.