Skip to content

borealBytes/tenacitOS

 
 

Repository files navigation

TenacitOS β€” Mission Control

A real-time dashboard and control center for OpenClaw AI agent instances. Built with Next.js, React 19, and Tailwind CSS v4.

TenacitOS lives inside your OpenClaw workspace and reads its configuration, agents, sessions, memory, and logs directly from the host. No extra database or backend required β€” OpenClaw is the backend.


Features

  • πŸ“Š System Monitor β€” Real-time VPS metrics (CPU, RAM, Disk, Network) + PM2/Docker status
  • πŸ€– Agent Dashboard β€” All agents, their sessions, token usage, model, and activity status
  • πŸ’° Cost Tracking β€” Real cost analytics from OpenClaw sessions (SQLite)
  • ⏰ Cron Manager β€” Visual cron manager with weekly timeline, run history, and manual triggers
  • πŸ“‹ Activity Feed β€” Real-time log of agent actions with heatmap and charts
  • 🧠 Memory Browser β€” Explore, search, and edit agent memory files
  • πŸ“ File Browser β€” Navigate workspace files with preview and in-browser editing
  • πŸ”Ž Global Search β€” Full-text search across memory and workspace files
  • πŸ”” Notifications β€” Real-time notification center with unread badge
  • 🏒 Office 3D β€” Interactive 3D office with one desk per agent (React Three Fiber)
  • πŸ“Ί Terminal β€” Read-only terminal for safe status commands
  • πŸ” Auth β€” Password-protected with rate limiting and secure cookie

Screenshots

Dashboard β€” activity overview, agent status, and weather widget

Dashboard

Session History β€” all OpenClaw sessions with token usage and context tracking

Sessions

Costs & Analytics β€” daily cost trends and breakdown per agent

Costs

System Monitor β€” real-time CPU, RAM, Disk, and Network metrics

System Monitor

Office 3D β€” interactive 3D office with one voxel avatar per agent (React Three Fiber)

Office 3D


Requirements

  • Node.js 18+ (tested with v22)
  • OpenClaw installed and running on the same host
  • PM2 or systemd (recommended for production)
  • Caddy or another reverse proxy (for HTTPS in production)

How it works

TenacitOS reads directly from your OpenClaw installation:

/root/.openclaw/              ← OPENCLAW_DIR (configurable)
β”œβ”€β”€ openclaw.json             ← agents list, channels, models config
β”œβ”€β”€ workspace/                ← main agent workspace (MEMORY.md, SOUL.md, etc.)
β”œβ”€β”€ workspace-studio/         ← sub-agent workspaces
β”œβ”€β”€ workspace-infra/
β”œβ”€β”€ ...
└── workspace/mission-control/ ← TenacitOS lives here

The app uses OPENCLAW_DIR to locate openclaw.json and all workspaces. No manual agent configuration needed β€” agents are auto-discovered from openclaw.json.


Installation

1. Clone into your OpenClaw workspace

cd /root/.openclaw/workspace   # or your OPENCLAW_DIR/workspace
git clone https://github.com/carlosazaustre/tenacitOS.git mission-control
cd mission-control
npm install

2. Configure environment

cp .env.example .env.local

Edit .env.local:

# --- Auth (required) ---
# Strong password to log in to the dashboard
ADMIN_PASSWORD=your-secure-password-here

# Random secret used to sign the auth cookie
# Generate with: openssl rand -base64 32
AUTH_SECRET=your-random-32-char-secret-here

# --- OpenClaw paths (optional β€” defaults work for standard installs) ---
# OPENCLAW_DIR=/root/.openclaw

# --- Branding (customize for your instance) ---
NEXT_PUBLIC_AGENT_NAME=Mission Control
NEXT_PUBLIC_AGENT_EMOJI=πŸ€–
NEXT_PUBLIC_AGENT_DESCRIPTION=Your AI co-pilot, powered by OpenClaw
NEXT_PUBLIC_AGENT_LOCATION=             # e.g. "Madrid, Spain"
NEXT_PUBLIC_BIRTH_DATE=                 # ISO date, e.g. "2026-01-01"
NEXT_PUBLIC_AGENT_AVATAR=               # path to image in /public, e.g. "/avatar.jpg"

NEXT_PUBLIC_OWNER_USERNAME=your-username
NEXT_PUBLIC_OWNER_EMAIL=your-email@example.com
NEXT_PUBLIC_TWITTER_HANDLE=@username
NEXT_PUBLIC_COMPANY_NAME=MISSION CONTROL, INC.
NEXT_PUBLIC_APP_TITLE=Mission Control

Tip: OPENCLAW_DIR defaults to /root/.openclaw. If your OpenClaw is installed elsewhere, set this variable.

3. Initialize data files

cp data/cron-jobs.example.json data/cron-jobs.json
cp data/activities.example.json data/activities.json
cp data/notifications.example.json data/notifications.json
cp data/configured-skills.example.json data/configured-skills.json
cp data/tasks.example.json data/tasks.json

4. Generate secrets

# Auth secret
openssl rand -base64 32

# Password (or use a password manager)
openssl rand -base64 18

5. Run

# Development
npm run dev
# β†’ http://localhost:3000

# Production build
npm run build
npm start

Login at http://localhost:3000 with the ADMIN_PASSWORD you set.


Production Deployment

PM2 (recommended)

npm run build

pm2 start npm --name "mission-control" -- start
pm2 save
pm2 startup   # enable auto-restart on reboot

