<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Abbas Imran</title>
    <description>The latest articles on DEV Community by Abbas Imran (@abbas_imran_dbc3c8df6447e).</description>
    <link>https://dev.to/abbas_imran_dbc3c8df6447e</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3756658%2Fdf068c39-cdd3-4bd0-ad33-07a5e5a5fef0.png</url>
      <title>DEV Community: Abbas Imran</title>
      <link>https://dev.to/abbas_imran_dbc3c8df6447e</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/abbas_imran_dbc3c8df6447e"/>
    <language>en</language>
    <item>
      <title>I built an AI phone receptionist in 3 weeks. Here's what nobody tells you.</title>
      <dc:creator>Abbas Imran</dc:creator>
      <pubDate>Tue, 12 May 2026 13:37:04 +0000</pubDate>
      <link>https://dev.to/abbas_imran_dbc3c8df6447e/i-built-an-ai-phone-receptionist-in-3-weeks-heres-what-nobody-tells-you-32n0</link>
      <guid>https://dev.to/abbas_imran_dbc3c8df6447e/i-built-an-ai-phone-receptionist-in-3-weeks-heres-what-nobody-tells-you-32n0</guid>
      <description>&lt;p&gt;I want to share something I've been working on for the past few weeks, mostly because I couldn't find a single honest write-up about it when I started. So here's mine.&lt;/p&gt;

&lt;p&gt;A client came to us with a really specific problem. They were losing leads. Not because their service was bad actually, the opposite. They were so good that their phone never stopped ringing, and a small team of two people couldn't pick up every call. The owner told me, almost embarrassed, that he'd been answering calls at 11 PM the night before because he didn't want to miss a sale.&lt;/p&gt;

&lt;p&gt;That hit me in a way I didn't expect.&lt;/p&gt;

&lt;p&gt;So we said, okay, let's build an AI that answers the phone like a real person. Books appointments. Qualifies leads. Tells callers what they need to know. Doesn't sound like a robot. And does it for under what a part-time receptionist would cost.&lt;/p&gt;

&lt;p&gt;Three weeks later, we shipped it. Here's the honest story.&lt;/p&gt;

&lt;h2&gt;
  
  
  Why I almost gave up in week 1
&lt;/h2&gt;

&lt;p&gt;I'd built voice apps before. I thought this would be easy. Twilio for the phone line, GPT-4o for the brain, some TTS for the voice done.&lt;/p&gt;

&lt;p&gt;Lol.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fv4mafw116w7rsa0wge5u.webp" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fv4mafw116w7rsa0wge5u.webp" alt=" " width="480" height="270"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;The first version we built worked exactly once, in the staging environment, with a perfect WiFi connection and me speaking in a clean American accent into a $200 microphone. The moment a real customer called in from a noisy car with a British accent, the whole thing collapsed.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fqhpnabvp00i5ncyxjzl3.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fqhpnabvp00i5ncyxjzl3.gif" alt=" " width="480" height="264"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Three things broke immediately:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;Latency.&lt;/strong&gt; Standard TTS pipelines add 600-1200ms before any audio comes back. On a phone call, that feels like the line went dead. People hung up.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Interruptions.&lt;/strong&gt; Real humans interrupt. Real humans say "uhh" and "wait, actually." Our agent waited politely for them to finish, which they never did.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Hallucinations on critical data.&lt;/strong&gt; The agent confidently told a caller our office was open Sundays. We are not open Sundays.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;I closed my laptop at 2 AM and considered emailing the client to ask for an extension. Instead I made coffee and started over.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F0rgl3hkyxqrhvlicy29y.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F0rgl3hkyxqrhvlicy29y.gif" alt=" " width="480" height="270"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"Coffee fixes everything except your code."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h2&gt;
  
  
  The stack that actually worked
&lt;/h2&gt;

&lt;p&gt;After three iterations, here's what stuck:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Twilio&lt;/strong&gt; for the carrier layer (porting numbers, SIP, programmable voice)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;OpenAI Realtime API&lt;/strong&gt; for speech-to-speech (this changed everything more on this below)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;LiveKit&lt;/strong&gt; for WebRTC audio routing (because Twilio's media streams alone have weird buffering)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Node.js&lt;/strong&gt; for the orchestration layer&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Postgres + Redis&lt;/strong&gt; for state and call session tracking&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The single biggest unlock was the Realtime API. Once we stopped doing the old &lt;code&gt;audio → STT → LLM → TTS → audio&lt;/code&gt; pipeline and switched to native speech-to-speech, our perceived latency dropped from ~1.5 seconds to about 350ms. That's the difference between "this feels like a robot" and "wait, is this a person?"&lt;/p&gt;

