Total Leads
β
Avg Response
β
seconds
Contacted <5 Min
β
Opt-Out Rate
β
Leads Per Day
Last 7 daysAvg Response Time
Seconds per dayNo lead data yet
Lead events will appear here once Make.com starts posting to POST /api/lead-event.
Total Missed
β
SMS Sent
β
Recovery Rate
β
Conversations
β
Avg Reply Time
β
seconds
Missed Call Events
| Timestamp | Caller | Call Status | SMS Sent | SMS Status | Replied | Conv. ID |
|---|---|---|---|---|---|---|
| Loading⦠| ||||||
Automation Error Log
| Occurred At | Event Type | Error | Module | Call UUID | Caller |
|---|---|---|---|---|---|
| No errors. β | |||||
No reports yet
Weekly reports are generated every Monday morning and emailed to you automatically. They'll appear here too.
Total Submissions
β
Active
β
Pending
β
Cancelled
β
Onboarding Submissions
| Business | Owner | Contact | Tier | Submitted | Client ID | Account | Status | Actions |
|---|---|---|---|---|---|---|---|---|
| Loading⦠| ||||||||
Client Onboarding Guide
Follow these steps every time you onboard a new client. Check off as you go β progress saves in your browser.
Backend β Create Client Account
Run seed-client.js to create their account
Open PowerShell, navigate to your backend folder, and run:
$env:DATABASE_URL="your_database_url"; node seed-client.js CLIENT_ID THEIR_PIN coreπ‘ Change core to growth or pro based on their tier. Pick a strong PIN β 8+ chars.
Then set their Telnyx number and forwarding phone in the DB:
UPDATE clients SET vonage_number = '+1XXXXXXXXXX', forward_phone = '+1XXXXXXXXXX' WHERE client_id = 'CLIENT_ID';π‘ vonage_number is the DB column name β it holds their Telnyx number. forward_phone = the roofer's real cell that calls get forwarded to.
Verify the client appears in Admin β Onboarding tab
Switch to the Onboarding tab above and confirm the account row shows as Active. If not, the seed script may have failed β check your DATABASE_URL.
Test their login URL
Open this in an incognito window β it should auto-login and show their (empty) dashboard:
https://dashboard.responsepro.app?client=CLIENT_ID&token=THEIR_PINMake.com β Outbound Scenario
Import ResponsePro β Outbound v4 (Telnyx) blueprint into Make.com
Make.com β Create new scenario β click the three dots (β―) β Import Blueprint β upload the file.
Set Client ID in Module 2 (βοΈ SET CLIENT ID HERE)
Open the variable module and replace YOUR_CLIENT_ID_HERE with:
CLIENT_IDReplace all YOUR_API_SECRET_HERE with your API secret
8 HTTP modules use it: module 32 (duplicate lead check), module 4 (opt-out check), and modules 6, 7, 10, 13, 35, 37 (event logging and contact recording). Same API_SECRET from Render. Use Find & Replace if your Make.com plan supports it β otherwise open each HTTP module and swap manually.
Set YOUR_TELNYX_NUMBER_HERE to their assigned Telnyx number
4 Telnyx SMS modules use the from number β modules 9 and 12 (customer texts) and modules 11 and 14 (business alerts). This is their dedicated number from Telnyx, not your main number.
β³ If Telnyx number is still pending, use the test number for now and swap it when it arrives.
Set YOUR_BUSINESS_PHONE_HERE to the owner's cell
Modules 11 and 14 send a "New Lead" alert to the business. This is where the roofer gets notified on their phone.
Review both SMS message texts (business hours + after hours)
Modules 9 and 12. Personalize with the client's business name or any custom wording from their onboarding form. Every message must end with "Reply STOP to opt out."
Connect the webhook to their lead source
Copy the Make.com webhook URL (module 1 β click the webhook β copy URL). Paste it into their CRM, website form, or wherever leads come from.
Run a test lead through the scenario
Click Run once in Make.com, submit a test form with your phone number. Confirm SMS arrives, dashboard shows the event, error log is clean.
β If SMS arrives and dashboard shows data β outbound is live.
Turn scenario ON
Toggle the scenario to ON. It's webhook-triggered so it fires automatically β no cron schedule needed.
Make.com β Inbound SMS Scenario
Import ResponsePro β Inbound SMS Handler v2 (Telnyx) blueprint into Make.com
Same process as outbound β Create new scenario β Import Blueprint.
Set Client ID in Module 2
Same as outbound β replace YOUR_CLIENT_ID_HERE with their client ID.
Replace all YOUR_API_SECRET_HERE
2 HTTP modules (Flag Opt-Out, Log Inbound Reply). Same API secret as outbound.
Set YOUR_TELNYX_NUMBER_HERE in HELP and Opt-Out reply modules
Modules 6 and 7 send SMS back to the customer. Use the same Telnyx number as outbound.
Update HELP message with real contact info
Module 7. Replace YOUR_BUSINESS_PHONE_HERE and YOUR_BUSINESS_EMAIL_HERE with the client's actual contact info.
Copy the inbound webhook URL
Module 1 β copy the webhook URL. This goes into Telnyx as the inbound SMS webhook for their number.
Set inbound webhook in Telnyx for their number
Telnyx Portal β Numbers β their number β Edit β set Messaging Webhook URL to the Make.com URL from the step above. Method: POST.
Test opt-out flow
Text STOP from your phone to their Telnyx number. Confirm you get the unsubscribe confirmation SMS and the number is blocked in the DB.
Turn inbound scenario ON
Telnyx Voice β Missed Call System
Create a Telnyx Call Control Application
Telnyx Portal β Voice β Call Control β Create Application. Set:
Webhook URL: https://responsepro-api.onrender.com/api/voice/event (POST)
Answer URL: https://responsepro-api.onrender.com/api/voice/answer (POST)π‘ One Call Control Application covers all clients β you don't need a new one per client.
Link their Telnyx number to the Call Control Application
Telnyx Portal β Numbers β find their number β Edit β assign it to the Call Control Application you just created. This tells Telnyx to hit your webhook URL when that number receives a call.
Confirm env vars are set in Render
Render Dashboard β ResponsePro API β Environment β confirm both are set:
MAKE_MISSED_CALL_WEBHOOKβ your Scenario 1 Make webhook URLTELNYX_WEBHOOK_PUBLIC_KEYβ your Ed25519 public key from Telnyx Portal β API Keys β Webhooks. Required β server rejects all voice webhooks without this.
π‘ These are one-time setup values β same for all clients.
Import ResponsePro β Outbound v4 (Telnyx) as the missed call scenario into Make.com
Create new scenario β Import Blueprint. Set Client ID in the SET CLIENT ID module. Replace all YOUR_API_SECRET_HERE in HTTP modules. Set YOUR_TELNYX_NUMBER_HERE to their Telnyx number. Set YOUR_BUSINESS_PHONE_HERE to the roofer's cell for the business alert SMS.
Review the missed call SMS message text
Personalize with the client's business name. Must include "Reply STOP to opt out." Example: "Hi, you just called [Business Name] and we missed you. Still need a roofing estimate? Reply here and we'll get right back to you. Reply STOP to opt out."
Test by calling the Telnyx number and not answering
Call their Telnyx number from your cell. Let it ring out β don't answer. Wait ~30 seconds then check: (1) Missed Calls tab shows a new row, (2) SMS arrives on your phone, (3) error log is clean.
β If all three pass β voice is live. Turn the Make scenario ON.
Make.com β Follow-up Sequences (Scenario 3)
Import ResponsePro β Follow-up Sequences (Telnyx) blueprint into Make.com
Create new scenario β Import Blueprint. This scenario runs on a 15-minute schedule and sends follow-up messages to leads who haven't replied.
Set Client ID in Module 2 (βοΈ SET CLIENT ID HERE)
Replace YOUR_CLIENT_ID_HERE with their client ID β same as outbound and inbound.
Replace all YOUR_API_SECRET_HERE
Same API secret as all other scenarios. Hits /api/follow-ups/due, /api/follow-ups/:id/advance, and /api/follow-ups/:id/complete.
Set YOUR_TELNYX_NUMBER_HERE in the SMS send module
Same Telnyx number used in outbound and inbound for this client.
Confirm the schedule is set to every 15 minutes
The trigger module should be a scheduled webhook firing every 15 minutes. Verify the interval in Make.com β do not set it longer or follow-up timing will drift from the expected 1hr / 24hr / 72hr / 7-day cadence.
Test follow-up sequence end-to-end
Trigger a test lead through outbound. Confirm a row appears in follow_up_queue in Supabase. After 1 hour, run the follow-up scenario manually (Run once) and verify the SMS sends and the step advances. Check that replying STOP stops the sequence.
β If step advances and SMS sends β turn scenario ON.
Client Handoff
Send the client their dashboard login URL
https://dashboard.responsepro.app?client=CLIENT_ID&token=THEIR_PINπ‘ Send via text or email. Tell them to bookmark it β that link logs them in automatically.
Walk them through the dashboard (5 min)
Show them: Lead Analytics KPIs, the weekly chart, Missed Calls tab, and how to read response times. Keep it simple β they care about leads contacted and response speed.
Confirm billing is set up
Make sure they've paid the setup fee (if applicable) and their first month is collected. Don't leave this step until billing is confirmed.
Update onboarding status to Active
Onboarding tab β find their row β click β Active. This is your internal record that they're fully live.
Schedule 7-day check-in
Set a reminder to follow up in 7 days. Ask: Are they getting SMS alerts? Any issues? This is also your shot to get a testimonial early.