Toingg Ops Toolkit
Create and launch Toingg voice-calling campaigns by POSTing user-supplied JSON to the toingg/make_campaign API. Use when Codex needs to turn campaign briefs...
Description
name: toingg-create-campaign description: End-to-end Toingg ops: create campaigns, (optionally) schedule daily analytics pulls, and turn Excel contact sheets into WhatsApp outreach via add_contacts + send_whatsapp_templates. Use when Codex needs to automate Toingg voice/WhatsApp workflows and requires scripts for campaign POSTs, analytics cron setup, or bulk contact uploads.
Toingg Ops Toolkit
This skill bundles everything needed to manage Toingg campaigns from Claw:
- Campaign creation via
create_campaign.py - Campaign discovery via
fetch_campaigns.pywhen you need to list active IDs for users - On-demand calls via
make_call.py(after collecting name, phone, and campaign) - Optional analytics cron (7 PM daily) powered by
get_campaign_analytics.py - Contact upload + WhatsApp broadcast using
xlsx_to_contacts.py,add_contacts.py, andsend_whatsapp_templates.py
All HTTP calls reuse the TOINGG_API_TOKEN bearer token.
Setup
- Export your token in every environment that runs these scripts (gateway, cron, terminals).
export TOINGG_API_TOKEN="tg_..." - Install Python deps once if you will ingest Excel files:
pip install openpyxl requests - Keep payloads (campaign JSON, analytics snapshots, contact exports) in version control or shared storage per your security rules.
Campaign discovery workflow
Use this whenever the user wants to see active campaigns or needs a campaign ID before launching a call.
- Ask whether they already know the campaign ID. If not, offer to fetch the latest list (default pagination is fine unless they request a different page size).
- Run:
Adjust./scripts/fetch_campaigns.py --skip 0 --limit 10 --sort -1 > responses/campaigns-$(date +%s).json--skip/--limit/--sortif the user needs deeper pages or a different ordering. - Summarize the response back to the user: surface at least
campID,name, status, and any relevant dates so they can choose confidently. - Store the JSON output when ongoing work depends on the snapshot.
On-demand call workflow
When the user asks you to place a call, gather three pieces of information before touching the API:
- Caller name (string shown in Toingg logs).
- Phone number in international format.
- Campaign selection. If they do not supply a campaign, ask whether they want the latest list. Use the campaign discovery workflow above to provide options, then confirm their pick.
Once those details are confirmed, trigger the API:
./scripts/make_call.py "Recipient Name" +919999999999 64fd3f9...
The helper always sends asr=AZURE, startMessage=true, clearMemory=false, and extraParams={} per the product team’s defaults. Echo the API response (success or failure) back to the user so they know the call status.
Campaign creation workflow
- Gather campaign fields from the user (title, voice, language, script, purpose, tone, post-call schema, notification numbers, autopilot flags, etc.).
- Draft a payload JSON using
references/payload-template.mdas the scaffold. - Run the helper:
cd skills/toingg-create-campaign ./scripts/create_campaign.py payloads/my_campaign.json > responses/create-$(date +%s).json - Return the API response (campaign ID, status, or validation errors) to the user and log it.
Opt-in analytics cron (7 PM daily)
Only offer this when the user explicitly asks for daily analytics.
- Confirm desired schedule/output directory.
- Follow
references/analytics-cron.mdto createopenclaw cron create toingg-analytics-digest ...with the provided command snippet. Adjust paths if needed. - Double-check
TOINGG_API_TOKENis visible to the gateway before enabling the cron. - After the first run, share where the JSON snapshots live and how to disable the cron (
openclaw cron delete ...).
get_campaign_analytics.py can also be run ad-hoc for on-demand pulls:
./scripts/get_campaign_analytics.py > analytics.json
Contact upload + WhatsApp templates
When a user supplies an Excel sheet (name / phone / context columns) and wants to blast a WhatsApp template:
-
Convert Excel → JSON
./scripts/xlsx_to_contacts.py ~/Downloads/leads.xlsx contacts.jsonSee
references/contact-workflow.mdfor the exact column expectations and troubleshooting. The script skips blank rows and normalizes phone numbers. -
Upload contacts to a Toingg contact list (auto-creates if missing):
./scripts/add_contacts.py ClawTest contacts.json -
Send WhatsApp templates once the list is ready:
./scripts/send_whatsapp_templates.py \ 231565687 \ bfesfbgf \ en-US \ ClawTest \ --payload template-variables.json- Omit
--payload(defaults to[]) if the template has no variables. - Pass
--resendonly when the user explicitly wants to re-contact existing recipients.
- Omit
-
Confirm delivery status in Toingg and report any errors back to the user (the helper prints full JSON responses for logging).
File map
| Script | Purpose |
|---|---|
scripts/create_campaign.py |
POST /api/v3/create_campaign with arbitrary payloads |
scripts/fetch_campaigns.py |
GET /api/v3/get_campaigns for quick campaign listings |
scripts/make_call.py |
POST /api/v3/make_call once you have name/phone/campaign |
scripts/get_campaign_analytics.py |
GET /api/v3/get_campaign_analytics (cron-friendly) |
scripts/xlsx_to_contacts.py |
Convert Excel sheets into Toingg contact JSON |
scripts/add_contacts.py |
Upload contact lists via /api/v3/add_contacts |
scripts/send_whatsapp_templates.py |
Trigger /api/v3/send_whatsapp_templates |
Keep this toolkit lightweight: update the references when Toingg adds new fields or workflows so other operators can follow the same patterns.
Reviews (0)
No reviews yet. Be the first to review!
Comments (0)
No comments yet. Be the first to share your thoughts!