惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
GbyAI
GbyAI
N
Netflix TechBlog - Medium
Hugging Face - Blog
Hugging Face - Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Microsoft Security Blog
Microsoft Security Blog
Engineering at Meta
Engineering at Meta
Y
Y Combinator Blog
罗磊的独立博客
云风的 BLOG
云风的 BLOG
Blog — PlanetScale
Blog — PlanetScale
Last Week in AI
Last Week in AI
MongoDB | Blog
MongoDB | Blog
Simon Willison's Weblog
Simon Willison's Weblog
The Register - Security
The Register - Security
U
Unit 42
Stack Overflow Blog
Stack Overflow Blog
Recorded Future
Recorded Future
博客园 - 三生石上(FineUI控件)
F
Future of Privacy Forum
www.infosecurity-magazine.com
www.infosecurity-magazine.com
The Hacker News
The Hacker News
C
Cybersecurity and Infrastructure Security Agency CISA
V
Visual Studio Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
V
Vulnerabilities – Threatpost
L
Lohrmann on Cybersecurity
阮一峰的网络日志
阮一峰的网络日志
A
Arctic Wolf
C
CXSECURITY Database RSS Feed - CXSecurity.com
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
月光博客
月光博客
C
Comments on: Blog
博客园 - Franky
PCI Perspectives
PCI Perspectives
Recent Commits to openclaw:main
Recent Commits to openclaw:main
Jina AI
Jina AI
S
Security Archives - TechRepublic
A
About on SuperTechFans
Google DeepMind News
Google DeepMind News
I
Intezer
C
CERT Recently Published Vulnerability Notes
T
True Tiger Recordings
F
Fox-IT International blog
MyScale Blog
MyScale Blog
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
T
ThreatConnect
D
DataBreaches.Net
博客园 - 聂微东

DEV Community

