首页龙虾技能列表 › smart asistant mail — 技能工具

smart asistant mail — 技能工具

v1.0.0

All-in-one Gmail agent for OpenClaw. Fuses email-reader, email-organizer, email-analyzer, email-responder, email-scheduler, and email-reporter into a single...

0· 123·0 当前·0 累计
by @coorops25 (Coorops25)·MIT-0
下载技能包
License
MIT-0
最后更新
2026/3/19
安全扫描
VirusTotal
无害
查看报告
OpenClaw
安全
medium confidence
The skill's code, instructions, and requested environment variables are consistent with a Gmail-focused agent that uses the gog CLI and an Anthropic API key for IA — nothing in the bundle indicates clear misdirection or hidden exfiltration, but there are a few implementation/details you should review before enabling it.
评估建议
This skill appears to be what it says: a Gmail assistant that uses the gog CLI plus Anthropic for analysis. Before installing/enabling it, check these points: 1) Registry metadata looks malformed in the listing — confirm which env vars the registry actually requires (so you don't accidentally provide extra secrets). 2) The skill requires an ANTHROPIC_API_KEY (sensitive); prefer a limited key or billing limits, and understand that the skill will call that provider for drafts/analysis. 3) The boot...
详细分析 ▾
用途与能力
Name/description (Gmail agent) align with the declared binaries (gog) and the declared IA usage (Anthropic). Requested env vars in the SKILL.md (GOG_ACCOUNT, ANTHROPIC_API_KEY, EMAIL_BUDGET_USD) are reasonable for an email agent. Registry metadata display appears corrupted (shows '[object Object]' for required env vars and 'Primary credential: none') — likely a metadata formatting bug but worth verifying in the registry UI.
指令范围
SKILL.md instructs the agent to run gog CLI queries and to use Anthropic for analysis/drafts; that is within scope. It also defines a heartbeat/check pattern and advises lazy-loading/merge of multiple email skills. The included scripts and hook read local workspace files (budget_tracker.json and .learnings) and inject summary text into the agent bootstrap context — this exposes local state to the agent at session start and should be considered when thinking about sensitive local content. There are no instructions to transmit local files to arbitrary external endpoints beyond the expected services (gog and Anthropic).
安装机制
No install spec (instruction-only plus small helper scripts), so nothing is downloaded or extracted during install. The only external dependency is the gog CLI (user-supplied) and standard Node/Python runtime for the hook and script — low install risk.
凭证需求
Environment variables requested by the skill (GOG_ACCOUNT, ANTHROPIC_API_KEY, EMAIL_BUDGET_USD; optional GMAIL_CREDENTIALS_PATH, NOTIFY_CHANNEL, SAFE_BROWSING_API_KEY) are plausible for the stated features. ANTHROPIC_API_KEY is sensitive (provider billing/usage) — appropriate for drafting/analysis but you may want to use a limited key or billing controls. The registry metadata rendering bug (env shown as [object Object]) is a minor inconsistency to confirm in the registry before trusting the listing.
持久化与权限
always:false (not forced). The hook (openclaw-handler.js) injects a virtual bootstrap file into every session once the hook is enabled; enabling the hook gives this skill persistent per-session presence (but it is user-enabled, not forced). Consider that enabling the hook will cause the agent to receive budget/learning summaries every bootstrap.
安全有层次,运行前请审查代码。

License

MIT-0

可自由使用、修改和再分发,无需署名。

运行时依赖

无特殊依赖

版本

latestv1.0.02026/3/19

Smart Email Agent v3 unifies all core Gmail management features into a single skill. - Combines email reading, organizing, analyzing, responding, scheduling, and reporting in one tool. - Integrates token optimization and a self-improvement engine for efficient performance. - Replaces six separate skills with a single entry point, dramatically reducing token usage. - Provides detailed instructions for setup, inbox management commands, batch actions, and automated routing. - Includes built-in error handling, confirmation for critical actions, and dynamic handling based on budget constraints.

● 无害

安装命令 点击复制

官方npx clawhub@latest install emailagy
镜像加速npx clawhub@latest install emailagy --registry https://cn.clawhub-mirror.com

技能文档

Un solo skill que reemplaza los 6 skills del pack original. Punto de entrada único para toda la gestión de correo.

Lazy loading activo: este skill se carga completo (~500 tokens).
NO cargues los 6 skills individuales — sería 4.800 tokens desperdiciados.

PARTE 1 — LEER CORREOS (email-reader)

Herramienta principal: gog CLI

# Verificar prerequisitos
which gog || echo "Instalar: npm i -g gogcli  OR  brew install gogcli"
echo $GOG_ACCOUNT  # debe estar configurado

# Autenticar si es la primera vez gog auth add $GOG_ACCOUNT

Comandos esenciales

# No leídos en inbox (acción por defecto cuando el usuario dice "revisa mi correo")
gog gmail search 'in:inbox is:unread' --max 5 --format minimal --json

# Buscar por criterio — usar sintaxis Gmail gog gmail search 'from:juan@empresa.com newer_than:3d' --max 10 --format minimal --json gog gmail search 'subject:factura has:attachment' --max 10 --format minimal --json gog gmail search 'in:spam is:unread' --max 20 --format minimal --json

# Leer correo completo gog gmail get --format full --json

# Leer hilo completo gog gmail thread --format minimal --json

Operadores de búsqueda Gmail

from: to: subject: label: is:unread is:starred has:attachment newer_than:Nd older_than:Nd in:inbox in:sent in:spam in:trash filename:ext

Flujo estándar de lectura

  • Verificar gog en PATH y GOG_ACCOUNT configurado
  • Construir query desde la intención del usuario (preguntar si es ambiguo)
  • Ejecutar con --format minimal --json --max N
  • Parsear JSON → presentar lista formateada:
📬 5 correos no leídos:
  • De: Juan García | Asunto: Propuesta Q2 | Hace 2h
Vista previa: Hola, te mando el resumen de... | ID: msg_abc123
  • Ofrecer: leer completo / buscar más / actuar sobre el mensaje

Reglas de lectura

  • SIEMPRE usar --format minimal --json --max N (N=5 por defecto)
  • Nunca mostrar JSON crudo; nunca leer contenido completo sin pedirlo
  • Preservar IDs para acciones de seguimiento
  • Sin resultados → confirmar criterios, sugerir términos más amplios
  • Solo lectura — enviar/responder requiere la sección RESPONDER (Parte 4)
  • No guardar contenido de correos en MEMORY.md salvo que el usuario lo pida

Errores comunes

ErrorCausaSolución
gog: command not foundgog no instaladonpm i -g gogcli o brew install gogcli
GOG_ACCOUNT not setVariable no configuradaPedir al usuario su email Gmail
Token expiradoOAuth vencidogog auth add
API error 429Rate limitEsperar 60s, reintentar con backoff

PARTE 2 — ORGANIZAR (email-organizer)

Jerarquía corporativa Corp/ (azul)

Corp/
├── Interno/
│   ├── Management      ← Gerencia, Directores
│   ├── Tech & Ops      ← Desarrollo, Soporte, Operaciones
│   ├── Commercial      ← Ventas, Marketing
│   ├── Admin & HR      ← Jurídica, RRHH, Contabilidad
│   └── Team            ← Resto del equipo @empresa.com
├── Partners & Clientes/
│   └── [empresa]       ← Wolkvox, Masiv, Unisanitas, Nuva, etc.
├── Proveedores/
│   └── [proveedor]     ← Google, Microsoft, AWS, etc.
└── Sistema/
    ├── DMARC
    ├── Notificaciones
    ├── Alertas
    └── No-Reply

Comandos de organización con gog

# Crear etiqueta
gog gmail label create "Corp/Interno/Tech & Ops"

# Aplicar etiqueta a mensaje gog gmail label apply "Corp/Interno/Management"

# Mover correo (quitar INBOX + aplicar etiqueta) gog gmail modify --add-label "Corp/Partners & Clientes/Wolkvox" --remove-label INBOX

# Archivar (quitar INBOX sin borrar) gog gmail modify --remove-label INBOX

# Mover a spam gog gmail modify --add-label SPAM --remove-label INBOX

# Mover a papelera gog gmail trash

# Operación batch (múltiples IDs) gog gmail batch-modify --ids id1,id2,id3 --add-label "Corp/Sistema/No-Reply" --remove-label INBOX

Reglas de routing automático

Antes de llamar a la IA, aplicar estas reglas sin costo:

from_domain @empresa.com + from_name contiene [Linda, Rafael, Director] → Corp/Interno/Management
from_domain @empresa.com + from_name contiene [Tech, Dev, Soporte]      → Corp/Interno/Tech & Ops
from_domain @empresa.com                                                  → Corp/Interno/Team
from contiene noreply / no-reply / donotreply                            → Corp/Sistema/No-Reply
subject contiene DMARC / SPF / DKIM                                      → Corp/Sistema/DMARC
subject contiene alerta / alert / warning                                → Corp/Sistema/Alertas

Guardar y mantener estas reglas en corp_routing_rules.json.

Protocolo de confirmación

NUNCA ejecutar acciones destructivas sin confirmación explícita:

⚠️ Pendiente de confirmación:
   → Mover 22 correos a Corp/Sistema/No-Reply
   → Eliminar etiqueta "noreply" (ya vacía)
   Esto NO borra correos, solo reorganiza etiquetas.
   ¿Confirmas? (sí/no)

PARTE 3 — ANALIZAR Y CLASIFICAR (email-analyzer)

Decisión de modelo ANTES de analizar

¿Tarea es clasificar / detectar spam / routing?
  → claude-haiku-4-5-20251001   (batch de 10-20 correos, ~$0.00009/correo)

¿Tarea es extraer tareas y fechas de correos importantes? → claude-haiku-4-5-20251001 (body[:800], ~$0.00015/correo)

¿El presupuesto está > 80% gastado? → forzar haiku para TODO, sin borradores automáticos

¿El presupuesto está > 95% gastado? → cero llamadas IA, solo reglas locales

Opus: PROHIBIDO para tareas de email. Sonnet: solo para borradores (ver Parte 4).

Pipeline de reducción de tokens (aplicar siempre)

# 1. Pre-filtro sin IA (resolver antes de gastar tokens)
#    - Dominio en corp_routing_rules.json → etiquetar directo
#    - from en known_spam_domains.txt → spam directo
#    - message_id ya en analysis_cache → reutilizar resultado
#    Objetivo: resolver 60-70% a costo $0.00

# 2. Recortar campos al mínimo necesario CAMPOS = { 'clasificacion': ['from', 'subject', 'snippet[:100]'], # ~30 tokens 'prioridad': ['from', 'subject', 'body[:400]'], # ~150 tokens 'tareas_fechas': ['from', 'subject', 'body[:800]'], # ~250 tokens }

# 3. Limpiar texto def limpiar(texto, limite): texto = re.sub(r'<[^>]+>', '', texto) # quitar HTML texto = re.sub(r'https?://\S+', '[URL]', texto) # comprimir URLs texto = re.sub(r'\s+', ' ', texto).strip() return texto[:limite]

# 4. Batch: NUNCA menos de 10 correos por llamada # Esperar hasta tener 10-20 correos pendientes BATCH_MIN = 10 BATCH_MAX = 20

Prompt de análisis en batch (Haiku)

SYSTEM (idéntico siempre — para prompt caching):
Eres un clasificador de correos corporativos.
Analiza cada correo y devuelve SOLO JSON array. Sin texto extra.
Para cada ítem: {"idx":N,"corp_label":"...","categoria":"spam|importante|informativo|sistema|otro",
"prioridad":0-10,"es_spam":bool,"necesita_respuesta":bool,
"tiene_phishing":bool,"tareas":[],"fecha_limite":"ISO o null","razon":"máx 10 palabras"}

USER: Analiza: [JSON array de hasta 20 correos con from+subject+snippet[:100]]

Presentación de resultados

🤖 Análisis — 47 correos procesados
⚡ Sin IA (pre-filtro): 31  (66%) → $0.000
🧠 Con Haiku (2 batches): 16     → $0.006

📊 Resultado: 🔵 Corp/Interno/Management: 2 (prioridad alta) 🔵 Corp/Partners & Clientes: 8 🔵 Corp/Sistema/No-Reply: 14 🗑️ Spam: 12 ⚠️ Phishing detectado: 1 → ALERTA 📋 Con tareas pendientes: 4

Críticos: [10/10] linda@empresa.com — "Aprobación contrato urgente" Tarea: confirmar antes del viernes


PARTE 4 — RESPONDER Y REDACTAR (email-responder)

Cuándo usar Sonnet vs Haiku para borradores

Prioridad >= 8 → claude-sonnet-4-6       (calidad importa)
Prioridad 5-7  → claude-haiku-4-5-20251001  (suficiente, más barato)
Prioridad < 5  → NO generar borrador automático

Máximo 3 borradores por sesión cuando presupuesto < 60%. Máximo 1 borrador por sesión cuando presupuesto 60-80%. Cero borradores automáticos cuando presupuesto > 80%.

Flujo de respuesta

# 1. Leer el hilo completo
gog gmail thread  --format minimal --json

# 2. Preparar contexto recortado para la IA # Solo: from + subject + body[:600] del último mensaje + resumen del hilo anterior

Prompt de generación de borrador

Redacta una respuesta profesional y concisa (máx 150 palabras).
Solo el cuerpo del mensaje, sin asunto ni encabezados.
Tono: profesional pero cercano.
Firma: [NOMBRE_USUARIO]

Hilo: [RESUMEN + ÚLTIMO MENSAJE RECORTADO]

Presentar borrador al usuario

✍️ Borrador para: juan@empresa.com
   Re: Propuesta Q2 2026
────────────────────────
Hola Juan,

Gracias por el resumen. Me parece viable la dirección propuesta. ¿Podemos agendar una llamada esta semana?

Saludos, [Tu nombre] ──────────────────────── [1] Guardar borrador [2] Editar [3] Enviar ahora [4] Descartar

Enviar con gog

# Guardar como borrador
gog gmail draft create --to "juan@empresa.com" \
  --subject "Re: Propuesta Q2 2026" \
  --body "Hola Juan,..." \
  --reply-to 

# Enviar borrador guardado gog gmail draft send

# Enviar directamente (SIEMPRE pedir confirmación antes) gog gmail send --to "juan@empresa.com" --subject "..." --body "..."

Templates de respuesta rápida

acuse_recibo:      "Recibido, te respondo a la brevedad."
confirmar_reunion: "Confirmado para [fecha/hora]. Hasta entonces."
solicitar_info:    "Necesito más información sobre X para proceder."
ausencia:          "Estoy fuera hasta [fecha]. Respondo a mi regreso."

Follow-ups automáticos

# Buscar correos enviados sin respuesta en últimos 5 días
gog gmail search 'in:sent newer_than:5d' --max 20 --format minimal --json
# Cruzar con INBOX para detectar cuáles no tienen respuesta

PARTE 5 — AUTOMATIZAR (email-scheduler)

Heartbeat optimizado: 55 minutos

Por qué 55 min: el caché de Anthropic expira a los 60 minutos. Con heartbeat de 55 min, el agente mantiene el caché caliente → cada mensaje paga cache-read en lugar de cache-write (3.75x más barato).

// ~/.openclaw/openclaw.json
{
  "agents": {
    "email-assistant": {
      "heartbeat": { "every": "55m" },
      "model": "anthropic/claude-haiku-4-5-20251001"
    }
  }
}

Cron jobs recomendados

{
  "cron": {
    "jobs": [
      {
        "id": "email-priority-check",
        "schedule": "/55    ",
        "description": "Revisar correos importantes — modelo Haiku",
        "message": "Revisa inbox no leídos. Si hay prioridad >= 8, notifícame.",
        "model": "anthropic/claude-haiku-4-5-20251001",
        "enabled": true
      },
      {
        "id": "email-spam-cleanup",
        "schedule": "0 8   ",
        "description": "Limpieza diaria de spam — solo reglas locales, costo $0",
        "message": "Aplica reglas locales de spam. Sin llamadas IA.",
        "model": "anthropic/claude-haiku-4-5-20251001",
        "enabled": true
      },
      {
        "id": "email-weekly-report",
        "schedule": "0 9   MON",
        "description": "Informe semanal",
        "message": "Genera informe semanal de correos con email-reporter.",
        "model": "anthropic/claude-haiku-4-5-20251001",
        "enabled": true
      }
    ]
  }
}

Regla de oro para crons: SIEMPRE especificar claude-haiku-4-5-20251001. Usar Opus para un cron de 10 tareas/día = $17.70/mes extra innecesario.

HEARTBEAT.md de correo

## Email Heartbeat — Modelo: claude-haiku-4-5-20251001

Check de correos (cada 55 min)

  • gog gmail search 'in:inbox is:unread' --max 10 --format minimal --json
  • Aplicar reglas locales de corp_routing_rules.json
  • Si hay correo con keywords urgente/crítico/emergencia → notificar
  • Si no hay urgentes → HEARTBEAT_OK (silencio)

Check de spam (cada 2h, sin IA)

  • gog gmail search 'in:spam is:unread' --max 50 --format minimal --json
  • Aplicar known_spam_domains.txt → mover a trash directo
  • Sin llamadas a IA

Quiet hours: 23:00–07:00 → HEARTBEAT_OK automático

Gmail Push Notifications (tiempo real)

# Configurar webhook Pub/Sub
python3 scripts/setup_pubsub.py --topic "email-agent-notifications"

# El webhook dispara cuando llega un correo nuevo: openclaw message "Nuevo correo. Revisa con gog y notifícame si es importante."

Activar automatización completa

Usuario: "Activa el agente de correo en modo automático"
Agente:
  1. Verificar: gog auth status
  2. Crear cron jobs recomendados (ver arriba)
  3. Copiar HEARTBEAT.md al workspace
  4. Preguntar: ¿activar Gmail Push para tiempo real?
  5. Confirmar canal de notificaciones (NOTIFY_CHANNEL)
  6. "✅ Agente activado. Reviso cada 55 min. Te aviso si hay algo importante."

PARTE 6 — INFORMES Y ESTADÍSTICAS (email-reporter)

Tipos de informe

# Resumen del día (al final de sesión — SIEMPRE mostrar)
# Ver sección "Resumen de costos" más abajo

# Estadísticas de spam gog gmail search 'in:trash newer_than:30d' --max 100 --format minimal --json # Parsear y agrupar por dominio remitente

# Tareas pendientes en correos # Consultar analysis_cache donde tareas[] no está vacío y sin respuesta

# Log de prompts IA detectados cat .learnings/PROMPTS_DETECTADOS.md

# Historial de acciones del agente cat email_audit.log | tail -50

# Deshacer última acción gog gmail modify --remove-label TRASH --add-label INBOX

Resumen de costos — mostrar al cerrar cada sesión

💰 Sesión de hoy
  Correos procesados:    47
  ├─ Sin IA (reglas):    31  (66%) → $0.000
  ├─ Haiku (2 batches):  14       → $0.005
  └─ Sonnet (borradores): 2       → $0.005

Tokens consumidos: 5.090 Costo sesión: $0.010 Ahorro estimado: $0.040 (80% vs. sin optimizar)

Presupuesto mes: $X.XX gastado / $Y.YY total (N%) Proyección mes: $Z.ZZ


PARTE 7 — MOTOR DE AUTO-MEJORA

Cuándo capturar un aprendizaje

EventoArchivoID
Usuario corrige clasificación.learnings/LEARNINGS.mdLRN-YYYYMMDD-NNN
Costo sesión > 2x el promedio.learnings/LEARNINGS.mdLRN-YYYYMMDD-NNN
Error de API (rate limit, auth).learnings/ERRORS.mdERR-YYYYMMDD-XXX
Optimización reduce costos >10%.learnings/LEARNINGS.mdLRN-YYYYMMDD-NNN
Remitente recurrente sin regla.learnings/LEARNINGS.mdLRN-YYYYMMDD-NNN

Formato

## [LRN-YYYYMMDD-NNN] 
Logged: ISO timestamp
Priority: low | medium | high
Status: pending | applied | promoted
Area: cost | classification | routing | api | spam | drafts

Summary

Una línea con el aprendizaje y su impacto.

Details

Qué pasó. Qué se asumía vs. qué era verdad.

Action

Cambio concreto: qué archivo editar, qué valor cambiar.

Impact

Ahorro estimado: $X/mes | Tokens -N%

Ciclo al cerrar sesión

1. Revisar .learnings/ con Status=pending
  • ¿Learnings con Impact > $0.01/mes?
→ Proponer: "Aprendí que X. ¿Lo aplico a las reglas?" → Si acepta → editar corp_routing_rules.json → Status=applied
  • ¿3+ learnings del mismo dominio/patrón?
→ Promover a regla permanente sin preguntar → Status=promoted
  • Reportar: "Apliqué N mejoras. Ahorro estimado: $X/mes"

Efecto compuesto del aprendizaje

Mes 1: ~$0.50/mes  (0 reglas)
Mes 2: ~$0.30/mes  (10 reglas aprendidas)
Mes 3: ~$0.18/mes  (25 reglas)
Mes 6: ~$0.10/mes  (60+ reglas)

PARTE 8 — CONTROL DE PRESUPUESTO

Cuatro modos operativos

% gastadoModoRestricciones
0–59%Normal ✅Todo habilitado
60–79%Ahorro leve 🟡Avisar. Máx 2 borradores/sesión
80–94%Ahorro fuerte 🟠Solo Haiku. Sin borradores auto. Batch obligatorio ≥20
95–100%Emergencia 🔴Cero IA. Solo gog + reglas locales

Diagnósticos con token-optimizer (si está instalado)

/context list    # qué archivos consumen tokens ahora
/usage full      # tokens + costo por respuesta
/usage cost      # resumen acumulado de sesión
/status          # modelo activo, % contexto

python3 scripts/token_tracker.py check # estado del budget diario python3 scripts/model_router.py "analizar correos nuevos" # qué modelo usar


Referencias — leer cuando necesites más detalle

  • references/cost-optimization.md — Técnicas avanzadas: prompt caching, deduplicación semántica, modo emergencia
  • references/learning-patterns.md — Patrones de auto-mejora y ciclo de vida de learnings
  • hooks/openclaw-handler.js — Inyecta estado de presupuesto + modo activo al inicio de sesión
  • scripts/init_orchestrator.py — Setup inicial: verifica gog, crea budget_tracker, SKILLS_INDEX
  • assets/HEARTBEAT.email.md — Plantilla lista para copiar al workspace
数据来源:ClawHub ↗ · 中文优化:龙虾技能库
OpenClaw 技能定制 / 插件定制 / 私有工作流定制

免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制

了解定制服务