with one click
calle
// Use Call-E from Codex through the calle CLI. Use for Call-E setup checks, authentication recovery, phone call planning, planned call execution, and call status checks.
// Use Call-E from Codex through the calle CLI. Use for Call-E setup checks, authentication recovery, phone call planning, planned call execution, and call status checks.
| name | calle |
| description | Use CALL-E from Codex through the calle CLI. Use for CALL-E setup checks, authentication recovery, phone call planning, planned call execution, and call status checks. |
| license | MIT |
Use this skill when the user wants Codex to use CALL-E through the calle CLI.
This plugin version intentionally calls the CLI instead of configuring Codex to
connect directly to the remote MCP server.
Use this skill for:
calle CLI is availableDo not use this skill when the user only wants a call script, roleplay, simulated conversation, or general contact lookup that does not require CALL-E.
plan_id and confirm_token.plan_id,
confirm_token, or run_id.All CLI commands run from this Codex plugin must include the CALL-E integration attribution environment:
env CALLE_SOURCE=codex CALLE_INTEGRATION=codex_plugin CALLE_INTEGRATION_VERSION=0.1.8
Use the first command form that works.
Prefer the repository-local CLI when the current workspace contains it:
env CALLE_SOURCE=codex CALLE_INTEGRATION=codex_plugin CALLE_INTEGRATION_VERSION=0.1.8 node packages/cli/bin/calle.js
If the repository-local CLI is unavailable, use the global command:
env CALLE_SOURCE=codex CALLE_INTEGRATION=codex_plugin CALLE_INTEGRATION_VERSION=0.1.8 calle
If neither command works, use the pinned npm package through npx:
env CALLE_SOURCE=codex CALLE_INTEGRATION=codex_plugin CALLE_INTEGRATION_VERSION=0.1.8 npx -y @call-e/cli@0.3.2
Only tell the user to install the CLI globally if npx is unavailable,
network access is blocked, or the user explicitly wants a persistent global
command.
Use this flow whenever this Codex plugin is actively invoked for a CALL-E request. Run it before call planning, before tool listing, when setup is uncertain, when auth fails, or when the user asks to verify CALL-E setup:
--help.auth status.auth status reports usable: false, do not continue to call planning
or mcp tools yet. Run blocking auth login and keep that command running
until it exits. Do not use auth login --start-only --no-browser-open for
the default Codex plugin flow.auth login prints the brokered login URL to command output or stderr,
immediately show the first authorization help with that URL. Keep waiting
for the same auth login command to complete; do not ask the user to reply
after browser authorization.auth login JSON included assistant_hint.message, show
that post-auth success message in the next user-facing reply. If the user
already gave a call goal, continue the original workflow after the message;
otherwise ask for the phone number and call goal, or offer a test call.mcp tools.plan_call, run_call, and get_call_run are available.Setup verification must not place a real phone call. Use only help, auth, and tool-listing commands until the user asks for a call workflow.
First authorization help template:
Hi, I'm CALL-E 👋
I can help you make phone calls, ask for information, and handle phone-related tasks. I'll also keep you updated on the call status, what was discussed, and the key points.
Before we officially begin, I'll send you the call goal for confirmation.
Before we start, please complete authorization here:
<login_url>
Post-authorization success template:
Great, authorization is complete ✨
- If you already shared the call goal, I'll continue as planned.
- If you haven't, that's okay. I can help you place a test call first, or start a real call directly.
You can tell me:
- Your phone number: Used only for this service. We will not disclose it to anyone else, including the callee.
- What you want me to say: For example, "This is a test call from CALL-E. Wishing you a good day, and asking if there's anything you'd like to share."
I'll keep you updated on the phone status, call content, and summary.
call plan first.
If the user has not provided enough explicit fields for call plan, use
mcp call plan_call --args-json '{"user_input":"<latest user message verbatim>"}'
so CALL-E can ask for the missing details.plan_id and confirm_token.call run with
the exact plan_id and confirm_token returned by planning.call plan and call run.run_id and latest call status. In call run output, the
latest call state is in status_result.structuredContent. In call status
output, the latest call state is in result.structuredContent.status_result.structuredContent.activity after call run, or
result.structuredContent.activity after call status.call status with that exact run_id until the call reaches a
terminal status or the user asks you to stop. Poll every 10 seconds: after
each non-terminal response, show the latest activity progress, wait 10
seconds, then fetch call status again. Do not stay silent until a terminal
status.call status only with a known run_id.Terminal statuses include COMPLETED, FAILED, NO_ANSWER, DECLINED,
CANCELED, CANCELLED, VOICEMAIL, BUSY, and EXPIRED.
For non-terminal statuses, reply with progress in this shape:
Phone call is in progress! Progress:
- <HH:MM:SS message>
Use one bullet per activity item, preserving the order returned by the CLI.
For each item, prefer the event ts formatted as HH:MM:SS plus message.
If ts is missing, use the message by itself. If there is no activity, use
- Status: <status> when a status exists; otherwise use
- Waiting for the next status update. Do not include the final summary,
details, or transcript until a terminal status is returned.
The polling cadence is: show progress, wait 10 seconds, run call status, show
new progress if still non-terminal, then repeat. Stop polling immediately when
the user asks you to stop, when a terminal status is returned, or when command
execution is interrupted.
When the call reaches a terminal status, reply with the final call result, including these sections in this order:
[Status]
<status>
[Call Summary]
<post_summary or summary or message>
[Details]
Callee Number: <primary callee or Not available>
Duration: <duration or Not available>
Time: <start/end time or Not available>
Call id: <call_id or Not available>
[Transcript]
<transcript or Not available.>
If the user asked for extra final content, such as key takeaways or next steps,
add it after [Transcript] under a short heading. Base all final sections only
on the JSON returned by call run or call status; do not invent a transcript.
If any command returns auth_required, switch to the readiness flow, complete
login, and then retry the original operation after login completes.
Use references/commands.md for exact command examples, supported options, and
JSON handling rules.
[HINT] Download the complete skill directory including SKILL.md and all related files