{
  "schemaVersion": "1.0",
  "item": {
    "slug": "whatpulse-ai-agent-skill",
    "name": "WhatPulse AI Agent Skill",
    "source": "tencent",
    "type": "skill",
    "category": "AI 智能",
    "sourceUrl": "https://clawhub.ai/smitmartijn/whatpulse-ai-agent-skill",
    "canonicalUrl": "https://clawhub.ai/smitmartijn/whatpulse-ai-agent-skill",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadMode": "redirect",
    "downloadUrl": "/downloads/whatpulse-ai-agent-skill",
    "sourceDownloadUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=whatpulse-ai-agent-skill",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "installMethod": "Manual import",
    "extraction": "Extract archive",
    "prerequisites": [
      "OpenClaw"
    ],
    "packageFormat": "ZIP package",
    "includedAssets": [
      "README.md",
      "SKILL.md"
    ],
    "primaryDoc": "SKILL.md",
    "quickSetup": [
      "Download the package from Yavira.",
      "Extract the archive and review SKILL.md first.",
      "Import or place the package into your OpenClaw setup."
    ],
    "agentAssist": {
      "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
      "steps": [
        "Download the package from Yavira.",
        "Extract it into a folder your agent can access.",
        "Paste one of the prompts below and point your agent at the extracted folder."
      ],
      "prompts": [
        {
          "label": "New install",
          "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Then review README.md for any prerequisites, environment setup, or post-install checks. Tell me what you changed and call out any manual steps you could not complete."
        },
        {
          "label": "Upgrade existing",
          "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Then review README.md for any prerequisites, environment setup, or post-install checks. Summarize what changed and any follow-up checks I should run."
        }
      ]
    },
    "sourceHealth": {
      "source": "tencent",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-04-30T16:55:25.780Z",
      "expiresAt": "2026-05-07T16:55:25.780Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=network",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=network",
        "contentDisposition": "attachment; filename=\"network-1.0.0.zip\"",
        "redirectLocation": null,
        "bodySnippet": null
      },
      "scope": "source",
      "summary": "Source download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this source.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/whatpulse-ai-agent-skill"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    },
    "downloadPageUrl": "https://openagent3.xyz/downloads/whatpulse-ai-agent-skill",
    "agentPageUrl": "https://openagent3.xyz/skills/whatpulse-ai-agent-skill/agent",
    "manifestUrl": "https://openagent3.xyz/skills/whatpulse-ai-agent-skill/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/whatpulse-ai-agent-skill/agent.md"
  },
  "agentAssist": {
    "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
    "steps": [
      "Download the package from Yavira.",
      "Extract it into a folder your agent can access.",
      "Paste one of the prompts below and point your agent at the extracted folder."
    ],
    "prompts": [
      {
        "label": "New install",
        "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Then review README.md for any prerequisites, environment setup, or post-install checks. Tell me what you changed and call out any manual steps you could not complete."
      },
      {
        "label": "Upgrade existing",
        "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Then review README.md for any prerequisites, environment setup, or post-install checks. Summarize what changed and any follow-up checks I should run."
      }
    ]
  },
  "documentation": {
    "source": "clawhub",
    "primaryDoc": "SKILL.md",
    "sections": [
      {
        "title": "WhatPulse Statistics Analyst",
        "body": "You help the user explore their WhatPulse computer usage data: keystrokes, mouse activity, application usage, network bandwidth, uptime, and more. Answer natural language questions by querying the local SQLite database.\n\nThe user asked: $ARGUMENTS"
      },
      {
        "title": "CRITICAL SAFETY RULES: READ-ONLY ACCESS ONLY",
        "body": "ALL queries MUST use sqlite3 -readonly. No exceptions.\nNEVER run INSERT, UPDATE, DELETE, DROP, ALTER, CREATE, ATTACH, VACUUM, or PRAGMA statements that write.\nNEVER use WAL mode or any operation that creates journal/lock files.\nIf a query fails, diagnose. Do NOT attempt workarounds that might write to disk.\n\nQuery format: ALWAYS use a heredoc to pass SQL to sqlite3. This avoids shell interpretation issues (e.g. ! in != triggers bash history expansion inside double quotes). NEVER pass SQL as a quoted string argument. Always use this exact pattern:\n\nsqlite3 -readonly \"<DB_PATH>\" -header -column <<'QUERY'\nSELECT ... FROM ... WHERE day != '0000-00-00'\nQUERY\n\nThe <<'QUERY' (with single quotes around the delimiter) ensures the shell does not interpret any characters inside the SQL. This is mandatory. Do not use -e, inline strings, or double-quoted SQL arguments."
      },
      {
        "title": "Finding the Database",
        "body": "Check these locations in order. Use the first one found.\n\n$WHATPULSE_DB environment variable (if set; enables remote/synced access)\nPlatform-specific default paths:\n\nmacOS: ~/Library/Application Support/WhatPulse/whatpulse.db\nWindows: %LOCALAPPDATA%\\WhatPulse\\whatpulse.db\nLinux: ~/.config/whatpulse/whatpulse.db\n\n\nwhatpulse.db in the current working directory\n\nRun a quick check at the start:\n\n# macOS/Linux\nDB=\"${WHATPULSE_DB:-}\" && [ -z \"$DB\" ] && for p in \"$HOME/Library/Application Support/WhatPulse/whatpulse.db\" \"$LOCALAPPDATA/WhatPulse/whatpulse.db\" \"$HOME/.config/whatpulse/whatpulse.db\" \"./whatpulse.db\"; do [ -f \"$p\" ] && DB=\"$p\" && break; done && echo \"DB: $DB\""
      },
      {
        "title": "Input: Keyboard",
        "body": "TableGranularityKey Columnskeypressesday + hourcount, profile_idkeypress_frequencyday + hour + keykey (Qt key code), count, profile_idkeypress_frequency_applicationday + hour + key + pathsame + pathkeycombo_frequencyday + hour + combocombo (format: \"shift,command,65\"), count, profile_idkeycombo_frequency_applicationday + hour + combo + pathsame + path"
      },
      {
        "title": "Input: Mouse",
        "body": "TableGranularityKey Columnsmouseclicksday + hourcount, profile_idmouseclicks_frequencyday + hour + buttonbutton, count, profile_idmouseclicks_frequency_applicationday + hour + button + pathsame + pathmousedistanceday + hourdistance_inches, profile_idmousescrollsday + hour + directiondirection (1=up,2=down,3=left,4=right), count, profile_idmousepointsday + hourx, y, display_id (heatmap coordinates)"
      },
      {
        "title": "Applications",
        "body": "TableKey Columnsapplicationspath (PK), name, bundle_identifier, app_category, vendor_name, version, server_category, server_tagsinput_per_applicationday + hour + path, keys, clicks, distance_inches, scrolls, profile_idapplication_active_hourday + hour + path, msec_active, profile_idapplication_activeuptime_hourday + hour + path, msec_active, profile_idapplication_uptimepath, time (total seconds), last_active, last_used, profile_idapplication_bandwidthday + hour + path, download, upload (bytes), profile_idapplications_upgradespath, previous_version, current_version, upgrade_datepending_applications_statspath, keys, clicks, download, upload, uptime, distance_inches, scrolls"
      },
      {
        "title": "Network",
        "body": "TableKey Columnsnetwork_interface_bandwidthday + hour + mac_address, download, upload (bytes)country_bandwidthday + hour + country (2-letter code), download, upload, profile_idnetwork_protocol_bandwidthday + hour + protocol + port_number, download, upload, profile_idnetwork_interfacesmac_address, description, wifi (bool), ip_list"
      },
      {
        "title": "Uptime and System",
        "body": "TableKey Columnsuptimesboot_time, end_time (each boot session)uptime_hourday + hour, msec_active, profile_idactiveuptime_hourday + hour, msec_active, profile_idprofilesid, name, active (bool), managedcomputer_infoname, value (hardware specs)settingsname, valueunpulsed_statsname, value (stats not yet synced to server)"
      },
      {
        "title": "Websites",
        "body": "TableKey Columnswebsite_domainsid, domain, first_seen_at, last_seen_atwebsite_time_seriesday_utc + hour_utc + domain_id + app_identifier, active_seconds, key_count, click_count, scrolls, mouse_distance_in, profile_id"
      },
      {
        "title": "Other",
        "body": "TablePurposefactBuilt-in insight queries from WhatPulse (SQL in data_query column)milestones / milestones_logUser-defined milestonesinput_controllersConnected controllers (gamepads, etc.)application_ignore / network_interfaces_ignore / website_domains_ignoreExcluded items"
      },
      {
        "title": "Qt Key Code Mapping",
        "body": "The key column in frequency tables uses Qt key codes. Common mappings:\n\nPrintable ASCII: codes 32 to 126 map directly. 32=Space, 48 to 57=0 to 9, 65 to 90=A to Z, etc.\n\nSpecial keys:\n\nCodeKeyCodeKey16777216Escape16777217Tab16777219Backspace16777220Return16777221Enter (numpad)16777222Insert16777223Delete16777232Home16777233End16777234Left Arrow16777235Up Arrow16777236Right Arrow16777237Down Arrow16777238Page Up16777239Page Down16777248Shift16777249Control16777250Meta/Super16777251Alt/Option16777252CapsLock16777264 to 16777275F1 to F12\n\nCombo format: modifier names joined by commas, then the key code. Example: shift,command,65 = Shift+Cmd+A.\n\nWhen displaying key frequencies, map codes to readable names. For unmapped codes, show the raw number with a note."
      },
      {
        "title": "Important Query Patterns",
        "body": "Always JOIN applications to get readable names:\n\nSELECT a.name, SUM(i.keys) as total_keys\nFROM input_per_application i\nJOIN applications a ON a.path = i.path\nGROUP BY i.path ORDER BY total_keys DESC LIMIT 10;\n\nAlways JOIN website_domains for domain names:\n\nSELECT d.domain, SUM(w.active_seconds) as seconds\nFROM website_time_series w\nJOIN website_domains d ON d.id = w.domain_id\nGROUP BY w.domain_id ORDER BY seconds DESC LIMIT 10;\n\nFilter out null dates: Many tables may have '0000-00-00' placeholder dates. Always filter with WHERE day != '0000-00-00'.\n\nProfile filtering: If the user asks about a specific work context, filter by profile_id after looking up the profile name in profiles. If they do not specify, aggregate across all profiles but mention the breakdown is available.\n\nUnit conversions to use when presenting results:\n\nBytes to human-readable: divide by 1024/1048576/1073741824 for KB/MB/GB\nInches to miles: divide by 63,360\nInches to kilometers: divide by 39,370\nMilliseconds to hours: divide by 3,600,000\nSeconds to hours: divide by 3,600"
      },
      {
        "title": "When no question is asked (empty $ARGUMENTS)",
        "body": "Provide a quick daily briefing by running these queries:\n\nToday's stats: total keys, clicks, scrolls, mouse distance, bandwidth\nCompare today vs the user's daily average\nCurrently active profile\nTop 5 apps by keystrokes today\nOne interesting insight (pick from the fact table queries or generate your own)"
      },
      {
        "title": "When a question is asked",
        "body": "Determine which tables are relevant\nWrite and run the appropriate SQL query (read-only!)\nPresent results in a clear, conversational format\nUse tables or lists for multi-row results\nAdd context: comparisons to averages, trends, or notable patterns"
      },
      {
        "title": "Proactive insights to offer",
        "body": "When relevant to the user's question, mention things like:\n\nAnomalies: \"Today is 40% above your daily average\"\nStreaks: consecutive days of high/low activity\nTrends: week-over-week or month-over-month changes\nRecords: all-time highs being approached\nApp shifts: significant changes in application usage patterns\nLate-night activity: working outside normal hours\nProfile patterns: how different work contexts compare"
      },
      {
        "title": "Formatting",
        "body": "Use markdown tables for tabular data\nRound numbers sensibly (no excessive decimals)\nUse human-friendly units (GB not bytes, miles not inches, hours not ms)\nFor time-of-day, use 24h format with :00 suffix\nFor dates, use YYYY-MM-DD\nKeep responses concise: data first, commentary second"
      },
      {
        "title": "Remote / Synced Database Access",
        "body": "For remote instances (e.g., OpenClaw running on a different machine), the database can be made available by:\n\nCloud sync: Copy the DB to a synced folder (Dropbox, OneDrive, iCloud). Use sqlite3 original.db \".backup '/path/to/synced/copy.db'\" for a safe snapshot.\nSet the env var: export WHATPULSE_DB=\"/path/to/synced/whatpulse.db\" on the remote machine.\nCron/scheduled task for periodic sync:\n# Example: sync every 4 hours on macOS/Linux\n0 */4 * * * sqlite3 ~/Library/Application\\ Support/WhatPulse/whatpulse.db \".backup '/path/to/synced/whatpulse.db'\"\n\nThe .backup command creates a consistent snapshot even while WhatPulse is running."
      }
    ],
    "body": "WhatPulse Statistics Analyst\n\nYou help the user explore their WhatPulse computer usage data: keystrokes, mouse activity, application usage, network bandwidth, uptime, and more. Answer natural language questions by querying the local SQLite database.\n\nThe user asked: $ARGUMENTS\n\nCRITICAL SAFETY RULES: READ-ONLY ACCESS ONLY\nALL queries MUST use sqlite3 -readonly. No exceptions.\nNEVER run INSERT, UPDATE, DELETE, DROP, ALTER, CREATE, ATTACH, VACUUM, or PRAGMA statements that write.\nNEVER use WAL mode or any operation that creates journal/lock files.\nIf a query fails, diagnose. Do NOT attempt workarounds that might write to disk.\n\nQuery format: ALWAYS use a heredoc to pass SQL to sqlite3. This avoids shell interpretation issues (e.g. ! in != triggers bash history expansion inside double quotes). NEVER pass SQL as a quoted string argument. Always use this exact pattern:\n\nsqlite3 -readonly \"<DB_PATH>\" -header -column <<'QUERY'\nSELECT ... FROM ... WHERE day != '0000-00-00'\nQUERY\n\n\nThe <<'QUERY' (with single quotes around the delimiter) ensures the shell does not interpret any characters inside the SQL. This is mandatory. Do not use -e, inline strings, or double-quoted SQL arguments.\n\nFinding the Database\n\nCheck these locations in order. Use the first one found.\n\n$WHATPULSE_DB environment variable (if set; enables remote/synced access)\nPlatform-specific default paths:\nmacOS: ~/Library/Application Support/WhatPulse/whatpulse.db\nWindows: %LOCALAPPDATA%\\WhatPulse\\whatpulse.db\nLinux: ~/.config/whatpulse/whatpulse.db\nwhatpulse.db in the current working directory\n\nRun a quick check at the start:\n\n# macOS/Linux\nDB=\"${WHATPULSE_DB:-}\" && [ -z \"$DB\" ] && for p in \"$HOME/Library/Application Support/WhatPulse/whatpulse.db\" \"$LOCALAPPDATA/WhatPulse/whatpulse.db\" \"$HOME/.config/whatpulse/whatpulse.db\" \"./whatpulse.db\"; do [ -f \"$p\" ] && DB=\"$p\" && break; done && echo \"DB: $DB\"\n\nSchema Quick Reference\nInput: Keyboard\nTable\tGranularity\tKey Columns\nkeypresses\tday + hour\tcount, profile_id\nkeypress_frequency\tday + hour + key\tkey (Qt key code), count, profile_id\nkeypress_frequency_application\tday + hour + key + path\tsame + path\nkeycombo_frequency\tday + hour + combo\tcombo (format: \"shift,command,65\"), count, profile_id\nkeycombo_frequency_application\tday + hour + combo + path\tsame + path\nInput: Mouse\nTable\tGranularity\tKey Columns\nmouseclicks\tday + hour\tcount, profile_id\nmouseclicks_frequency\tday + hour + button\tbutton, count, profile_id\nmouseclicks_frequency_application\tday + hour + button + path\tsame + path\nmousedistance\tday + hour\tdistance_inches, profile_id\nmousescrolls\tday + hour + direction\tdirection (1=up,2=down,3=left,4=right), count, profile_id\nmousepoints\tday + hour\tx, y, display_id (heatmap coordinates)\nApplications\nTable\tKey Columns\napplications\tpath (PK), name, bundle_identifier, app_category, vendor_name, version, server_category, server_tags\ninput_per_application\tday + hour + path, keys, clicks, distance_inches, scrolls, profile_id\napplication_active_hour\tday + hour + path, msec_active, profile_id\napplication_activeuptime_hour\tday + hour + path, msec_active, profile_id\napplication_uptime\tpath, time (total seconds), last_active, last_used, profile_id\napplication_bandwidth\tday + hour + path, download, upload (bytes), profile_id\napplications_upgrades\tpath, previous_version, current_version, upgrade_date\npending_applications_stats\tpath, keys, clicks, download, upload, uptime, distance_inches, scrolls\nNetwork\nTable\tKey Columns\nnetwork_interface_bandwidth\tday + hour + mac_address, download, upload (bytes)\ncountry_bandwidth\tday + hour + country (2-letter code), download, upload, profile_id\nnetwork_protocol_bandwidth\tday + hour + protocol + port_number, download, upload, profile_id\nnetwork_interfaces\tmac_address, description, wifi (bool), ip_list\nUptime and System\nTable\tKey Columns\nuptimes\tboot_time, end_time (each boot session)\nuptime_hour\tday + hour, msec_active, profile_id\nactiveuptime_hour\tday + hour, msec_active, profile_id\nprofiles\tid, name, active (bool), managed\ncomputer_info\tname, value (hardware specs)\nsettings\tname, value\nunpulsed_stats\tname, value (stats not yet synced to server)\nWebsites\nTable\tKey Columns\nwebsite_domains\tid, domain, first_seen_at, last_seen_at\nwebsite_time_series\tday_utc + hour_utc + domain_id + app_identifier, active_seconds, key_count, click_count, scrolls, mouse_distance_in, profile_id\nOther\nTable\tPurpose\nfact\tBuilt-in insight queries from WhatPulse (SQL in data_query column)\nmilestones / milestones_log\tUser-defined milestones\ninput_controllers\tConnected controllers (gamepads, etc.)\napplication_ignore / network_interfaces_ignore / website_domains_ignore\tExcluded items\nQt Key Code Mapping\n\nThe key column in frequency tables uses Qt key codes. Common mappings:\n\nPrintable ASCII: codes 32 to 126 map directly. 32=Space, 48 to 57=0 to 9, 65 to 90=A to Z, etc.\n\nSpecial keys:\n\nCode\tKey\tCode\tKey\n16777216\tEscape\t16777217\tTab\n16777219\tBackspace\t16777220\tReturn\n16777221\tEnter (numpad)\t16777222\tInsert\n16777223\tDelete\t16777232\tHome\n16777233\tEnd\t16777234\tLeft Arrow\n16777235\tUp Arrow\t16777236\tRight Arrow\n16777237\tDown Arrow\t16777238\tPage Up\n16777239\tPage Down\t16777248\tShift\n16777249\tControl\t16777250\tMeta/Super\n16777251\tAlt/Option\t16777252\tCapsLock\n16777264 to 16777275\tF1 to F12\t\t\n\nCombo format: modifier names joined by commas, then the key code. Example: shift,command,65 = Shift+Cmd+A.\n\nWhen displaying key frequencies, map codes to readable names. For unmapped codes, show the raw number with a note.\n\nImportant Query Patterns\n\nAlways JOIN applications to get readable names:\n\nSELECT a.name, SUM(i.keys) as total_keys\nFROM input_per_application i\nJOIN applications a ON a.path = i.path\nGROUP BY i.path ORDER BY total_keys DESC LIMIT 10;\n\n\nAlways JOIN website_domains for domain names:\n\nSELECT d.domain, SUM(w.active_seconds) as seconds\nFROM website_time_series w\nJOIN website_domains d ON d.id = w.domain_id\nGROUP BY w.domain_id ORDER BY seconds DESC LIMIT 10;\n\n\nFilter out null dates: Many tables may have '0000-00-00' placeholder dates. Always filter with WHERE day != '0000-00-00'.\n\nProfile filtering: If the user asks about a specific work context, filter by profile_id after looking up the profile name in profiles. If they do not specify, aggregate across all profiles but mention the breakdown is available.\n\nUnit conversions to use when presenting results:\n\nBytes to human-readable: divide by 1024/1048576/1073741824 for KB/MB/GB\nInches to miles: divide by 63,360\nInches to kilometers: divide by 39,370\nMilliseconds to hours: divide by 3,600,000\nSeconds to hours: divide by 3,600\nBehavior\nWhen no question is asked (empty $ARGUMENTS)\n\nProvide a quick daily briefing by running these queries:\n\nToday's stats: total keys, clicks, scrolls, mouse distance, bandwidth\nCompare today vs the user's daily average\nCurrently active profile\nTop 5 apps by keystrokes today\nOne interesting insight (pick from the fact table queries or generate your own)\nWhen a question is asked\nDetermine which tables are relevant\nWrite and run the appropriate SQL query (read-only!)\nPresent results in a clear, conversational format\nUse tables or lists for multi-row results\nAdd context: comparisons to averages, trends, or notable patterns\nProactive insights to offer\n\nWhen relevant to the user's question, mention things like:\n\nAnomalies: \"Today is 40% above your daily average\"\nStreaks: consecutive days of high/low activity\nTrends: week-over-week or month-over-month changes\nRecords: all-time highs being approached\nApp shifts: significant changes in application usage patterns\nLate-night activity: working outside normal hours\nProfile patterns: how different work contexts compare\nFormatting\nUse markdown tables for tabular data\nRound numbers sensibly (no excessive decimals)\nUse human-friendly units (GB not bytes, miles not inches, hours not ms)\nFor time-of-day, use 24h format with :00 suffix\nFor dates, use YYYY-MM-DD\nKeep responses concise: data first, commentary second\nRemote / Synced Database Access\n\nFor remote instances (e.g., OpenClaw running on a different machine), the database can be made available by:\n\nCloud sync: Copy the DB to a synced folder (Dropbox, OneDrive, iCloud). Use sqlite3 original.db \".backup '/path/to/synced/copy.db'\" for a safe snapshot.\nSet the env var: export WHATPULSE_DB=\"/path/to/synced/whatpulse.db\" on the remote machine.\nCron/scheduled task for periodic sync:\n# Example: sync every 4 hours on macOS/Linux\n0 */4 * * * sqlite3 ~/Library/Application\\ Support/WhatPulse/whatpulse.db \".backup '/path/to/synced/whatpulse.db'\"\n\n\nThe .backup command creates a consistent snapshot even while WhatPulse is running."
  },
  "trust": {
    "sourceLabel": "tencent",
    "provenanceUrl": "https://clawhub.ai/smitmartijn/whatpulse-ai-agent-skill",
    "publisherUrl": "https://clawhub.ai/smitmartijn/whatpulse-ai-agent-skill",
    "owner": "smitmartijn",
    "version": "1.0.0",
    "license": null,
    "verificationStatus": "Indexed source record"
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/whatpulse-ai-agent-skill",
    "downloadUrl": "https://openagent3.xyz/downloads/whatpulse-ai-agent-skill",
    "agentUrl": "https://openagent3.xyz/skills/whatpulse-ai-agent-skill/agent",
    "manifestUrl": "https://openagent3.xyz/skills/whatpulse-ai-agent-skill/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/whatpulse-ai-agent-skill/agent.md"
  }
}