system-prompts-and-models-o.../salesflow-saas/backend/app/integrations/sms.py
Claude f1852c1121
Add SalesMatic AI Sales SaaS Platform - Complete Foundation
Full-stack AI-powered sales automation platform for Saudi SMEs:

Backend (FastAPI + PostgreSQL):
- Multi-tenant architecture with row-level isolation
- JWT auth with RBAC (owner/manager/agent/admin)
- Lead, Customer, Deal, Pipeline, Activity, Message, Proposal models
- Dashboard analytics API (overview, pipeline, revenue)
- WhatsApp Business API, Email (SMTP/SendGrid), SMS (Unifonic) integrations
- Celery + Redis workers for automated follow-ups and scheduled messages
- Property model for Real Estate module (Riyadh districts)
- Hijri date utilities, Arabic/English localization

Frontend (Next.js + Tailwind):
- Professional Arabic RTL landing page with 10 sections
- Brand identity: SalesMatic (سيلزماتك) with custom SVG logo
- Color system: Trust Blue #0F4C81, Growth Teal #00BFA6, CTA Orange #FF6B35
- IBM Plex Sans Arabic + Inter typography
- Responsive design, dark hero section, pricing table, FAQ

Industry Templates:
- Healthcare/Clinics: pipeline stages, WhatsApp message templates, auto-workflows
- Real Estate Riyadh: 20 districts, property tours, payment plans, matching

Infrastructure:
- Docker Compose (PostgreSQL, Redis, Backend, Celery, Frontend, Nginx)
- Nginx reverse proxy config
- Makefile for common operations

https://claude.ai/code/session_01LLR7jzpyNRwDA9kojtT3CW
2026-03-28 03:06:53 +00:00

27 lines
895 B
Python

import httpx
from app.config import get_settings
settings = get_settings()
UNIFONIC_API_URL = "https://el.cloud.unifonic.com/rest/SMS/messages"
async def send_sms(phone: str, message: str) -> dict:
"""Send SMS via Unifonic (Saudi market)."""
if not settings.UNIFONIC_APP_SID:
return {"status": "error", "detail": "Unifonic SMS not configured"}
payload = {
"AppSid": settings.UNIFONIC_APP_SID,
"SenderID": settings.UNIFONIC_SENDER_ID,
"Recipient": phone,
"Body": message,
}
async with httpx.AsyncClient() as client:
response = await client.post(UNIFONIC_API_URL, data=payload)
result = response.json()
if result.get("success"):
return {"status": "sent", "message_id": result.get("data", {}).get("MessageID")}
return {"status": "error", "detail": result.get("message", "Unknown error")}