Curriculum Generator OpenClaw Plugin & Skill | ClawHub
Looking to integrate Curriculum Generator into your AI workflows? This free OpenClaw plugin from ClawHub helps you automate health & fitness tasks instantly, without having to write custom tools from scratch.
What this skill does
Intelligent educational curriculum generation system with strict step enforcement and human escalation policies
Install
npx clawhub@latest install curriculum-generatorFull SKILL.md
Open original| name | description |
|---|---|
| curriculum-generator | Intelligent educational curriculum generation system with strict step enforcement and human escalation policies |
SKILL.md content below is scrollable.
DEBUG MODE
When the user includes "debug mode" or "show searches" in their curriculum request:
Enable verbose output:
- Print every neo-ddg-search query before executing
- Print number of results returned
- Print first 2-3 URLs extracted
- Print resource assignment: "Assigning to {topic}: {url}"
Example debug output:
[DEBUG] Executing neo-ddg-search("Python basics tutorial for beginners")
[DEBUG] Search returned 10 results
[DEBUG] Extracting URLs...
[DEBUG] Found: https://www.youtube.com/watch?v=rfscVS0vtbw
[DEBUG] Found: https://www.freecodecamp.org/learn/scientific-computing-with-python/
[DEBUG] Assigning to "Python Basics": https://www.youtube.com/watch?v=rfscVS0vtbw
Dependencies
Required Skills
This skill requires the following other skills to be installed:
- neo-ddg-search: For web searching educational resources
- Install:
clawhub install neobotjan2026/neo-ddg-search - Verify: Check if neo-ddg-search skill exists in skills directory
- Install:
Dependency Verification
At the start of curriculum generation, verify neo-ddg-search is available:
IF neo-ddg-search skill NOT found:
šØ DEPENDENCY MISSING
The curriculum generator requires the neo-ddg-search skill for finding educational resources.
Please install it:
clawhub install neobotjan2026/neo-ddg-search
Then restart this process.
ā ļø GENERATION CANNOT PROCEED without search capability
STOP
Search Tool Health Check
Before starting resource research, perform a test search:
Test: neo-ddg-search("Python tutorial test")
IF successful:
ā
Search tool operational
Proceeding with resource research...
IF failed:
šØ SEARCH TOOL ERROR
neo-ddg-search is installed but not responding correctly.
Error: {error_details}
Please check:
⢠neo-ddg-search skill is properly installed
⢠Internet connection is available
⢠No firewall blocking DuckDuckGo
ā ļø Cannot proceed with resource research
ESCALATE
Curriculum Generator Skill
Purpose
This skill helps generate customized educational curricula for PODs (Points of Delivery) through a structured, step-enforced process with mandatory human escalation when needed.
Core Capabilities
- Guided requirement gathering via structured questionnaire
- Research-based curriculum design or assessment
- Excel (.xlsx) output generation
- Local memory storage for continuous improvement
- Background task execution
- Strict human escalation policy enforcement
Storage Locations
- Memory:
~/.openclaw/skills/curriculum-generator/memory/ - Outputs:
~/.openclaw/skills/curriculum-generator/outputs/ - Templates:
~/.openclaw/skills/curriculum-generator/templates/
Activation Triggers
This skill activates when the user:
- Says "create curriculum", "design curriculum", or "assess curriculum"
- Says "curriculum help" or "start curriculum process"
- Explicitly requests curriculum generation for a POD
CRITICAL RULES (NON-NEGOTIABLE)
Core Principle
You MUST ask a human whenever you are forced to guess, infer, or trade off risk. If a wrong decision could affect students, teachers, or POD operations, escalation is MANDATORY.
Hard-Stop Escalation Triggers
You MUST stop and escalate to human if ANY of these occur:
A. Missing or Ambiguous Inputs
- Target age/grade level is unclear
- Teacher availability or capability is unknown
- Daily lab hours are not specified
- Infrastructure reliability (computers/internet/electricity) is unclear
- Whether existing curriculum exists is not confirmed
B. Teacher Capability Risk
- Teachers cannot operate computers independently
- Teachers lack experience running labs
- Teachers cannot manage lab discipline or session flow
C. Operational Infeasibility
- Curriculum hours exceed available lab hours
- Sessions per week exceed teacher capacity
- Student-to-computer ratio is unsafe
- Infrastructure cannot support planned activities
D. High-Risk Curriculum Changes
- Removing major learning outcomes
- Changing curriculum duration significantly
- Shifting learning area (e.g., digital literacy ā employment readiness)
- Introducing new tools/platforms not previously used
E. Contradictory Stakeholder Signals
- Teachers say curriculum is too hard, students say too easy
- POD leader priorities conflict with feasibility
- Feedback loops contradict assessment data
Escalation Format (MANDATORY)
When escalating, use this EXACT format:
šØ HUMAN INPUT REQUIRED
Reason: [specific trigger]
Impact if Unresolved: [clear consequence]
Options (if any):
1. [option 1]
2. [option 2]
Awaiting Decision From: [POD Leader / Curriculum Owner]
PROCESS FLOW
STEP 0: SCENARIO IDENTIFICATION (MANDATORY)
Before anything else, determine:
- Scenario A: Assessment of existing curriculum
- Scenario B: Design of new curriculum
If unclear, STOP and ask user to confirm. Do NOT proceed without classification.
SCENARIO A: ASSESSING EXISTING CURRICULUM
STEP A1: Gather Basic Information
Collect ALL of the following using the structured form:
Section 0: Request Metadata
- Request ID (auto-generate using timestamp)
- Date of Request (auto-capture)
- Requested By (Name + Role)
- POD Name (REQUIRED)
- Scenario Type (must be selected)
ā ļø If Scenario Type not selected ā HARD STOP
Section 1: Target Audience Profile (MANDATORY)
- Primary Student Group:
- Age range
- Grade/Education level
- Student Background (check all that apply):
- First-time computer users
- Basic exposure (mouse, keyboard)
- Prior digital lab experience
- Mixed levels
- Language Comfort:
- Medium of instruction
- English proficiency (Low/Medium/High)
- Special Constraints:
- Learning disabilities
- Attendance inconsistency
- Social/economic limitations
ā ļø If age/grade missing ā HARD STOP and escalate
Section 2: POD & Infrastructure Details (MANDATORY)
- Lab Infrastructure:
- Number of computers
- Average students per session
- Internet availability (Reliable/Unstable/None)
- Power backup (Yes/No)
- Daily Lab Usage:
- Available hours per day
- Days per week lab is operational
- Existing Tools/Platforms:
- Operating System
- Software already installed
- Internet restrictions
ā ļø If lab hours or computer count missing ā HARD STOP and escalate
Section 3: Teacher Capability & Availability (MANDATORY)
- Number of Teachers Assigned
- Teacher Availability:
- Days per week
- Hours per day
- Teacher Capability Assessment:
- Can operate computers independently? (Yes/No)
- Comfortable managing digital labs? (Yes/No)
- Prior experience with similar programs? (Yes/No)
- Training Requirement:
- No training needed
- Short training needed
- Extensive training needed
ā ļø Any "No" in capability assessment ā Potential escalation
STEP A2: Stakeholder Inputs (Structured Summary)
Simulate structured stakeholder inputs based on provided data:
- POD Leader: Effectiveness, challenges, change needs
- Teachers: Teaching experience, curriculum gaps, student progress
- Students: Difficulty level, engagement, relevance
Then perform Teacher Capability Assessment:
- Can teachers operate computers independently?
- Can they run the lab as per curriculum?
- Can they manage discipline, safety, and session flow?
- Identify training gaps (if any)
STEP A3: Curriculum Evaluation
Evaluate curriculum on these dimensions:
- Relevance to student needs
- Alignment with industry/digital literacy goals
- Flexibility for varied learning speeds
- Outcome clarity and measurability
- Technology integration quality
Then perform Operational Feasibility Check:
- Lab schedule feasibility
- Teacher sufficiency
- Infrastructure readiness (computers, internet, electricity)
STEP A4: Recommendations
- Clearly state whether modification is required or optional
- If required, propose specific, actionable changes
- Flag risks explicitly
End with: Status: Draft Assessment ā Pending Human Review
SCENARIO B: DESIGNING A NEW CURRICULUM
STEP B1: Define Curriculum Foundation
Explicitly define:
- Learning Areas: Digital Literacy / Academic Empowerment / Skill Development / Employment Readiness
- Target Audience: Grade, background
- Clear, measurable Learning Outcomes (no vague outcomes allowed)
STEP B2: Develop Course Structure
Generate:
- Modules and sub-topics
- Weekly lesson breakdown
- Learning objective per lesson
- Program duration (e.g., 3 months / 6 months)
- Class frequency
Lab Planning (Mandatory):
- Daily lab operating hours
- Sessions per week
- Max students per session
END OF STEP B2 - MANDATORY ACTION BEFORE PROCEEDING:
BEFORE moving to Step B3, execute this command sequence:
1. Review the curriculum structure you just created
2. Identify ALL topics that will appear in the final output
3. For EACH topic, RIGHT NOW, execute:
neo-ddg-search("{topic} tutorial for beginners")
4. Extract the first valid educational URL from results
5. Store it in a resource_map dictionary:
resource_map["{topic}"] = "https://..."
6. Verify resource_map has entries for ALL topics
7. Only then proceed to Step B3
Example:
Topic: "Python Lists"
Execute: neo-ddg-search("Python Lists tutorial for beginners")
Result: Found https://www.youtube.com/watch?v=W8KRzm-HUcc
Store: resource_map["Python Lists"] = "https://www.youtube.com/watch?v=W8KRzm-HUcc"
DO NOT SKIP THIS. DO NOT PROCEED WITHOUT COMPLETING THIS.
## **Step 5: Create a Simpler Test in Telegram**
Now test with very explicit instructions. In Telegram, send:
Create a tiny test curriculum:
- Topic: HTML Basics
- Duration: 1 week only
- 2 lessons total
IMPORTANT INSTRUCTIONS:
- After creating the structure, use neo-ddg-search to find resources for EACH lesson
- Before generating the CSV file, verify ALL resource links are real URLs
- Show me each search you perform
- If ANY resource link is empty or "TBD", STOP and search for it immediately
Start now.
MANDATORY: End of Step B2 Resource Collection
Before proceeding to Step B3, you MUST complete this:
STOP HERE.
Before moving to Step B3, execute this sequence:
1. List all topics you just created: [topic1, topic2, topic3, ...]
2. Create an empty dictionary: resource_links = {}
3. FOR EACH topic:
a. Execute: result = neo-ddg-search("{topic} tutorial for beginners")
b. Look at the result text
c. Find all text that starts with "https://"
d. Extract the complete URL
e. Store: resource_links[topic] = that_url
f. Print: "Stored for {topic}: {that_url}"
4. Verify resource_links has ALL topics
5. Print the complete resource_links dictionary
6. ONLY THEN proceed to Step B3
Example for "HTML Basics":
Execute: neo-ddg-search("HTML Basics tutorial for beginners")
Result contains: "...https://www.youtube.com/watch?v=pQN-pnXPaVg..."
Extract: "https://www.youtube.com/watch?v=pQN-pnXPaVg"
Store: resource_links["HTML Basics"] = "https://www.youtube.com/watch?v=pQN-pnXPaVg"
Print: "Stored for HTML Basics: https://www.youtube.com/watch?v=pQN-pnXPaVg"
DO THIS FOR EVERY SINGLE TOPIC BEFORE MOVING ON.
END OF STEP B2 - RESOURCE COLLECTION (MANDATORY)
YOU MUST NOW COLLECT RESOURCES BEFORE PROCEEDING.
Execute this EXACT sequence:
1. Create empty dictionary: resource_links = {}
2. List all topics from Step B2
3. For EACH topic, execute:
bash_tool: python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py "{topic} tutorial for beginners" 5
4. From the output, find all text starting with "https://"
5. Take the first URL that contains "youtube.com", or if none, the first URL
6. Store it: resource_links[topic] = that_url
7. Print: "Collected for {topic}: {that_url}"
8. After ALL topics are done, print the complete resource_links dictionary
9. Verify every topic has a URL
10. ONLY THEN create the CSV using URLs from resource_links
DO NOT WRITE "TBD" IN THE CSV.
USE THE URLS FROM resource_links DICTIONARY.
If you cannot find a URL for a topic, STOP and ESCALATE.
Do not proceed to CSV generation without URLs for all topics.
## **Save and Test**
Save the file, then in Telegram:
reload skills
Then test with a VERY simple example:
Create curriculum:
- Topic: HTML only
- 1 lesson total
- Show me EVERY step
After you build the structure:
- Search for HTML resources using: python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py "HTML tutorial for beginners" 5
- Show me the raw output
- Extract the URLs
- Show me what URL you extracted
- Show me the CSV content BEFORE writing it
- If Resource Link shows "TBD", STOP immediately
Start.
## **What to Watch For**
You should see output like:
ā Course structure complete
š Starting resource search...
Topic: HTML Basics Executing: python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py "HTML Basics tutorial for beginners" 5
[Results shown] [1] HTML Tutorial | https://www.youtube.com/watch?v=... [2] Learn HTML | https://www.w3schools.com/html/
Found 2 URLs Selected: https://www.youtube.com/watch?v=... ā Stored for HTML Basics: https://www.youtube.com/watch?v=...
Resource Links Dictionary: HTML Basics: https://www.youtube.com/watch?v=...
š CSV Preview: Covered Topics | Resource Link HTML Basics | https://www.youtube.com/watch?v=...
Writing file...
STEP B2.5: RESOURCE LINK POPULATION (SIMPLIFIED)
After completing Step B2 structure, execute this EXACT process:
Simple 3-Step Process Per Topic
For EACH topic:
STEP 1: Search
python3 ~/.openclaw/workspace/skills/neo-ddg-search/scripts/search.py "{topic} tutorial for beginners" 5
STEP 2: Look at output and extract FIRST URL
- Scan the output line by line
- When you see
https://ā copy everything fromhttps://until the next space - That's your URL
STEP 3: Store it
resource_links["{topic}"] = "the_url_you_found"
Then IMMEDIATELY move to next topic. Do NOT do additional searches unless the first one returns ZERO results.
Hard Limit: 1 Search Per Topic
RULE: Execute ONE search per topic. Extract ONE URL. Move on.
Do NOT:
- ā Execute multiple searches for the same topic
- ā Try to find "better" resources
- ā Analyze quality extensively
- ā Wait or pause
DO:
- ā Search once
- ā Grab first URL
- ā Move to next topic
- ā Complete all topics quickly
Exact Execution Template
Print: "š Resource Research Starting..."
Print: ""
resource_links = {}
topics = [list of all topics from Step B2]
For topic in topics:
Print: f"Topic: {topic}"
# Execute search (ONE TIME ONLY)
result = bash_tool(f'python3 ~/.openclaw/workspace/skills/neo-ddg-search/scripts/search.py "{topic} tutorial" 5')
# Extract first URL (simple method)
url = None
for line in result.split('\n'):
if 'https://' in line:
start = line.find('https://')
end_of_line = line[start:]
# Get URL until space or end
space_index = end_of_line.find(' ')
if space_index > 0:
url = end_of_line[:space_index]
else:
url = end_of_line.strip()
break # Take FIRST URL and stop
if url:
resource_links[topic] = url
Print: f" ā
{url}"
else:
resource_links[topic] = "MANUAL_RESEARCH_NEEDED"
Print: f" ā ļø No URL found - marked for manual research"
# IMMEDIATELY continue to next topic
Print: ""
Print: "ā
Resource research complete"
Print: f"Collected {len(resource_links)} resource links"
Print: ""
Time Limit
Maximum time for resource research: 2 minutes total
If you're taking longer than 2 minutes for resource collection, you're doing something wrong. This should be fast:
- 5 seconds per search
- 2 topics = 10 seconds
- 10 topics = 50 seconds
What Gets Stored
# Good examples:
resource_links["Python Basics"] = "https://datascientest.com/en/python-variables-beginners-guide"
resource_links["HTML Intro"] = "https://www.w3schools.com/python/python_variables.asp"
# Acceptable if no URL found:
resource_links["Obscure Topic"] = "MANUAL_RESEARCH_NEEDED"
# NEVER acceptable:
resource_links["Topic"] = "TBD" # ā
resource_links["Topic"] = "" # ā
After Collection: Immediate CSV Generation
Do NOT pause or wait. Immediately proceed to CSV generation.
Print: "š Generating CSV with collected resources..."
csv_data = []
for topic in curriculum_structure:
resource_url = resource_links.get(topic, "MANUAL_RESEARCH_NEEDED")
csv_row = {
"Curriculum ID": curriculum_id,
"File Name": file_name,
"Target POD Type": pod_type,
"Clusters": clusters,
"Content Type": content_type,
"Covered Topics": topic,
"Owner": owner,
"Resource Link": resource_url, # ā Use collected URL
"Document Creation Date": date,
"Last Updated On": date
}
csv_data.append(csv_row)
write_csv(csv_data)
Print: "ā
CSV file generated"
Example: Complete 2-Topic Execution
Topics: ["Python Basics", "Python Functions"]
š Resource Research Starting...
Topic: Python Basics
Executing search...
[Results received]
Found URL: https://datascientest.com/en/python-variables-beginners-guide
ā
https://datascientest.com/en/python-variables-beginners-guide
Topic: Python Functions
Executing search...
[Results received]
Found URL: https://www.w3schools.com/python/python_functions.asp
ā
https://www.w3schools.com/python/python_functions.asp
ā
Resource research complete
Collected 2 resource links
š Generating CSV with collected resources...
ā
CSV file generated: Python_Basics_v1.0.csv
Total time: ~15 seconds
No Escalation for "Imperfect" Resources
Accept whatever URL you find in the first search.
Priority is:
- Speed ā
- Completion ā
- Perfect resources ā ļø (nice to have, not required)
If the first search returns W3Schools instead of YouTube, that's FINE. Use it and move on.
Escalation Only For Zero Results
Only escalate if:
- ā Search returns absolutely no results
- ā Search returns results but contains ZERO URLs
- ā Search tool completely fails
Do NOT escalate if:
- ā URL is from W3Schools instead of YouTube (still good!)
- ā URL is from a lesser-known educational site (acceptable!)
- ā URL is documentation instead of video (perfectly fine!)
Debug Output (When Requested)
If user requests DEBUG MODE:
[DEBUG] Topic: Python Basics
[DEBUG] Command: python3 ~/.openclaw/workspace/skills/neo-ddg-search/scripts/search.py "Python Basics tutorial" 5
[DEBUG] Results: 5 entries returned
[DEBUG] Extracting URLs...
[DEBUG] Line 1: Contains 'https://datascientest.com/...'
[DEBUG] Extracted: https://datascientest.com/en/python-variables-beginners-guide
[DEBUG] Storing: resource_links["Python Basics"] = "https://datascientest.com/..."
[DEBUG] ā
Complete - moving to next topic
MANDATORY: After Step B2, execute resource collection IMMEDIATELY
After completing Step B2 course structure:
1. DO NOT pause
2. DO NOT ask for confirmation
3. IMMEDIATELY start resource collection
4. Use the Simple 3-Step Process above
5. Complete ALL topics within 2 minutes
6. Then IMMEDIATELY generate CSV
7. Do NOT wait between steps
This should be ONE CONTINUOUS FLOW:
Step B2 ā Resource Collection ā CSV Generation ā Done
No breaks. No pauses. No waiting.
Implementation in Curriculum Generation
After Step B2 (course structure), do this:
Print: "š Starting resource search for all topics..."
Print: ""
Initialize: resource_links = {}
For each topic in curriculum:
Print: "Topic: {topic}"
# Execute search
command = f"python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py \"{topic} tutorial for beginners\" 5"
result = execute_bash(command)
# Extract URLs (look for https://)
lines = result.split('\n')
urls = []
for line in lines:
if 'https://' in line:
# Extract the URL part
start = line.find('https://')
# Find end (space or newline)
rest = line[start:]
space_pos = rest.find(' ')
if space_pos > 0:
url = rest[:space_pos]
else:
url = rest.strip()
urls.append(url)
Print: f" Found {len(urls)} URLs"
# Choose best URL
best_url = None
for url in urls:
if 'youtube.com' in url:
best_url = url
break
if not best_url and urls:
for url in urls:
if 'freecodecamp.org' in url:
best_url = url
break
if not best_url and urls:
best_url = urls[0] # Use first URL
if best_url:
resource_links[topic] = best_url
Print: f" ā
Stored: {best_url}"
else:
Print: f" ā No URLs found - trying alternative search..."
# Try one more time
alt_command = f"python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py \"{topic} free course\" 5"
alt_result = execute_bash(alt_command)
# Extract URLs again...
# [same extraction logic]
if alt_urls:
resource_links[topic] = alt_urls[0]
Print: f" ā
Stored: {alt_urls[0]}"
else:
ESCALATE(f"No resources found for {topic}")
Print: ""
Print: "ā
Resource collection complete!"
Print: f"Total topics: {len(resource_links)}"
Print: ""
Print: "Resource Links Dictionary:"
for topic, url in resource_links.items():
Print: f" {topic}: {url}"
STEP B3: Teacher Preparation & Readiness
Specify:
- Teacher resources required
- Teaching methodology (interactive, adaptable)
- Teacher readiness evaluation:
- Prior experience
- Comfort with computer labs
- Whether short training is required (Yes/No + why)
STEP B4: Assessments & Feedback Design
Define:
- Formative assessments (quizzes, projects, assignments)
- Summative assessment (final exam/capstone project)
- What each assessment measures
STEP B5: Continuous Improvement Loop
Define:
- Feedback sources (teachers, students, assessments)
- Review frequency
- Criteria for curriculum revision
RESOURCE RESEARCH (MANDATORY)
ANTI-STUCK RULE
If resource collection is taking longer than 3 minutes total:
STOP what you're doing and execute this:
Print: "ā±ļø Resource collection timeout (3 min exceeded)"
Print: "Completing with available resources..."
For any topic without a resource:
resource_links[topic] = "MANUAL_RESEARCH_NEEDED"
Proceed immediately to CSV generation
Never get stuck searching indefinitely.
## **Test Again**
Save the file and test:
reload skills
Then:
Create curriculum:
- Python basics
- 2 lessons
- 1 week
DO NOT GET STUCK. If resource search takes more than 1 minute total, skip to CSV generation.
Show me when you start resource search and when you finish.
## **What Should Happen**
You should see:
š Resource Research Starting...
Topic: Lesson 1 - Python Intro ā https://datascientest.com/en/python-variables-beginners-guide
Topic: Lesson 2 - Python Functions ā https://www.w3schools.com/python/python_functions.asp
ā Resource research complete (15 seconds) Collected 2 resource links
š Generating CSV... ā Done
**NOT this:**
Topic: Lesson 1 Executing search... [Results] Trying alternative search... [More results] Evaluating quality... [STUCK HERE] ā Never gets to CSV
How to Execute Searches
To search for resources, use this EXACT command:
python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py "YOUR QUERY HERE" 5
This returns search results with URLs that you must extract.
Simple Search and Extract Process
For EACH topic in the curriculum:
Step 1: Execute Search
# Example for "HTML Basics"
python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py "HTML basics tutorial for beginners" 5
Step 2: Look at the Output
The output looks like this:
[1] Page Title | Year | Type | Site https://example.com/url1
Description text
[2] Another Title | Year | Type | Site https://another.com/url2
More description
Step 3: Extract URLs (Simple Pattern)
Look for any text starting with https://
From the example above, extract:
https://example.com/url1https://another.com/url2
Step 4: Choose Best URL
Priority order:
- URLs containing
youtube.com(first choice) - URLs containing
freecodecamp.org(second choice) - URLs containing
w3schools.com(third choice) - Any other educational site
- If none found, use the first URL
Step 5: Store the URL
Store in a simple format:
Topic: HTML Basics
Resource: https://www.youtube.com/watch?v=...
Complete Example Workflow
Topic: "Python Lists"
Step 1 - Search:
python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py "Python lists tutorial for beginners" 5
Step 2 - Output Received:
[1] Python Lists Tutorial | 2023 | Video | YouTube https://www.youtube.com/watch?v=W8KRzm-HUcc
Learn Python lists from scratch
[2] Python Lists Guide | 2024 | Article | W3Schools https://www.w3schools.com/python/python_lists.asp
Complete guide to Python lists
Step 3 - Extract URLs:
- Found:
https://www.youtube.com/watch?v=W8KRzm-HUcc - Found:
https://www.w3schools.com/python/python_lists.asp
Step 4 - Choose Best:
- First URL contains "youtube.com" ā Select this one
- Selected:
https://www.youtube.com/watch?v=W8KRzm-HUcc
Step 5 - Store:
resource_links["Python Lists"] = "https://www.youtube.com/watch?v=W8KRzm-HUcc"
Before Writing CSV
MANDATORY CHECK:
Print: "š Verifying resource links before CSV generation..."
Print: ""
csv_data = []
for row in curriculum_structure:
topic = row['topic']
# Get resource from resource_links dictionary
if topic in resource_links:
resource_url = resource_links[topic]
else:
Print: f"ā ERROR: No resource link for '{topic}'"
STOP
# Verify it's a valid URL
if not resource_url.startswith('http'):
Print: f"ā ERROR: Invalid URL for '{topic}': {resource_url}"
STOP
Print: f"ā
{topic}: {resource_url[:60]}..."
# Add to CSV data
csv_row = {
"Curriculum ID": curriculum_id,
"File Name": file_name,
"Target POD Type": pod_type,
"Clusters": clusters,
"Content Type": content_type,
"Covered Topics": topic,
"Owner": owner,
"Resource Link": resource_url, # ā ACTUAL URL HERE
"Document Creation Date": date,
"Last Updated On": date
}
csv_data.append(csv_row)
Print: ""
Print: "ā
All rows verified with valid URLs"
Print: "š Writing CSV file..."
write_csv_file(csv_data)
CSV Preview Before Writing
Show user the data:
Print: "š CSV Preview:"
Print: "=" * 80
Print: f"Covered Topics | Resource Link"
Print: "-" * 80
for row in csv_data:
topic = row["Covered Topics"]
url = row["Resource Link"]
Print: f"{topic[:30]:30} | {url}"
Print: "=" * 80
Print: ""
Print: "Writing to file..."
Escalation for Missing Resources
If after searching, a topic has no URL:
šØ RESOURCE SEARCH FAILED - HUMAN INPUT REQUIRED
Topic: {topic_name}
Search 1: "python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py '{topic} tutorial for beginners' 5"
Result: {number} URLs found
None matched quality criteria
Search 2: "python3 ~/.openclaw/skills/neo-ddg-search/scripts/search.py '{topic} free course' 5"
Result: {number} URLs found
None matched quality criteria
Issue: Cannot find suitable free educational resources
Options:
1. Modify topic name to be more general
2. Accept lower-quality resource if available
3. Mark for manual research
Awaiting Decision From: Curriculum Owner
ā ļø CSV generation paused
OUTPUT GENERATION
PRE-FILE-GENERATION CHECKLIST (MANDATORY)
Before writing ANY output file, you MUST complete this checklist:
Checklist Item 1: Resource Link Verification
STOP and verify:
FOR EACH row in the curriculum data:
topic = row['Covered Topics']
resource_link = row['Resource Link']
IF resource_link is empty OR resource_link == "TBD" OR resource_link == "N/A":
PRINT "ā ļø Missing resource link for: {topic}"
PRINT "š Executing search now..."
# Execute neo-ddg-search immediately
search_query = f"{topic} tutorial for beginners"
EXECUTE: neo-ddg-search(search_query)
# Extract URLs from results
urls = EXTRACT_URLS_FROM_RESULTS()
IF urls found:
row['Resource Link'] = urls[0] # Use first result
PRINT "ā
Found resource: {urls[0]}"
ELSE:
# Try alternative search
search_query_2 = f"{topic} free course"
EXECUTE: neo-ddg-search(search_query_2)
urls = EXTRACT_URLS_FROM_RESULTS()
IF urls found:
row['Resource Link'] = urls[0]
PRINT "ā
Found resource: {urls[0]}"
ELSE:
ESCALATE("Cannot find resources for {topic}")
STOP_FILE_GENERATION
You MUST see output like:
Checking resource links before file generation...
ā
Row 1 - HTML Basics: Has resource link
ā
Row 2 - CSS Fundamentals: Has resource link
ā ļø Row 3 - JavaScript: Missing resource link
š Executing search now...
Using neo-ddg-search: "JavaScript tutorial for beginners"
ā
Found resource: https://www.youtube.com/watch?v=...
ā
Row 3 - JavaScript: Resource link populated
All rows verified. Proceeding to file generation...
Checklist Item 2: URL Format Validation
Verify all resource links are actual URLs:
FOR EACH resource_link in curriculum:
IF NOT resource_link.startswith("http"):
ERROR: "Invalid resource link format: {resource_link}"
STOP
Checklist Item 3: Final Count
total_topics = COUNT(curriculum rows)
topics_with_resources = COUNT(rows where Resource Link is valid URL)
PRINT "š Resource Link Status:"
PRINT " Total topics: {total_topics}"
PRINT " With resources: {topics_with_resources}"
PRINT " Missing: {total_topics - topics_with_resources}"
IF topics_with_resources < total_topics:
ESCALATE("Some topics still missing resources after search")
STOP
ELSE:
PRINT "ā
All topics have resource links. Safe to generate file."
CSV/EXCEL FILE GENERATION - WITH RESOURCE LINKS
Pre-Generation: Build Complete Resource Map
Before writing any file, build a complete resource map:
# Initialize resource map
resource_map = {}
# Get all topics from curriculum structure
all_topics = extract_all_topics_from_curriculum()
print(f"\nš Building resource map for {len(all_topics)} topics...\n")
# For each topic, search and extract URL
for topic in all_topics:
print(f"š Topic: {topic}")
# Execute search
search_query = f"{topic} tutorial for beginners"
print(f" Searching: {search_query}")
search_results = neo_ddg_search(search_query)
# Extract URLs from results
urls_found = extract_urls_from_search_result(search_results)
print(f" Found {len(urls_found)} URLs")
# Select best URL
if urls_found:
best_url = select_best_url(urls_found)
resource_map[topic] = best_url
print(f" ā
Selected: {best_url}\n")
else:
print(f" ā ļø No URLs found, trying alternative search...")
# Try alternative search
alt_search = neo_ddg_search(f"{topic} free course")
urls_found_alt = extract_urls_from_search_result(alt_search)
if urls_found_alt:
best_url = select_best_url(urls_found_alt)
resource_map[topic] = best_url
print(f" ā
Selected: {best_url}\n")
else:
resource_map[topic] = "ESCALATION_NEEDED"
print(f" ā No resources found - will escalate\n")
# Verify all topics have resources
missing_resources = [t for t, url in resource_map.items() if url == "ESCALATION_NEEDED"]
if missing_resources:
print(f"šØ {len(missing_resources)} topics need escalation:")
for topic in missing_resources:
print(f" - {topic}")
ESCALATE("Resource search failed for some topics")
STOP
else:
print(f"ā
All {len(all_topics)} topics have resource links!")
print(f"š Proceeding to CSV generation...\n")
CSV Generation with Resource Map
When creating each row in the CSV:
for week_num, lesson in curriculum_structure:
topic = lesson['topic']
# Get resource link from resource_map
resource_link = resource_map.get(topic, "ERROR_NO_RESOURCE")
# Verify it's a valid URL
if not resource_link.startswith("http"):
print(f"ERROR: Invalid resource for {topic}: {resource_link}")
STOP
csv_row = {
"Curriculum ID": curriculum_id,
"File Name": file_name,
"Target POD Type": pod_type,
"Clusters": clusters,
"Content Type": content_type,
"Covered Topics": topic,
"Owner": owner,
"Resource Link": resource_link, # ā USE THE ACTUAL URL HERE
"Document Creation Date": creation_date,
"Last Updated On": last_updated
}
csv_data.append(csv_row)
Critical Check Before Writing:
# Final verification
print("\nš Final CSV Data Verification:")
for i, row in enumerate(csv_data):
resource = row["Resource Link"]
topic = row["Covered Topics"]
if resource == "TBD" or not resource.startswith("http"):
print(f"ā Row {i+1} ({topic}): INVALID resource '{resource}'")
STOP_GENERATION
else:
print(f"ā
Row {i+1} ({topic}): {resource[:60]}...")
print("\nā
All rows verified - writing file...")
write_csv_file(csv_data)
FILE GENERATION - FINAL RESOURCE CHECK
CRITICAL: Execute this immediately before writing the file:
# Pseudo-code showing the exact logic needed
def prepare_curriculum_data_for_file():
"""
This function runs RIGHT BEFORE creating the CSV/Excel file.
It ensures NO 'TBD' values slip through.
"""
curriculum_rows = get_curriculum_structure()
print("\nš FINAL RESOURCE LINK CHECK (Pre-File-Generation)")
print("=" * 50)
for i, row in enumerate(curriculum_rows):
topic = row['Covered Topics']
resource_link = row.get('Resource Link', '')
# Check if resource link is missing or placeholder
if not resource_link or resource_link in ['TBD', 'N/A', '', 'null', 'None']:
print(f"\nā ļø Row {i+1}: '{topic}' has no resource link")
print(f" Current value: '{resource_link}'")
print(f" š Searching now with neo-ddg-search...")
# EXECUTE NEO-DDG-SEARCH HERE
search_results = neo_ddg_search(f"{topic} tutorial for beginners free")
# Extract URLs from search results
urls_found = extract_urls_from_search_results(search_results)
if urls_found and len(urls_found) > 0:
row['Resource Link'] = urls_found[0]
print(f" ā
Updated with: {urls_found[0]}")
else:
# Try one more time with different query
print(f" š First search returned no URLs, trying again...")
search_results_2 = neo_ddg_search(f"{topic} learn online")
urls_found_2 = extract_urls_from_search_results(search_results_2)
if urls_found_2 and len(urls_found_2) > 0:
row['Resource Link'] = urls_found_2[0]
print(f" ā
Updated with: {urls_found_2[0]}")
else:
# HARD STOP - escalate
print(f" ā FAILED: No resources found after 2 searches")
escalate_resource_failure(topic)
return None # Don't proceed to file generation
else:
print(f"ā
Row {i+1}: '{topic}' has resource: {resource_link[:50]}...")
print("\n" + "=" * 50)
print("ā
All resource links verified. Proceeding to file write.\n")
return curriculum_rows
# THEN write the file
verified_data = prepare_curriculum_data_for_file()
if verified_data is None:
print("šØ File generation cancelled - resource verification failed")
# STOP HERE, don't write file
else:
write_csv_file(verified_data) # Only write if all checks passed
What the user should see:
š FINAL RESOURCE LINK CHECK (Pre-File-Generation)
==================================================
ā
Row 1: 'HTML Basics' has resource: https://www.youtube.com/watch?v=pQN-pnXPaVg
ā
Row 2: 'CSS Fundamentals' has resource: https://www.youtube.com/watch?v=1Rs2ND1ryYc
ā ļø Row 3: 'JavaScript Intro' has no resource link
Current value: 'TBD'
š Searching now with neo-ddg-search...
Using neo-ddg-search: "JavaScript Intro tutorial for beginners free"
ā
Updated with: https://www.youtube.com/watch?v=PkZNo7MFNFg
ā
Row 4: 'DOM Manipulation' has resource: https://www.freecodecamp.org/...
==================================================
ā
All resource links verified. Proceeding to file write.
š Writing file: Web_Dev_Fundamentals_v1.0.csv
ā
File generated successfully!
Excel File Structure
Generate .xlsx file with these columns:
- Curriculum ID
- File Name
- Target POD Type
- Clusters
- Content Type
- Covered Topics
- Owner
- Resource Link ā ļø MUST contain actual URLs, NEVER "TBD"
- Document Creation Date
- Last Updated On
Column Population Rules:
- Resource Link: Search and populate with real URLs during curriculum generation
- Format: "URL1 | URL2 | URL3" if multiple resources
- Use web_search before writing Excel file
- If search fails, escalate (never write "TBD")
Mandatory Footer in Every Output
Curriculum Version: vX.X
Scenario: [Assessment / New Design]
Prepared By: Clawdbot
Status: Draft ā Pending POD Leader / Authority Approval
Key Risks & Assumptions:
- [List all assumptions made]
- [List all identified risks]
MEMORY MANAGEMENT
After each curriculum generation:
- Save conversation context to
~/.openclaw/skills/curriculum-generator/memory/curriculum_[REQUEST_ID].json - Store lessons learned in
~/.openclaw/skills/curriculum-generator/memory/learnings.md - Track escalations in
~/.openclaw/skills/curriculum-generator/memory/escalations.log
Memory file structure:
{
"request_id": "CUR_20260208_001",
"date": "2026-02-08",
"scenario": "new_design",
"pod_name": "Example POD",
"user": "madhur",
"inputs_collected": {},
"decisions_made": [],
"escalations": [],
"output_file": "curriculum_example_v1.0.xlsx",
"learnings": []
}
TOOLS REQUIRED
Primary Tools
web_search: Research educational standards, best practices, resourcescreate_file: Generate Excel output filesbash_tool: File management, directory operationsview: Read memory files, check existing curricula
Research Sources (Use web_search for)
- Educational standards and frameworks
- Age-appropriate learning resources
- Digital literacy benchmarks
- Best practices for computer lab education
- Free educational tools and platforms
BACKGROUND TASK EXECUTION
When triggered, inform user:
š¦ Starting curriculum generation process...
This may take 5-10 minutes. I'll notify you when complete.
You can continue other tasks in the meantime.
Then proceed with research and generation in background.
AUTO-APPROVAL ZONE
You may proceed autonomously when:
- All required inputs are present
- Teacher capability is sufficient
- Infrastructure is adequate
- Changes are incremental, not structural
- Curriculum stays within defined learning areas
Even then: Final output is still Draft ā Pending Human Review
META-RULES (VERY IMPORTANT)
You must NEVER:
- Fill gaps silently
- Optimize feasibility without disclosure
- Reduce curriculum scope to make things work unless approved
Transparency > automation speed
Example Usage
User: "Create a new curriculum for our POD"
Clawdbot:
š¦ Curriculum Generator Activated
I'll guide you through a structured questionnaire to design the curriculum.
First, let me confirm: Is this for:
A) Assessing an existing curriculum
B) Designing a new curriculum from scratch
Please select A or B.
User: "B - new curriculum"
Clawdbot:
Perfect! Starting new curriculum design process.
SECTION 0: REQUEST METADATA
- Request ID: CUR_20260208_001 (auto-generated)
- Date: February 8, 2026
- Requested By: Please provide your name and role
- POD Name: Please provide the POD name
[Continue with structured questions...]
Success Criteria
- All mandatory fields collected
- No silent assumptions made
- Appropriate escalations triggered
- Excel file generated successfully
- Memory stored for future reference
- User receives clear, actionable output
Preferred Resource Platforms (Priority Order)
- YouTube: Structured courses from reputable channels
- FreeCodeCamp, Traversy Media, Programming with Mosh, Fireship
- Interactive Platforms: Free tiers
- freeCodeCamp.org, Khan Academy, Codecademy free, W3Schools
- Documentation: Official docs when appropriate
- MDN Web Docs, Python.org, official framework docs
- Written Tutorials: High-quality articles
- Dev.to, Medium (free articles), DigitalOcean tutorials
- Practice Platforms: Free exercises
- Exercism.io, LeetCode (free problems), HackerRank