&lt;h2&gt;
  
  
  The webhook that started it all
&lt;/h2&gt;

&lt;p&gt;This is the entry point. When Twilio receives a call, it pings our webhook, and we hand off the call to LiveKit which then bridges to the realtime model.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="c1"&gt;// app/api/voice/incoming/route.ts&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;NextRequest&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;NextResponse&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;next/server&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;generateLiveKitToken&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;@/lib/livekit&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="k"&gt;async&lt;/span&gt; &lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;POST&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;req&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;NextRequest&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;formData&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nx"&gt;req&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;formData&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;callSid&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;formData&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;get&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;CallSid&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="k"&gt;as&lt;/span&gt; &lt;span class="kr"&gt;string&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;formData&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;get&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;From&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="k"&gt;as&lt;/span&gt; &lt;span class="kr"&gt;string&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

  &lt;span class="c1"&gt;// create a session row so we can track the call later&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;session&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nx"&gt;db&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;callSession&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;create&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
    &lt;span class="na"&gt;data&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;callSid&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;startedAt&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;Date&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;

  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;token&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nf"&gt;generateLiveKitToken&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
    &lt;span class="na"&gt;room&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;`call-&lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;session&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;id&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;identity&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;`caller-&lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="k"&gt;from&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;

  &lt;span class="c1"&gt;// hand the call off to our LiveKit room&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;twiml&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="s2"&gt;`
    &amp;lt;Response&amp;gt;
      &amp;lt;Connect&amp;gt;
        &amp;lt;Stream url="wss://livekit.example.com/twilio?token=&lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;token&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;" /&amp;gt;
      &amp;lt;/Connect&amp;gt;
    &amp;lt;/Response&amp;gt;
  `&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

  &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;NextResponse&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;twiml&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="na"&gt;headers&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Content-Type&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;text/xml&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="p"&gt;});&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Looks simple. Took me four days to get right.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftwtbnt35c34uxdte9wos.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftwtbnt35c34uxdte9wos.gif" alt=" " width="480" height="320"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Teaching the agent the business
&lt;/h2&gt;

&lt;p&gt;This is the part that I think most tutorials skip, and it's the most important part.&lt;/p&gt;

&lt;p&gt;The model is smart. The model does not know your business. We had to give it a "brain file" a structured prompt that combined business hours, services offered, pricing rules, escalation paths, and behavior guardrails. We also gave it function-calling tools so it could actually &lt;em&gt;do&lt;/em&gt; things, not just talk about them.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;tools&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;
  &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;function&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;book_appointment&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;description&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Book a service appointment in the calendar&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;parameters&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;object&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
      &lt;span class="na"&gt;properties&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
        &lt;span class="na"&gt;customer_name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;string&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt;
        &lt;span class="na"&gt;phone&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;string&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt;
        &lt;span class="na"&gt;service&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;string&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;enum&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;SERVICES&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt;
        &lt;span class="na"&gt;preferred_date&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;string&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;format&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;date-time&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt;
      &lt;span class="p"&gt;},&lt;/span&gt;
      &lt;span class="na"&gt;required&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;customer_name&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;phone&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;service&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt;
    &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;function&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;escalate_to_human&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;description&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Transfer to a human agent for sensitive or complex cases&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;parameters&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;object&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
      &lt;span class="na"&gt;properties&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
        &lt;span class="na"&gt;reason&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;string&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt;
      &lt;span class="p"&gt;},&lt;/span&gt;
    &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
&lt;span class="p"&gt;];&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The &lt;code&gt;escalate_to_human&lt;/code&gt; tool was the one that earned the client's trust. We baked in rules: any pricing dispute, any angry caller, any mention of legal escalate. The agent doesn't try to be a hero. It knows when to tap out.&lt;/p&gt;

&lt;h2&gt;
  
  
  The interruption problem
&lt;/h2&gt;

&lt;p&gt;This took me a full evening to solve and I'm still not 100% happy with it.&lt;/p&gt;

&lt;p&gt;Real humans interrupt. If you don't handle interruptions, your agent feels like it's lecturing them. We used voice activity detection to cut the agent off mid-sentence when the caller starts speaking, then resumed the conversation from where the caller left off not from where the agent was.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="nx"&gt;session&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;on&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;user_speaking_started&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="k"&gt;if &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;agentIsSpeaking&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="nx"&gt;session&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;cancelResponse&lt;/span&gt;&lt;span class="p"&gt;();&lt;/span&gt;
    &lt;span class="nx"&gt;agentIsSpeaking&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kc"&gt;false&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Two lines. One evening of debugging. I'm not proud, but I'm tired.&lt;/p&gt;

&lt;h2&gt;
  
  
  What I'd do differently
&lt;/h2&gt;

&lt;p&gt;A few honest takeaways:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Don't try to make it sound exactly human.&lt;/strong&gt; Tell callers it's an AI in the first 5 seconds. Trust goes up, not down. The ones who care will appreciate the honesty. The ones who don't will keep talking.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Log every single conversation.&lt;/strong&gt; We were debugging hallucinations from memory for three days before we set up proper transcript logging. Don't be us.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Edge cases are 60% of the work.&lt;/strong&gt; "What if they don't speak English?" "What if they say a number wrong?" "What if they're on speaker phone?" We have a 47-item edge case checklist now.&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Latency matters more than intelligence.&lt;/strong&gt; A slightly dumber model that responds in 300ms feels better than a smarter one that takes 1.2s.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Where we are now
&lt;/h2&gt;

&lt;p&gt;The agent has been live for two months. It answers about 80 calls a day. It books roughly half of them as actual appointments. The client tells me he sleeps through the night now, which honestly is the metric I care about most.&lt;/p&gt;

&lt;p&gt;Was it worth three weeks of evenings and one mild breakdown at 2 AM?&lt;/p&gt;

&lt;p&gt;Yeah. It was.&lt;/p&gt;




&lt;p&gt;If you're building something similar, feel free to reach out. I'm Abbas, I run engineering at &lt;a href="https://www.seedinov.com" rel="noopener noreferrer"&gt;Seedinov&lt;/a&gt; we build AI products for small teams who can't hire a Big Tech AI department. You can see the &lt;a href="https://www.seedinov.com/portfolio" rel="noopener noreferrer"&gt;voice agent work in our portfolio&lt;/a&gt; or &lt;a href="https://www.seedinov.com/contact" rel="noopener noreferrer"&gt;drop us a line&lt;/a&gt; if you want to talk shop.&lt;/p&gt;

&lt;p&gt;Good luck out there. Build the thing.&lt;/p&gt;

</description>
      <category>ai</category>
      <category>voiceai</category>
      <category>typescript</category>
      <category>webdev</category>
    </item>
    <item>
      <title>How AI is Revolutionizing Digital Marketing in 2026</title>
      <dc:creator>Abbas Imran</dc:creator>
      <pubDate>Fri, 06 Feb 2026 13:08:22 +0000</pubDate>
      <link>https://dev.to/abbas_imran_dbc3c8df6447e/how-ai-is-revolutionizing-digital-marketing-in-2026-294f</link>
      <guid>https://dev.to/abbas_imran_dbc3c8df6447e/how-ai-is-revolutionizing-digital-marketing-in-2026-294f</guid>
      <description>&lt;h1&gt;
  
  
  How AI is Revolutionizing Digital Marketing in 2026
&lt;/h1&gt;

&lt;p&gt;The digital marketing landscape has undergone a massive transformation with the advent of artificial intelligence. At &lt;a href="https://seedinov.com" rel="noopener noreferrer"&gt;Seedinov&lt;/a&gt;, we've been at the forefront of implementing AI-driven solutions that deliver measurable results for our clients.&lt;/p&gt;

&lt;h2&gt;
  
  
  The Rise of AI in Marketing
&lt;/h2&gt;

&lt;p&gt;Artificial intelligence is no longer a futuristic concept—it's here, and it's changing how businesses connect with their audiences. From personalized content recommendations to automated campaign optimization, AI is making marketing smarter and more efficient.&lt;/p&gt;

&lt;h3&gt;
  
  
  Key Statistics
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;80% of marketers now use AI tools in their daily operations&lt;/li&gt;
&lt;li&gt;AI-powered campaigns see an average 30% increase in ROI&lt;/li&gt;
&lt;li&gt;Automated content generation has reduced production time by 60%&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  How Seedinov Leverages AI for Your Success
&lt;/h2&gt;

&lt;p&gt;At Seedinov, we integrate cutting-edge AI technologies into our &lt;a href="https://seedinov.com/services/digital-marketing" rel="noopener noreferrer"&gt;digital marketing services&lt;/a&gt; to help businesses scale efficiently.&lt;/p&gt;

&lt;h3&gt;
  
  
  1. AI-Powered Content Creation
&lt;/h3&gt;

&lt;p&gt;Our &lt;a href="https://seedinov.com/services/content-marketing" rel="noopener noreferrer"&gt;content marketing solutions&lt;/a&gt; use advanced AI to:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Generate SEO-optimized blog posts&lt;/li&gt;
&lt;li&gt;Create engaging social media content&lt;/li&gt;
&lt;li&gt;Develop personalized email campaigns&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  2. Predictive Analytics
&lt;/h3&gt;

&lt;p&gt;Understanding your audience is crucial. Our &lt;a href="https://seedinov.com/services/analytics" rel="noopener noreferrer"&gt;analytics services&lt;/a&gt; leverage machine learning to:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Predict customer behavior patterns&lt;/li&gt;
&lt;li&gt;Identify high-converting audience segments&lt;/li&gt;
&lt;li&gt;Optimize ad spend in real-time&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  3. SEO Automation
&lt;/h3&gt;

&lt;p&gt;Search engine optimization is evolving rapidly. Our &lt;a href="https://seedinov.com/services/seo" rel="noopener noreferrer"&gt;SEO services&lt;/a&gt; now include:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Automated keyword research and tracking&lt;/li&gt;
&lt;li&gt;AI-driven content optimization&lt;/li&gt;
&lt;li&gt;Intelligent backlink building strategies&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Real Results: A Case Study
&lt;/h2&gt;

&lt;p&gt;One of our clients, a B2B SaaS company, saw remarkable improvements after implementing our AI-driven marketing strategy:&lt;/p&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Metric&lt;/th&gt;
&lt;th&gt;Before&lt;/th&gt;
&lt;th&gt;After&lt;/th&gt;
&lt;th&gt;Improvement&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;Organic Traffic&lt;/td&gt;
&lt;td&gt;5,000/mo&lt;/td&gt;
&lt;td&gt;18,000/mo&lt;/td&gt;
&lt;td&gt;+260%&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Lead Generation&lt;/td&gt;
&lt;td&gt;50/mo&lt;/td&gt;
&lt;td&gt;180/mo&lt;/td&gt;
&lt;td&gt;+260%&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;Domain Authority&lt;/td&gt;
&lt;td&gt;25&lt;/td&gt;
&lt;td&gt;42&lt;/td&gt;
&lt;td&gt;+68%&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;

&lt;blockquote&gt;
&lt;p&gt;"Seedinov's AI-powered approach transformed our digital presence. The results exceeded our expectations." — &lt;em&gt;Marketing Director, Client X&lt;/em&gt;&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h2&gt;
  
  
  Getting Started with AI Marketing
&lt;/h2&gt;

&lt;p&gt;Ready to harness the power of AI for your marketing efforts? Here's how to begin:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;
&lt;strong&gt;Audit your current strategy&lt;/strong&gt; - Identify areas where AI can add value&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Start small&lt;/strong&gt; - Implement one AI tool at a time&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Measure and iterate&lt;/strong&gt; - Track results and optimize continuously&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Partner with experts&lt;/strong&gt; - Work with specialists who understand AI&lt;/li&gt;
&lt;/ol&gt;

&lt;h2&gt;
  
  
  Conclusion
&lt;/h2&gt;

&lt;p&gt;AI is not replacing marketers—it's empowering them to achieve more. By combining human creativity with artificial intelligence, businesses can create more effective, personalized, and scalable marketing campaigns.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Want to explore how AI can transform your marketing?&lt;/strong&gt; &lt;a href="https://seedinov.com/contact" rel="noopener noreferrer"&gt;Contact Seedinov today&lt;/a&gt; for a free consultation.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;Connect with us:&lt;/em&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Website: &lt;a href="https://seedinov.com" rel="noopener noreferrer"&gt;seedinov.com&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;LinkedIn: &lt;a href="https://linkedin.com/company/seedinov" rel="noopener noreferrer"&gt;Seedinov on LinkedIn&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;Twitter: &lt;a href="https://twitter.com/seedinov" rel="noopener noreferrer"&gt;@seedinov&lt;/a&gt;
&lt;/li&gt;
&lt;/ul&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

</description>
    </item>
  </channel>
</rss>