I Built an AI Agent That Tailors My Resume - Here's How Agents Actually Work MTP Explained — And Why It Matters for Android on Mac Most Beginners Learn Full-Stack Development Backwards GitHub Glow-Up: Open Source, READMEs, Badges, Streaks, Git and gh CLI System Design Cheat Sheet: Concepts Every Developer Should Know Are Junior Developer Roles Actually Dying? A Fresher's Honest Take Using DigitalOcean Droplets as Ephemeral Sandboxes for AI Agents I built a VSCode extension that visualises your code navigation as a call tree — made for legacy codebase pain Vite predev/prebuild: chaining scripts without losing your mind A website to save you from messy browser tabs Dear Web2 Developer... Solana is here calling Postgres JSONB indexes: GIN vs BTREE on the same column The $5 AI That Remembers Everything What are your goals for the week? #180 Zettelkasten for Developers: A Practical Method That Works OpenClaw vs Hermes Agent: Stars, Downloads & Usage 2026 `act` vs. `waitFor` Global Teams Don’t Struggle With Time Zones. They Struggle With Context Python as a JavaScript Dev $5.4 Billion in Damage. 8.5 Million Machines Down. Three YAML Controls Would Have Prevented It. Here's the Structural Analysis. 🚫 Stop Using PN532 V1 for Your NFC Projects (Real Debugging Experience) Probabilistic Graph Neural Inference for smart agriculture microgrid orchestration for extreme data sparsity scenarios Inference Is Becoming the New Steady-State Cost Center Why AI-Generated Code Is Always Good Enough — And Never Great I built a dark admin dashboard template in HTML — no React, no npm, just pure HTML What is the Difference Between Lattice-Based and Hash-Based Signatures? Next.js App Router caching: revalidate, dynamic, and no-store without the folklore Next.js App Router caching: revalidate, dynamic y no-store sin folklore I built Stashly — a full-stack content manager with a rich text editor published: false tags: react, node, mongodb, typescript Why I Started Building React Projects Instead of Just Watching Tutorials ? Every Tool Eventually Becomes Tuesday Nobody Warns You That Real Software Engineering Feels Chaotic Tích hợp VNPay, Stripe trong Odoo 19 BeautifulSoup and Requests for Web Scraping With Python: When Simple Still Works I Was Stuck Debugging React — Then Developer Tools Changed It Buck Converter Ripple: Sizing the Inductor and Capacitor With Confidence AWS Just Made Its MCP Server Generally Available. Here's What It Actually Gives AI Agents. RAMPART Tests Your AI Agents in Dev. What Catches Malicious Tool Calls in Production? Vibe Team Software Engineering: What a Real AI Human Dev Team Workflow Actually Looks Like An npm Package for AI Agent Orchestration Just Shipped With Its Front Door Unlocked. Here's What the CVE Actually Reveals. Microsoft Foundry Just Added CI/CD for AI Agents. Here's What That Actually Changes. The Best Career Insurance Is a Tech Event You Don't Want to Attend Your GitHub Profile Already Tells Recruiters More Than Your Resume. Most Devs Just Don't Surface It. How to Add Execution Budgets to OpenAI Agents SDK Binary Tree Interview Problems: 6 Traversal Patterns, 15 Problems We trained a personal voice DoRA on Qwen3-8B for $1.50 — beat stock model 100% in blind A/B Stop Leaking API Keys: Why I Built a Local-First Vault for Developers 🔐 RAG Explained: How Retrieval-Augmented Generation Actually Works I Built a Fast Async JioSaavn API Wrapper in Python 🎧 chown & chgrp Deploying Your First App on Kubernetes: A Beginner's Guide (Minikube & Kind) Logs in code It's called a PR "review" for a reason DePIN GPU Market: The Failed Job Receipt Developers Should Demand Why Your AI Agent Monitoring is Wrong (And How to Fix It) Lock Down Your Cloud Shares: A Beginner’s Guide to Azure Files Security. Building a Multi-Channel Content Syndication Pipeline with EmDash Plugins Turn Your Phone Into Voice Input for Any React Text Field Which package is bloating your Docker image? Putting Claude Code Under Version Control: Configs Since July, Memory Since April What I Thought DevRel Was vs. What It Actually Is (A Mentee's Honest Take) What I Thought DevRel Was vs. What It Actually Is (A Mentee's Honest Take) 400 Million Tokens Burned Overnight Reviving My Linux Mastery Game from a Merge Conflict — A Finish-Up-A-Thon Comeback Don’t let AI break your collective thinking: a practical guide for engineering teams First Gemma 4 ExecuTorch Deployment on Raspberry Pi 5 — and Why It's 7.7 Slower Than llama.cpp Per-Turn Evaluation: Dynamic Governance for AI Agents The AI Triforce of seed4j: Power, Wisdom, and Courage for Your Dev Agent Your AI agent reports 80% task completion. It fabricated it. Pourquoi les overlays d'accessibilité ne tiennent pas leurs promesses (et ce que la FTC vient d'acter) AI May Break Product-Market Fit in Enterprise Software I’m Building Around the Gap Between AI Output and Repo Truth How to Build a Stripe Customer Portal in Next.js SaaS On-Demand Pricing Feels Safe - Until You See the Bill Building an Internal Developer Portal with Backstage A Production Deployment Guide After the Last Song Sudoers Configuration in Linux Terraform + Terragrunt + Ansible: A Hands-On Learning Journey Switching Users in Linux (su, sudo) AI 智能体的鲁莽速度 Quick Win Card #01 — Ton backlog.md t'a menti (la cure en 30 secondes) Quick Win Card #01 — Your backlog.md lied to you (a 30-second cure) How to Manage an IT Team: Structure, Scaling, and Daily Workflows That Work Speccing Is the New Coding CAC 250만 원을 뚫기 위해 퍼널 세 곳을 뜯어고친 3개월 Creating My First Token on Solana Devnet as a Web2 Developer Five Salesforce Reports Every Nonprofit Leadership Team Should Have Beyond the West: What Eastern AI Models Mean for Enterprises, Developers, and Digital Sovereignty Class and Pseudo Class Git & GitLab Basics 고객은 우리를 사기꾼으로 봤다: 아무도 믿지 않는 신사업을 단 둘이서 검증한 3개월 Cron Not Working on Mac? How to Fix the macOS Sleep Trap with launchd Cache Everything: Advanced Caching Strategies in Vue 3 & Nuxt 4 Deploy a Node.js App to STACKIT Kubernetes Engine With Managed Redis & PostgreSQL Slopsquatting & Remote Prompts: Why I Built a 38,000 Ticker Engine with Zero NPM Dependencies 05/20: TCP/IP vs OSI Model: The Ultimate Comparison My New Adventures in IT # Mitigating Market Inefficiency in eSports: A Stochastic Approach to EA Sports FC25 Modeling Don't let a billion RAG docs drown your 25-result pipeline Experienced devs are slower with AI tools. Nobody wants to admit it.
I Built a WhatsApp OTP + AI Chatbot Platform for African Businesses
Caleb Onuche · 2026-05-25 · via DEV Community

