# Send Intranet to your agent
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
## Fast path
- Download the package from Yavira.
- Extract it into a folder your agent can access.
- Paste one of the prompts below and point your agent at the extracted folder.
## Suggested prompts
### New install

```text
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
```
### Upgrade existing

```text
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
```
## Machine-readable fields
```json
{
  "schemaVersion": "1.0",
  "item": {
    "slug": "intranet",
    "name": "Intranet",
    "source": "tencent",
    "type": "skill",
    "category": "通讯协作",
    "sourceUrl": "https://clawhub.ai/odrobnik/intranet",
    "canonicalUrl": "https://clawhub.ai/odrobnik/intranet",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadUrl": "/downloads/intranet",
    "sourceDownloadUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=intranet",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "packageFormat": "ZIP package",
    "primaryDoc": "SKILL.md",
    "includedAssets": [
      "SETUP.md",
      "SKILL.md",
      "scripts/intranet.py",
      "scripts/intranet_web.py"
    ],
    "downloadMode": "redirect",
    "sourceHealth": {
      "source": "tencent",
      "slug": "intranet",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-04-30T07:36:27.798Z",
      "expiresAt": "2026-05-07T07:36:27.798Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=intranet",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=intranet",
        "contentDisposition": "attachment; filename=\"intranet-3.2.7.zip\"",
        "redirectLocation": null,
        "bodySnippet": null,
        "slug": "intranet"
      },
      "scope": "item",
      "summary": "Item download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this item.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/intranet"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    }
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/intranet",
    "downloadUrl": "https://openagent3.xyz/downloads/intranet",
    "agentUrl": "https://openagent3.xyz/skills/intranet/agent",
    "manifestUrl": "https://openagent3.xyz/skills/intranet/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/intranet/agent.md"
  }
}
```
## Documentation

### Intranet

Lightweight local HTTP file server — no Apache/nginx needed, no root required. Serves static files, mounts plugin directories, and runs index.py entry points as CGI.

Entry point: {baseDir}/scripts/intranet.py

### Setup

See SETUP.md for prerequisites and setup instructions.

### Commands

python3 {baseDir}/scripts/intranet.py start                          # Start on default port 8080
python3 {baseDir}/scripts/intranet.py start --port 9000              # Custom port
python3 {baseDir}/scripts/intranet.py start --host 0.0.0.0            # LAN access (requires token + allowed_hosts)
python3 {baseDir}/scripts/intranet.py start --token SECRET            # Enable bearer token auth
python3 {baseDir}/scripts/intranet.py status                         # Check if running
python3 {baseDir}/scripts/intranet.py stop                           # Stop server

### Directory Layout

{workspace}/intranet/
├── config.json          # Server config (NOT served)
└── www/                 # Webroot (served files go here)
    ├── index.html
    └── ...

Config lives in {workspace}/intranet/config.json, webroot is {workspace}/intranet/www/. The config file is never exposed to HTTP.

### Plugins

Plugins mount external directories at URL prefixes. Configure in config.json:

{
  "plugins": {
    "banker": "{workspace}/skills/banker/web",
    "deliveries": "{workspace}/skills/deliveries/web"
  }
}

Plugin config supports simple (static only) or extended (with CGI hash) format:

{
  "plugins": {
    "static-only": "/path/to/dir",
    "with-cgi": {
      "dir": "/path/to/dir",
      "hash": "sha256:abc123..."
    }
  }
}

Plugin paths must be inside the workspace
If CGI is enabled and a plugin has a hash, index.py at the plugin root handles all sub-paths — but only if its SHA-256 matches
Plugins without a hash are static-only (CGI blocked even when globally enabled)
Generate a hash: shasum -a 256 /path/to/index.py

### CGI Execution

Off by default. Enable in config.json:

{
  "cgi": true
}

When enabled, only files named index.py can execute as CGI:

Webroot: index.py in any subdirectory handles that directory's requests
Plugins: index.py at the plugin root handles all plugin sub-paths
All other .py files → 403 Forbidden (never served, never executed)
Scripts must have the executable bit set (chmod +x)

### Security

Webroot isolation — config.json is outside the webroot (www/), never served
CGI off by default — must be explicitly enabled via "cgi": true in config.json
Path containment — all resolved paths must stay within their base directory. Symlinks are followed but the resolved target is checked for containment.
Plugin allowlist — only directories explicitly registered in config.json are served; must be inside workspace
CGI restricted to index.py — no arbitrary script execution; plugin CGI requires SHA-256 hash in config.json. Webroot CGI does not require a hash (webroot files are under your direct control)
All .py files blocked except index.py entry points (not served as text, not executed)
Host allowlist — optional allowed_hosts restricts which Host headers are accepted
Token auth — optional bearer token via --token flag or config.json. Browser clients visit ?token=SECRET once → session cookie set → all subsequent navigation works. API clients use Authorization: Bearer <token> header.
Path traversal protection — all paths resolved and validated before serving
Default bind: 127.0.0.1 (loopback only). LAN access via --host 0.0.0.0 requires both token auth and allowed_hosts in config.json.

### Workspace Detection

The server auto-detects the workspace by walking up from $PWD (or the script location) looking for a skills/ directory. The detected path is printed on startup so you can verify it.

To skip autodiscovery, set INTRANET_WORKSPACE to the workspace root:

INTRANET_WORKSPACE=/path/to/workspace python3 scripts/intranet.py start

### Notes

All state files are inside the workspace:

Config: {workspace}/intranet/config.json
PID: {workspace}/intranet/.pid
Runtime: {workspace}/intranet/.conf
Webroot: {workspace}/intranet/www/


No files are written outside the workspace
30-second timeout on CGI execution (when enabled)
## Trust
- Source: tencent
- Verification: Indexed source record
- Publisher: odrobnik
- Version: 3.2.7
## Source health
- Status: healthy
- Item download looks usable.
- Yavira can redirect you to the upstream package for this item.
- Health scope: item
- Reason: direct_download_ok
- Checked at: 2026-04-30T07:36:27.798Z
- Expires at: 2026-05-07T07:36:27.798Z
- Recommended action: Download for OpenClaw
## Links
- [Detail page](https://openagent3.xyz/skills/intranet)
- [Send to Agent page](https://openagent3.xyz/skills/intranet/agent)
- [JSON manifest](https://openagent3.xyz/skills/intranet/agent.json)
- [Markdown brief](https://openagent3.xyz/skills/intranet/agent.md)
- [Download page](https://openagent3.xyz/downloads/intranet)