MyAIBOX (AI็พๅฎ็ฎฑ) is a comprehensive Gen-AI application suite built with FastAPI and React. It provides access to various AI capabilities including AI Agent, multimodal chat, text processing, summarization, image/document recognition, and image creation.
The application integrates multiple GenAI models (Bedrock, Gemini, OpenAI), with secure authentication via Amazon Cognito and session management backed by DynamoDB. It features a modular architecture with a React frontend communicating via AG-UI Protocol (SSE streaming).
๐ What's New in v3.5
- Unified Chat Module: Assistant + Persona merged into a single
/chat/:agentIdroute; each agent = system prompt + tools + params + skills - Strands-native Skills: Agents can load Anthropic-style skills via the
AgentSkillsplugin (requiresstrands-agents>=1.39) - Per-agent Workspace: Each agent gets its own isolated workspace at
storage/workspace/<username>/<agent_id>/ - Configurable Agents: Users can override model, parameters, tools, and skills per agent (persisted in DynamoDB)
- Breaking:
/assistantand/personaroutes now redirect to/chat/assistant;/api/assistant/*and/api/persona/*endpoints replaced by/api/chat/*
v3.2
- Agent Session Cache: Per-session Strands Agent caching with 2h TTL, hot-swap model, persistent MCP connections
- Multimodal Chat: File attachments and image display in Agent conversations
- Image Editing: Edit images with text instructions (Gemini, Nova Canvas, Stability AI)
- Shared SSE Parser: Unified
readSSE()with proper line buffering, fixing stream truncation across modules - CLI Tools:
my-aibox build(with auto version sync) andmy-aibox check(ruff linting)
v3.0
- React Frontend: Full migration from Gradio to React + AG-UI Protocol with SSE streaming
- Generative UI: Dual-track streaming (CoT reasoning + tool use UI)
- Model & MCP Management: In-app model registry and MCP server configuration
v2.x
- Multi-provider Agent: Bedrock, Gemini, and OpenAI models via Strands SDK
- Chat ๐ฌ โ Unified conversational AI: pick an agent (Assistant, Q&A persona, etc.), each with its own tools, skills, system prompt, and workspace
- Text ๐ โ Proofreading, rewriting, reduction, expansion, multi-language support
- Summary ๐ฐ โ Document and text summarization
- Asking ๐ง โ Deep reasoning with thinking + text dual-channel streaming
- Vision ๐ โ Image analysis, document understanding (PDF), multi-model support
- Draw ๐จ โ AI image generation and editing with prompt optimization, style/ratio/seed options
- Settings โ๏ธ โ Account management, module configuration, model registry, MCP server management
Supported input formats: jpg/jpeg, png, gif, webp, pdf, csv, doc/docx, xls/xlsx, txt, md, mp4, webm, mov
my-aibox/
โโโ app.py # FastAPI + uvicorn entry point
โโโ backend/ # Backend Python modules
โ โโโ api/ # REST + SSE endpoints (chat, text, summary,
โ โ # asking, vision, draw, settings, upload)
โ โโโ core/ # Config, service layer, DynamoDB sessions
โ โโโ common/ # Auth, logger, CLI, provider cache, async stream
โ โโโ genai/ # LLM providers (Bedrock/Gemini/OpenAI), agents, tools
โ โโโ utils/ # AWS + Bedrock helpers
โ โโโ tests/ # pytest unit + integration
โโโ frontend/ # React SPA (Vite + TypeScript)
โ โโโ src/ # components / pages / api / styles
โ โโโ assets/ # UI static assets (avatars, icons)
โโโ storage/ # Runtime data (gitignored)
โ โโโ uploads/ # User-uploaded files
โ โโโ generated/ # Generated images / videos
โโโ logs/ # Application logs (gitignored)
โโโ deploy/ # Deployment artifacts
โ โโโ my-aibox.service # systemd user unit template
โ โโโ full-stack/ # Dockerfile + IAM + K8s manifests
โโโ docs/ # README screenshots, etc.
โโโ pyproject.toml
โโโ README.md
| Type | Configuration | Examples |
|---|---|---|
| Strands Tools | Per-agent toggle | calculator, current_time, file_write |
| MCP Tools | Settings โ MCP Server | exa-server, core-mcp-server |
| Legacy Tools | Per-agent toggle | get_weather, search_wikipedia |
| Skills | Per-agent toggle (from ~/.agents/skills/) |
Anthropic-style skills loaded via Strands AgentSkills plugin |
MCP server types: HTTP, stdio, SSE.
- Install dependencies:
curl -LsSf https://astral.sh/uv/install.sh | sh
uv sync- Configure environment:
aws configure
cp .env.example .env
# Edit .env: AWS region, Cognito, DynamoDB, API keys- Build frontend:
my-aibox build- Run:
uv run python app.py| Path | Description |
|---|---|
/ |
React SPA (default โ /chat/assistant) |
/login |
Login page |
/chat/:agentId |
Chat with the selected agent (e.g. /chat/assistant, /chat/family_doctor) |
/text, /summary, /asking, /vision, /draw |
Tool modules |
/settings/session, /settings/modules, /settings/models, /settings/mcp |
Settings pages |
/api/* |
Backend API |
my-aibox install # set up the systemd user service (one-time)
my-aibox run # run in the foreground (skips systemd)
my-aibox start|stop|restart # manage the systemd user service
my-aibox status # show service status
my-aibox logs [-f] # tail journalctl logs
my-aibox build # build frontend (syncs version)
my-aibox check # lint (ruff) + run unit tests
my-aibox test # run pytest (default: tests/unit)
# use `my-aibox test -m integration` for real-service testsMIT License - see LICENSE file for details



