Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Crawler Summary
Etalon memory architecture with Knowledge Graph (PARA), session isolation, memory decay, and QMD hybrid search --- name: engram description: Etalon memory architecture with Knowledge Graph (PARA), session isolation, memory decay, and QMD hybrid search --- ⚠️ **READ-ONLY SKILL**: This skill is a reference implementation. Do not edit files directly. When installing, copy scripts to your workspace folder: Templates and assets remain in the skill folder. Specify the path via env: Without ENGRAM_SKILL_DIR, scripts look for assets Published capability contract available. No trust telemetry is available yet. Last updated 2/24/2026.
Freshness
Last checked 2/23/2026
Best For
Contract is available with explicit auth and schema references.
Not Ideal For
engram is not ideal for teams that need stronger public trust telemetry, lower setup complexity, or more explicit contract coverage before production rollout.
Evidence Sources Checked
editorial-content, capability-contract, runtime-metrics, public facts pack
Etalon memory architecture with Knowledge Graph (PARA), session isolation, memory decay, and QMD hybrid search --- name: engram description: Etalon memory architecture with Knowledge Graph (PARA), session isolation, memory decay, and QMD hybrid search --- ⚠️ **READ-ONLY SKILL**: This skill is a reference implementation. Do not edit files directly. When installing, copy scripts to your workspace folder: Templates and assets remain in the skill folder. Specify the path via env: Without ENGRAM_SKILL_DIR, scripts look for assets
Public facts
6
Change events
1
Artifacts
0
Freshness
Feb 23, 2026
Published capability contract available. No trust telemetry is available yet. Last updated 2/24/2026.
Trust score
Unknown
Compatibility
OpenClaw
Freshness
Feb 23, 2026
Vendor
Qwexs
Artifacts
0
Benchmarks
0
Last release
Unpublished
Key links, install path, and a quick operational read before the deeper crawl record.
Summary
Published capability contract available. No trust telemetry is available yet. Last updated 2/24/2026.
Setup snapshot
git clone https://github.com/qwexs/engram.gitSetup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.
Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.
Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.
Vendor
Qwexs
Protocol compatibility
OpenClaw
Auth modes
api_key
Machine-readable schemas
OpenAPI or schema references published
Handshake status
UNKNOWN
Crawlable docs
6 indexed pages on the official domain
Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.
Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.
Extracted files
0
Examples
6
Snippets
0
Languages
typescript
Parameters
bash
> # Scripts → workspace scripts/ > cp skills/engram/scripts/*.js scripts/ >
bash
> export ENGRAM_SKILL_DIR=skills/engram # or absolute path > bun scripts/init.js >
bash
# 1. Install QMD (if not installed) bun skills/engram/scripts/install-qmd.js # 2. Initialize everything bun skills/engram/scripts/init.js # Add a group session bun skills/engram/scripts/add-session.js --platform telegram --id 3382546134 # Validate integrity bun skills/engram/scripts/validate.js # Migrate to v2 schema bun skills/engram/scripts/migrate-v2.js --dry-run
text
┌─────────────────────────────────────────────┐ ║ Layer 3: MEMORY.md (Curated Wisdom) ║ ║ Long-term personal insights, decisions ║ ├─────────────────────────────────────────────┤ ║ Layer 2: Knowledge Graph (life/) ║ ║ PARA entities with atomic facts ║ ├─────────────────────────────────────────────┤ ║ Layer 1: Daily Notes (memory/) ║ ║ Raw session notes, per-session isolation ║ └─────────────────────────────────────────────┘
text
life/ ├── projects/<name>/ # Active work (summary.md + items.json) ├── areas/people/<name>/ # People (summary.md + items.json) ├── areas/groups/<name>/ # Groups ├── resources/<topic>/ # Reference material ├── archives/ # Inactive entities └── index.md # Master entity index
bash
# Hybrid search (BM25 + vectors + rerank) qmd query "search text" -c <collection> # Multi-collection search (searches across multiple collections) qmd query "search text" -c life -c openclaw-memory-agent-main-main # BM25-only search (no GPU required, faster) qmd search "search text" -c <collection> # Update index after changes qmd update # BM25 (instant) qmd embed # Vectors (heartbeat only)
Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB OPENCLEW
Editorial quality
ready
Etalon memory architecture with Knowledge Graph (PARA), session isolation, memory decay, and QMD hybrid search --- name: engram description: Etalon memory architecture with Knowledge Graph (PARA), session isolation, memory decay, and QMD hybrid search --- ⚠️ **READ-ONLY SKILL**: This skill is a reference implementation. Do not edit files directly. When installing, copy scripts to your workspace folder: Templates and assets remain in the skill folder. Specify the path via env: Without ENGRAM_SKILL_DIR, scripts look for assets
⚠️ READ-ONLY SKILL: This skill is a reference implementation. Do not edit files directly. When installing, copy scripts to your workspace folder:
# Scripts → workspace scripts/ cp skills/engram/scripts/*.js scripts/Templates and assets remain in the skill folder. Specify the path via env:
export ENGRAM_SKILL_DIR=skills/engram # or absolute path bun scripts/init.jsWithout
ENGRAM_SKILL_DIR, scripts look for assets relative to../from their location.
Three-layer memory architecture for OpenClaw agents: curated long-term memory (MEMORY.md), structured knowledge graph (life/), and session-isolated daily notes (memory/).
# 1. Install QMD (if not installed)
bun skills/engram/scripts/install-qmd.js
# 2. Initialize everything
bun skills/engram/scripts/init.js
# Add a group session
bun skills/engram/scripts/add-session.js --platform telegram --id 3382546134
# Validate integrity
bun skills/engram/scripts/validate.js
# Migrate to v2 schema
bun skills/engram/scripts/migrate-v2.js --dry-run
┌─────────────────────────────────────────────┐
║ Layer 3: MEMORY.md (Curated Wisdom) ║
║ Long-term personal insights, decisions ║
├─────────────────────────────────────────────┤
║ Layer 2: Knowledge Graph (life/) ║
║ PARA entities with atomic facts ║
├─────────────────────────────────────────────┤
║ Layer 1: Daily Notes (memory/) ║
║ Raw session notes, per-session isolation ║
└─────────────────────────────────────────────┘
Data flows upward: Daily notes → extracted to Knowledge Graph → distilled to MEMORY.md
For full architecture details, see references/architecture.md.
Golden Rule: Memory is isolated by session.
| Session Type | Memory Path | QMD Collection | Access |
|-------------|-------------|----------------|--------|
| Main (personal) | memory/agent-{id}/main/ | openclaw-memory-agent-{id}-main | Full: MEMORY.md + life/ |
| Telegram group | memory/agent-{id}/telegram-{gid}/ | openclaw-memory-agent-{id}-telegram-{gid} | Own daily notes ONLY |
| Discord channel | memory/agent-{id}/discord-{cid}/ | openclaw-memory-agent-{id}-discord-{cid} | Own daily notes ONLY |
Rules:
-c <collection> in QMD queriesFirst, detect init mode based on the incoming message:
Heartbeats need speed, not full context. SOUL.md and USER.md are typically already in project context (OpenClaw loads them automatically).
memory/heartbeat-state.jsonSkipped: SOUL.md, USER.md, yesterday's daily note, MEMORY.md, life/index.md, QMD query — none needed for heartbeat flow.
memory/agent-{id}/{session}/YYYY-MM-DD.mdMEMORY.md + life/index.mdqmd query "topic" -c <collection> for deeper contextmemory/agent-{id}/{session}/YYYY-MM-DD.md# YYYY-MM-DDarchives/YYYY-MM/ (nothing lost)qmd queryStructured memory in life/ using Projects/Areas/Resources/Archives:
life/
├── projects/<name>/ # Active work (summary.md + items.json)
├── areas/people/<name>/ # People (summary.md + items.json)
├── areas/groups/<name>/ # Groups
├── resources/<topic>/ # Reference material
├── archives/ # Inactive entities
└── index.md # Master entity index
Tiered retrieval:
qmd query "topic" -c life — search firstsummary.md — quick context (~90% sufficient)items.json — only for granular detailEntity creation rules:
For the atomic fact schema (v2), see references/fact-schema.md.
| Type | Destination | |------|-------------| | Operational lesson | TOOLS.md or AGENTS.md | | Personal insight | MEMORY.md (main session only) | | Event/fact | Today's daily note | | Durable knowledge | Knowledge Graph (life/) |
When someone says "remember this":
qmd update# Hybrid search (BM25 + vectors + rerank)
qmd query "search text" -c <collection>
# Multi-collection search (searches across multiple collections)
qmd query "search text" -c life -c openclaw-memory-agent-main-main
# BM25-only search (no GPU required, faster)
qmd search "search text" -c <collection>
# Update index after changes
qmd update # BM25 (instant)
qmd embed # Vectors (heartbeat only)
Strategy:
-c flag for session isolation-c col1 -c col2) for cross-cutting searches (e.g., KG + daily notes)qmd search (BM25-only) when GPU is busy or unavailableqmd update after writing memoryqmd embed manually (heartbeat handles it)For QMD installation and configuration, see references/qmd-setup.md.
Add to your HEARTBEAT.md:
## Heartbeat Flow (every 30 minutes)
0. Create today's daily note + Three-Layer Rotation check
1. Monday? → Weekly Synthesis
2. Knowledge Graph Extraction (if notes changed)
3. Memory Maintenance (every few days)
3.5. Domain Supervisor Scan (if domains exist)
4. QMD Index Update (qmd update + qmd embed)
Rewrites summary.md with memory decay applied:
Modifiers:
confidence < 0.5 → Cold threshold is 14 daysaccessCount >= 10 → bumps Cold to Warmprinciple (L3) → always in summarypattern (L2) → in summary if Warm+For full decay rules, see references/decay-rules.md.
During heartbeats, scan daily notes for durable facts:
<!-- extracted:L{N}:{timestamp} --> at the end of each daily note. If found, only parse lines after the last watermark. No watermark = parse entire file (backward compatible).items.json with confidence and abstraction levelsummary.md for new Hot facts<!-- extracted:L{lastLine}:{ISO timestamp} -->For the complete heartbeat flow, see references/heartbeat.md.
If subagent domains exist (memory/domains/), heartbeat acts as supervisor:
qmd query "PROPOSAL" -c domains → auto-approve low-risk, alert user for high-riskstatus.md, alert if missed >2x schedulechangelog.md >1000 lines to archives/For full details, see references/heartbeat.md and references/subagent-memory.md.
Facts decay based on recency, with modifiers for confidence, frequency, and abstraction:
| Tier | Recency | In summary? | |------|---------|-------------| | Hot | ≤7 days | ✅ Prominent | | Warm | 8-30 days | ✅ Lower priority | | Cold | 30+ days | ❌ (searchable via QMD) |
Full rules: references/decay-rules.md
Each fact in items.json includes:
{
"id": "<entity>-NNN",
"fact": "Human-readable statement",
"category": "relationship|milestone|status|preference|context",
"confidence": 0.85,
"abstractionLevel": "episode|pattern|principle",
"tags": ["tag1"],
"timestamp": "2026-02-08",
"source": "2026-02-07",
"status": "active|superseded",
"supersededBy": null,
"relatedEntities": ["people/sergey"],
"lastAccessed": "2026-02-08",
"accessCount": 1
}
No-Deletion Rule: Facts are NEVER deleted. Set status: "superseded" and link via supersededBy.
Write Pipeline Rule: NEVER write items.json directly. Always use bun scripts/memory-write.js. Direct writes bypass dedup, validation, and hash registration, causing schema mismatches (e.g., content vs fact, created vs timestamp). This applies to heartbeats, inline extraction, and entity creation. No exceptions.
Full schema: references/fact-schema.md
Pattern for subagents with cleanup: "delete" and long-term memory via domains.
# Create a domain
bun skills/engram/scripts/add-domain.js --domain monitoring --description "Server monitoring"
# Configure rules in decisions.md
# Launch subagent with prompt from templates/spawn-prompt.md
memory/domains/{domain}/
├── decisions.md # Rules (read-only for subagent)
├── workflow.md # HOW the domain works: scripts, scope, tools (optional)
├── status.md # Current state (written by subagent)
├── changelog.md # Append-only log (written by subagent)
├── archives/ # Changelog rotation
└── README.md
workflow.md — optional file describing the domain's infrastructure (scripts, API, task scope, wiki links). Recommended for domains with 2+ task types. Simple domains (single task) can work without it.
Separation of concerns:
decisions.md — read-only for subagents; changes via PROPOSAL in changelogdomains collection for all domainsDomains can be linked to projects in the Knowledge Graph (life/projects/). This provides a two-way binding:
life/projects/{name}/) — what the bot knows about the project (facts, summary)memory/domains/{name}/) — context for the subagent (decisions, status, changelog)The binding is defined via the domain registry (memory/domains/registry.json):
{
"domains": {
"engram": {
"type": "dev-project",
"kgEntity": "projects/engram",
"description": "Memory architecture skill",
"subagentLabel": "engram",
"spawnTemplate": "dev-project.md"
},
"monitoring": {
"type": "cron-task",
"description": "Server monitoring",
"subagentLabel": "monitoring",
"spawnTemplate": "cron-task.md"
}
}
}
Registry fields:
| Field | Required | Description |
|-------|----------|-------------|
| type | ✅ | dev-project or cron-task |
| description | ✅ | Brief description |
| spawnTemplate | ⚠️ recommended | File from templates/spawn-prompts/ |
| subagentLabel | ⚠️ recommended | Fixed label for sessions_spawn |
| kgEntity | no | Link to Knowledge Graph entity |
Domain types:
dev-project — development, linked to KG entity, subagent on demandcron-task — periodic tasks, subagent on scheduleRule: always use a template. Don't write prompts manually — use spawnTemplate from the registry. This ensures the subagent receives the Domain Lifecycle (paths to decisions, status, changelog).
Templates are in templates/spawn-prompts/:
dev-project.md — for development (decisions + status + changelog tail)cron-task.md — for periodic tasks (decisions + status)Templates use placeholders: {{domain}}, {{task}}, {{workflow}}, {{decisions}}, {{status}}, {{changelog_tail}}.
Context chain: Template → workflow.md → decisions.md → wiki (if needed) → execution.
Workflow:
registry.jsonspawnTemplatesubagentLabel and cleanup: "delete"Where to work — not specified in the domain. The bot determines the working directory from its memory and conversation context.
// 1. Find the domain
const registry = readFile("memory/domains/registry.json")
const domain = registry.domains["engram"]
// 2. Load the template
const template = readFile(`skills/engram/templates/spawn-prompts/${domain.spawnTemplate}`)
// 3. Inject context
const task = template
.replace("{{domain}}", "engram")
.replace("{{task}}", userTask)
.replace("{{workflow}}", readFile("memory/domains/engram/workflow.md") ?? "")
.replace("{{decisions}}", readFile("memory/domains/engram/decisions.md"))
.replace("{{status}}", readFile("memory/domains/engram/status.md"))
.replace("{{changelog_tail}}", last20lines("memory/domains/engram/changelog.md"))
// 4. Spawn
sessions_spawn({
label: domain.subagentLabel, // from registry
cleanup: "delete",
task: task
})
Detailed documentation: references/subagent-memory.md
Instead of waiting for heartbeats (up to 30 min), extract high-signal facts inline during conversations.
Message → Signal Scan (regex, <10ms) → Classify
├── HIGH (preference, decision, correction, milestone, instruction, identity)
│ → Dedup (SHA-256) → Contradiction check → Write to KG → QMD update
├── LOW (context, work) → Daily note → Heartbeat extracts later
└── NONE (casual) → Skip
bun scripts/memory-signal.js --text "Я предпочитаю TypeScript"
# → { "signal": "high", "categories": ["preference"], "confidence": 0.88 }
Supports Russian and English. Six categories: correction, preference, decision, identity, instruction, milestone.
bun scripts/memory-write.js \
--entity "areas/people/sergey" \
--fact "Prefers Bun over Node.js" \
--category preference \
--confidence 0.9 \
--abstraction pattern \
--tags "tools,runtime" \
--source "2026-02-16"
# With contradiction detection
bun scripts/memory-write.js --entity "..." --fact "..." --category ... \
--check-contradictions --cross-entity
# With semantic similarity check (BM25)
bun scripts/memory-write.js --entity "..." --fact "..." --category ... \
--semantic-check --search-collections "life,openclaw-memory-agent-main-main"
Automatically: content-hash dedup → optional contradiction/semantic check → write fact → validate KG → update QMD.
# Intra-entity (fast, no QMD)
bun scripts/memory-contradict.js --fact "Uses Node.js" --entity "areas/people/sergey"
# Cross-entity (via QMD BM25, searches all entities)
bun scripts/memory-contradict.js --fact "Uses Node.js" --entity "areas/people/sergey" \
--cross-entity --collections "life,openclaw-memory-agent-main-main"
memory-write.jsbun skills/engram/scripts/install-qmd.js [--variant local|jina] [--jina-key <key>]
Interactive installer for QMD. Two variants:
Handles npm install, API key configuration, .env file creation, and verification.
bun skills/engram/scripts/init.js [--agent-id main] [--qmd-variant auto|local|jina] [--force]
Creates complete directory structure, copies templates, sets up QMD collections, runs initial index. Use --force to merge with existing directories.
bun skills/engram/scripts/add-session.js --platform telegram --id <groupId> [--agent-id main]
Creates session directory, copies group-knowledge templates, adds QMD collection, updates heartbeat-state.json.
bun skills/engram/scripts/add-domain.js --domain <name> [--description "Description"]
Creates memory/domains/{domain}/ with decisions.md, status.md, changelog.md, README.md. Registers QMD collection domains (one for all domains). Warns if >20 domains.
bun skills/engram/scripts/validate.js [--fix] [--agent-id main]
Checks directory structure, required files, items.json validity, v2 schema compliance, ID uniqueness, supersededBy references. Use --fix to auto-repair.
bun skills/engram/scripts/migrate-v2.js [--dry-run]
Adds missing v2 fields (confidence, abstractionLevel, tags) to all items.json files with sensible defaults.
bun scripts/memory-signal.js --text "I prefer TypeScript"
Classifies text as high/low/none signal. Regex-based, no LLM, <10ms. Returns categories, keywords, confidence.
bun scripts/memory-write.js --entity <path> --fact <text> --category <cat> \
[--confidence 0.9] [--abstraction pattern] [--tags "a,b"] [--source "2026-02-16"] \
[--entity-create] [--check-contradictions] [--cross-entity] \
[--semantic-check] [--search-collections "life,collection2"]
Single entry point for all KG writes. Handles dedup, validation, QMD update, optional contradiction/semantic checks. Use --entity-create to create new entities on the fly.
bun scripts/memory-dedup.js --seed # Index all existing facts
bun scripts/memory-dedup.js --check --hash <sha256> # Check if exists
Manages workspace/memory-state/fact-hashes.json. Run --seed after initial setup or weekly synthesis.
bun scripts/memory-contradict.js --fact <text> --entity <path> \
[--cross-entity] [--collections "life,other"]
Finds conflicting facts via Jaccard similarity. Intra-entity by default; --cross-entity discovers related entities via QMD BM25.
Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
ready
Auth
api_key
Streaming
No
Data region
global
Protocol support
Requires: openclew, lang:typescript
Forbidden: none
Guardrails
Operational confidence: medium
curl -s "https://xpersona.co/api/v1/agents/qwexs-engram/snapshot"
curl -s "https://xpersona.co/api/v1/agents/qwexs-engram/contract"
curl -s "https://xpersona.co/api/v1/agents/qwexs-engram/trust"
Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.
Trust signals
Handshake
UNKNOWN
Confidence
unknown
Attempts 30d
unknown
Fallback rate
unknown
Runtime metrics
Observed P50
unknown
Observed P95
unknown
Rate limit
unknown
Estimated cost
unknown
Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.
Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.
Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Rank
70
AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs
Traction
No public download signal
Freshness
Updated 5d ago
Rank
70
Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!
Traction
No public download signal
Freshness
Updated 6d ago
Rank
70
The Frontend for Agents & Generative UI. React + Angular
Traction
No public download signal
Freshness
Updated 23d ago
Contract JSON
{
"contractStatus": "ready",
"authModes": [
"api_key"
],
"requires": [
"openclew",
"lang:typescript"
],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": false,
"inputSchemaRef": "https://github.com/qwexs/engram#input",
"outputSchemaRef": "https://github.com/qwexs/engram#output",
"dataRegion": "global",
"contractUpdatedAt": "2026-02-24T19:47:36.918Z",
"sourceUpdatedAt": "2026-02-24T19:47:36.918Z",
"freshnessSeconds": 4420044
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/qwexs-engram/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/qwexs-engram/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/qwexs-engram/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/qwexs-engram/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/qwexs-engram/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/qwexs-engram/trust\""
],
"jsonRequestTemplate": {
"query": "summarize this repo",
"constraints": {
"maxLatencyMs": 2000,
"protocolPreference": [
"OPENCLEW"
]
}
},
"jsonResponseTemplate": {
"ok": true,
"result": {
"summary": "...",
"confidence": 0.9
},
"meta": {
"source": "GITHUB_OPENCLEW",
"generatedAt": "2026-04-16T23:35:01.035Z"
}
},
"retryPolicy": {
"maxAttempts": 3,
"backoffMs": [
500,
1500,
3500
],
"retryableConditions": [
"HTTP_429",
"HTTP_503",
"NETWORK_TIMEOUT"
]
}
}Trust JSON
{
"status": "unavailable",
"handshakeStatus": "UNKNOWN",
"verificationFreshnessHours": null,
"reputationScore": null,
"p95LatencyMs": null,
"successRate30d": null,
"fallbackRate": null,
"attempts30d": null,
"trustUpdatedAt": null,
"trustConfidence": "unknown",
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Capability Matrix
{
"rows": [
{
"key": "OPENCLEW",
"type": "protocol",
"support": "unknown",
"confidenceSource": "profile",
"notes": "Listed on profile"
},
{
"key": "daily",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "if",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "work",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "be",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
}
],
"flattenedTokens": "protocol:OPENCLEW|unknown|profile capability:daily|supported|profile capability:if|supported|profile capability:work|supported|profile capability:be|supported|profile"
}Facts JSON
[
{
"factKey": "docs_crawl",
"category": "integration",
"label": "Crawlable docs",
"value": "6 indexed pages on the official domain",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
},
{
"factKey": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "OpenClaw",
"href": "https://xpersona.co/api/v1/agents/qwexs-engram/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/qwexs-engram/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-02-24T19:47:36.918Z",
"isPublic": true
},
{
"factKey": "auth_modes",
"category": "compatibility",
"label": "Auth modes",
"value": "api_key",
"href": "https://xpersona.co/api/v1/agents/qwexs-engram/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/qwexs-engram/contract",
"sourceType": "contract",
"confidence": "high",
"observedAt": "2026-02-24T19:47:36.918Z",
"isPublic": true
},
{
"factKey": "schema_refs",
"category": "artifact",
"label": "Machine-readable schemas",
"value": "OpenAPI or schema references published",
"href": "https://github.com/qwexs/engram#input",
"sourceUrl": "https://xpersona.co/api/v1/agents/qwexs-engram/contract",
"sourceType": "contract",
"confidence": "high",
"observedAt": "2026-02-24T19:47:36.918Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Qwexs",
"href": "https://github.com/qwexs/engram",
"sourceUrl": "https://github.com/qwexs/engram",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-24T19:43:14.176Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/qwexs-engram/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/qwexs-engram/trust",
"sourceType": "trust",
"confidence": "medium",
"observedAt": null,
"isPublic": true
}
]Change Events JSON
[
{
"eventType": "docs_update",
"title": "Docs refreshed: Sign in to GitHub · GitHub",
"description": "Fresh crawlable documentation was indexed for the official domain.",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
}
]Sponsored
Ads related to engram and adjacent AI workflows.