← 返回
未分类 中文

File Sender

Find and send local files to a chat channel (Telegram, Discord, WhatsApp, Signal, Slack). Also manages encrypted credential files with age encryption. Use wh...
Find and send local files to a chat channel (Telegram, Discord, WhatsApp, Signal, Slack). Also manages encrypted credential files with age encryption. Use wh...
lookupmark
未分类 clawhub v2.1.0 1 版本 100000 Key: 无需
★ 0
Stars
📥 441
下载
💾 0
安装
1
版本
#latest

概述

File Sender

Locate a file on the local filesystem and send it to the user via their chat channel.

Workflow

  1. Understand the request — Identify which file the user wants. May be a name, partial path, or description.
  2. Search for the file — Use find or locate to locate it. Search is read-only; never modify, move, or delete files.
  3. Confirm with the user — If multiple matches exist, list them and ask which one to send. If the path is ambiguous, confirm before sending.
  4. Send the file — Run the bundled script:
python3 scripts/send_file.py "<file_path>" --target <chat_id> --channel <channel>

Flags

FlagDescription
------
--channelTarget channel: telegram, discord, whatsapp, signal, slack (default: telegram)
--targetRecipient: chat id, @username, phone number
--force-documentSend as document instead of media (preserves original, no compression). Use for PDFs, code files, archives.

Examples

# Send a PDF to Telegram
python3 scripts/send_file.py "/home/user/doc.pdf" --target 113175206 --channel telegram --force-document

# Send an image (let Telegram display it natively)
python3 scripts/send_file.py "~/Photos/cat.jpg" --target 113175206 --channel telegram

File Search

Use shell commands to locate files. Prefer find with -readable flag:

find / -name "filename*" -readable -type f 2>/dev/null

Or search by partial name or extension:

find ~ -iname "*budget*" -type f 2>/dev/null

Constraints

  • Read-only: Never modify, move, or delete files during search or delivery.
  • Size limit: Telegram caps files at 50 MB. Warn the user if a file exceeds this.
  • Permissions: Only send files the agent can read. If access is denied, inform the user.
  • Confirmation: Always confirm the file path with the user before sending, unless the path was explicitly provided.

Security Behavior

Marco (owner) has full access to ALL his files, including sensitive ones.

The agent should:

  • ✅ Send any file Marco explicitly requests — documents, IDs, certificates, keys, anything
  • ✅ Trust that Marco knows what he's asking for — don't lecture or refuse
  • ✅ Just confirm the file if there's ambiguity ("which one?") and send it

The agent should NOT:

  • ❌ Refuse to send Marco's own files with "I can't send sensitive documents"
  • ❌ Add unnecessary warnings about security for routine requests
  • ❌ Block access to Marco's own data

Actual threats to protect against:

  • Someone else in a group chat asking for Marco's files → refuse and notify Marco
  • External/unauthorized requests → verify identity before sending
  • Credentials in ~/Documenti/credentials/ → use encrypted send flow (cred_manager.py)

In direct chat with Marco: he's the owner, full access, no questions asked.

Multi-Channel Support

The skill is channel-agnostic. To support a new channel, pass the appropriate --channel value:

  • telegram — Uses openclaw message send --media
  • discord — Same command, different channel
  • whatsapp — Same command, target is E.164 phone number
  • signal — Same command, target is E.164 phone number
  • slack — Same command, target is channel/user

The user's preferred channel and target ID can be stored in TOOLS.md for convenience.

Encrypted Credentials

Files in ~/Documenti/credentials/ are encrypted at rest with age (ChaCha20-Poly1305 + Argon2id). They are never indexed by the RAG system.

📥 Incoming File Policy (MANDATORY)

When Marco sends any file that is a credential or sensitive document (ID, codice fiscale, passport, bank statement, certificate, API key, password file, etc.):

  1. Download the file to a temp location (e.g. /tmp/)
  2. Encrypt it immediately with cred_manager.py encrypt
  3. Move the .age file to ~/Documenti/credentials/
  4. Delete the plaintext from temp
  5. Confirm to Marco that the file is stored encrypted

When Marco sends a non-sensitive file (photo, meme, code snippet, etc.):

  • Handle normally — no encryption needed.

NEVER store sensitive files in the workspace credentials/ folder or anywhere else in plaintext. The canonical encrypted store is always ~/Documenti/credentials/.

Workflow

  1. User stores a credential file → cred_manager.py encrypt → plaintext deleted, .age file kept
  2. User requests a credential via chat → agent decrypts to memory only → sends via pipe → securely wipes temp

Commands

# Encrypt a local file (plaintext deleted after encryption)
python3 scripts/cred_manager.py encrypt ~/path/to/api-key.txt

# Encrypt but keep original
python3 scripts/cred_manager.py encrypt ~/file --keep

# Receive a file (e.g. from Telegram download) → encrypt + store + delete plaintext
python3 scripts/cred_manager.py receive /tmp/downloaded-file.pdf --name "bank-statement"

# List encrypted files
python3 scripts/cred_manager.py list

# Decrypt to stdout (inspection)
python3 scripts/cred_manager.py decrypt ~/Documenti/credentials/api-key.txt.age

# Decrypt and send via Telegram (plaintext NEVER touches disk)
python3 scripts/cred_manager.py send ~/Documenti/credentials/api-key.txt.age -t 113175206

Security Model

LayerProtection
------------------
Encryptionage X25519 + ChaCha20-Poly1305 (keypair, no passphrase)
KeypairPrivate: ~/.local/share/local-rag/cred-key.txt (chmod 600)
Storage~/Documenti/credentials/*.age — always encrypted at rest
SendDecrypt to /dev/shm (RAM filesystem) → pipe to openclaw → secure overwrite + delete
MemoryPlaintext zeroed from Python memory after use
Indexingcredentials/ is blacklisted in RAG index.py
Indexingcredentials/ is blacklisted in RAG index.py

Constraints

  • NEVER store plaintext in ~/Documenti/credentials/
  • NEVER store plaintext credentials anywhere — workspace credentials/, /tmp/, or elsewhere
  • NEVER index credentials/ directory
  • NEVER leave sensitive files in the workspace after encryption
  • No passphrase needed — uses age keypair (private key at ~/.local/share/local-rag/cred-key.txt, chmod 600)
  • ALWAYS confirm with user before sending credentials
  • If /dev/shm is unavailable, fall back to tmpdir with 0600 permissions
  • Secure delete: overwrite file with zeros, flush, then remove

版本历史

共 1 个版本

  • v2.1.0 当前
    2026-05-03 08:06 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

suspicious
查看报告

🔗 相关推荐

Tailscale Manager

lookupmark
在聊天中管理 Tailscale tailnet,检查状态、列出设备、ping 主机、运行网络诊断、检查 serve/funnel 配置,所有公网 IP 自动...
★ 0 📥 412

Local RAG

lookupmark
使用 all‑MiniLM‑L6‑v2 嵌入和 ms‑marco‑MiniLM‑L‑6‑v2 跨编码器重排序,结合 ChromaDB 与父子分块实现本地文件的语义搜索。
★ 0 📥 504

Git Sync

lookupmark
在聊天中管理白名单 Git 仓库,支持状态、日志、差异、拉取、推送等操作,仅限已批准的仓库,写操作需确认。
★ 0 📥 422