systemd

Create /etc/systemd/system/mission-control.service:

[Unit]
Description=TenacitOS β€” OpenClaw Mission Control
After=network.target

[Service]
Type=simple
User=root
WorkingDirectory=/root/.openclaw/workspace/mission-control
ExecStart=/usr/bin/npm start
Restart=always
RestartSec=10
Environment=NODE_ENV=production

[Install]
WantedBy=multi-user.target
sudo systemctl daemon-reload
sudo systemctl enable mission-control
sudo systemctl start mission-control

Reverse proxy β€” Caddy (HTTPS)

mission-control.yourdomain.com {
    reverse_proxy localhost:3000
}

When behind HTTPS, secure: true is set automatically on the auth cookie.


Configuration

Agent branding

All personal data stays in .env.local (gitignored). The src/config/branding.ts file reads from env vars β€” never edit it directly with your personal data.

Agent discovery

Agents are auto-discovered from openclaw.json at startup. The /api/agents endpoint reads:

{
  "agents": {
    "list": [
      { "id": "main", "name": "...", "workspace": "...", "model": {...} },
      { "id": "studio", "name": "...", "workspace": "..." }
    ]
  }
}

Each agent can define its own visual appearance in openclaw.json:

{
  "id": "studio",
  "name": "My Studio Agent",
  "ui": {
    "emoji": "🎬",
    "color": "#E91E63"
  }
}

Office 3D β€” agent positions

The 3D office has default positions for up to 6 agents. To customize positions, names, and colors for your own agents, edit src/components/Office3D/agentsConfig.ts:

export const AGENTS: AgentConfig[] = [
  {
    id: "main",       // must match workspace ID
    name: "...",      // display name (can also come from API)
    emoji: "πŸ€–",
    position: [0, 0, 0],
    color: "#FFCC00",
    role: "Main Agent",
  },
  // add your sub-agents here
];

3D Avatar models

To add custom 3D avatars (Ready Player Me GLB format), place them in public/models/:

public/models/
β”œβ”€β”€ main.glb        ← main agent avatar
β”œβ”€β”€ studio.glb      ← workspace-studio agent
└── infra.glb       ← workspace-infra agent

Filename must match the agent id. If no file is found, a colored sphere is shown as fallback.
See public/models/README.md for full instructions.

Cost tracking

Usage is collected from OpenClaw's SQLite databases via a script:

# Collect once
npx tsx scripts/collect-usage.ts

# Auto-collect every hour (adds a cron job)
./scripts/setup-cron.sh

See docs/COST-TRACKING.md for details.


Project Structure

mission-control/
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ app/
β”‚   β”‚   β”œβ”€β”€ (dashboard)/      # Dashboard pages (protected)
β”‚   β”‚   β”œβ”€β”€ api/              # API routes
β”‚   β”‚   β”œβ”€β”€ login/            # Login page
β”‚   β”‚   └── office/           # 3D office (unprotected route)
β”‚   β”œβ”€β”€ components/
β”‚   β”‚   β”œβ”€β”€ TenacitOS/        # OS-style UI shell (topbar, dock, status bar)
β”‚   β”‚   └── Office3D/         # React Three Fiber 3D office
β”‚   β”œβ”€β”€ config/
β”‚   β”‚   └── branding.ts       # Branding constants (reads from env vars)
β”‚   └── lib/                  # Utilities (pricing, queries, activity logger...)
β”œβ”€β”€ data/                     # JSON data files (gitignored β€” use .example versions)
β”œβ”€β”€ docs/                     # Extended documentation
β”œβ”€β”€ public/
β”‚   └── models/               # GLB avatar models (add your own)
β”œβ”€β”€ scripts/                  # Setup and data collection scripts
β”œβ”€β”€ .env.example              # Environment variable template
└── middleware.ts             # Auth guard for all routes

Security

  • All routes (including all /api/*) require authentication β€” handled by src/middleware.ts
  • /api/auth/login and /api/health are the only public endpoints
  • Login is rate-limited: 5 failed attempts β†’ 15-minute lockout per IP
  • Auth cookie is httpOnly, sameSite: lax, and secure in production
  • Terminal API uses a strict command allowlist β€” env, curl, wget, node, python are blocked
  • Never commit .env.local β€” it contains your credentials

Generate fresh secrets:

openssl rand -base64 32   # AUTH_SECRET
openssl rand -base64 18   # ADMIN_PASSWORD

Troubleshooting

"Gateway not reachable" / agent data missing

openclaw status
openclaw gateway start   # if not running

"Database not found" (cost tracking)

npx tsx scripts/collect-usage.ts

Build errors after pulling updates

rm -rf .next node_modules
npm install
npm run build

Scripts not executable

chmod +x scripts/*.sh

Tech Stack

Layer Tech
Framework Next.js 15 (App Router)
UI React 19 + Tailwind CSS v4
3D React Three Fiber + Drei
Charts Recharts
Icons Lucide React
Database SQLite (better-sqlite3)
Runtime Node.js 22

Contributing

  1. Fork the repo
  2. Create a feature branch (git checkout -b feat/my-feature)
  3. Keep personal data out of commits β€” use .env.local and data/ (both gitignored)
  4. Write clear commit messages
  5. Open a PR

See CONTRIBUTING.md for more details.


License

MIT β€” see LICENSE


Links

About

OpenClaw Mission Control Dashboard

Resources

License

Contributing

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • TypeScript 98.5%
  • Other 1.5%