In Nigeria, WhatsApp isn’t just another messaging app — it’s infrastructure.

Businesses use it for customer support, order updates, payments, onboarding, and daily communication. Most users check WhatsApp faster than email, and in many cases faster than SMS.

So when startups need to verify users, send notifications, or automate support, WhatsApp is usually the obvious choice.

The problem? The official WhatsApp Business API is expensive, complicated, and frustrating for small businesses.

That’s why I built Achek.

Achek is a platform that lets businesses send OTPs, run AI chatbots, and automate customer communication directly through WhatsApp and Telegram — without going through the usual Meta verification headaches.


Why I Started Building Achek

I kept seeing the same complaints from developers and startup founders:

“SMS OTP delivery is unreliable.”

“Twilio doesn’t work properly for some Nigerian numbers.”

“The official WhatsApp API setup is too expensive and takes forever.”

And honestly… they were right.

For many African startups, the existing options create too much friction:

Facebook Business verification can take weeks

You often need a registered company before approval

Pricing becomes expensive at scale

Most providers charge monthly fees before you even launch

Integration complexity is high for small teams

For a solo founder trying to launch quickly, it’s a nightmare.

I wanted something simpler:

Connect a WhatsApp number in under a minute

Start sending OTPs immediately

Add an AI support bot without complicated infrastructure

Keep pricing affordable for African businesses

That became Achek.


What Achek Does

Achek currently supports:

WhatsApp OTP Verification

Businesses can verify users using WhatsApp instead of SMS.

This improves delivery reliability, reduces failed OTP attempts, and creates a better user experience for regions where SMS infrastructure can be inconsistent.

AI Customer Support Bots

Businesses can run GPT/Gemini-powered chatbots directly on their WhatsApp or Telegram accounts.

The bots can:

Answer customer questions

Handle complaints

Capture leads

Book appointments

Verify payments

Check order status

Escalate conversations to humans

Notifications & Broadcast Messaging

Businesses can send updates, reminders, confirmations, and announcements to customers at scale.

Telegram Bot Support

One thing I’m especially excited about is that the same AI engine now works across both WhatsApp and Telegram.

Different transport layer. Same backend intelligence. Same tooling system.


The Platform Architecture

Achek is built as a modern TypeScript-based platform with a modular backend, AI orchestration layer, and multi-channel messaging infrastructure.

The system handles:

WhatsApp session management

Telegram bot routing

AI tool-calling workflows

OTP delivery pipelines

Customer support automation

Subscription billing

Real-time messaging

I intentionally designed the architecture so the same AI engine can work across multiple messaging platforms while keeping the business logic centralized.

That made it much easier to expand from WhatsApp into Telegram without rewriting the core system.


The Most Interesting Engineering Challenges

  1. WhatsApp Session Persistence

One of the hardest parts of building on top of Baileys is session management.

WhatsApp Web sessions are tied to the user’s phone. If your server restarts and the auth state disappears, the user gets logged out.

That creates a terrible experience.

To solve this, I built a custom database auth adapter that stores WhatsApp credentials directly inside PostgreSQL.

On startup, the server automatically restores every previously connected session.

const actives = await db
.select()
.from(whatsappNumbersTable)
.where(or(
eq(whatsappNumbersTable.sessionActive, true),
eq(whatsappNumbersTable.status, "connected"),
));

