Get the FREE Ultimate OpenClaw Setup Guide →

search-strategy

npx machina-cli add skill anthropics/knowledge-work-plugins/search-strategy --openclaw
Files (1)
SKILL.md
7.0 KB

Search Strategy

If you see unfamiliar placeholders or need to check which tools are connected, see CONNECTORS.md.

The core intelligence behind enterprise search. Transforms a single natural language question into parallel, source-specific searches and produces ranked, deduplicated results.

The Goal

Turn this:

"What did we decide about the API migration timeline?"

Into targeted searches across every connected source:

~~chat:  "API migration timeline decision" (semantic) + "API migration" in:#engineering after:2025-01-01
~~knowledge base: semantic search "API migration timeline decision"
~~project tracker:  text search "API migration" in relevant workspace

Then synthesize the results into a single coherent answer.

Query Decomposition

Step 1: Identify Query Type

Classify the user's question to determine search strategy:

Query TypeExampleStrategy
Decision"What did we decide about X?"Prioritize conversations (~~chat, email), look for conclusion signals
Status"What's the status of Project Y?"Prioritize recent activity, task trackers, status updates
Document"Where's the spec for Z?"Prioritize Drive, wiki, shared docs
Person"Who's working on X?"Search task assignments, message authors, doc collaborators
Factual"What's our policy on X?"Prioritize wiki, official docs, then confirmatory conversations
Temporal"When did X happen?"Search with broad date range, look for timestamps
Exploratory"What do we know about X?"Broad search across all sources, synthesize

Step 2: Extract Search Components

From the query, extract:

  • Keywords: Core terms that must appear in results
  • Entities: People, projects, teams, tools (use memory system if available)
  • Intent signals: Decision words, status words, temporal markers
  • Constraints: Time ranges, source hints, author filters
  • Negations: Things to exclude

Step 3: Generate Sub-Queries Per Source

For each available source, create one or more targeted queries:

Prefer semantic search for:

  • Conceptual questions ("What do we think about...")
  • Questions where exact keywords are unknown
  • Exploratory queries

Prefer keyword search for:

  • Known terms, project names, acronyms
  • Exact phrases the user quoted
  • Filter-heavy queries (from:, in:, after:)

Generate multiple query variants when the topic might be referred to differently:

User: "Kubernetes setup"
Queries: "Kubernetes", "k8s", "cluster", "container orchestration"

Source-Specific Query Translation

~~chat

Semantic search (natural language questions):

query: "What is the status of project aurora?"

Keyword search:

query: "project aurora status update"
query: "aurora in:#engineering after:2025-01-15"
query: "from:<@UserID> aurora"

Filter mapping:

Enterprise filter~~chat syntax
from:sarahfrom:sarah or from:<@USERID>
in:engineeringin:engineering
after:2025-01-01after:2025-01-01
before:2025-02-01before:2025-02-01
type:threadis:thread
type:filehas:file

~~knowledge base (Wiki)

Semantic search — Use for conceptual queries:

descriptive_query: "API migration timeline and decision rationale"

Keyword search — Use for exact terms:

query: "API migration"
query: "\"API migration timeline\""  (exact phrase)

~~project tracker

Task search:

text: "API migration"
workspace: [workspace_id]
completed: false  (for status queries)
assignee_any: "me"  (for "my tasks" queries)

Filter mapping:

Enterprise filter~~project tracker parameter
from:sarahassignee_any or created_by_any
after:2025-01-01modified_on_after: "2025-01-01"
type:milestoneresource_subtype: "milestone"

Result Ranking

Relevance Scoring

Score each result on these factors (weighted by query type):

FactorWeight (Decision)Weight (Status)Weight (Document)Weight (Factual)
Keyword match0.30.20.40.3
Freshness0.30.40.20.1
Authority0.20.10.30.4
Completeness0.20.30.10.2

Authority Hierarchy

Depends on query type:

For factual/policy questions:

Wiki/Official docs > Shared documents > Email announcements > Chat messages

For "what happened" / decision questions:

Meeting notes > Thread conclusions > Email confirmations > Chat messages

For status questions:

Task tracker > Recent chat > Status docs > Email updates

Handling Ambiguity

When a query is ambiguous, prefer asking one focused clarifying question over guessing:

Ambiguous: "search for the migration"
→ "I found references to a few migrations. Are you looking for:
   1. The database migration (Project Phoenix)
   2. The cloud migration (AWS → GCP)
   3. The email migration (Exchange → O365)"

Only ask for clarification when:

  • There are genuinely distinct interpretations that would produce very different results
  • The ambiguity would significantly affect which sources to search

Do NOT ask for clarification when:

  • The query is clear enough to produce useful results
  • Minor ambiguity can be resolved by returning results from multiple interpretations

Fallback Strategies

When a source is unavailable or returns no results:

  1. Source unavailable: Skip it, search remaining sources, note the gap
  2. No results from a source: Try broader query terms, remove date filters, try alternate keywords
  3. All sources return nothing: Suggest query modifications to the user
  4. Rate limited: Note the limitation, return results from other sources, suggest retrying later

Query Broadening

If initial queries return too few results:

Original: "PostgreSQL migration Q2 timeline decision"
Broader:  "PostgreSQL migration"
Broader:  "database migration"
Broadest: "migration"

Remove constraints in this order:

  1. Date filters (search all time)
  2. Source/location filters
  3. Less important keywords
  4. Keep only core entity/topic terms

Parallel Execution

Always execute searches across sources in parallel, never sequentially. The total search time should be roughly equal to the slowest single source, not the sum of all sources.

[User query]
     ↓ decompose
[~~chat query] [~~email query] [~~cloud storage query] [Wiki query] [~~project tracker query]
     ↓            ↓            ↓              ↓            ↓
  (parallel execution)
     ↓
[Merge + Rank + Deduplicate]
     ↓
[Synthesized answer]

Source

git clone https://github.com/anthropics/knowledge-work-plugins/blob/main/enterprise-search/skills/search-strategy/SKILL.mdView on GitHub

Overview

Search-strategy turns a single natural language question into parallel, source-specific searches across connected sources and returns ranked, deduplicated results. It acts as the core intelligence of enterprise search, synthesizing information from chat, knowledge bases, and project trackers into a single answer. It also handles ambiguity and fallback strategies to maximize relevance.

How This Skill Works

It first classifies the user query to determine the search strategy, then extracts keywords, entities, intent signals, and constraints. It generates per-source sub-queries using semantic or keyword approaches, translates them into source-specific syntax, and applies to each connected source. Finally, results are deduplicated, ranked by relevance, and synthesized into a single coherent answer.

When to Use It

  • You need an answer that spans multiple connected sources (chat, knowledge base, and project tracker).
  • You require the latest status or updates from a project or task tracker.
  • You’re searching for policy, specifications, or official docs rather than just conversations.
  • The query is ambiguous or exploratory, benefiting from multiple variant analyses and fallbacks.
  • You want a synthesized, deduplicated, ranked result rather than a pile of raw documents.

Quick Start

  1. Step 1: Identify Query Type and extract keywords, entities, and constraints from the user's question.
  2. Step 2: Generate per-source sub-queries using semantic and keyword variants, translating to chat, knowledge base, and tracker syntax with filters.
  3. Step 3: Run parallel searches, deduplicate results, rank by relevance, and synthesize a single answer.

Best Practices

  • Define the query type first (Decision, Status, Document, Person, Factual, Temporal, Exploratory) to guide source prioritization.
  • Extract and record keywords, entities, intent signals, constraints, and negations from the user query.
  • Generate multiple per-source sub-queries, using semantic for exploratory questions and keyword search for precise terms.
  • Translate queries into source-specific syntax (e.g., chat, knowledge base, project tracker) with appropriate filters.
  • Validate deduplication and ranking by ensuring results are synthesized into a single coherent answer.

Example Use Cases

  • User asks: What did we decide about the API migration timeline? The system decomposes to retrieve conclusions from chats, meetings, and docs across sources and returns a synthesized decision summary.
  • User asks: What’s the status of Project Phoenix? The strategy queries the project tracker for recent activity and relevant updates, then briefs the current state.
  • User asks: Where is the spec for Z? The tool prioritizes official docs and shared drives, then corroborates with related discussions.
  • User asks: Who's working on X? The system searches task assignments, mentions, and collaborators across sources to present a clear ownership view.
  • User asks: What’s our policy on X? The strategy searches policy docs and official guidelines, then surfaces supporting conversations for context.

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers