Spaces:
Sleeping
Sleeping
Deploy Agent-Zero with HF adaptations and clone-at-runtime support
Browse files- Dockerfile +18 -38
- README.md +16 -512
- api/api_docs.py +27 -0
- helpers/api.py +63 -0
- helpers/runtime.py +26 -0
- helpers/settings.py +69 -0
- helpers/ws.py +18 -0
- run_ui.py +85 -0
- start_hf.sh +42 -0
Dockerfile
CHANGED
|
@@ -1,46 +1,26 @@
|
|
| 1 |
-
FROM
|
| 2 |
|
| 3 |
-
|
| 4 |
-
|
| 5 |
-
|
|
|
|
|
|
|
| 6 |
|
| 7 |
-
RUN
|
|
|
|
|
|
|
| 8 |
|
| 9 |
-
|
|
|
|
| 10 |
|
| 11 |
-
|
| 12 |
-
|
| 13 |
-
|
| 14 |
-
apt-get clean && \
|
| 15 |
-
rm -rf /var/lib/apt/lists/* /var/cache/apt/archives/*
|
| 16 |
|
| 17 |
-
|
| 18 |
|
| 19 |
-
|
| 20 |
-
|
| 21 |
-
COPY patches ./patches
|
| 22 |
-
COPY scripts ./scripts
|
| 23 |
|
| 24 |
-
COPY . .
|
| 25 |
-
RUN pnpm install --no-frozen-lockfile --recursive
|
| 26 |
-
RUN CLAWDBOT_A2UI_SKIP_MISSING=1 pnpm build
|
| 27 |
-
|
| 28 |
-
# Force pnpm for UI build (Bun may fail on ARM/Synology architectures)
|
| 29 |
-
ENV CLAWDBOT_PREFER_PNPM=1
|
| 30 |
-
RUN cd ui && pnpm install --no-frozen-lockfile
|
| 31 |
-
RUN cd ui && pnpm add -D postcss-nesting tailwindcss postcss-import autoprefixer @tailwindcss/postcss
|
| 32 |
-
RUN pnpm ui:build
|
| 33 |
-
|
| 34 |
-
RUN chown -R node:node /app
|
| 35 |
-
|
| 36 |
-
ENV NODE_ENV=production
|
| 37 |
-
|
| 38 |
-
# Security hardening: Run as non-root user
|
| 39 |
-
# The node:22-bookworm image includes a 'node' user (uid 1000)
|
| 40 |
-
# This reduces the attack surface by preventing container escape via root privileges
|
| 41 |
-
USER node
|
| 42 |
-
|
| 43 |
-
ENV PORT=7860
|
| 44 |
EXPOSE 7860
|
| 45 |
-
|
| 46 |
-
CMD ["node", "dist/index.js"]
|
|
|
|
| 1 |
+
FROM python:3.11-slim-bookworm
|
| 2 |
|
| 3 |
+
ENV PYTHONUNBUFFERED=1 \
|
| 4 |
+
PYTHONDONTWRITEBYTECODE=1 \
|
| 5 |
+
DEBIAN_FRONTEND=noninteractive \
|
| 6 |
+
HOME=/home/user \
|
| 7 |
+
APP_HOME=/home/user/app
|
| 8 |
|
| 9 |
+
RUN apt-get update && apt-get install -y --no-install-recommends \
|
| 10 |
+
git curl build-essential libffi-dev libssl-dev pkg-config python3-dev \
|
| 11 |
+
&& apt-get clean && rm -rf /var/lib/apt/lists/*
|
| 12 |
|
| 13 |
+
RUN curl -LsSf https://astral.sh/uv/install.sh | sh
|
| 14 |
+
ENV PATH="/root/.local/bin:$PATH"
|
| 15 |
|
| 16 |
+
RUN useradd -m -u 1000 user
|
| 17 |
+
WORKDIR /home/user/app
|
| 18 |
+
RUN chown -R user:user /home/user
|
|
|
|
|
|
|
| 19 |
|
| 20 |
+
COPY --chown=user:user . /home/user/app
|
| 21 |
|
| 22 |
+
USER user
|
| 23 |
+
RUN chmod +x /home/user/app/start_hf.sh
|
|
|
|
|
|
|
| 24 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 25 |
EXPOSE 7860
|
| 26 |
+
CMD ["./start_hf.sh"]
|
|
|
README.md
CHANGED
|
@@ -1,522 +1,26 @@
|
|
| 1 |
---
|
| 2 |
-
title:
|
|
|
|
|
|
|
|
|
|
| 3 |
sdk: docker
|
| 4 |
app_port: 7860
|
|
|
|
| 5 |
---
|
| 6 |
|
| 7 |
-
#
|
| 8 |
|
| 9 |
-
|
| 10 |
-
<img src="https://raw.githubusercontent.com/moltbot/moltbot/main/docs/whatsapp-clawd.jpg" alt="Clawdbot" width="400">
|
| 11 |
-
</p>
|
| 12 |
|
| 13 |
-
|
| 14 |
-
<strong>EXFOLIATE! EXFOLIATE!</strong>
|
| 15 |
-
</p>
|
| 16 |
|
| 17 |
-
|
| 18 |
-
|
| 19 |
-
|
| 20 |
-
|
| 21 |
-
<a href="https://discord.gg/clawd"><img src="https://img.shields.io/discord/1456350064065904867?label=Discord&logo=discord&logoColor=white&color=5865F2&style=for-the-badge" alt="Discord"></a>
|
| 22 |
-
<a href="LICENSE"><img src="https://img.shields.io/badge/License-MIT-blue.svg?style=for-the-badge" alt="MIT License"></a>
|
| 23 |
-
</p>
|
| 24 |
|
| 25 |
-
|
| 26 |
-
It answers you on the channels you already use (WhatsApp, Telegram, Slack, Discord, Google Chat, Signal, iMessage, Microsoft Teams, WebChat), plus extension channels like BlueBubbles, Matrix, Zalo, and Zalo Personal. It can speak and listen on macOS/iOS/Android, and can render a live Canvas you control. The Gateway is just the control plane — the product is the assistant.
|
| 27 |
|
| 28 |
-
|
| 29 |
-
|
| 30 |
-
|
| 31 |
-
|
| 32 |
-
Preferred setup: run the onboarding wizard (`moltbot onboard`). It walks through gateway, workspace, channels, and skills. The CLI wizard is the recommended path and works on **macOS, Linux, and Windows (via WSL2; strongly recommended)**.
|
| 33 |
-
Works with npm, pnpm, or bun.
|
| 34 |
-
New install? Start here: [Getting started](https://docs.molt.bot/start/getting-started)
|
| 35 |
-
|
| 36 |
-
**Subscriptions (OAuth):**
|
| 37 |
-
- **[Anthropic](https://www.anthropic.com/)** (Claude Pro/Max)
|
| 38 |
-
- **[OpenAI](https://openai.com/)** (ChatGPT/Codex)
|
| 39 |
-
|
| 40 |
-
Model note: while any model is supported, I strongly recommend **Anthropic Pro/Max (100/200) + Opus 4.5** for long‑context strength and better prompt‑injection resistance. See [Onboarding](https://docs.molt.bot/start/onboarding).
|
| 41 |
-
|
| 42 |
-
## Models (selection + auth)
|
| 43 |
-
|
| 44 |
-
- Models config + CLI: [Models](https://docs.molt.bot/concepts/models)
|
| 45 |
-
- Auth profile rotation (OAuth vs API keys) + fallbacks: [Model failover](https://docs.molt.bot/concepts/model-failover)
|
| 46 |
-
|
| 47 |
-
## Install (recommended)
|
| 48 |
-
|
| 49 |
-
Runtime: **Node ≥22**.
|
| 50 |
-
|
| 51 |
-
```bash
|
| 52 |
-
npm install -g moltbot@latest
|
| 53 |
-
# or: pnpm add -g moltbot@latest
|
| 54 |
-
|
| 55 |
-
moltbot onboard --install-daemon
|
| 56 |
-
```
|
| 57 |
-
|
| 58 |
-
The wizard installs the Gateway daemon (launchd/systemd user service) so it stays running.
|
| 59 |
-
Legacy note: `clawdbot` remains available as a compatibility shim.
|
| 60 |
-
|
| 61 |
-
## Quick start (TL;DR)
|
| 62 |
-
|
| 63 |
-
Runtime: **Node ≥22**.
|
| 64 |
-
|
| 65 |
-
Full beginner guide (auth, pairing, channels): [Getting started](https://docs.molt.bot/start/getting-started)
|
| 66 |
-
|
| 67 |
-
```bash
|
| 68 |
-
moltbot onboard --install-daemon
|
| 69 |
-
|
| 70 |
-
moltbot gateway --port 18789 --verbose
|
| 71 |
-
|
| 72 |
-
# Send a message
|
| 73 |
-
moltbot message send --to +1234567890 --message "Hello from Moltbot"
|
| 74 |
-
|
| 75 |
-
# Talk to the assistant (optionally deliver back to any connected channel: WhatsApp/Telegram/Slack/Discord/Google Chat/Signal/iMessage/BlueBubbles/Microsoft Teams/Matrix/Zalo/Zalo Personal/WebChat)
|
| 76 |
-
moltbot agent --message "Ship checklist" --thinking high
|
| 77 |
-
```
|
| 78 |
-
|
| 79 |
-
Upgrading? [Updating guide](https://docs.molt.bot/install/updating) (and run `moltbot doctor`).
|
| 80 |
-
|
| 81 |
-
## Development channels
|
| 82 |
-
|
| 83 |
-
- **stable**: tagged releases (`vYYYY.M.D` or `vYYYY.M.D-<patch>`), npm dist-tag `latest`.
|
| 84 |
-
- **beta**: prerelease tags (`vYYYY.M.D-beta.N`), npm dist-tag `beta` (macOS app may be missing).
|
| 85 |
-
- **dev**: moving head of `main`, npm dist-tag `dev` (when published).
|
| 86 |
-
|
| 87 |
-
Switch channels (git + npm): `moltbot update --channel stable|beta|dev`.
|
| 88 |
-
Details: [Development channels](https://docs.molt.bot/install/development-channels).
|
| 89 |
-
|
| 90 |
-
## From source (development)
|
| 91 |
-
|
| 92 |
-
Prefer `pnpm` for builds from source. Bun is optional for running TypeScript directly.
|
| 93 |
-
|
| 94 |
-
```bash
|
| 95 |
-
git clone https://github.com/moltbot/moltbot.git
|
| 96 |
-
cd moltbot
|
| 97 |
-
|
| 98 |
-
pnpm install
|
| 99 |
-
pnpm ui:build # auto-installs UI deps on first run
|
| 100 |
-
pnpm build
|
| 101 |
-
|
| 102 |
-
pnpm moltbot onboard --install-daemon
|
| 103 |
-
|
| 104 |
-
# Dev loop (auto-reload on TS changes)
|
| 105 |
-
pnpm gateway:watch
|
| 106 |
-
```
|
| 107 |
-
|
| 108 |
-
Note: `pnpm moltbot ...` runs TypeScript directly (via `tsx`). `pnpm build` produces `dist/` for running via Node / the packaged `moltbot` binary.
|
| 109 |
-
|
| 110 |
-
## Security defaults (DM access)
|
| 111 |
-
|
| 112 |
-
Moltbot connects to real messaging surfaces. Treat inbound DMs as **untrusted input**.
|
| 113 |
-
|
| 114 |
-
Full security guide: [Security](https://docs.molt.bot/gateway/security)
|
| 115 |
-
|
| 116 |
-
Default behavior on Telegram/WhatsApp/Signal/iMessage/Microsoft Teams/Discord/Google Chat/Slack:
|
| 117 |
-
- **DM pairing** (`dmPolicy="pairing"` / `channels.discord.dm.policy="pairing"` / `channels.slack.dm.policy="pairing"`): unknown senders receive a short pairing code and the bot does not process their message.
|
| 118 |
-
- Approve with: `moltbot pairing approve <channel> <code>` (then the sender is added to a local allowlist store).
|
| 119 |
-
- Public inbound DMs require an explicit opt-in: set `dmPolicy="open"` and include `"*"` in the channel allowlist (`allowFrom` / `channels.discord.dm.allowFrom` / `channels.slack.dm.allowFrom`).
|
| 120 |
-
|
| 121 |
-
Run `moltbot doctor` to surface risky/misconfigured DM policies.
|
| 122 |
-
|
| 123 |
-
## Highlights
|
| 124 |
-
|
| 125 |
-
- **[Local-first Gateway](https://docs.molt.bot/gateway)** — single control plane for sessions, channels, tools, and events.
|
| 126 |
-
- **[Multi-channel inbox](https://docs.molt.bot/channels)** — WhatsApp, Telegram, Slack, Discord, Google Chat, Signal, iMessage, BlueBubbles, Microsoft Teams, Matrix, Zalo, Zalo Personal, WebChat, macOS, iOS/Android.
|
| 127 |
-
- **[Multi-agent routing](https://docs.molt.bot/gateway/configuration)** — route inbound channels/accounts/peers to isolated agents (workspaces + per-agent sessions).
|
| 128 |
-
- **[Voice Wake](https://docs.molt.bot/nodes/voicewake) + [Talk Mode](https://docs.molt.bot/nodes/talk)** — always-on speech for macOS/iOS/Android with ElevenLabs.
|
| 129 |
-
- **[Live Canvas](https://docs.molt.bot/platforms/mac/canvas)** — agent-driven visual workspace with [A2UI](https://docs.molt.bot/platforms/mac/canvas#canvas-a2ui).
|
| 130 |
-
- **[First-class tools](https://docs.molt.bot/tools)** — browser, canvas, nodes, cron, sessions, and Discord/Slack actions.
|
| 131 |
-
- **[Companion apps](https://docs.molt.bot/platforms/macos)** — macOS menu bar app + iOS/Android [nodes](https://docs.molt.bot/nodes).
|
| 132 |
-
- **[Onboarding](https://docs.molt.bot/start/wizard) + [skills](https://docs.molt.bot/tools/skills)** — wizard-driven setup with bundled/managed/workspace skills.
|
| 133 |
-
|
| 134 |
-
## Star History
|
| 135 |
-
|
| 136 |
-
[](https://www.star-history.com/#moltbot/moltbot&type=date&legend=top-left)
|
| 137 |
-
|
| 138 |
-
## Everything we built so far
|
| 139 |
-
|
| 140 |
-
### Core platform
|
| 141 |
-
- [Gateway WS control plane](https://docs.molt.bot/gateway) with sessions, presence, config, cron, webhooks, [Control UI](https://docs.molt.bot/web), and [Canvas host](https://docs.molt.bot/platforms/mac/canvas#canvas-a2ui).
|
| 142 |
-
- [CLI surface](https://docs.molt.bot/tools/agent-send): gateway, agent, send, [wizard](https://docs.molt.bot/start/wizard), and [doctor](https://docs.molt.bot/gateway/doctor).
|
| 143 |
-
- [Pi agent runtime](https://docs.molt.bot/concepts/agent) in RPC mode with tool streaming and block streaming.
|
| 144 |
-
- [Session model](https://docs.molt.bot/concepts/session): `main` for direct chats, group isolation, activation modes, queue modes, reply-back. Group rules: [Groups](https://docs.molt.bot/concepts/groups).
|
| 145 |
-
- [Media pipeline](https://docs.molt.bot/nodes/images): images/audio/video, transcription hooks, size caps, temp file lifecycle. Audio details: [Audio](https://docs.molt.bot/nodes/audio).
|
| 146 |
-
|
| 147 |
-
### Channels
|
| 148 |
-
- [Channels](https://docs.molt.bot/channels): [WhatsApp](https://docs.molt.bot/channels/whatsapp) (Baileys), [Telegram](https://docs.molt.bot/channels/telegram) (grammY), [Slack](https://docs.molt.bot/channels/slack) (Bolt), [Discord](https://docs.molt.bot/channels/discord) (discord.js), [Google Chat](https://docs.molt.bot/channels/googlechat) (Chat API), [Signal](https://docs.molt.bot/channels/signal) (signal-cli), [iMessage](https://docs.molt.bot/channels/imessage) (imsg), [BlueBubbles](https://docs.molt.bot/channels/bluebubbles) (extension), [Microsoft Teams](https://docs.molt.bot/channels/msteams) (extension), [Matrix](https://docs.molt.bot/channels/matrix) (extension), [Zalo](https://docs.molt.bot/channels/zalo) (extension), [Zalo Personal](https://docs.molt.bot/channels/zalouser) (extension), [WebChat](https://docs.molt.bot/web/webchat).
|
| 149 |
-
- [Group routing](https://docs.molt.bot/concepts/group-messages): mention gating, reply tags, per-channel chunking and routing. Channel rules: [Channels](https://docs.molt.bot/channels).
|
| 150 |
-
|
| 151 |
-
### Apps + nodes
|
| 152 |
-
- [macOS app](https://docs.molt.bot/platforms/macos): menu bar control plane, [Voice Wake](https://docs.molt.bot/nodes/voicewake)/PTT, [Talk Mode](https://docs.molt.bot/nodes/talk) overlay, [WebChat](https://docs.molt.bot/web/webchat), debug tools, [remote gateway](https://docs.molt.bot/gateway/remote) control.
|
| 153 |
-
- [iOS node](https://docs.molt.bot/platforms/ios): [Canvas](https://docs.molt.bot/platforms/mac/canvas), [Voice Wake](https://docs.molt.bot/nodes/voicewake), [Talk Mode](https://docs.molt.bot/nodes/talk), camera, screen recording, Bonjour pairing.
|
| 154 |
-
- [Android node](https://docs.molt.bot/platforms/android): [Canvas](https://docs.molt.bot/platforms/mac/canvas), [Talk Mode](https://docs.molt.bot/nodes/talk), camera, screen recording, optional SMS.
|
| 155 |
-
- [macOS node mode](https://docs.molt.bot/nodes): system.run/notify + canvas/camera exposure.
|
| 156 |
-
|
| 157 |
-
### Tools + automation
|
| 158 |
-
- [Browser control](https://docs.molt.bot/tools/browser): dedicated moltbot Chrome/Chromium, snapshots, actions, uploads, profiles.
|
| 159 |
-
- [Canvas](https://docs.molt.bot/platforms/mac/canvas): [A2UI](https://docs.molt.bot/platforms/mac/canvas#canvas-a2ui) push/reset, eval, snapshot.
|
| 160 |
-
- [Nodes](https://docs.molt.bot/nodes): camera snap/clip, screen record, [location.get](https://docs.molt.bot/nodes/location-command), notifications.
|
| 161 |
-
- [Cron + wakeups](https://docs.molt.bot/automation/cron-jobs); [webhooks](https://docs.molt.bot/automation/webhook); [Gmail Pub/Sub](https://docs.molt.bot/automation/gmail-pubsub).
|
| 162 |
-
- [Skills platform](https://docs.molt.bot/tools/skills): bundled, managed, and workspace skills with install gating + UI.
|
| 163 |
-
|
| 164 |
-
### Runtime + safety
|
| 165 |
-
- [Channel routing](https://docs.molt.bot/concepts/channel-routing), [retry policy](https://docs.molt.bot/concepts/retry), and [streaming/chunking](https://docs.molt.bot/concepts/streaming).
|
| 166 |
-
- [Presence](https://docs.molt.bot/concepts/presence), [typing indicators](https://docs.molt.bot/concepts/typing-indicators), and [usage tracking](https://docs.molt.bot/concepts/usage-tracking).
|
| 167 |
-
- [Models](https://docs.molt.bot/concepts/models), [model failover](https://docs.molt.bot/concepts/model-failover), and [session pruning](https://docs.molt.bot/concepts/session-pruning).
|
| 168 |
-
- [Security](https://docs.molt.bot/gateway/security) and [troubleshooting](https://docs.molt.bot/channels/troubleshooting).
|
| 169 |
-
|
| 170 |
-
### Ops + packaging
|
| 171 |
-
- [Control UI](https://docs.molt.bot/web) + [WebChat](https://docs.molt.bot/web/webchat) served directly from the Gateway.
|
| 172 |
-
- [Tailscale Serve/Funnel](https://docs.molt.bot/gateway/tailscale) or [SSH tunnels](https://docs.molt.bot/gateway/remote) with token/password auth.
|
| 173 |
-
- [Nix mode](https://docs.molt.bot/install/nix) for declarative config; [Docker](https://docs.molt.bot/install/docker)-based installs.
|
| 174 |
-
- [Doctor](https://docs.molt.bot/gateway/doctor) migrations, [logging](https://docs.molt.bot/logging).
|
| 175 |
-
|
| 176 |
-
## How it works (short)
|
| 177 |
-
|
| 178 |
-
```
|
| 179 |
-
WhatsApp / Telegram / Slack / Discord / Google Chat / Signal / iMessage / BlueBubbles / Microsoft Teams / Matrix / Zalo / Zalo Personal / WebChat
|
| 180 |
-
│
|
| 181 |
-
▼
|
| 182 |
-
┌───────────────────────────────┐
|
| 183 |
-
│ Gateway │
|
| 184 |
-
│ (control plane) │
|
| 185 |
-
│ ws://127.0.0.1:18789 │
|
| 186 |
-
└──────────────┬────────────────┘
|
| 187 |
-
│
|
| 188 |
-
├─ Pi agent (RPC)
|
| 189 |
-
├─ CLI (moltbot …)
|
| 190 |
-
├─ WebChat UI
|
| 191 |
-
├─ macOS app
|
| 192 |
-
└─ iOS / Android nodes
|
| 193 |
-
```
|
| 194 |
-
|
| 195 |
-
## Key subsystems
|
| 196 |
-
|
| 197 |
-
- **[Gateway WebSocket network](https://docs.molt.bot/concepts/architecture)** — single WS control plane for clients, tools, and events (plus ops: [Gateway runbook](https://docs.molt.bot/gateway)).
|
| 198 |
-
- **[Tailscale exposure](https://docs.molt.bot/gateway/tailscale)** — Serve/Funnel for the Gateway dashboard + WS (remote access: [Remote](https://docs.molt.bot/gateway/remote)).
|
| 199 |
-
- **[Browser control](https://docs.molt.bot/tools/browser)** — moltbot‑managed Chrome/Chromium with CDP control.
|
| 200 |
-
- **[Canvas + A2UI](https://docs.molt.bot/platforms/mac/canvas)** — agent‑driven visual workspace (A2UI host: [Canvas/A2UI](https://docs.molt.bot/platforms/mac/canvas#canvas-a2ui)).
|
| 201 |
-
- **[Voice Wake](https://docs.molt.bot/nodes/voicewake) + [Talk Mode](https://docs.molt.bot/nodes/talk)** — always‑on speech and continuous conversation.
|
| 202 |
-
- **[Nodes](https://docs.molt.bot/nodes)** — Canvas, camera snap/clip, screen record, `location.get`, notifications, plus macOS‑only `system.run`/`system.notify`.
|
| 203 |
-
|
| 204 |
-
## Tailscale access (Gateway dashboard)
|
| 205 |
-
|
| 206 |
-
Moltbot can auto-configure Tailscale **Serve** (tailnet-only) or **Funnel** (public) while the Gateway stays bound to loopback. Configure `gateway.tailscale.mode`:
|
| 207 |
-
|
| 208 |
-
- `off`: no Tailscale automation (default).
|
| 209 |
-
- `serve`: tailnet-only HTTPS via `tailscale serve` (uses Tailscale identity headers by default).
|
| 210 |
-
- `funnel`: public HTTPS via `tailscale funnel` (requires shared password auth).
|
| 211 |
-
|
| 212 |
-
Notes:
|
| 213 |
-
- `gateway.bind` must stay `loopback` when Serve/Funnel is enabled (Moltbot enforces this).
|
| 214 |
-
- Serve can be forced to require a password by setting `gateway.auth.mode: "password"` or `gateway.auth.allowTailscale: false`.
|
| 215 |
-
- Funnel refuses to start unless `gateway.auth.mode: "password"` is set.
|
| 216 |
-
- Optional: `gateway.tailscale.resetOnExit` to undo Serve/Funnel on shutdown.
|
| 217 |
-
|
| 218 |
-
Details: [Tailscale guide](https://docs.molt.bot/gateway/tailscale) · [Web surfaces](https://docs.molt.bot/web)
|
| 219 |
-
|
| 220 |
-
## Remote Gateway (Linux is great)
|
| 221 |
-
|
| 222 |
-
It’s perfectly fine to run the Gateway on a small Linux instance. Clients (macOS app, CLI, WebChat) can connect over **Tailscale Serve/Funnel** or **SSH tunnels**, and you can still pair device nodes (macOS/iOS/Android) to execute device‑local actions when needed.
|
| 223 |
-
|
| 224 |
-
- **Gateway host** runs the exec tool and channel connections by default.
|
| 225 |
-
- **Device nodes** run device‑local actions (`system.run`, camera, screen recording, notifications) via `node.invoke`.
|
| 226 |
-
In short: exec runs where the Gateway lives; device actions run where the device lives.
|
| 227 |
-
|
| 228 |
-
Details: [Remote access](https://docs.molt.bot/gateway/remote) · [Nodes](https://docs.molt.bot/nodes) · [Security](https://docs.molt.bot/gateway/security)
|
| 229 |
-
|
| 230 |
-
## macOS permissions via the Gateway protocol
|
| 231 |
-
|
| 232 |
-
The macOS app can run in **node mode** and advertises its capabilities + permission map over the Gateway WebSocket (`node.list` / `node.describe`). Clients can then execute local actions via `node.invoke`:
|
| 233 |
-
|
| 234 |
-
- `system.run` runs a local command and returns stdout/stderr/exit code; set `needsScreenRecording: true` to require screen-recording permission (otherwise you’ll get `PERMISSION_MISSING`).
|
| 235 |
-
- `system.notify` posts a user notification and fails if notifications are denied.
|
| 236 |
-
- `canvas.*`, `camera.*`, `screen.record`, and `location.get` are also routed via `node.invoke` and follow TCC permission status.
|
| 237 |
-
|
| 238 |
-
Elevated bash (host permissions) is separate from macOS TCC:
|
| 239 |
-
|
| 240 |
-
- Use `/elevated on|off` to toggle per‑session elevated access when enabled + allowlisted.
|
| 241 |
-
- Gateway persists the per‑session toggle via `sessions.patch` (WS method) alongside `thinkingLevel`, `verboseLevel`, `model`, `sendPolicy`, and `groupActivation`.
|
| 242 |
-
|
| 243 |
-
Details: [Nodes](https://docs.molt.bot/nodes) · [macOS app](https://docs.molt.bot/platforms/macos) · [Gateway protocol](https://docs.molt.bot/concepts/architecture)
|
| 244 |
-
|
| 245 |
-
## Agent to Agent (sessions_* tools)
|
| 246 |
-
|
| 247 |
-
- Use these to coordinate work across sessions without jumping between chat surfaces.
|
| 248 |
-
- `sessions_list` — discover active sessions (agents) and their metadata.
|
| 249 |
-
- `sessions_history` — fetch transcript logs for a session.
|
| 250 |
-
- `sessions_send` — message another session; optional reply‑back ping‑pong + announce step (`REPLY_SKIP`, `ANNOUNCE_SKIP`).
|
| 251 |
-
|
| 252 |
-
Details: [Session tools](https://docs.molt.bot/concepts/session-tool)
|
| 253 |
-
|
| 254 |
-
## Skills registry (ClawdHub)
|
| 255 |
-
|
| 256 |
-
ClawdHub is a minimal skill registry. With ClawdHub enabled, the agent can search for skills automatically and pull in new ones as needed.
|
| 257 |
-
|
| 258 |
-
[ClawdHub](https://ClawdHub.com)
|
| 259 |
-
|
| 260 |
-
## Chat commands
|
| 261 |
-
|
| 262 |
-
Send these in WhatsApp/Telegram/Slack/Google Chat/Microsoft Teams/WebChat (group commands are owner-only):
|
| 263 |
-
|
| 264 |
-
- `/status` — compact session status (model + tokens, cost when available)
|
| 265 |
-
- `/new` or `/reset` — reset the session
|
| 266 |
-
- `/compact` — compact session context (summary)
|
| 267 |
-
- `/think <level>` — off|minimal|low|medium|high|xhigh (GPT-5.2 + Codex models only)
|
| 268 |
-
- `/verbose on|off`
|
| 269 |
-
- `/usage off|tokens|full` — per-response usage footer
|
| 270 |
-
- `/restart` — restart the gateway (owner-only in groups)
|
| 271 |
-
- `/activation mention|always` — group activation toggle (groups only)
|
| 272 |
-
|
| 273 |
-
## Apps (optional)
|
| 274 |
-
|
| 275 |
-
The Gateway alone delivers a great experience. All apps are optional and add extra features.
|
| 276 |
-
|
| 277 |
-
If you plan to build/run companion apps, follow the platform runbooks below.
|
| 278 |
-
|
| 279 |
-
### macOS (Moltbot.app) (optional)
|
| 280 |
-
|
| 281 |
-
- Menu bar control for the Gateway and health.
|
| 282 |
-
- Voice Wake + push-to-talk overlay.
|
| 283 |
-
- WebChat + debug tools.
|
| 284 |
-
- Remote gateway control over SSH.
|
| 285 |
-
|
| 286 |
-
Note: signed builds required for macOS permissions to stick across rebuilds (see `docs/mac/permissions.md`).
|
| 287 |
-
|
| 288 |
-
### iOS node (optional)
|
| 289 |
-
|
| 290 |
-
- Pairs as a node via the Bridge.
|
| 291 |
-
- Voice trigger forwarding + Canvas surface.
|
| 292 |
-
- Controlled via `moltbot nodes …`.
|
| 293 |
-
|
| 294 |
-
Runbook: [iOS connect](https://docs.molt.bot/platforms/ios).
|
| 295 |
-
|
| 296 |
-
### Android node (optional)
|
| 297 |
-
|
| 298 |
-
- Pairs via the same Bridge + pairing flow as iOS.
|
| 299 |
-
- Exposes Canvas, Camera, and Screen capture commands.
|
| 300 |
-
- Runbook: [Android connect](https://docs.molt.bot/platforms/android).
|
| 301 |
-
|
| 302 |
-
## Agent workspace + skills
|
| 303 |
-
|
| 304 |
-
- Workspace root: `~/clawd` (configurable via `agents.defaults.workspace`).
|
| 305 |
-
- Injected prompt files: `AGENTS.md`, `SOUL.md`, `TOOLS.md`.
|
| 306 |
-
- Skills: `~/clawd/skills/<skill>/SKILL.md`.
|
| 307 |
-
|
| 308 |
-
## Configuration
|
| 309 |
-
|
| 310 |
-
Minimal `~/.clawdbot/moltbot.json` (model + defaults):
|
| 311 |
-
|
| 312 |
-
```json5
|
| 313 |
-
{
|
| 314 |
-
agent: {
|
| 315 |
-
model: "anthropic/claude-opus-4-5"
|
| 316 |
-
}
|
| 317 |
-
}
|
| 318 |
-
```
|
| 319 |
-
|
| 320 |
-
[Full configuration reference (all keys + examples).](https://docs.molt.bot/gateway/configuration)
|
| 321 |
-
|
| 322 |
-
## Security model (important)
|
| 323 |
-
|
| 324 |
-
- **Default:** tools run on the host for the **main** session, so the agent has full access when it’s just you.
|
| 325 |
-
- **Group/channel safety:** set `agents.defaults.sandbox.mode: "non-main"` to run **non‑main sessions** (groups/channels) inside per‑session Docker sandboxes; bash then runs in Docker for those sessions.
|
| 326 |
-
- **Sandbox defaults:** allowlist `bash`, `process`, `read`, `write`, `edit`, `sessions_list`, `sessions_history`, `sessions_send`, `sessions_spawn`; denylist `browser`, `canvas`, `nodes`, `cron`, `discord`, `gateway`.
|
| 327 |
-
|
| 328 |
-
Details: [Security guide](https://docs.molt.bot/gateway/security) · [Docker + sandboxing](https://docs.molt.bot/install/docker) · [Sandbox config](https://docs.molt.bot/gateway/configuration)
|
| 329 |
-
|
| 330 |
-
### [WhatsApp](https://docs.molt.bot/channels/whatsapp)
|
| 331 |
-
|
| 332 |
-
- Link the device: `pnpm moltbot channels login` (stores creds in `~/.clawdbot/credentials`).
|
| 333 |
-
- Allowlist who can talk to the assistant via `channels.whatsapp.allowFrom`.
|
| 334 |
-
- If `channels.whatsapp.groups` is set, it becomes a group allowlist; include `"*"` to allow all.
|
| 335 |
-
|
| 336 |
-
### [Telegram](https://docs.molt.bot/channels/telegram)
|
| 337 |
-
|
| 338 |
-
- Set `TELEGRAM_BOT_TOKEN` or `channels.telegram.botToken` (env wins).
|
| 339 |
-
- Optional: set `channels.telegram.groups` (with `channels.telegram.groups."*".requireMention`); when set, it is a group allowlist (include `"*"` to allow all). Also `channels.telegram.allowFrom` or `channels.telegram.webhookUrl` as needed.
|
| 340 |
-
|
| 341 |
-
```json5
|
| 342 |
-
{
|
| 343 |
-
channels: {
|
| 344 |
-
telegram: {
|
| 345 |
-
botToken: "123456:ABCDEF"
|
| 346 |
-
}
|
| 347 |
-
}
|
| 348 |
-
}
|
| 349 |
-
```
|
| 350 |
-
|
| 351 |
-
### [Slack](https://docs.molt.bot/channels/slack)
|
| 352 |
-
|
| 353 |
-
- Set `SLACK_BOT_TOKEN` + `SLACK_APP_TOKEN` (or `channels.slack.botToken` + `channels.slack.appToken`).
|
| 354 |
-
|
| 355 |
-
### [Discord](https://docs.molt.bot/channels/discord)
|
| 356 |
-
|
| 357 |
-
- Set `DISCORD_BOT_TOKEN` or `channels.discord.token` (env wins).
|
| 358 |
-
- Optional: set `commands.native`, `commands.text`, or `commands.useAccessGroups`, plus `channels.discord.dm.allowFrom`, `channels.discord.guilds`, or `channels.discord.mediaMaxMb` as needed.
|
| 359 |
-
|
| 360 |
-
```json5
|
| 361 |
-
{
|
| 362 |
-
channels: {
|
| 363 |
-
discord: {
|
| 364 |
-
token: "1234abcd"
|
| 365 |
-
}
|
| 366 |
-
}
|
| 367 |
-
}
|
| 368 |
-
```
|
| 369 |
-
|
| 370 |
-
### [Signal](https://docs.molt.bot/channels/signal)
|
| 371 |
-
|
| 372 |
-
- Requires `signal-cli` and a `channels.signal` config section.
|
| 373 |
-
|
| 374 |
-
### [iMessage](https://docs.molt.bot/channels/imessage)
|
| 375 |
-
|
| 376 |
-
- macOS only; Messages must be signed in.
|
| 377 |
-
- If `channels.imessage.groups` is set, it becomes a group allowlist; include `"*"` to allow all.
|
| 378 |
-
|
| 379 |
-
### [Microsoft Teams](https://docs.molt.bot/channels/msteams)
|
| 380 |
-
|
| 381 |
-
- Configure a Teams app + Bot Framework, then add a `msteams` config section.
|
| 382 |
-
- Allowlist who can talk via `msteams.allowFrom`; group access via `msteams.groupAllowFrom` or `msteams.groupPolicy: "open"`.
|
| 383 |
-
|
| 384 |
-
### [WebChat](https://docs.molt.bot/web/webchat)
|
| 385 |
-
|
| 386 |
-
- Uses the Gateway WebSocket; no separate WebChat port/config.
|
| 387 |
-
|
| 388 |
-
Browser control (optional):
|
| 389 |
-
|
| 390 |
-
```json5
|
| 391 |
-
{
|
| 392 |
-
browser: {
|
| 393 |
-
enabled: true,
|
| 394 |
-
color: "#FF4500"
|
| 395 |
-
}
|
| 396 |
-
}
|
| 397 |
-
```
|
| 398 |
-
|
| 399 |
-
## Docs
|
| 400 |
-
|
| 401 |
-
Use these when you’re past the onboarding flow and want the deeper reference.
|
| 402 |
-
- [Start with the docs index for navigation and “what’s where.”](https://docs.molt.bot)
|
| 403 |
-
- [Read the architecture overview for the gateway + protocol model.](https://docs.molt.bot/concepts/architecture)
|
| 404 |
-
- [Use the full configuration reference when you need every key and example.](https://docs.molt.bot/gateway/configuration)
|
| 405 |
-
- [Run the Gateway by the book with the operational runbook.](https://docs.molt.bot/gateway)
|
| 406 |
-
- [Learn how the Control UI/Web surfaces work and how to expose them safely.](https://docs.molt.bot/web)
|
| 407 |
-
- [Understand remote access over SSH tunnels or tailnets.](https://docs.molt.bot/gateway/remote)
|
| 408 |
-
- [Follow the onboarding wizard flow for a guided setup.](https://docs.molt.bot/start/wizard)
|
| 409 |
-
- [Wire external triggers via the webhook surface.](https://docs.molt.bot/automation/webhook)
|
| 410 |
-
- [Set up Gmail Pub/Sub triggers.](https://docs.molt.bot/automation/gmail-pubsub)
|
| 411 |
-
- [Learn the macOS menu bar companion details.](https://docs.molt.bot/platforms/mac/menu-bar)
|
| 412 |
-
- [Platform guides: Windows (WSL2)](https://docs.molt.bot/platforms/windows), [Linux](https://docs.molt.bot/platforms/linux), [macOS](https://docs.molt.bot/platforms/macos), [iOS](https://docs.molt.bot/platforms/ios), [Android](https://docs.molt.bot/platforms/android)
|
| 413 |
-
- [Debug common failures with the troubleshooting guide.](https://docs.molt.bot/channels/troubleshooting)
|
| 414 |
-
- [Review security guidance before exposing anything.](https://docs.molt.bot/gateway/security)
|
| 415 |
-
|
| 416 |
-
## Advanced docs (discovery + control)
|
| 417 |
-
|
| 418 |
-
- [Discovery + transports](https://docs.molt.bot/gateway/discovery)
|
| 419 |
-
- [Bonjour/mDNS](https://docs.molt.bot/gateway/bonjour)
|
| 420 |
-
- [Gateway pairing](https://docs.molt.bot/gateway/pairing)
|
| 421 |
-
- [Remote gateway README](https://docs.molt.bot/gateway/remote-gateway-readme)
|
| 422 |
-
- [Control UI](https://docs.molt.bot/web/control-ui)
|
| 423 |
-
- [Dashboard](https://docs.molt.bot/web/dashboard)
|
| 424 |
-
|
| 425 |
-
## Operations & troubleshooting
|
| 426 |
-
|
| 427 |
-
- [Health checks](https://docs.molt.bot/gateway/health)
|
| 428 |
-
- [Gateway lock](https://docs.molt.bot/gateway/gateway-lock)
|
| 429 |
-
- [Background process](https://docs.molt.bot/gateway/background-process)
|
| 430 |
-
- [Browser troubleshooting (Linux)](https://docs.molt.bot/tools/browser-linux-troubleshooting)
|
| 431 |
-
- [Logging](https://docs.molt.bot/logging)
|
| 432 |
-
|
| 433 |
-
## Deep dives
|
| 434 |
-
|
| 435 |
-
- [Agent loop](https://docs.molt.bot/concepts/agent-loop)
|
| 436 |
-
- [Presence](https://docs.molt.bot/concepts/presence)
|
| 437 |
-
- [TypeBox schemas](https://docs.molt.bot/concepts/typebox)
|
| 438 |
-
- [RPC adapters](https://docs.molt.bot/reference/rpc)
|
| 439 |
-
- [Queue](https://docs.molt.bot/concepts/queue)
|
| 440 |
-
|
| 441 |
-
## Workspace & skills
|
| 442 |
-
|
| 443 |
-
- [Skills config](https://docs.molt.bot/tools/skills-config)
|
| 444 |
-
- [Default AGENTS](https://docs.molt.bot/reference/AGENTS.default)
|
| 445 |
-
- [Templates: AGENTS](https://docs.molt.bot/reference/templates/AGENTS)
|
| 446 |
-
- [Templates: BOOTSTRAP](https://docs.molt.bot/reference/templates/BOOTSTRAP)
|
| 447 |
-
- [Templates: IDENTITY](https://docs.molt.bot/reference/templates/IDENTITY)
|
| 448 |
-
- [Templates: SOUL](https://docs.molt.bot/reference/templates/SOUL)
|
| 449 |
-
- [Templates: TOOLS](https://docs.molt.bot/reference/templates/TOOLS)
|
| 450 |
-
- [Templates: USER](https://docs.molt.bot/reference/templates/USER)
|
| 451 |
-
|
| 452 |
-
## Platform internals
|
| 453 |
-
|
| 454 |
-
- [macOS dev setup](https://docs.molt.bot/platforms/mac/dev-setup)
|
| 455 |
-
- [macOS menu bar](https://docs.molt.bot/platforms/mac/menu-bar)
|
| 456 |
-
- [macOS voice wake](https://docs.molt.bot/platforms/mac/voicewake)
|
| 457 |
-
- [iOS node](https://docs.molt.bot/platforms/ios)
|
| 458 |
-
- [Android node](https://docs.molt.bot/platforms/android)
|
| 459 |
-
- [Windows (WSL2)](https://docs.molt.bot/platforms/windows)
|
| 460 |
-
- [Linux app](https://docs.molt.bot/platforms/linux)
|
| 461 |
-
|
| 462 |
-
## Email hooks (Gmail)
|
| 463 |
-
|
| 464 |
-
- [docs.molt.bot/gmail-pubsub](https://docs.molt.bot/automation/gmail-pubsub)
|
| 465 |
-
|
| 466 |
-
## Molty
|
| 467 |
-
|
| 468 |
-
Moltbot was built for **Molty**, a space lobster AI assistant. 🦞
|
| 469 |
-
by Peter Steinberger and the community.
|
| 470 |
-
|
| 471 |
-
- [clawd.me](https://clawd.me)
|
| 472 |
-
- [soul.md](https://soul.md)
|
| 473 |
-
- [steipete.me](https://steipete.me)
|
| 474 |
-
- [@moltbot](https://x.com/moltbot)
|
| 475 |
-
|
| 476 |
-
## Community
|
| 477 |
-
|
| 478 |
-
See [CONTRIBUTING.md](CONTRIBUTING.md) for guidelines, maintainers, and how to submit PRs.
|
| 479 |
-
AI/vibe-coded PRs welcome! 🤖
|
| 480 |
-
|
| 481 |
-
Special thanks to [Mario Zechner](https://mariozechner.at/) for his support and for
|
| 482 |
-
[pi-mono](https://github.com/badlogic/pi-mono).
|
| 483 |
-
|
| 484 |
-
Thanks to all clawtributors:
|
| 485 |
-
|
| 486 |
-
<p align="left">
|
| 487 |
-
<a href="https://github.com/steipete"><img src="https://avatars.githubusercontent.com/u/58493?v=4&s=48" width="48" height="48" alt="steipete" title="steipete"/></a> <a href="https://github.com/plum-dawg"><img src="https://avatars.githubusercontent.com/u/5909950?v=4&s=48" width="48" height="48" alt="plum-dawg" title="plum-dawg"/></a> <a href="https://github.com/bohdanpodvirnyi"><img src="https://avatars.githubusercontent.com/u/31819391?v=4&s=48" width="48" height="48" alt="bohdanpodvirnyi" title="bohdanpodvirnyi"/></a> <a href="https://github.com/iHildy"><img src="https://avatars.githubusercontent.com/u/25069719?v=4&s=48" width="48" height="48" alt="iHildy" title="iHildy"/></a> <a href="https://github.com/jaydenfyi"><img src="https://avatars.githubusercontent.com/u/213395523?v=4&s=48" width="48" height="48" alt="jaydenfyi" title="jaydenfyi"/></a> <a href="https://github.com/joaohlisboa"><img src="https://avatars.githubusercontent.com/u/8200873?v=4&s=48" width="48" height="48" alt="joaohlisboa" title="joaohlisboa"/></a> <a href="https://github.com/mneves75"><img src="https://avatars.githubusercontent.com/u/2423436?v=4&s=48" width="48" height="48" alt="mneves75" title="mneves75"/></a> <a href="https://github.com/MatthieuBizien"><img src="https://avatars.githubusercontent.com/u/173090?v=4&s=48" width="48" height="48" alt="MatthieuBizien" title="MatthieuBizien"/></a> <a href="https://github.com/MaudeBot"><img src="https://avatars.githubusercontent.com/u/255777700?v=4&s=48" width="48" height="48" alt="MaudeBot" title="MaudeBot"/></a> <a href="https://github.com/Glucksberg"><img src="https://avatars.githubusercontent.com/u/80581902?v=4&s=48" width="48" height="48" alt="Glucksberg" title="Glucksberg"/></a>
|
| 488 |
-
<a href="https://github.com/rahthakor"><img src="https://avatars.githubusercontent.com/u/8470553?v=4&s=48" width="48" height="48" alt="rahthakor" title="rahthakor"/></a> <a href="https://github.com/vrknetha"><img src="https://avatars.githubusercontent.com/u/20596261?v=4&s=48" width="48" height="48" alt="vrknetha" title="vrknetha"/></a> <a href="https://github.com/radek-paclt"><img src="https://avatars.githubusercontent.com/u/50451445?v=4&s=48" width="48" height="48" alt="radek-paclt" title="radek-paclt"/></a> <a href="https://github.com/vignesh07"><img src="https://avatars.githubusercontent.com/u/1436853?v=4&s=48" width="48" height="48" alt="vignesh07" title="vignesh07"/></a> <a href="https://github.com/tobiasbischoff"><img src="https://avatars.githubusercontent.com/u/711564?v=4&s=48" width="48" height="48" alt="Tobias Bischoff" title="Tobias Bischoff"/></a> <a href="https://github.com/joshp123"><img src="https://avatars.githubusercontent.com/u/1497361?v=4&s=48" width="48" height="48" alt="joshp123" title="joshp123"/></a> <a href="https://github.com/czekaj"><img src="https://avatars.githubusercontent.com/u/1464539?v=4&s=48" width="48" height="48" alt="czekaj" title="czekaj"/></a> <a href="https://github.com/mukhtharcm"><img src="https://avatars.githubusercontent.com/u/56378562?v=4&s=48" width="48" height="48" alt="mukhtharcm" title="mukhtharcm"/></a> <a href="https://github.com/sebslight"><img src="https://avatars.githubusercontent.com/u/19554889?v=4&s=48" width="48" height="48" alt="sebslight" title="sebslight"/></a> <a href="https://github.com/maxsumrall"><img src="https://avatars.githubusercontent.com/u/628843?v=4&s=48" width="48" height="48" alt="maxsumrall" title="maxsumrall"/></a>
|
| 489 |
-
<a href="https://github.com/xadenryan"><img src="https://avatars.githubusercontent.com/u/165437834?v=4&s=48" width="48" height="48" alt="xadenryan" title="xadenryan"/></a> <a href="https://github.com/rodrigouroz"><img src="https://avatars.githubusercontent.com/u/384037?v=4&s=48" width="48" height="48" alt="rodrigouroz" title="rodrigouroz"/></a> <a href="https://github.com/juanpablodlc"><img src="https://avatars.githubusercontent.com/u/92012363?v=4&s=48" width="48" height="48" alt="juanpablodlc" title="juanpablodlc"/></a> <a href="https://github.com/hsrvc"><img src="https://avatars.githubusercontent.com/u/129702169?v=4&s=48" width="48" height="48" alt="hsrvc" title="hsrvc"/></a> <a href="https://github.com/magimetal"><img src="https://avatars.githubusercontent.com/u/36491250?v=4&s=48" width="48" height="48" alt="magimetal" title="magimetal"/></a> <a href="https://github.com/zerone0x"><img src="https://avatars.githubusercontent.com/u/39543393?v=4&s=48" width="48" height="48" alt="zerone0x" title="zerone0x"/></a> <a href="https://github.com/tyler6204"><img src="https://avatars.githubusercontent.com/u/64381258?v=4&s=48" width="48" height="48" alt="tyler6204" title="tyler6204"/></a> <a href="https://github.com/meaningfool"><img src="https://avatars.githubusercontent.com/u/2862331?v=4&s=48" width="48" height="48" alt="meaningfool" title="meaningfool"/></a> <a href="https://github.com/patelhiren"><img src="https://avatars.githubusercontent.com/u/172098?v=4&s=48" width="48" height="48" alt="patelhiren" title="patelhiren"/></a> <a href="https://github.com/NicholasSpisak"><img src="https://avatars.githubusercontent.com/u/129075147?v=4&s=48" width="48" height="48" alt="NicholasSpisak" title="NicholasSpisak"/></a>
|
| 490 |
-
<a href="https://github.com/jonisjongithub"><img src="https://avatars.githubusercontent.com/u/86072337?v=4&s=48" width="48" height="48" alt="jonisjongithub" title="jonisjongithub"/></a> <a href="https://github.com/AbhisekBasu1"><img src="https://avatars.githubusercontent.com/u/40645221?v=4&s=48" width="48" height="48" alt="abhisekbasu1" title="abhisekbasu1"/></a> <a href="https://github.com/jamesgroat"><img src="https://avatars.githubusercontent.com/u/2634024?v=4&s=48" width="48" height="48" alt="jamesgroat" title="jamesgroat"/></a> <a href="https://github.com/claude"><img src="https://avatars.githubusercontent.com/u/81847?v=4&s=48" width="48" height="48" alt="claude" title="claude"/></a> <a href="https://github.com/JustYannicc"><img src="https://avatars.githubusercontent.com/u/52761674?v=4&s=48" width="48" height="48" alt="JustYannicc" title="JustYannicc"/></a> <a href="https://github.com/mbelinky"><img src="https://avatars.githubusercontent.com/u/132747814?v=4&s=48" width="48" height="48" alt="Mariano Belinky" title="Mariano Belinky"/></a> <a href="https://github.com/Hyaxia"><img src="https://avatars.githubusercontent.com/u/36747317?v=4&s=48" width="48" height="48" alt="Hyaxia" title="Hyaxia"/></a> <a href="https://github.com/dantelex"><img src="https://avatars.githubusercontent.com/u/631543?v=4&s=48" width="48" height="48" alt="dantelex" title="dantelex"/></a> <a href="https://github.com/SocialNerd42069"><img src="https://avatars.githubusercontent.com/u/118244303?v=4&s=48" width="48" height="48" alt="SocialNerd42069" title="SocialNerd42069"/></a> <a href="https://github.com/daveonkels"><img src="https://avatars.githubusercontent.com/u/533642?v=4&s=48" width="48" height="48" alt="daveonkels" title="daveonkels"/></a>
|
| 491 |
-
<a href="https://github.com/apps/google-labs-jules"><img src="https://avatars.githubusercontent.com/in/842251?v=4&s=48" width="48" height="48" alt="google-labs-jules[bot]" title="google-labs-jules[bot]"/></a> <a href="https://github.com/lc0rp"><img src="https://avatars.githubusercontent.com/u/2609441?v=4&s=48" width="48" height="48" alt="lc0rp" title="lc0rp"/></a> <a href="https://github.com/mousberg"><img src="https://avatars.githubusercontent.com/u/57605064?v=4&s=48" width="48" height="48" alt="mousberg" title="mousberg"/></a> <a href="https://github.com/adam91holt"><img src="https://avatars.githubusercontent.com/u/9592417?v=4&s=48" width="48" height="48" alt="adam91holt" title="adam91holt"/></a> <a href="https://github.com/hougangdev"><img src="https://avatars.githubusercontent.com/u/105773686?v=4&s=48" width="48" height="48" alt="hougangdev" title="hougangdev"/></a> <a href="https://github.com/shakkernerd"><img src="https://avatars.githubusercontent.com/u/165377636?v=4&s=48" width="48" height="48" alt="shakkernerd" title="shakkernerd"/></a> <a href="https://github.com/gumadeiras"><img src="https://avatars.githubusercontent.com/u/5599352?v=4&s=48" width="48" height="48" alt="gumadeiras" title="gumadeiras"/></a> <a href="https://github.com/mteam88"><img src="https://avatars.githubusercontent.com/u/84196639?v=4&s=48" width="48" height="48" alt="mteam88" title="mteam88"/></a> <a href="https://github.com/hirefrank"><img src="https://avatars.githubusercontent.com/u/183158?v=4&s=48" width="48" height="48" alt="hirefrank" title="hirefrank"/></a> <a href="https://github.com/joeynyc"><img src="https://avatars.githubusercontent.com/u/17919866?v=4&s=48" width="48" height="48" alt="joeynyc" title="joeynyc"/></a>
|
| 492 |
-
<a href="https://github.com/orlyjamie"><img src="https://avatars.githubusercontent.com/u/6668807?v=4&s=48" width="48" height="48" alt="orlyjamie" title="orlyjamie"/></a> <a href="https://github.com/dbhurley"><img src="https://avatars.githubusercontent.com/u/5251425?v=4&s=48" width="48" height="48" alt="dbhurley" title="dbhurley"/></a> <a href="https://github.com/omniwired"><img src="https://avatars.githubusercontent.com/u/322761?v=4&s=48" width="48" height="48" alt="Eng. Juan Combetto" title="Eng. Juan Combetto"/></a> <a href="https://github.com/TSavo"><img src="https://avatars.githubusercontent.com/u/877990?v=4&s=48" width="48" height="48" alt="TSavo" title="TSavo"/></a> <a href="https://github.com/julianengel"><img src="https://avatars.githubusercontent.com/u/10634231?v=4&s=48" width="48" height="48" alt="julianengel" title="julianengel"/></a> <a href="https://github.com/bradleypriest"><img src="https://avatars.githubusercontent.com/u/167215?v=4&s=48" width="48" height="48" alt="bradleypriest" title="bradleypriest"/></a> <a href="https://github.com/benithors"><img src="https://avatars.githubusercontent.com/u/20652882?v=4&s=48" width="48" height="48" alt="benithors" title="benithors"/></a> <a href="https://github.com/rohannagpal"><img src="https://avatars.githubusercontent.com/u/4009239?v=4&s=48" width="48" height="48" alt="rohannagpal" title="rohannagpal"/></a> <a href="https://github.com/timolins"><img src="https://avatars.githubusercontent.com/u/1440854?v=4&s=48" width="48" height="48" alt="timolins" title="timolins"/></a> <a href="https://github.com/f-trycua"><img src="https://avatars.githubusercontent.com/u/195596869?v=4&s=48" width="48" height="48" alt="f-trycua" title="f-trycua"/></a>
|
| 493 |
-
<a href="https://github.com/benostein"><img src="https://avatars.githubusercontent.com/u/31802821?v=4&s=48" width="48" height="48" alt="benostein" title="benostein"/></a> <a href="https://github.com/elliotsecops"><img src="https://avatars.githubusercontent.com/u/141947839?v=4&s=48" width="48" height="48" alt="elliotsecops" title="elliotsecops"/></a> <a href="https://github.com/Nachx639"><img src="https://avatars.githubusercontent.com/u/71144023?v=4&s=48" width="48" height="48" alt="nachx639" title="nachx639"/></a> <a href="https://github.com/pvoo"><img src="https://avatars.githubusercontent.com/u/20116814?v=4&s=48" width="48" height="48" alt="pvoo" title="pvoo"/></a> <a href="https://github.com/sreekaransrinath"><img src="https://avatars.githubusercontent.com/u/50989977?v=4&s=48" width="48" height="48" alt="sreekaransrinath" title="sreekaransrinath"/></a> <a href="https://github.com/gupsammy"><img src="https://avatars.githubusercontent.com/u/20296019?v=4&s=48" width="48" height="48" alt="gupsammy" title="gupsammy"/></a> <a href="https://github.com/cristip73"><img src="https://avatars.githubusercontent.com/u/24499421?v=4&s=48" width="48" height="48" alt="cristip73" title="cristip73"/></a> <a href="https://github.com/stefangalescu"><img src="https://avatars.githubusercontent.com/u/52995748?v=4&s=48" width="48" height="48" alt="stefangalescu" title="stefangalescu"/></a> <a href="https://github.com/nachoiacovino"><img src="https://avatars.githubusercontent.com/u/50103937?v=4&s=48" width="48" height="48" alt="nachoiacovino" title="nachoiacovino"/></a> <a href="https://github.com/vsabavat"><img src="https://avatars.githubusercontent.com/u/50385532?v=4&s=48" width="48" height="48" alt="Vasanth Rao Naik Sabavat" title="Vasanth Rao Naik Sabavat"/></a>
|
| 494 |
-
<a href="https://github.com/petter-b"><img src="https://avatars.githubusercontent.com/u/62076402?v=4&s=48" width="48" height="48" alt="petter-b" title="petter-b"/></a> <a href="https://github.com/thewilloftheshadow"><img src="https://avatars.githubusercontent.com/u/35580099?v=4&s=48" width="48" height="48" alt="thewilloftheshadow" title="thewilloftheshadow"/></a> <a href="https://github.com/cpojer"><img src="https://avatars.githubusercontent.com/u/13352?v=4&s=48" width="48" height="48" alt="cpojer" title="cpojer"/></a> <a href="https://github.com/scald"><img src="https://avatars.githubusercontent.com/u/1215913?v=4&s=48" width="48" height="48" alt="scald" title="scald"/></a> <a href="https://github.com/andranik-sahakyan"><img src="https://avatars.githubusercontent.com/u/8908029?v=4&s=48" width="48" height="48" alt="andranik-sahakyan" title="andranik-sahakyan"/></a> <a href="https://github.com/davidguttman"><img src="https://avatars.githubusercontent.com/u/431696?v=4&s=48" width="48" height="48" alt="davidguttman" title="davidguttman"/></a> <a href="https://github.com/sleontenko"><img src="https://avatars.githubusercontent.com/u/7135949?v=4&s=48" width="48" height="48" alt="sleontenko" title="sleontenko"/></a> <a href="https://github.com/denysvitali"><img src="https://avatars.githubusercontent.com/u/4939519?v=4&s=48" width="48" height="48" alt="denysvitali" title="denysvitali"/></a> <a href="https://github.com/sircrumpet"><img src="https://avatars.githubusercontent.com/u/4436535?v=4&s=48" width="48" height="48" alt="sircrumpet" title="sircrumpet"/></a> <a href="https://github.com/peschee"><img src="https://avatars.githubusercontent.com/u/63866?v=4&s=48" width="48" height="48" alt="peschee" title="peschee"/></a>
|
| 495 |
-
<a href="https://github.com/nonggialiang"><img src="https://avatars.githubusercontent.com/u/14367839?v=4&s=48" width="48" height="48" alt="nonggialiang" title="nonggialiang"/></a> <a href="https://github.com/rafaelreis-r"><img src="https://avatars.githubusercontent.com/u/57492577?v=4&s=48" width="48" height="48" alt="rafaelreis-r" title="rafaelreis-r"/></a> <a href="https://github.com/dominicnunez"><img src="https://avatars.githubusercontent.com/u/43616264?v=4&s=48" width="48" height="48" alt="dominicnunez" title="dominicnunez"/></a> <a href="https://github.com/lploc94"><img src="https://avatars.githubusercontent.com/u/28453843?v=4&s=48" width="48" height="48" alt="lploc94" title="lploc94"/></a> <a href="https://github.com/ratulsarna"><img src="https://avatars.githubusercontent.com/u/105903728?v=4&s=48" width="48" height="48" alt="ratulsarna" title="ratulsarna"/></a> <a href="https://github.com/lutr0"><img src="https://avatars.githubusercontent.com/u/76906369?v=4&s=48" width="48" height="48" alt="lutr0" title="lutr0"/></a> <a href="https://github.com/danielz1z"><img src="https://avatars.githubusercontent.com/u/235270390?v=4&s=48" width="48" height="48" alt="danielz1z" title="danielz1z"/></a> <a href="https://github.com/AdeboyeDN"><img src="https://avatars.githubusercontent.com/u/65312338?v=4&s=48" width="48" height="48" alt="AdeboyeDN" title="AdeboyeDN"/></a> <a href="https://github.com/Alg0rix"><img src="https://avatars.githubusercontent.com/u/53804949?v=4&s=48" width="48" height="48" alt="Alg0rix" title="Alg0rix"/></a> <a href="https://github.com/papago2355"><img src="https://avatars.githubusercontent.com/u/68721273?v=4&s=48" width="48" height="48" alt="papago2355" title="papago2355"/></a>
|
| 496 |
-
<a href="https://github.com/emanuelst"><img src="https://avatars.githubusercontent.com/u/9994339?v=4&s=48" width="48" height="48" alt="emanuelst" title="emanuelst"/></a> <a href="https://github.com/KristijanJovanovski"><img src="https://avatars.githubusercontent.com/u/8942284?v=4&s=48" width="48" height="48" alt="KristijanJovanovski" title="KristijanJovanovski"/></a> <a href="https://github.com/rdev"><img src="https://avatars.githubusercontent.com/u/8418866?v=4&s=48" width="48" height="48" alt="rdev" title="rdev"/></a> <a href="https://github.com/rhuanssauro"><img src="https://avatars.githubusercontent.com/u/164682191?v=4&s=48" width="48" height="48" alt="rhuanssauro" title="rhuanssauro"/></a> <a href="https://github.com/joshrad-dev"><img src="https://avatars.githubusercontent.com/u/62785552?v=4&s=48" width="48" height="48" alt="joshrad-dev" title="joshrad-dev"/></a> <a href="https://github.com/kiranjd"><img src="https://avatars.githubusercontent.com/u/25822851?v=4&s=48" width="48" height="48" alt="kiranjd" title="kiranjd"/></a> <a href="https://github.com/osolmaz"><img src="https://avatars.githubusercontent.com/u/2453968?v=4&s=48" width="48" height="48" alt="osolmaz" title="osolmaz"/></a> <a href="https://github.com/adityashaw2"><img src="https://avatars.githubusercontent.com/u/41204444?v=4&s=48" width="48" height="48" alt="adityashaw2" title="adityashaw2"/></a> <a href="https://github.com/CashWilliams"><img src="https://avatars.githubusercontent.com/u/613573?v=4&s=48" width="48" height="48" alt="CashWilliams" title="CashWilliams"/></a> <a href="https://github.com/search?q=sheeek"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="sheeek" title="sheeek"/></a>
|
| 497 |
-
<a href="https://github.com/ryancontent"><img src="https://avatars.githubusercontent.com/u/39743613?v=4&s=48" width="48" height="48" alt="ryancontent" title="ryancontent"/></a> <a href="https://github.com/artuskg"><img src="https://avatars.githubusercontent.com/u/11966157?v=4&s=48" width="48" height="48" alt="artuskg" title="artuskg"/></a> <a href="https://github.com/Takhoffman"><img src="https://avatars.githubusercontent.com/u/781889?v=4&s=48" width="48" height="48" alt="Takhoffman" title="Takhoffman"/></a> <a href="https://github.com/onutc"><img src="https://avatars.githubusercontent.com/u/152018508?v=4&s=48" width="48" height="48" alt="onutc" title="onutc"/></a> <a href="https://github.com/pauloportella"><img src="https://avatars.githubusercontent.com/u/22947229?v=4&s=48" width="48" height="48" alt="pauloportella" title="pauloportella"/></a> <a href="https://github.com/neooriginal"><img src="https://avatars.githubusercontent.com/u/54811660?v=4&s=48" width="48" height="48" alt="neooriginal" title="neooriginal"/></a> <a href="https://github.com/ManuelHettich"><img src="https://avatars.githubusercontent.com/u/17690367?v=4&s=48" width="48" height="48" alt="manuelhettich" title="manuelhettich"/></a> <a href="https://github.com/minghinmatthewlam"><img src="https://avatars.githubusercontent.com/u/14224566?v=4&s=48" width="48" height="48" alt="minghinmatthewlam" title="minghinmatthewlam"/></a> <a href="https://github.com/myfunc"><img src="https://avatars.githubusercontent.com/u/19294627?v=4&s=48" width="48" height="48" alt="myfunc" title="myfunc"/></a> <a href="https://github.com/travisirby"><img src="https://avatars.githubusercontent.com/u/5958376?v=4&s=48" width="48" height="48" alt="travisirby" title="travisirby"/></a>
|
| 498 |
-
<a href="https://github.com/obviyus"><img src="https://avatars.githubusercontent.com/u/22031114?v=4&s=48" width="48" height="48" alt="obviyus" title="obviyus"/></a> <a href="https://github.com/buddyh"><img src="https://avatars.githubusercontent.com/u/31752869?v=4&s=48" width="48" height="48" alt="buddyh" title="buddyh"/></a> <a href="https://github.com/connorshea"><img src="https://avatars.githubusercontent.com/u/2977353?v=4&s=48" width="48" height="48" alt="connorshea" title="connorshea"/></a> <a href="https://github.com/kyleok"><img src="https://avatars.githubusercontent.com/u/58307870?v=4&s=48" width="48" height="48" alt="kyleok" title="kyleok"/></a> <a href="https://github.com/mcinteerj"><img src="https://avatars.githubusercontent.com/u/3613653?v=4&s=48" width="48" height="48" alt="mcinteerj" title="mcinteerj"/></a> <a href="https://github.com/apps/dependabot"><img src="https://avatars.githubusercontent.com/in/29110?v=4&s=48" width="48" height="48" alt="dependabot[bot]" title="dependabot[bot]"/></a> <a href="https://github.com/John-Rood"><img src="https://avatars.githubusercontent.com/u/62669593?v=4&s=48" width="48" height="48" alt="John-Rood" title="John-Rood"/></a> <a href="https://github.com/timkrase"><img src="https://avatars.githubusercontent.com/u/38947626?v=4&s=48" width="48" height="48" alt="timkrase" title="timkrase"/></a> <a href="https://github.com/uos-status"><img src="https://avatars.githubusercontent.com/u/255712580?v=4&s=48" width="48" height="48" alt="uos-status" title="uos-status"/></a> <a href="https://github.com/gerardward2007"><img src="https://avatars.githubusercontent.com/u/3002155?v=4&s=48" width="48" height="48" alt="gerardward2007" title="gerardward2007"/></a>
|
| 499 |
-
<a href="https://github.com/roshanasingh4"><img src="https://avatars.githubusercontent.com/u/88576930?v=4&s=48" width="48" height="48" alt="roshanasingh4" title="roshanasingh4"/></a> <a href="https://github.com/tosh-hamburg"><img src="https://avatars.githubusercontent.com/u/58424326?v=4&s=48" width="48" height="48" alt="tosh-hamburg" title="tosh-hamburg"/></a> <a href="https://github.com/azade-c"><img src="https://avatars.githubusercontent.com/u/252790079?v=4&s=48" width="48" height="48" alt="azade-c" title="azade-c"/></a> <a href="https://github.com/dlauer"><img src="https://avatars.githubusercontent.com/u/757041?v=4&s=48" width="48" height="48" alt="dlauer" title="dlauer"/></a> <a href="https://github.com/JonUleis"><img src="https://avatars.githubusercontent.com/u/7644941?v=4&s=48" width="48" height="48" alt="JonUleis" title="JonUleis"/></a> <a href="https://github.com/shivamraut101"><img src="https://avatars.githubusercontent.com/u/110457469?v=4&s=48" width="48" height="48" alt="shivamraut101" title="shivamraut101"/></a> <a href="https://github.com/bjesuiter"><img src="https://avatars.githubusercontent.com/u/2365676?v=4&s=48" width="48" height="48" alt="bjesuiter" title="bjesuiter"/></a> <a href="https://github.com/cheeeee"><img src="https://avatars.githubusercontent.com/u/21245729?v=4&s=48" width="48" height="48" alt="cheeeee" title="cheeeee"/></a> <a href="https://github.com/robbyczgw-cla"><img src="https://avatars.githubusercontent.com/u/239660374?v=4&s=48" width="48" height="48" alt="robbyczgw-cla" title="robbyczgw-cla"/></a> <a href="https://github.com/j1philli"><img src="https://avatars.githubusercontent.com/u/3744255?v=4&s=48" width="48" height="48" alt="Josh Phillips" title="Josh Phillips"/></a>
|
| 500 |
-
<a href="https://github.com/YuriNachos"><img src="https://avatars.githubusercontent.com/u/19365375?v=4&s=48" width="48" height="48" alt="YuriNachos" title="YuriNachos"/></a> <a href="https://github.com/pookNast"><img src="https://avatars.githubusercontent.com/u/14242552?v=4&s=48" width="48" height="48" alt="pookNast" title="pookNast"/></a> <a href="https://github.com/Whoaa512"><img src="https://avatars.githubusercontent.com/u/1581943?v=4&s=48" width="48" height="48" alt="Whoaa512" title="Whoaa512"/></a> <a href="https://github.com/chriseidhof"><img src="https://avatars.githubusercontent.com/u/5382?v=4&s=48" width="48" height="48" alt="chriseidhof" title="chriseidhof"/></a> <a href="https://github.com/ngutman"><img src="https://avatars.githubusercontent.com/u/1540134?v=4&s=48" width="48" height="48" alt="ngutman" title="ngutman"/></a> <a href="https://github.com/ysqander"><img src="https://avatars.githubusercontent.com/u/80843820?v=4&s=48" width="48" height="48" alt="ysqander" title="ysqander"/></a> <a href="https://github.com/aj47"><img src="https://avatars.githubusercontent.com/u/8023513?v=4&s=48" width="48" height="48" alt="aj47" title="aj47"/></a> <a href="https://github.com/kennyklee"><img src="https://avatars.githubusercontent.com/u/1432489?v=4&s=48" width="48" height="48" alt="kennyklee" title="kennyklee"/></a> <a href="https://github.com/superman32432432"><img src="https://avatars.githubusercontent.com/u/7228420?v=4&s=48" width="48" height="48" alt="superman32432432" title="superman32432432"/></a> <a href="https://github.com/search?q=Yurii%20Chukhlib"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Yurii Chukhlib" title="Yurii Chukhlib"/></a>
|
| 501 |
-
<a href="https://github.com/grp06"><img src="https://avatars.githubusercontent.com/u/1573959?v=4&s=48" width="48" height="48" alt="grp06" title="grp06"/></a> <a href="https://github.com/antons"><img src="https://avatars.githubusercontent.com/u/129705?v=4&s=48" width="48" height="48" alt="antons" title="antons"/></a> <a href="https://github.com/austinm911"><img src="https://avatars.githubusercontent.com/u/31991302?v=4&s=48" width="48" height="48" alt="austinm911" title="austinm911"/></a> <a href="https://github.com/apps/blacksmith-sh"><img src="https://avatars.githubusercontent.com/in/807020?v=4&s=48" width="48" height="48" alt="blacksmith-sh[bot]" title="blacksmith-sh[bot]"/></a> <a href="https://github.com/damoahdominic"><img src="https://avatars.githubusercontent.com/u/4623434?v=4&s=48" width="48" height="48" alt="damoahdominic" title="damoahdominic"/></a> <a href="https://github.com/dan-dr"><img src="https://avatars.githubusercontent.com/u/6669808?v=4&s=48" width="48" height="48" alt="dan-dr" title="dan-dr"/></a> <a href="https://github.com/HeimdallStrategy"><img src="https://avatars.githubusercontent.com/u/223014405?v=4&s=48" width="48" height="48" alt="HeimdallStrategy" title="HeimdallStrategy"/></a> <a href="https://github.com/imfing"><img src="https://avatars.githubusercontent.com/u/5097752?v=4&s=48" width="48" height="48" alt="imfing" title="imfing"/></a> <a href="https://github.com/jalehman"><img src="https://avatars.githubusercontent.com/u/550978?v=4&s=48" width="48" height="48" alt="jalehman" title="jalehman"/></a> <a href="https://github.com/jarvis-medmatic"><img src="https://avatars.githubusercontent.com/u/252428873?v=4&s=48" width="48" height="48" alt="jarvis-medmatic" title="jarvis-medmatic"/></a>
|
| 502 |
-
<a href="https://github.com/kkarimi"><img src="https://avatars.githubusercontent.com/u/875218?v=4&s=48" width="48" height="48" alt="kkarimi" title="kkarimi"/></a> <a href="https://github.com/mahmoudashraf93"><img src="https://avatars.githubusercontent.com/u/9130129?v=4&s=48" width="48" height="48" alt="mahmoudashraf93" title="mahmoudashraf93"/></a> <a href="https://github.com/pkrmf"><img src="https://avatars.githubusercontent.com/u/1714267?v=4&s=48" width="48" height="48" alt="pkrmf" title="pkrmf"/></a> <a href="https://github.com/RandyVentures"><img src="https://avatars.githubusercontent.com/u/149904821?v=4&s=48" width="48" height="48" alt="RandyVentures" title="RandyVentures"/></a> <a href="https://github.com/search?q=Ryan%20Lisse"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Ryan Lisse" title="Ryan Lisse"/></a> <a href="https://github.com/dougvk"><img src="https://avatars.githubusercontent.com/u/401660?v=4&s=48" width="48" height="48" alt="dougvk" title="dougvk"/></a> <a href="https://github.com/erikpr1994"><img src="https://avatars.githubusercontent.com/u/6299331?v=4&s=48" width="48" height="48" alt="erikpr1994" title="erikpr1994"/></a> <a href="https://github.com/fal3"><img src="https://avatars.githubusercontent.com/u/6484295?v=4&s=48" width="48" height="48" alt="fal3" title="fal3"/></a> <a href="https://github.com/search?q=Ghost"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Ghost" title="Ghost"/></a> <a href="https://github.com/jonasjancarik"><img src="https://avatars.githubusercontent.com/u/2459191?v=4&s=48" width="48" height="48" alt="jonasjancarik" title="jonasjancarik"/></a>
|
| 503 |
-
<a href="https://github.com/search?q=Keith%20the%20Silly%20Goose"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Keith the Silly Goose" title="Keith the Silly Goose"/></a> <a href="https://github.com/search?q=L36%20Server"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="L36 Server" title="L36 Server"/></a> <a href="https://github.com/search?q=Marc"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Marc" title="Marc"/></a> <a href="https://github.com/mitschabaude-bot"><img src="https://avatars.githubusercontent.com/u/247582884?v=4&s=48" width="48" height="48" alt="mitschabaude-bot" title="mitschabaude-bot"/></a> <a href="https://github.com/mkbehr"><img src="https://avatars.githubusercontent.com/u/1285?v=4&s=48" width="48" height="48" alt="mkbehr" title="mkbehr"/></a> <a href="https://github.com/neist"><img src="https://avatars.githubusercontent.com/u/1029724?v=4&s=48" width="48" height="48" alt="neist" title="neist"/></a> <a href="https://github.com/sibbl"><img src="https://avatars.githubusercontent.com/u/866535?v=4&s=48" width="48" height="48" alt="sibbl" title="sibbl"/></a> <a href="https://github.com/chrisrodz"><img src="https://avatars.githubusercontent.com/u/2967620?v=4&s=48" width="48" height="48" alt="chrisrodz" title="chrisrodz"/></a> <a href="https://github.com/search?q=Friederike%20Seiler"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Friederike Seiler" title="Friederike Seiler"/></a> <a href="https://github.com/gabriel-trigo"><img src="https://avatars.githubusercontent.com/u/38991125?v=4&s=48" width="48" height="48" alt="gabriel-trigo" title="gabriel-trigo"/></a>
|
| 504 |
-
<a href="https://github.com/Iamadig"><img src="https://avatars.githubusercontent.com/u/102129234?v=4&s=48" width="48" height="48" alt="iamadig" title="iamadig"/></a> <a href="https://github.com/jdrhyne"><img src="https://avatars.githubusercontent.com/u/7828464?v=4&s=48" width="48" height="48" alt="Jonathan D. Rhyne (DJ-D)" title="Jonathan D. Rhyne (DJ-D)"/></a> <a href="https://github.com/search?q=Joshua%20Mitchell"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Joshua Mitchell" title="Joshua Mitchell"/></a> <a href="https://github.com/search?q=Kit"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Kit" title="Kit"/></a> <a href="https://github.com/koala73"><img src="https://avatars.githubusercontent.com/u/996596?v=4&s=48" width="48" height="48" alt="koala73" title="koala73"/></a> <a href="https://github.com/manmal"><img src="https://avatars.githubusercontent.com/u/142797?v=4&s=48" width="48" height="48" alt="manmal" title="manmal"/></a> <a href="https://github.com/ogulcancelik"><img src="https://avatars.githubusercontent.com/u/7064011?v=4&s=48" width="48" height="48" alt="ogulcancelik" title="ogulcancelik"/></a> <a href="https://github.com/pasogott"><img src="https://avatars.githubusercontent.com/u/23458152?v=4&s=48" width="48" height="48" alt="pasogott" title="pasogott"/></a> <a href="https://github.com/petradonka"><img src="https://avatars.githubusercontent.com/u/7353770?v=4&s=48" width="48" height="48" alt="petradonka" title="petradonka"/></a> <a href="https://github.com/rubyrunsstuff"><img src="https://avatars.githubusercontent.com/u/246602379?v=4&s=48" width="48" height="48" alt="rubyrunsstuff" title="rubyrunsstuff"/></a>
|
| 505 |
-
<a href="https://github.com/siddhantjain"><img src="https://avatars.githubusercontent.com/u/4835232?v=4&s=48" width="48" height="48" alt="siddhantjain" title="siddhantjain"/></a> <a href="https://github.com/suminhthanh"><img src="https://avatars.githubusercontent.com/u/2907636?v=4&s=48" width="48" height="48" alt="suminhthanh" title="suminhthanh"/></a> <a href="https://github.com/svkozak"><img src="https://avatars.githubusercontent.com/u/31941359?v=4&s=48" width="48" height="48" alt="svkozak" title="svkozak"/></a> <a href="https://github.com/VACInc"><img src="https://avatars.githubusercontent.com/u/3279061?v=4&s=48" width="48" height="48" alt="VACInc" title="VACInc"/></a> <a href="https://github.com/wes-davis"><img src="https://avatars.githubusercontent.com/u/16506720?v=4&s=48" width="48" height="48" alt="wes-davis" title="wes-davis"/></a> <a href="https://github.com/zats"><img src="https://avatars.githubusercontent.com/u/2688806?v=4&s=48" width="48" height="48" alt="zats" title="zats"/></a> <a href="https://github.com/24601"><img src="https://avatars.githubusercontent.com/u/1157207?v=4&s=48" width="48" height="48" alt="24601" title="24601"/></a> <a href="https://github.com/ameno-"><img src="https://avatars.githubusercontent.com/u/2416135?v=4&s=48" width="48" height="48" alt="ameno-" title="ameno-"/></a> <a href="https://github.com/search?q=Chris%20Taylor"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Chris Taylor" title="Chris Taylor"/></a> <a href="https://github.com/dguido"><img src="https://avatars.githubusercontent.com/u/294844?v=4&s=48" width="48" height="48" alt="dguido" title="dguido"/></a>
|
| 506 |
-
<a href="https://github.com/djangonavarro220"><img src="https://avatars.githubusercontent.com/u/251162586?v=4&s=48" width="48" height="48" alt="Django Navarro" title="Django Navarro"/></a> <a href="https://github.com/evalexpr"><img src="https://avatars.githubusercontent.com/u/23485511?v=4&s=48" width="48" height="48" alt="evalexpr" title="evalexpr"/></a> <a href="https://github.com/henrino3"><img src="https://avatars.githubusercontent.com/u/4260288?v=4&s=48" width="48" height="48" alt="henrino3" title="henrino3"/></a> <a href="https://github.com/humanwritten"><img src="https://avatars.githubusercontent.com/u/206531610?v=4&s=48" width="48" height="48" alt="humanwritten" title="humanwritten"/></a> <a href="https://github.com/larlyssa"><img src="https://avatars.githubusercontent.com/u/13128869?v=4&s=48" width="48" height="48" alt="larlyssa" title="larlyssa"/></a> <a href="https://github.com/Lukavyi"><img src="https://avatars.githubusercontent.com/u/1013690?v=4&s=48" width="48" height="48" alt="Lukavyi" title="Lukavyi"/></a> <a href="https://github.com/odysseus0"><img src="https://avatars.githubusercontent.com/u/8635094?v=4&s=48" width="48" height="48" alt="odysseus0" title="odysseus0"/></a> <a href="https://github.com/oswalpalash"><img src="https://avatars.githubusercontent.com/u/6431196?v=4&s=48" width="48" height="48" alt="oswalpalash" title="oswalpalash"/></a> <a href="https://github.com/pcty-nextgen-service-account"><img src="https://avatars.githubusercontent.com/u/112553441?v=4&s=48" width="48" height="48" alt="pcty-nextgen-service-account" title="pcty-nextgen-service-account"/></a> <a href="https://github.com/pi0"><img src="https://avatars.githubusercontent.com/u/5158436?v=4&s=48" width="48" height="48" alt="pi0" title="pi0"/></a>
|
| 507 |
-
<a href="https://github.com/rmorse"><img src="https://avatars.githubusercontent.com/u/853547?v=4&s=48" width="48" height="48" alt="rmorse" title="rmorse"/></a> <a href="https://github.com/search?q=Roopak%20Nijhara"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Roopak Nijhara" title="Roopak Nijhara"/></a> <a href="https://github.com/Syhids"><img src="https://avatars.githubusercontent.com/u/671202?v=4&s=48" width="48" height="48" alt="Syhids" title="Syhids"/></a> <a href="https://github.com/search?q=Aaron%20Konyer"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Aaron Konyer" title="Aaron Konyer"/></a> <a href="https://github.com/aaronveklabs"><img src="https://avatars.githubusercontent.com/u/225997828?v=4&s=48" width="48" height="48" alt="aaronveklabs" title="aaronveklabs"/></a> <a href="https://github.com/andreabadesso"><img src="https://avatars.githubusercontent.com/u/3586068?v=4&s=48" width="48" height="48" alt="andreabadesso" title="andreabadesso"/></a> <a href="https://github.com/search?q=Andrii"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Andrii" title="Andrii"/></a> <a href="https://github.com/cash-echo-bot"><img src="https://avatars.githubusercontent.com/u/252747386?v=4&s=48" width="48" height="48" alt="cash-echo-bot" title="cash-echo-bot"/></a> <a href="https://github.com/search?q=Clawd"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Clawd" title="Clawd"/></a> <a href="https://github.com/search?q=ClawdFx"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="ClawdFx" title="ClawdFx"/></a>
|
| 508 |
-
<a href="https://github.com/EnzeD"><img src="https://avatars.githubusercontent.com/u/9866900?v=4&s=48" width="48" height="48" alt="EnzeD" title="EnzeD"/></a> <a href="https://github.com/erik-agens"><img src="https://avatars.githubusercontent.com/u/80908960?v=4&s=48" width="48" height="48" alt="erik-agens" title="erik-agens"/></a> <a href="https://github.com/Evizero"><img src="https://avatars.githubusercontent.com/u/10854026?v=4&s=48" width="48" height="48" alt="Evizero" title="Evizero"/></a> <a href="https://github.com/fcatuhe"><img src="https://avatars.githubusercontent.com/u/17382215?v=4&s=48" width="48" height="48" alt="fcatuhe" title="fcatuhe"/></a> <a href="https://github.com/itsjaydesu"><img src="https://avatars.githubusercontent.com/u/220390?v=4&s=48" width="48" height="48" alt="itsjaydesu" title="itsjaydesu"/></a> <a href="https://github.com/ivancasco"><img src="https://avatars.githubusercontent.com/u/2452858?v=4&s=48" width="48" height="48" alt="ivancasco" title="ivancasco"/></a> <a href="https://github.com/ivanrvpereira"><img src="https://avatars.githubusercontent.com/u/183991?v=4&s=48" width="48" height="48" alt="ivanrvpereira" title="ivanrvpereira"/></a> <a href="https://github.com/search?q=Jarvis"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Jarvis" title="Jarvis"/></a> <a href="https://github.com/jayhickey"><img src="https://avatars.githubusercontent.com/u/1676460?v=4&s=48" width="48" height="48" alt="jayhickey" title="jayhickey"/></a> <a href="https://github.com/jeffersonwarrior"><img src="https://avatars.githubusercontent.com/u/89030989?v=4&s=48" width="48" height="48" alt="jeffersonwarrior" title="jeffersonwarrior"/></a>
|
| 509 |
-
<a href="https://github.com/search?q=jeffersonwarrior"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="jeffersonwarrior" title="jeffersonwarrior"/></a> <a href="https://github.com/jverdi"><img src="https://avatars.githubusercontent.com/u/345050?v=4&s=48" width="48" height="48" alt="jverdi" title="jverdi"/></a> <a href="https://github.com/longmaba"><img src="https://avatars.githubusercontent.com/u/9361500?v=4&s=48" width="48" height="48" alt="longmaba" title="longmaba"/></a> <a href="https://github.com/MarvinCui"><img src="https://avatars.githubusercontent.com/u/130876763?v=4&s=48" width="48" height="48" alt="MarvinCui" title="MarvinCui"/></a> <a href="https://github.com/mickahouan"><img src="https://avatars.githubusercontent.com/u/31423109?v=4&s=48" width="48" height="48" alt="mickahouan" title="mickahouan"/></a> <a href="https://github.com/mjrussell"><img src="https://avatars.githubusercontent.com/u/1641895?v=4&s=48" width="48" height="48" alt="mjrussell" title="mjrussell"/></a> <a href="https://github.com/odnxe"><img src="https://avatars.githubusercontent.com/u/403141?v=4&s=48" width="48" height="48" alt="odnxe" title="odnxe"/></a> <a href="https://github.com/p6l-richard"><img src="https://avatars.githubusercontent.com/u/18185649?v=4&s=48" width="48" height="48" alt="p6l-richard" title="p6l-richard"/></a> <a href="https://github.com/philipp-spiess"><img src="https://avatars.githubusercontent.com/u/458591?v=4&s=48" width="48" height="48" alt="philipp-spiess" title="philipp-spiess"/></a> <a href="https://github.com/search?q=Pocket%20Clawd"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Pocket Clawd" title="Pocket Clawd"/></a>
|
| 510 |
-
<a href="https://github.com/robaxelsen"><img src="https://avatars.githubusercontent.com/u/13132899?v=4&s=48" width="48" height="48" alt="robaxelsen" title="robaxelsen"/></a> <a href="https://github.com/search?q=Sash%20Catanzarite"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Sash Catanzarite" title="Sash Catanzarite"/></a> <a href="https://github.com/Suksham-sharma"><img src="https://avatars.githubusercontent.com/u/94667656?v=4&s=48" width="48" height="48" alt="Suksham-sharma" title="Suksham-sharma"/></a> <a href="https://github.com/T5-AndyML"><img src="https://avatars.githubusercontent.com/u/22801233?v=4&s=48" width="48" height="48" alt="T5-AndyML" title="T5-AndyML"/></a> <a href="https://github.com/tewatia"><img src="https://avatars.githubusercontent.com/u/22875334?v=4&s=48" width="48" height="48" alt="tewatia" title="tewatia"/></a> <a href="https://github.com/travisp"><img src="https://avatars.githubusercontent.com/u/165698?v=4&s=48" width="48" height="48" alt="travisp" title="travisp"/></a> <a href="https://github.com/search?q=VAC"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="VAC" title="VAC"/></a> <a href="https://github.com/search?q=william%20arzt"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="william arzt" title="william arzt"/></a> <a href="https://github.com/zknicker"><img src="https://avatars.githubusercontent.com/u/1164085?v=4&s=48" width="48" height="48" alt="zknicker" title="zknicker"/></a> <a href="https://github.com/0oAstro"><img src="https://avatars.githubusercontent.com/u/79555780?v=4&s=48" width="48" height="48" alt="0oAstro" title="0oAstro"/></a>
|
| 511 |
-
<a href="https://github.com/abhaymundhara"><img src="https://avatars.githubusercontent.com/u/62872231?v=4&s=48" width="48" height="48" alt="abhaymundhara" title="abhaymundhara"/></a> <a href="https://github.com/aduk059"><img src="https://avatars.githubusercontent.com/u/257603478?v=4&s=48" width="48" height="48" alt="aduk059" title="aduk059"/></a> <a href="https://github.com/search?q=alejandro%20maza"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="alejandro maza" title="alejandro maza"/></a> <a href="https://github.com/Alex-Alaniz"><img src="https://avatars.githubusercontent.com/u/88956822?v=4&s=48" width="48" height="48" alt="Alex-Alaniz" title="Alex-Alaniz"/></a> <a href="https://github.com/alexstyl"><img src="https://avatars.githubusercontent.com/u/1665273?v=4&s=48" width="48" height="48" alt="alexstyl" title="alexstyl"/></a> <a href="https://github.com/andrewting19"><img src="https://avatars.githubusercontent.com/u/10536704?v=4&s=48" width="48" height="48" alt="andrewting19" title="andrewting19"/></a> <a href="https://github.com/anpoirier"><img src="https://avatars.githubusercontent.com/u/1245729?v=4&s=48" width="48" height="48" alt="anpoirier" title="anpoirier"/></a> <a href="https://github.com/araa47"><img src="https://avatars.githubusercontent.com/u/22760261?v=4&s=48" width="48" height="48" alt="araa47" title="araa47"/></a> <a href="https://github.com/arthyn"><img src="https://avatars.githubusercontent.com/u/5466421?v=4&s=48" width="48" height="48" alt="arthyn" title="arthyn"/></a> <a href="https://github.com/Asleep123"><img src="https://avatars.githubusercontent.com/u/122379135?v=4&s=48" width="48" height="48" alt="Asleep123" title="Asleep123"/></a>
|
| 512 |
-
<a href="https://github.com/bguidolim"><img src="https://avatars.githubusercontent.com/u/987360?v=4&s=48" width="48" height="48" alt="bguidolim" title="bguidolim"/></a> <a href="https://github.com/bolismauro"><img src="https://avatars.githubusercontent.com/u/771999?v=4&s=48" width="48" height="48" alt="bolismauro" title="bolismauro"/></a> <a href="https://github.com/chenyuan99"><img src="https://avatars.githubusercontent.com/u/25518100?v=4&s=48" width="48" height="48" alt="chenyuan99" title="chenyuan99"/></a> <a href="https://github.com/search?q=Clawdbot%20Maintainers"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Clawdbot Maintainers" title="Clawdbot Maintainers"/></a> <a href="https://github.com/conhecendoia"><img src="https://avatars.githubusercontent.com/u/82890727?v=4&s=48" width="48" height="48" alt="conhecendoia" title="conhecendoia"/></a> <a href="https://github.com/dasilva333"><img src="https://avatars.githubusercontent.com/u/947827?v=4&s=48" width="48" height="48" alt="dasilva333" title="dasilva333"/></a> <a href="https://github.com/David-Marsh-Photo"><img src="https://avatars.githubusercontent.com/u/228404527?v=4&s=48" width="48" height="48" alt="David-Marsh-Photo" title="David-Marsh-Photo"/></a> <a href="https://github.com/search?q=Developer"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Developer" title="Developer"/></a> <a href="https://github.com/search?q=Dimitrios%20Ploutarchos"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Dimitrios Ploutarchos" title="Dimitrios Ploutarchos"/></a> <a href="https://github.com/search?q=Drake%20Thomsen"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Drake Thomsen" title="Drake Thomsen"/></a>
|
| 513 |
-
<a href="https://github.com/dylanneve1"><img src="https://avatars.githubusercontent.com/u/31746704?v=4&s=48" width="48" height="48" alt="dylanneve1" title="dylanneve1"/></a> <a href="https://github.com/search?q=Felix%20Krause"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Felix Krause" title="Felix Krause"/></a> <a href="https://github.com/foeken"><img src="https://avatars.githubusercontent.com/u/13864?v=4&s=48" width="48" height="48" alt="foeken" title="foeken"/></a> <a href="https://github.com/frankekn"><img src="https://avatars.githubusercontent.com/u/4488090?v=4&s=48" width="48" height="48" alt="frankekn" title="frankekn"/></a> <a href="https://github.com/search?q=ganghyun%20kim"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="ganghyun kim" title="ganghyun kim"/></a> <a href="https://github.com/grrowl"><img src="https://avatars.githubusercontent.com/u/907140?v=4&s=48" width="48" height="48" alt="grrowl" title="grrowl"/></a> <a href="https://github.com/gtsifrikas"><img src="https://avatars.githubusercontent.com/u/8904378?v=4&s=48" width="48" height="48" alt="gtsifrikas" title="gtsifrikas"/></a> <a href="https://github.com/HazAT"><img src="https://avatars.githubusercontent.com/u/363802?v=4&s=48" width="48" height="48" alt="HazAT" title="HazAT"/></a> <a href="https://github.com/hrdwdmrbl"><img src="https://avatars.githubusercontent.com/u/554881?v=4&s=48" width="48" height="48" alt="hrdwdmrbl" title="hrdwdmrbl"/></a> <a href="https://github.com/hugobarauna"><img src="https://avatars.githubusercontent.com/u/2719?v=4&s=48" width="48" height="48" alt="hugobarauna" title="hugobarauna"/></a>
|
| 514 |
-
<a href="https://github.com/search?q=Jamie%20Openshaw"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Jamie Openshaw" title="Jamie Openshaw"/></a> <a href="https://github.com/search?q=Jane"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Jane" title="Jane"/></a> <a href="https://github.com/search?q=Jarvis%20Deploy"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Jarvis Deploy" title="Jarvis Deploy"/></a> <a href="https://github.com/search?q=Jefferson%20Nunn"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Jefferson Nunn" title="Jefferson Nunn"/></a> <a href="https://github.com/jogi47"><img src="https://avatars.githubusercontent.com/u/1710139?v=4&s=48" width="48" height="48" alt="jogi47" title="jogi47"/></a> <a href="https://github.com/kentaro"><img src="https://avatars.githubusercontent.com/u/3458?v=4&s=48" width="48" height="48" alt="kentaro" title="kentaro"/></a> <a href="https://github.com/search?q=Kevin%20Lin"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Kevin Lin" title="Kevin Lin"/></a> <a href="https://github.com/kira-ariaki"><img src="https://avatars.githubusercontent.com/u/257352493?v=4&s=48" width="48" height="48" alt="kira-ariaki" title="kira-ariaki"/></a> <a href="https://github.com/kitze"><img src="https://avatars.githubusercontent.com/u/1160594?v=4&s=48" width="48" height="48" alt="kitze" title="kitze"/></a> <a href="https://github.com/Kiwitwitter"><img src="https://avatars.githubusercontent.com/u/25277769?v=4&s=48" width="48" height="48" alt="Kiwitwitter" title="Kiwitwitter"/></a>
|
| 515 |
-
<a href="https://github.com/levifig"><img src="https://avatars.githubusercontent.com/u/1605?v=4&s=48" width="48" height="48" alt="levifig" title="levifig"/></a> <a href="https://github.com/search?q=Lloyd"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Lloyd" title="Lloyd"/></a> <a href="https://github.com/longjos"><img src="https://avatars.githubusercontent.com/u/740160?v=4&s=48" width="48" height="48" alt="longjos" title="longjos"/></a> <a href="https://github.com/loukotal"><img src="https://avatars.githubusercontent.com/u/18210858?v=4&s=48" width="48" height="48" alt="loukotal" title="loukotal"/></a> <a href="https://github.com/louzhixian"><img src="https://avatars.githubusercontent.com/u/7994361?v=4&s=48" width="48" height="48" alt="louzhixian" title="louzhixian"/></a> <a href="https://github.com/martinpucik"><img src="https://avatars.githubusercontent.com/u/5503097?v=4&s=48" width="48" height="48" alt="martinpucik" title="martinpucik"/></a> <a href="https://github.com/search?q=Matt%20mini"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Matt mini" title="Matt mini"/></a> <a href="https://github.com/mertcicekci0"><img src="https://avatars.githubusercontent.com/u/179321902?v=4&s=48" width="48" height="48" alt="mertcicekci0" title="mertcicekci0"/></a> <a href="https://github.com/search?q=Miles"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Miles" title="Miles"/></a> <a href="https://github.com/mrdbstn"><img src="https://avatars.githubusercontent.com/u/58957632?v=4&s=48" width="48" height="48" alt="mrdbstn" title="mrdbstn"/></a>
|
| 516 |
-
<a href="https://github.com/MSch"><img src="https://avatars.githubusercontent.com/u/7475?v=4&s=48" width="48" height="48" alt="MSch" title="MSch"/></a> <a href="https://github.com/search?q=Mustafa%20Tag%20Eldeen"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Mustafa Tag Eldeen" title="Mustafa Tag Eldeen"/></a> <a href="https://github.com/ndraiman"><img src="https://avatars.githubusercontent.com/u/12609607?v=4&s=48" width="48" height="48" alt="ndraiman" title="ndraiman"/></a> <a href="https://github.com/nexty5870"><img src="https://avatars.githubusercontent.com/u/3869659?v=4&s=48" width="48" height="48" alt="nexty5870" title="nexty5870"/></a> <a href="https://github.com/Noctivoro"><img src="https://avatars.githubusercontent.com/u/183974570?v=4&s=48" width="48" height="48" alt="Noctivoro" title="Noctivoro"/></a> <a href="https://github.com/ppamment"><img src="https://avatars.githubusercontent.com/u/2122919?v=4&s=48" width="48" height="48" alt="ppamment" title="ppamment"/></a> <a href="https://github.com/prathamdby"><img src="https://avatars.githubusercontent.com/u/134331217?v=4&s=48" width="48" height="48" alt="prathamdby" title="prathamdby"/></a> <a href="https://github.com/ptn1411"><img src="https://avatars.githubusercontent.com/u/57529765?v=4&s=48" width="48" height="48" alt="ptn1411" title="ptn1411"/></a> <a href="https://github.com/reeltimeapps"><img src="https://avatars.githubusercontent.com/u/637338?v=4&s=48" width="48" height="48" alt="reeltimeapps" title="reeltimeapps"/></a> <a href="https://github.com/RLTCmpe"><img src="https://avatars.githubusercontent.com/u/10762242?v=4&s=48" width="48" height="48" alt="RLTCmpe" title="RLTCmpe"/></a>
|
| 517 |
-
<a href="https://github.com/search?q=Rolf%20Fredheim"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Rolf Fredheim" title="Rolf Fredheim"/></a> <a href="https://github.com/search?q=Rony%20Kelner"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Rony Kelner" title="Rony Kelner"/></a> <a href="https://github.com/search?q=Samrat%20Jha"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Samrat Jha" title="Samrat Jha"/></a> <a href="https://github.com/senoldogann"><img src="https://avatars.githubusercontent.com/u/45736551?v=4&s=48" width="48" height="48" alt="senoldogann" title="senoldogann"/></a> <a href="https://github.com/sergical"><img src="https://avatars.githubusercontent.com/u/3760543?v=4&s=48" width="48" height="48" alt="sergical" title="sergical"/></a> <a href="https://github.com/shiv19"><img src="https://avatars.githubusercontent.com/u/9407019?v=4&s=48" width="48" height="48" alt="shiv19" title="shiv19"/></a> <a href="https://github.com/shiyuanhai"><img src="https://avatars.githubusercontent.com/u/1187370?v=4&s=48" width="48" height="48" alt="shiyuanhai" title="shiyuanhai"/></a> <a href="https://github.com/siraht"><img src="https://avatars.githubusercontent.com/u/73152895?v=4&s=48" width="48" height="48" alt="siraht" title="siraht"/></a> <a href="https://github.com/snopoke"><img src="https://avatars.githubusercontent.com/u/249606?v=4&s=48" width="48" height="48" alt="snopoke" title="snopoke"/></a> <a href="https://github.com/search?q=techboss"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="techboss" title="techboss"/></a>
|
| 518 |
-
<a href="https://github.com/testingabc321"><img src="https://avatars.githubusercontent.com/u/8577388?v=4&s=48" width="48" height="48" alt="testingabc321" title="testingabc321"/></a> <a href="https://github.com/search?q=The%20Admiral"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="The Admiral" title="The Admiral"/></a> <a href="https://github.com/thesash"><img src="https://avatars.githubusercontent.com/u/1166151?v=4&s=48" width="48" height="48" alt="thesash" title="thesash"/></a> <a href="https://github.com/search?q=Ubuntu"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Ubuntu" title="Ubuntu"/></a> <a href="https://github.com/voidserf"><img src="https://avatars.githubusercontent.com/u/477673?v=4&s=48" width="48" height="48" alt="voidserf" title="voidserf"/></a> <a href="https://github.com/search?q=Vultr-Clawd%20Admin"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Vultr-Clawd Admin" title="Vultr-Clawd Admin"/></a> <a href="https://github.com/search?q=Wimmie"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Wimmie" title="Wimmie"/></a> <a href="https://github.com/search?q=wolfred"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="wolfred" title="wolfred"/></a> <a href="https://github.com/wstock"><img src="https://avatars.githubusercontent.com/u/1394687?v=4&s=48" width="48" height="48" alt="wstock" title="wstock"/></a> <a href="https://github.com/YangHuang2280"><img src="https://avatars.githubusercontent.com/u/201681634?v=4&s=48" width="48" height="48" alt="YangHuang2280" title="YangHuang2280"/></a>
|
| 519 |
-
<a href="https://github.com/yazinsai"><img src="https://avatars.githubusercontent.com/u/1846034?v=4&s=48" width="48" height="48" alt="yazinsai" title="yazinsai"/></a> <a href="https://github.com/YiWang24"><img src="https://avatars.githubusercontent.com/u/176262341?v=4&s=48" width="48" height="48" alt="YiWang24" title="YiWang24"/></a> <a href="https://github.com/search?q=ymat19"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="ymat19" title="ymat19"/></a> <a href="https://github.com/search?q=Zach%20Knickerbocker"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Zach Knickerbocker" title="Zach Knickerbocker"/></a> <a href="https://github.com/zackerthescar"><img src="https://avatars.githubusercontent.com/u/38077284?v=4&s=48" width="48" height="48" alt="zackerthescar" title="zackerthescar"/></a> <a href="https://github.com/0xJonHoldsCrypto"><img src="https://avatars.githubusercontent.com/u/81202085?v=4&s=48" width="48" height="48" alt="0xJonHoldsCrypto" title="0xJonHoldsCrypto"/></a> <a href="https://github.com/aaronn"><img src="https://avatars.githubusercontent.com/u/1653630?v=4&s=48" width="48" height="48" alt="aaronn" title="aaronn"/></a> <a href="https://github.com/Alphonse-arianee"><img src="https://avatars.githubusercontent.com/u/254457365?v=4&s=48" width="48" height="48" alt="Alphonse-arianee" title="Alphonse-arianee"/></a> <a href="https://github.com/atalovesyou"><img src="https://avatars.githubusercontent.com/u/3534502?v=4&s=48" width="48" height="48" alt="atalovesyou" title="atalovesyou"/></a> <a href="https://github.com/search?q=Azade"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Azade" title="Azade"/></a>
|
| 520 |
-
<a href="https://github.com/carlulsoe"><img src="https://avatars.githubusercontent.com/u/34673973?v=4&s=48" width="48" height="48" alt="carlulsoe" title="carlulsoe"/></a> <a href="https://github.com/search?q=ddyo"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="ddyo" title="ddyo"/></a> <a href="https://github.com/search?q=Erik"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Erik" title="Erik"/></a> <a href="https://github.com/latitudeki5223"><img src="https://avatars.githubusercontent.com/u/119656367?v=4&s=48" width="48" height="48" alt="latitudeki5223" title="latitudeki5223"/></a> <a href="https://github.com/search?q=Manuel%20Maly"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Manuel Maly" title="Manuel Maly"/></a> <a href="https://github.com/search?q=Mourad%20Boustani"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Mourad Boustani" title="Mourad Boustani"/></a> <a href="https://github.com/odrobnik"><img src="https://avatars.githubusercontent.com/u/333270?v=4&s=48" width="48" height="48" alt="odrobnik" title="odrobnik"/></a> <a href="https://github.com/pcty-nextgen-ios-builder"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="pcty-nextgen-ios-builder" title="pcty-nextgen-ios-builder"/></a> <a href="https://github.com/search?q=Quentin"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Quentin" title="Quentin"/></a> <a href="https://github.com/search?q=Randy%20Torres"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="Randy Torres" title="Randy Torres"/></a>
|
| 521 |
-
<a href="https://github.com/rhjoh"><img src="https://avatars.githubusercontent.com/u/105699450?v=4&s=48" width="48" height="48" alt="rhjoh" title="rhjoh"/></a> <a href="https://github.com/ronak-guliani"><img src="https://avatars.githubusercontent.com/u/23518228?v=4&s=48" width="48" height="48" alt="ronak-guliani" title="ronak-guliani"/></a> <a href="https://github.com/search?q=William%20Stock"><img src="assets/avatar-placeholder.svg" width="48" height="48" alt="William Stock" title="William Stock"/></a>
|
| 522 |
-
</p>
|
|
|
|
| 1 |
---
|
| 2 |
+
title: OpenOperator Agent-Zero
|
| 3 |
+
emoji: 🧠
|
| 4 |
+
colorFrom: blue
|
| 5 |
+
colorTo: indigo
|
| 6 |
sdk: docker
|
| 7 |
app_port: 7860
|
| 8 |
+
pinned: false
|
| 9 |
---
|
| 10 |
|
| 11 |
+
# Agent-Zero Deployment on Hugging Face Spaces
|
| 12 |
|
| 13 |
+
This space runs a modified version of **Agent-Zero**, adapted for Hugging Face Spaces. It automatically pulls the latest version from the main branch on startup while maintaining custom adaptations for API accessibility and non-root environment compatibility.
|
|
|
|
|
|
|
| 14 |
|
| 15 |
+
## Key Adaptations
|
|
|
|
|
|
|
| 16 |
|
| 17 |
+
1. **Authentication & CSRF Bypass**: Security is adjusted for Hugging Face's environment to allow public API access via `https://Leon4gr45-openoperator.hf.space`.
|
| 18 |
+
2. **Health Check & API Documentation**: Mandatory endpoints `/health` and `/api-docs` are available at the root.
|
| 19 |
+
3. **Port Mapping**: The application is configured to listen on port 7860, as required by the Space.
|
| 20 |
+
4. **Runtime Logic**: The system automatically identifies the Dockerized environment and adjusts paths and settings accordingly.
|
|
|
|
|
|
|
|
|
|
| 21 |
|
| 22 |
+
## API Endpoints
|
|
|
|
| 23 |
|
| 24 |
+
- **Health**: `/health`
|
| 25 |
+
- **API Documentation**: `/api-docs`
|
| 26 |
+
- **Core API**: `/api/message` (requires JSON payload)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
api/api_docs.py
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import os
|
| 2 |
+
import threading
|
| 3 |
+
from typing import Any
|
| 4 |
+
from flask import Flask
|
| 5 |
+
|
| 6 |
+
class ApiDocs:
|
| 7 |
+
def __init__(self, webapp: Flask, lock: threading.Lock) -> None:
|
| 8 |
+
self.webapp = webapp
|
| 9 |
+
self.lock = lock
|
| 10 |
+
|
| 11 |
+
async def process(self, data: dict[str, Any], request: Any) -> dict[str, Any]:
|
| 12 |
+
endpoints = []
|
| 13 |
+
for rule in self.webapp.url_map.iter_rules():
|
| 14 |
+
if rule.rule.startswith("/api/"):
|
| 15 |
+
methods = ",".join(m for m in rule.methods if m not in ["OPTIONS", "HEAD"])
|
| 16 |
+
endpoints.append({
|
| 17 |
+
"path": rule.rule,
|
| 18 |
+
"methods": methods,
|
| 19 |
+
"endpoint": rule.endpoint
|
| 20 |
+
})
|
| 21 |
+
|
| 22 |
+
return {
|
| 23 |
+
"title": "Agent-Zero API Documentation",
|
| 24 |
+
"version": "1.0.0",
|
| 25 |
+
"hf_space": os.getenv("HF_SPACE") == "true",
|
| 26 |
+
"endpoints": endpoints
|
| 27 |
+
}
|
helpers/api.py
ADDED
|
@@ -0,0 +1,63 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
from abc import abstractmethod
|
| 2 |
+
import json
|
| 3 |
+
import threading
|
| 4 |
+
import os
|
| 5 |
+
from typing import Union, TypedDict, Dict, Any
|
| 6 |
+
from flask import Request, Response, Flask, request
|
| 7 |
+
from python.helpers.print_style import PrintStyle
|
| 8 |
+
from python.helpers.errors import format_error
|
| 9 |
+
|
| 10 |
+
Input = dict
|
| 11 |
+
Output = Union[Dict[str, Any], Response, TypedDict]
|
| 12 |
+
|
| 13 |
+
class ApiHandler:
|
| 14 |
+
def __init__(self, app: Flask, thread_lock: threading.Lock):
|
| 15 |
+
self.app = app
|
| 16 |
+
self.thread_lock = thread_lock
|
| 17 |
+
|
| 18 |
+
@classmethod
|
| 19 |
+
def requires_loopback(cls) -> bool: return False
|
| 20 |
+
@classmethod
|
| 21 |
+
def requires_api_key(cls) -> bool: return False
|
| 22 |
+
@classmethod
|
| 23 |
+
def requires_auth(cls) -> bool:
|
| 24 |
+
return False if os.getenv("HF_SPACE") == "true" else True
|
| 25 |
+
@classmethod
|
| 26 |
+
def get_methods(cls) -> list[str]: return ["POST", "GET"]
|
| 27 |
+
@classmethod
|
| 28 |
+
def requires_csrf(cls) -> bool:
|
| 29 |
+
return False if os.getenv("HF_SPACE") == "true" else cls.requires_auth()
|
| 30 |
+
|
| 31 |
+
@abstractmethod
|
| 32 |
+
async def process(self, input: Input, request: Request) -> Output: pass
|
| 33 |
+
|
| 34 |
+
async def handle_request(self, request: Request) -> Response:
|
| 35 |
+
try:
|
| 36 |
+
input_data: Input = {}
|
| 37 |
+
if request.is_json:
|
| 38 |
+
if request.data: input_data = request.get_json()
|
| 39 |
+
else:
|
| 40 |
+
input_data = request.args.to_dict()
|
| 41 |
+
if request.method == "POST":
|
| 42 |
+
input_data.update({"data": request.get_data(as_text=True)})
|
| 43 |
+
|
| 44 |
+
output = await self.process(input_data, request)
|
| 45 |
+
|
| 46 |
+
if isinstance(output, Response): return output
|
| 47 |
+
return Response(response=json.dumps(output), status=200, mimetype="application/json")
|
| 48 |
+
except Exception as e:
|
| 49 |
+
error = format_error(e)
|
| 50 |
+
PrintStyle.error(f"API error: {error}")
|
| 51 |
+
return Response(response=error, status=500, mimetype="text/plain")
|
| 52 |
+
|
| 53 |
+
def get_context(self, ctxid: str):
|
| 54 |
+
from agent import AgentContext
|
| 55 |
+
from initialize import initialize_agent
|
| 56 |
+
with self.thread_lock:
|
| 57 |
+
if not ctxid:
|
| 58 |
+
first = AgentContext.first()
|
| 59 |
+
if first: return first
|
| 60 |
+
return AgentContext(config=initialize_agent())
|
| 61 |
+
got = AgentContext.get(ctxid)
|
| 62 |
+
if got: return got
|
| 63 |
+
return AgentContext(config=initialize_agent(), id=ctxid)
|
helpers/runtime.py
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import argparse
|
| 2 |
+
import secrets
|
| 3 |
+
import os
|
| 4 |
+
|
| 5 |
+
parser = argparse.ArgumentParser()
|
| 6 |
+
args = {}
|
| 7 |
+
runtime_id = None
|
| 8 |
+
|
| 9 |
+
def initialize():
|
| 10 |
+
global args
|
| 11 |
+
if args: return
|
| 12 |
+
parser.add_argument("--port", type=int, default=None)
|
| 13 |
+
parser.add_argument("--host", type=str, default=None)
|
| 14 |
+
parser.add_argument("--dockerized", type=bool, default=False)
|
| 15 |
+
known, unknown = parser.parse_known_args()
|
| 16 |
+
args = vars(known)
|
| 17 |
+
|
| 18 |
+
def get_arg(name: str): return args.get(name, None)
|
| 19 |
+
def is_dockerized() -> bool: return bool(get_arg("dockerized")) or os.getenv("HF_SPACE") == "true"
|
| 20 |
+
def get_runtime_id() -> str:
|
| 21 |
+
global runtime_id
|
| 22 |
+
if not runtime_id: runtime_id = secrets.token_hex(8)
|
| 23 |
+
return runtime_id
|
| 24 |
+
def get_web_ui_port():
|
| 25 |
+
if os.getenv("HF_SPACE") == "true": return 7860
|
| 26 |
+
return get_arg("port") or 5000
|
helpers/settings.py
ADDED
|
@@ -0,0 +1,69 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import json
|
| 2 |
+
import os
|
| 3 |
+
import secrets
|
| 4 |
+
from python.helpers import files
|
| 5 |
+
from python.helpers.print_style import PrintStyle
|
| 6 |
+
|
| 7 |
+
def get_settings() -> dict:
|
| 8 |
+
try:
|
| 9 |
+
path = files.get_abs_path("settings.json")
|
| 10 |
+
if os.path.exists(path):
|
| 11 |
+
with open(path, "r") as f:
|
| 12 |
+
return json.load(f)
|
| 13 |
+
except Exception as e:
|
| 14 |
+
PrintStyle.error(f"Error loading settings: {e}")
|
| 15 |
+
# Return defaults
|
| 16 |
+
return {
|
| 17 |
+
"chat_model_provider": "openai",
|
| 18 |
+
"chat_model_name": "gpt-4",
|
| 19 |
+
"chat_model_api_base": "",
|
| 20 |
+
"chat_model_ctx_length": 128000,
|
| 21 |
+
"chat_model_vision": True,
|
| 22 |
+
"chat_model_rl_requests": 0,
|
| 23 |
+
"chat_model_rl_input": 0,
|
| 24 |
+
"chat_model_rl_output": 0,
|
| 25 |
+
"chat_model_kwargs": {},
|
| 26 |
+
"util_model_provider": "openai",
|
| 27 |
+
"util_model_name": "gpt-4o-mini",
|
| 28 |
+
"util_model_api_base": "",
|
| 29 |
+
"util_model_ctx_length": 128000,
|
| 30 |
+
"util_model_rl_requests": 0,
|
| 31 |
+
"util_model_rl_input": 0,
|
| 32 |
+
"util_model_rl_output": 0,
|
| 33 |
+
"util_model_kwargs": {},
|
| 34 |
+
"embed_model_provider": "openai",
|
| 35 |
+
"embed_model_name": "text-embedding-3-small",
|
| 36 |
+
"embed_model_api_base": "",
|
| 37 |
+
"embed_model_rl_requests": 0,
|
| 38 |
+
"embed_model_kwargs": {},
|
| 39 |
+
"browser_model_provider": "openai",
|
| 40 |
+
"browser_model_name": "gpt-4o-mini",
|
| 41 |
+
"browser_model_api_base": "",
|
| 42 |
+
"browser_model_vision": True,
|
| 43 |
+
"browser_model_kwargs": {},
|
| 44 |
+
"agent_profile": "default",
|
| 45 |
+
"agent_memory_subdir": "default",
|
| 46 |
+
"agent_knowledge_subdir": "custom",
|
| 47 |
+
"mcp_servers": "",
|
| 48 |
+
"rfc_url": "localhost",
|
| 49 |
+
"rfc_port_http": 55521
|
| 50 |
+
}
|
| 51 |
+
|
| 52 |
+
def save_settings(settings: dict) -> bool:
|
| 53 |
+
try:
|
| 54 |
+
path = files.get_abs_path("settings.json")
|
| 55 |
+
with open(path, "w") as f:
|
| 56 |
+
json.dump(settings, f, indent=4)
|
| 57 |
+
return True
|
| 58 |
+
except Exception as e:
|
| 59 |
+
PrintStyle.error(f"Error saving settings: {e}")
|
| 60 |
+
return False
|
| 61 |
+
|
| 62 |
+
def get_runtime_config(set):
|
| 63 |
+
return {
|
| 64 |
+
"code_exec_docker_enabled": False,
|
| 65 |
+
"code_exec_ssh_enabled": False
|
| 66 |
+
}
|
| 67 |
+
|
| 68 |
+
def create_auth_token():
|
| 69 |
+
return secrets.token_hex(16)
|
helpers/ws.py
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import os
|
| 2 |
+
from urllib.parse import parse_qs
|
| 3 |
+
|
| 4 |
+
def validate_ws_origin(environ):
|
| 5 |
+
if os.getenv("HF_SPACE") == "true":
|
| 6 |
+
return True, None
|
| 7 |
+
return True, None
|
| 8 |
+
|
| 9 |
+
def get_ws_auth(environ, auth):
|
| 10 |
+
ws_password = os.getenv("WS_PASSWORD")
|
| 11 |
+
client_password = (auth.get("password") or auth.get("pwd")) if isinstance(auth, dict) else None
|
| 12 |
+
if not client_password:
|
| 13 |
+
query = parse_qs(environ.get("QUERY_STRING", ""))
|
| 14 |
+
client_password = query.get("pwd", [None])[0]
|
| 15 |
+
|
| 16 |
+
if ws_password and client_password == ws_password:
|
| 17 |
+
return True
|
| 18 |
+
return False
|
run_ui.py
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
from datetime import timedelta
|
| 2 |
+
import os
|
| 3 |
+
import secrets
|
| 4 |
+
import threading
|
| 5 |
+
from flask import Flask, request, Response, session
|
| 6 |
+
from werkzeug.middleware.proxy_fix import ProxyFix
|
| 7 |
+
import initialize
|
| 8 |
+
from python.helpers import files, git, mcp_server, fasta2a_server
|
| 9 |
+
from python.helpers.files import get_abs_path
|
| 10 |
+
from python.helpers import runtime, dotenv, process
|
| 11 |
+
from python.helpers.extract_tools import load_classes_from_folder
|
| 12 |
+
from python.helpers.api import ApiHandler
|
| 13 |
+
from python.helpers.print_style import PrintStyle
|
| 14 |
+
|
| 15 |
+
# initialize the internal Flask server
|
| 16 |
+
webapp = Flask("app", static_folder=get_abs_path("./webui"), static_url_path="/")
|
| 17 |
+
webapp.secret_key = os.getenv("FLASK_SECRET_KEY") or secrets.token_hex(32)
|
| 18 |
+
|
| 19 |
+
# HF Space reverse proxy support
|
| 20 |
+
if os.getenv("HF_SPACE") == "true":
|
| 21 |
+
webapp.wsgi_app = ProxyFix(webapp.wsgi_app, x_for=1, x_proto=1, x_host=1)
|
| 22 |
+
|
| 23 |
+
webapp.config.update(
|
| 24 |
+
JSON_SORT_KEYS=False,
|
| 25 |
+
SESSION_COOKIE_NAME="session_" + runtime.get_runtime_id(),
|
| 26 |
+
SESSION_COOKIE_SAMESITE="Lax",
|
| 27 |
+
SESSION_PERMANENT=True,
|
| 28 |
+
PERMANENT_SESSION_LIFETIME=timedelta(days=1)
|
| 29 |
+
)
|
| 30 |
+
|
| 31 |
+
lock = threading.Lock()
|
| 32 |
+
|
| 33 |
+
@webapp.route("/", methods=["GET"])
|
| 34 |
+
async def serve_index():
|
| 35 |
+
index = files.read_file("webui/index.html")
|
| 36 |
+
return index
|
| 37 |
+
|
| 38 |
+
@webapp.route("/health", methods=["GET"])
|
| 39 |
+
async def health():
|
| 40 |
+
return {"status": "ok", "service": "agent-zero"}
|
| 41 |
+
|
| 42 |
+
@webapp.route("/api-docs", methods=["GET"])
|
| 43 |
+
async def api_docs():
|
| 44 |
+
from python.api.api_docs import ApiDocs
|
| 45 |
+
handler = ApiDocs(webapp, lock)
|
| 46 |
+
result = await handler.process({}, request)
|
| 47 |
+
return result
|
| 48 |
+
|
| 49 |
+
def run():
|
| 50 |
+
from werkzeug.serving import make_server
|
| 51 |
+
from werkzeug.middleware.dispatcher import DispatcherMiddleware
|
| 52 |
+
from a2wsgi import ASGIMiddleware
|
| 53 |
+
|
| 54 |
+
port = runtime.get_web_ui_port()
|
| 55 |
+
host = "0.0.0.0"
|
| 56 |
+
|
| 57 |
+
# register API handlers
|
| 58 |
+
handlers = load_classes_from_folder("python/api", "*.py", ApiHandler)
|
| 59 |
+
for handler in handlers:
|
| 60 |
+
name = handler.__module__.split(".")[-1]
|
| 61 |
+
instance = handler(webapp, lock)
|
| 62 |
+
async def handler_wrap(h=instance): return await h.handle_request(request=request)
|
| 63 |
+
webapp.add_url_rule(f"/api/{name}", f"/{name}", handler_wrap, methods=handler.get_methods())
|
| 64 |
+
|
| 65 |
+
middleware_routes = {
|
| 66 |
+
"/mcp": ASGIMiddleware(app=mcp_server.DynamicMcpProxy.get_instance()),
|
| 67 |
+
"/a2a": ASGIMiddleware(app=fasta2a_server.DynamicA2AProxy.get_instance()),
|
| 68 |
+
}
|
| 69 |
+
|
| 70 |
+
app = DispatcherMiddleware(webapp, middleware_routes)
|
| 71 |
+
server = make_server(host=host, port=port, app=app, threaded=True)
|
| 72 |
+
process.set_server(server)
|
| 73 |
+
|
| 74 |
+
# Init tasks
|
| 75 |
+
initialize.initialize_chats().result_sync()
|
| 76 |
+
initialize.initialize_mcp()
|
| 77 |
+
initialize.initialize_job_loop()
|
| 78 |
+
|
| 79 |
+
PrintStyle().debug(f"Starting server at http://{host}:{port} ...")
|
| 80 |
+
server.serve_forever()
|
| 81 |
+
|
| 82 |
+
if __name__ == "__main__":
|
| 83 |
+
runtime.initialize()
|
| 84 |
+
dotenv.load_dotenv()
|
| 85 |
+
run()
|
start_hf.sh
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/bin/bash
|
| 2 |
+
set -e
|
| 3 |
+
|
| 4 |
+
REPO_URL="https://github.com/JsonLord/agent-zero.git"
|
| 5 |
+
CLONE_DIR="/home/user/app/agent-zero-clone"
|
| 6 |
+
APP_DIR="/home/user/app"
|
| 7 |
+
|
| 8 |
+
echo "Cloning Agent-Zero (fix-a2a-auth-15797037665282663574 branch)..."
|
| 9 |
+
if [ -d "$CLONE_DIR" ]; then
|
| 10 |
+
rm -rf "$CLONE_DIR"
|
| 11 |
+
fi
|
| 12 |
+
|
| 13 |
+
git clone --branch fix-a2a-auth-15797037665282663574 "$REPO_URL" "$CLONE_DIR"
|
| 14 |
+
|
| 15 |
+
echo "Applying adaptations..."
|
| 16 |
+
cp -rn "$CLONE_DIR"/* "$APP_DIR/" 2>/dev/null || true
|
| 17 |
+
|
| 18 |
+
cp -f /home/user/app/helpers/api.py "$APP_DIR/python/helpers/api.py"
|
| 19 |
+
cp -f /home/user/app/helpers/runtime.py "$APP_DIR/python/helpers/runtime.py"
|
| 20 |
+
cp -f /home/user/app/helpers/settings.py "$APP_DIR/python/helpers/settings.py"
|
| 21 |
+
cp -f /home/user/app/run_ui.py "$APP_DIR/run_ui.py"
|
| 22 |
+
cp -f /home/user/app/api/api_docs.py "$APP_DIR/python/api/api_docs.py"
|
| 23 |
+
|
| 24 |
+
if [ -f "/home/user/app/helpers/ws.py" ]; then
|
| 25 |
+
cp -f /home/user/app/helpers/ws.py "$APP_DIR/python/helpers/ws.py"
|
| 26 |
+
fi
|
| 27 |
+
|
| 28 |
+
echo "Installing dependencies..."
|
| 29 |
+
if command -v uv > /dev/null; then
|
| 30 |
+
uv pip install --system --no-cache -r "$APP_DIR/requirements.txt"
|
| 31 |
+
uv pip install --system flask-socketio eventlet
|
| 32 |
+
else
|
| 33 |
+
pip install --no-cache-dir -r "$APP_DIR/requirements.txt"
|
| 34 |
+
pip install flask-socketio eventlet
|
| 35 |
+
fi
|
| 36 |
+
|
| 37 |
+
export HF_SPACE=true
|
| 38 |
+
export PORT=7860
|
| 39 |
+
export HOST=0.0.0.0
|
| 40 |
+
|
| 41 |
+
echo "Starting Agent-Zero..."
|
| 42 |
+
python run_ui.py --host 0.0.0.0 --port 7860 --dockerized=true
|