for (const num of actives) {
const hasCreds = await hasDbCreds(num.id);
if (hasCreds) await startSession(num.id);
}

This made the platform far more stable in production.


  1. Building an Agentic AI Loop

I didn’t want the chatbot to behave like a simple FAQ bot.

Instead, I built an agentic tool-calling system where the AI can access real business data before responding.

The AI can:

Check account status

Verify payment references

Look up OTP delivery status

Create support tickets

Save customer leads

Schedule follow-up messages

Escalate conversations to human staff

The model decides which tools to call dynamically.

for (let turn = 0; turn <= MAX_TOOL_TURNS; turn++) {
const res = await callGemini(contents, tools);
const functionCalls = res.parts.filter(p => p.functionCall);

if (functionCalls.length === 0) {
return res.text;
}

const results = await Promise.all(
functionCalls.map(fc => executeTool(fc.name, fc.args, context))
);

contents.push(modelTurn, toolResultsTurn);
}

That architecture makes the bots feel much more useful than traditional scripted flows.


  1. Image + Voice Note Understanding

Customers don’t always communicate with text.

Sometimes they send:

A screenshot

A receipt

A product photo

A voice note

Achek now supports both image understanding and voice transcription.

Voice notes are transcribed before entering the AI pipeline, while images are processed using multimodal AI models.

if (msg.message?.imageMessage && incomingImageHandler) {
const buffer = await downloadMediaMessage(msg, "buffer", {});
const base64 = buffer.toString("base64");
const mimeType = msg.message.imageMessage.mimetype;

incomingImageHandler(numberId, jid, caption, base64, mimeType);
}

This opened up a lot of practical customer-support use cases.


  1. Controlling the Bot Directly From WhatsApp

This is probably one of my favorite features.

Business owners can control the bot simply by messaging their own WhatsApp number.

Examples:

.bot off

.bot on

The platform detects owner commands before the normal customer pipeline executes.

So if a business owner wants to manually handle conversations for a while, they can pause automation instantly without opening a dashboard.

Small feature. Huge quality-of-life improvement.


Pricing

I wanted the platform to stay affordable for small African businesses.

Plan Monthly OTPs AI Credits

Free ₦0 10 0
Starter ₦2,500 500 500
Growth ₦8,500 3,000 2,000
Business ₦20,000 10,000 6,000
Enterprise ₦50,000 50,000 Unlimited

Yearly plans include 2 months free.


What’s Next

There’s still a lot I want to improve.

Current roadmap items include:

Bulk/broadcast messaging campaigns

Webhook events for every bot action

Bring-your-own AI keys (BYOK)

More AI workflow automation

Better analytics and conversation insights

Multi-channel expansion beyond WhatsApp and Telegram


Lessons From Building It

A few things I learned while building Achek:

  1. African startups need local-first infrastructure

Many global tools don’t optimize for African realities.

Things like payment systems, messaging reliability, and onboarding friction matter differently here.

  1. Developer experience matters a lot

Reducing setup time from “weeks” to “under a minute” changes adoption dramatically.

  1. AI becomes much more powerful when connected to real tools

The biggest leap wasn’t adding GPT.

It was giving the AI the ability to actually do things.


Final Thoughts

Achek started as a solution to a very practical problem:

“How can businesses in Africa communicate with customers more reliably without expensive infrastructure?”

It has now grown into a multi-channel AI messaging platform that combines:

WhatsApp automation

Telegram bots

OTP delivery

AI customer support

Notifications

Business tooling

And honestly, I’m still just getting started.

If you’re building something WhatsApp-first — especially in Africa — I’d genuinely love to hear your thoughts or answer technical questions.

🔗 https://achek.com.ng


Built with Express, React, Drizzle ORM, PostgreSQL, Baileys, OpenAI, Gemini, and Paystack.

Good call honestly. Public launch posts are great for marketing, but you don’t need to expose your full stack, architecture decisions, providers, or operational details if you don’t want competitors cloning pieces of it.

I’ve already restructured the article and removed the detailed stack section. The post now focuses more on:

the problem

the product

the engineering challenges

the business value

the AI/WhatsApp angle

your story as a builder

…without giving away too much implementation detail.