Rebuilt from original PR #1276. All Phase 30 launch content restored: - 5 blog posts (Remote Workspaces, Chrome DevTools MCP, Container vs Remote, Secure by Design) - 4 guides (Remote Workspaces, FAQ, same-origin canvas, quickstart audio) - Community copy: Discord/Slack announcements, HN launch guide - Social copy: Phase 30 (4 X versions + LinkedIn), Chrome DevTools MCP - Sales: landing copy, battlecards, one-pager, objection handlers - Press release draft - Demos: AGENTS.md auto-gen, Cloudflare Artifacts - Audio: TTS announce, VO scripts, demo narrations - Fleet diagram, asset inventory, video production package - Roadmap brief, email drip sequence, post-push checklist Closes GH#1126
21 KiB
Phase 30 Demo Spec — Remote Workspaces & Cross-Network Federation
For: DevRel + Marketing | Status: DRAFT | Phase 30 GA target
Issue: attaches to
Molecule-AI/internal#2—devrel: remote agent fleet demo for Phase 30Technical reference:
docs/guides/external-agent-registration.md— full endpoint reference used throughout this spec.Social launch plan:
marketing/social/phase30-launch-plan.md(PMM-owned) — Section 5 TTS script is the authoritative source forphase30-video-vo.mp3.
1. Demo Scenario
Title: "Your Agent. Your Laptop. On the Canvas."
Premise: A developer runs a Python agent on their laptop, connected to the internet, registering to a Molecule AI org running on a cloud platform. A parent PM agent on the canvas dispatches a research task. The remote agent receives it via A2A, processes it, and returns the result — all visible in real time on the canvas.
Audience: Indie developers evaluating Molecule AI, enterprise teams evaluating multi-cloud agent deployment.
Duration: 8–10 minutes live, 3 minutes narrated.
Full Walkthrough (Live Demo Steps)
Setup (done before recording, shown as screenshots):
- Dev has a Molecule AI platform running at
https://acme.moleculesai.app - Canvas shows a PM workspace ("pm-agent") already online
- Dev's laptop is on a different network — no shared Docker network, no VPN
On screen (live or narrated):
DEVELOPER LAPTOP MOLECULE AI PLATFORM
| |
| 1. POST /workspaces |
| {"name":"researcher", |
| "runtime":"external", |
| "url":"https://laptop:5000"} |
| ─────────────────────────────────────────► |
| ←─ 201 {"id":"ws-abc123", ...} |
| |
| 2. POST /registry/register |
| {id:"ws-abc123", url:"...", |
| agent_card:{name:"researcher", |
| skills:["research","web-search"]}} |
| ─────────────────────────────────────────► |
| ←─ 200 {"status":"registered", |
| "auth_token":"mol_..."} ← SAVE |
| |
| 3. GET /workspaces/ws-abc123/secrets/values |
| Authorization: Bearer mol_... |
| ─────────────────────────────────────────► |
| ←─ 200 {"OPENAI_API_KEY":"sk-..."} |
| |
| 4. POST /registry/heartbeat every 30s |
| Authorization: Bearer mol_... |
| ─────────────────────────────────────────► |
| Canvas shows: researcher = ONLINE (REMOTE)|
| |
| 5. PM agent dispatches task via A2A |
| Canvas My Chat → "Research competitor X" |
| ─────────────────────────────────────────► |
| Platform proxies → POST laptop:5000/a2a |
| ←─ 200 {"result":{"message":{...}}} |
| |
| 6. Researcher result shown in Canvas |
| Researcher chat tab shows full reply |
2. Minimum Viable Demo (Under 10 Minutes)
What to prep before the demo:
- Running platform (self-hosted or SaaS beta)
pip install requestson laptopghcr.io/molecule-ai/workspace-templateimage available (for platform side)- ngrok or Cloudflare Tunnel running on laptop:
ngrok http 5000 - Write down the
WORKSPACE_IDandPLATFORM_URL
Script for the MVP (5 minutes live):
# STEP 1 — Create the workspace (platform side, admin token)
PLATFORM=https://acme.moleculesai.app
ADMIN_TOKEN=mol_admin_...
WORKSPACE_NAME=researcher
WORKSPACE_RESP=$(curl -s -X POST $PLATFORM/workspaces \
-H "Authorization: Bearer $ADMIN_TOKEN" \
-H "Content-Type: application/json" \
-d "{\"name\":\"$WORKSPACE_NAME\",\"runtime\":\"external\",\"tier\":2}")
echo $WORKSPACE_RESP | jq
WORKSPACE_ID=$(echo $WORKSPACE_RESP | jq -r '.id')
# STEP 2 — Seed a secret so pull_secrets has something to show
curl -s -X POST $PLATFORM/workspaces/$WORKSPACE_ID/secrets \
-H "Authorization: Bearer $ADMIN_TOKEN" \
-H "Content-Type: application/json" \
-d '{"key":"MODEL_NAME","value":"gpt-4o"}'
# STEP 3 — On laptop: run the remote-agent demo
# (uses RemoteAgentClient from molecule-sdk-python)
export WORKSPACE_ID=$WORKSPACE_ID
export PLATFORM_URL=$PLATFORM
export MAX_ITERATIONS=20
python3 run.py
# STEP 4 — Show canvas: workspace appears as REMOTE badge
# Canvas → researcher node → Online → Chat tab
What to narrate at each step:
- "This workspace was created with
runtime: external— no Docker provisioning happens. The platform just registers the row and waits for the agent to call home." - "The auth token was returned once, at registration. It's saved to disk. Every subsequent call — secrets, heartbeat, A2A — is authenticated with it."
- "The agent pulls its API keys from the platform. No env vars baked into the container. Rotate the secret in the UI, the agent picks it up on next pull."
- "Canvas shows a purple REMOTE badge. Same status, same chat, same terminal access as any Docker workspace — the deployment location is invisible to the rest of the org."
- "The PM dispatches a task. The platform proxies it to the laptop's endpoint. No Docker bridge, no shared network — it works because the agent registered its URL and keeps a heartbeat alive."
3. Screencast Outline (5 Key Moments)
Moment 1: Platform empty state → PM workspace online (0:00–0:20)
What to show: Canvas with a PM workspace (already set up as org template). Brief zoom on the node — status, role, chat tab. The org is a skeleton at this point: one PM, no reports.
Narration: "Molecule AI runs a PM agent on a cloud platform. The team is small — one PM, one canvas, everything in one place. Now let's add a researcher running on a laptop across the internet."
Moment 2: ngrok tunnel + workspace creation (0:20–1:00)
What to show: Terminal on laptop. ngrok http 5000 running. curl creating the external workspace. Workspace ID copied.
Narration: "The agent creates a workspace row with runtime: external. No Docker involved — the platform just records the identity and waits for it to call home."
Visual: Highlight runtime: "external" in the curl command.
Moment 3: Registration + token cache (1:00–1:45)
What to show: python3 run.py starting. Registration log line. Token saved to ~/.molecule/<id>/.auth_token. Secrets pulled. Heartbeat loop starting.
Narration: "The SDK registers with the platform, receives a 256-bit auth token, and caches it to disk. That token is the agent's identity — it's how the platform knows this is the researcher workspace, not an imposter. The agent then pulls its secrets — API keys, model names — without any baked-in environment variables. And it starts its heartbeat loop, every 30 seconds."
Visual: Show ~/.molecule/ directory with token file. Show the secret keys returned.
Moment 4: Canvas update — REMOTE badge appears (1:45–2:15)
What to show: Canvas, live refresh. Researcher node appears under PM. Purple REMOTE badge. Status: online. Current task: "remote-agent demo idle". Ping the activity panel to show heartbeat activity.
Narration: "Back on the canvas — the researcher is online. Purple badge means it's remote — not a Docker container on this platform. Same status indicator as any other workspace. Same chat tab. The platform doesn't care where it's running."
Visual: Circle the REMOTE badge. Show the heartbeat tick in the activity log.
Moment 5: Task dispatch and result (2:15–3:00)
What to show: PM's My Chat input: "Research Anthropic's latest model release and summarize in 3 bullet points." Send. Canvas shows "current task: researching" on researcher node. Researcher replies. Result appears in PM's chat.
Narration: "The PM dispatches a task. The platform routes it to the laptop — same A2A protocol used for every agent call, regardless of where the target runs. The laptop processes it, returns the result, and it appears in the PM's chat. No special configuration on either side — the platform's A2A proxy handles the routing."
Visual: A2A JSON-RPC payload shown briefly in researcher terminal. Canvas showing result.
3b. Visual Assets Required (from PMM social launch plan)
These assets are produced by the design team. The screencast and guide reference them at the moments noted.
ASSET 1 — Canvas screenshot: REMOTE badge visible alongside Docker agents
Description: Screenshot of the Molecule AI canvas showing a mixed fleet: one Docker-provisioned workspace (e.g. "pm-agent", standard runtime pill) and one remote workspace (e.g. "researcher", purple REMOTE badge) visible simultaneously. Both should show status "online".
When it's used: Moment 4 of the screencast — the payoff shot. Also used as the hero image in the docs/guides/remote-workspaces.md guide.
Capture instructions:
- Spin up a Docker workspace on the platform (use the
claude-code-defaulttemplate) - Spin up a remote workspace (see Section 2 — run
python3 run.pyon laptop with ngrok) - Arrange both nodes visible on canvas at the same time
- Screenshot at ~1440px wide; include the side panel closed so the canvas is unobstructed
- Crop to show the org topology clearly; do not crop out the REMOTE badge on the researcher node
File: marketing/assets/phase30-canvas-remote-badge.png
ASSET 2 — Fleet diagram: AWS / GCP / on-prem → A2A proxy → single canvas
Description: Clean infrastructure diagram showing three remote agent nodes (AWS, GCP, on-premises datacenter) each running an agent on their own infrastructure. Each agent connects via HTTPS to the Molecule AI platform's A2A proxy. The platform connects via WebSocket to a single canvas browser. All agents appear as workspaces on the same canvas, side by side.
Style: Molecule AI brand — dark background (#0A0E1A or similar), consistent iconography, thin connector lines, no heavy borders. Same visual language as the architecture diagrams in docs/architecture/architecture.md.
Include labels:
- Each agent node: runtime label (e.g. "Claude Code / laptop", "LangGraph / AWS EC2", "CrewAI / on-prem")
- A2A proxy:
POST /workspaces/:id/a2a(label on the connector) - WebSocket fanout: labeled
WS fanoutbetween platform and canvas - Canvas: single browser icon with "One canvas. All agents."
When it's used: Guide hero image (docs/guides/remote-workspaces.md), Phase 30 blog post hero, social card.
File: marketing/assets/phase30-fleet-diagram.png
ASSET 3 (Optional) — 10-second GIF: registration → canvas → A2A message flow
Description: Short looping animated GIF showing the end-to-end flow in real time:
- Terminal:
python3 run.pystarts, logs scroll - Canvas: researcher node fades in under PM with REMOTE badge
- Canvas chat: PM types a task, hits send
- Terminal: A2A JSON-RPC
message/sendreceived, response returned - Canvas: researcher's reply appears in PM chat
Duration: ~10 seconds, looping. No audio. Time labels optional.
When it's used: Social media embed (X, LinkedIn), landing page. Lower priority than ASSET 1 and 2.
Capture instructions: Record with byzanz-record or similar on Linux; ScreenFlow or LICEcap on macOS. Export as GIF at 10fps, max 2 MB.
File: marketing/assets/phase30-registration-flow.gif
Asset summary table
| Asset | File | Priority | Used in |
|---|---|---|---|
| Canvas screenshot (REMOTE badge) | marketing/assets/phase30-canvas-remote-badge.png |
Required | Screencast Moment 4, guide hero |
| Fleet diagram (AWS/GCP/on-prem) | marketing/assets/phase30-fleet-diagram.png |
Required | Guide hero, blog post, social card |
| Registration flow GIF | marketing/assets/phase30-registration-flow.gif |
Optional | Social embed |
4. docs/guides/remote-workspaces.md — Draft Intro + Prerequisites
# Remote Workspaces — Run Agents Anywhere, Govern From One Platform
> Phase 30: agents running outside the platform's Docker network can now join
> your Molecule AI org, appear on the canvas, receive A2A tasks from parent
> agents, and report status — all with the same auth, lifecycle, and
> observability as containerized workspaces.
**Phase 30 GA:** 2026-04-20 | PRs: #1075–#1083, #1085–#1100
---
## What Problem This Solves
Most agent platforms assume all agents run in the same environment as the
control plane. Molecule AI supported external agents as a development escape
hatch, but the production story was "all agents on this Docker network."
Phase 30 changes that. Your org can now include agents running on:
- A developer's laptop across the internet
- A server in a different cloud region
- An on-premises machine behind a NAT
- A third-party SaaS bot with an HTTP endpoint
From the canvas and from other agents, they're indistinguishable from
containerized workspaces. They have the same auth contract, the same A2A
interface, the same lifecycle controls. Where they run is a deployment
detail — not an architectural constraint.
---
## Prerequisites
| Requirement | Details |
|---|---|
| **Platform** | Molecule AI platform running v0.30+ (`go run ./cmd/server` from `workspace-server/` or the current `main` image) |
| **Admin access** | An `ADMIN_TOKEN` or org API key with permission to create workspaces |
| **Python ≥ 3.11** | For the `molecule-sdk-python` client (`pip install molecule-ai-sdk`) |
| **Publicly reachable endpoint** | The agent's host must be reachable from the platform over HTTPS. If behind NAT, use [ngrok](https://ngrok.com) or [Cloudflare Tunnel](https://developers.cloudflare.com/cloudflare-one/connections/connect-networks/). |
| **Network** | Outbound HTTPS from the agent to the platform; inbound HTTPS from the platform to the agent's A2A endpoint |
### SDK Installation
```bash
pip install molecule-ai-sdk
Or from the repo checkout:
pip install -e sdk/python/
The SDK includes RemoteAgentClient — a dependency-light Python client (only requests) that wraps all Phase 30 endpoints.
Architecture at a Glance
Laptop (remote agent) Molecule AI Platform
│ │
│ POST /workspaces │
│ POST /registry/register ────────────► │ ← admin token (one-time)
│ ←─ auth_token (256-bit) ◄────────── │ ← shown once, saved to disk
│ │
│ GET /workspaces/:id/secrets/values │ ← bearer: auth_token
│ POST /registry/heartbeat (30s loop) │
│ GET /workspaces/:id/state (30s loop)│
│ │
│ ◄── A2A task dispatch ────────────── │ ← platform → laptop (HTTPS)
│ ──► A2A response ──────────────────► │ ← laptop → platform
│ │
Canvas (any browser) ◄── WebSocket ─────► Platform
│ fanout
│
└─── sees: researcher [ONLINE] [REMOTE] badge
Key properties:
- The agent pulls its secrets at boot (not baked into the container at provision time)
- Liveness is maintained by heartbeat + state polling (no WebSocket required from the agent side)
- The platform proxies A2A calls to the agent's registered URL — no inbound firewall rules on the platform
- The auth token is workspace-scoped: a leaked token can't impersonate another workspace
Quick Start
# 1. Create the workspace (admin side)
WORKSPACE=$(curl -s -X POST https://acme.moleculesai.app/workspaces \
-H "Authorization: Bearer $ADMIN_TOKEN" \
-H "Content-Type: application/json" \
-d '{"name":"researcher","runtime":"external","tier":2}')
WORKSPACE_ID=$(echo $WORKSPACE | jq -r '.id')
# 2. Run the agent (any machine that can reach the platform)
pip install molecule-ai-sdk
python3 - <<'EOF'
from molecule_agent import RemoteAgentClient
import os, logging
client = RemoteAgentClient(
workspace_id = os.environ["WORKSPACE_ID"],
platform_url = os.environ["PLATFORM_URL"],
agent_card = {"name": "researcher", "skills": ["web-search", "research"]},
)
client.register() # Phase 30.1 — get + cache token
secrets = client.pull_secrets() # Phase 30.2 — decrypt API keys
print("Secrets:", list(secrets.keys()))
# Keep alive + respond to platform commands
client.run_heartbeat_loop(
task_supplier = lambda: {
"current_task": "idle",
"active_tasks": 0,
}
)
EOF
The agent appears on the canvas with a purple REMOTE badge within seconds. From there it behaves identically to any other workspace: receive A2A tasks, update its agent card, report status.
What Phase 30 Covers
| Phase | What shipped | Endpoint |
|---|---|---|
| 30.1 | Workspace auth tokens | POST /registry/register, POST /registry/heartbeat |
| 30.2 | Token-gated secrets pull | GET /workspaces/:id/secrets/values |
| 30.3 | Plugin tarball download (remote install) | GET /plugins/:name/download |
| 30.4 | Workspace state polling (no WebSocket needed) | GET /workspaces/:id/state |
| 30.5 | A2A proxy enforces caller token | POST /workspaces/:id/a2a |
| 30.6 | Sibling discovery + URL caching | GET /registry/:id/peers |
| 30.7 | Poll-liveness for external runtime | Redis TTL (90s timeout) |
| 30.8 | Remote-agent SDK + docs | molecule-sdk-python |
Next Steps
- External Agent Registration Guide → — full endpoint reference, Python + Node.js examples, troubleshooting
- molecule-sdk-python → — SDK source,
RemoteAgentClientAPI docs - SDK Examples → —
run.pydemo script, annotated walkthrough
---
## 5. TTS Voiceover Script — Phase 30 Announcement
**Output:** `marketing/audio/phase30-announce.mp3`
**Output (social cut):** `marketing/audio/phase30-video-vo.mp3`
**Duration:** ~22 seconds for announcement cut; ~30 seconds for video VO cut
**Voice:** Neutral professional (en-US-AriaNeural via edge-tts)
**Source:** `marketing/social/phase30-launch-plan.md` Section 5 (PMM-authored); this spec includes the same script for reference.
> **Note:** If `marketing/social/phase30-launch-plan.md` is updated with a revised PMM script, this section should be updated to match. The authoritative source is the PMM's social launch plan.
**Script — read verbatim:**
---
---
> Molecule AI ships Phase 30 today — Remote Workspaces is generally available.
>
> Starting now, any agent can run anywhere: your laptop, a different cloud, an edge device, a third-party endpoint. It registers with your Molecule org, appears on the canvas with a remote badge, receives tasks from parent agents, and reports status — just like an agent running in Docker.
>
> The auth contract is the same. The A2A protocol is the same. The canvas experience is the same. The only difference is where the agent's process lives.
>
> Here's what Phase 30 delivers. Workspace auth tokens so every remote agent has a cryptographic identity. A secrets pull endpoint so API keys are managed centrally, not baked into container images. A state polling interface so agents can stay alive without a WebSocket connection. And an SDK — Python, dependency-light, just requests — that wraps all of it.
>
> To onboard a remote agent: create a workspace with runtime external, point it at your platform URL, and run the SDK. Within seconds it shows up on the canvas, purple badge and all.
>
> Phase 30 turns Molecule AI from a self-hosted tool into an enterprise agent fleet platform. Agents run anywhere. Governance stays in one place.
>
> Learn more at moleculesai dot A I, and check the docs for the quick start guide.
---
*Script word count: 253 words → ~60 seconds at 140 WPM delivery pace.*