← 返回
未分类 Key 中文

Keyapi Facebook Analysis

Explore and analyze public Facebook data — profile details, posts, photos, Reels, group activity, group events, and identifier resolution for profiles and gr...
Explore and analyze public Facebook data — profile details, posts, photos, Reels, group activity, group events, and identifier resolution for profiles and gr...
lycici
未分类 clawhub v1.0.0 1 版本 99635 Key: 需要
★ 0
Stars
📥 273
下载
💾 0
安装
1
版本
#latest

概述

keyapi-facebook-analysis

> Explore and analyze public Facebook profiles, pages, and groups — from profile details and content feeds to group activity, events, and identifier resolution.

This skill provides comprehensive public Facebook intelligence using the KeyAPI MCP service. It enables retrieval of profile details (by URL or numeric ID), published posts, photos, Reels, group details, group posts, future group events, and ID resolution for both profiles and groups — all through a unified, cache-first workflow.

Use this skill when you need to:

  • Retrieve a public Facebook profile's details, posts, photos, or Reels by URL
  • Resolve a profile URL to its numeric profile ID for downstream API calls
  • Analyze public Facebook group activity — posts, member details, and upcoming events
  • Resolve a group URL to its numeric group ID
  • Research brand pages, public figures, or community groups on Facebook

author: KeyAPI

license: MIT

repository: https://github.com/EchoSell/keyapi-skills


Prerequisites

RequirementDetails
----------------------
KEYAPI_TOKENA valid API token from keyapi.ai. Register at the site to obtain your free token. Set it as an environment variable: export KEYAPI_TOKEN=your_token_here
Node.jsv18 or higher
DependenciesRun npm install in the skill directory to install @modelcontextprotocol/sdk

author: KeyAPI

license: MIT

repository: https://github.com/EchoSell/keyapi-skills


MCP Server Configuration

All tool calls in this skill target the KeyAPI Facebook MCP server:

Server URL : https://mcp.keyapi.ai/facebook/mcp
Auth Header: Authorization: Bearer $KEYAPI_TOKEN

Setup (one-time):

# 1. Install dependencies
npm install

# 2. Set your API token (get one free at https://keyapi.ai/)
export KEYAPI_TOKEN=your_token_here

# 3. List all available tools to verify the connection
node scripts/run.js --platform facebook --list-tools

author: KeyAPI

license: MIT

repository: https://github.com/EchoSell/keyapi-skills


Analysis Scenarios

User NeedNode(s)Best For
------------------------------
Full profile details from a URLprofile_details_by_urlQuick profile snapshot without knowing the numeric ID
Resolve profile URL → numeric IDget_profile_idID resolution for use with profile_posts, profiles_photos, profile_reels
Profile details by numeric IDprofiles_details_by_idProfile lookup when ID is already known
Published posts from a profile/pageprofile_postsContent feed analysis, posting cadence
Photos from a profile/pageprofiles_photosVisual content audit, photo library
Reels from a profile/pageprofile_reelsShort-video content analysis
Group details from a URLget_group_detailsGroup overview, member count, description
Resolve group URL → numeric group IDget_group_idID resolution for get_group_posts and get_group_future_events
Posts from a public groupget_group_postsGroup activity monitoring, content analysis
Upcoming events in a groupget_group_future_eventsEvent discovery, community activity tracking

author: KeyAPI

license: MIT

repository: https://github.com/EchoSell/keyapi-skills


Workflow

Step 1 — Identify Analysis Targets and Select Nodes

Clarify the research objective and map it to one or more nodes. Typical entry points:

  • Profile research by URL: Use profile_details_by_url for a quick snapshot, OR use get_profile_id to obtain the numeric profile_id then call profiles_details_by_id.
  • Profile content audit: Call get_profile_id first, then use profile_posts, profiles_photos, profile_reels with the numeric ID.
  • Group research: Use get_group_details with the full URL, then get_group_id to obtain group_id for get_group_posts and get_group_future_events.

> Critical: Three Distinct Identifier Types

>

> Facebook endpoints require different identifiers depending on the endpoint:

>

> | Identifier | Format | Used by |

> |---|---|---|

> | Profile URL | Full URL, e.g., https://www.facebook.com/mantraindianfolsom | profile_details_by_url, get_profile_id |

> | Numeric profile ID | Integer string, e.g., 100063669491743 | profile_posts, profiles_photos, profiles_details_by_id |

> | reels_profile_id | Base64 collection ID (opaque string) | profile_reels only |

> | Group URL | Full group URL, e.g., https://www.facebook.com/groups/1270525996445602/ | get_group_details, get_group_id |

> | Numeric group ID | Integer string, e.g., 1439220986320043 | get_group_posts, get_group_future_events |

> profile_reels — Special reels_profile_id

>

> profile_reels uses a distinct reels_profile_id parameter that is NOT the same as the numeric profile_id. This opaque base64 collection ID is obtained from the profile_details_by_url or profiles_details_by_id response data. You cannot derive it from the numeric profile ID alone.

>

> Workflow: profile_details_by_url (or get_profile_idprofiles_details_by_id) → extract reels_profile_id from response → call profile_reels.

> Public Content Only

>

> All endpoints in this skill return data from public Facebook profiles, pages, and groups only. Private profiles, private groups, and content requiring login cannot be accessed.

Step 2 — Retrieve API Schema

Before calling any node, inspect its input schema to confirm required parameters and available options:

node scripts/run.js --platform facebook --schema <tool_name>

# Examples
node scripts/run.js --platform facebook --schema profile_details_by_url
node scripts/run.js --platform facebook --schema get_group_posts

Step 3 — Call APIs and Cache Results Locally

Execute tool calls and persist responses to the local cache to avoid redundant API calls.

Calling a tool:

# Single call with pretty output
node scripts/run.js --platform facebook --tool <tool_name> \
  --params '<json_args>' --pretty

# Force fresh data, skip cache
node scripts/run.js --platform facebook --tool <tool_name> \
  --params '<json_args>' --no-cache --pretty

Example — get profile details by URL:

node scripts/run.js --platform facebook --tool profile_details_by_url \
  --params '{"url":"https://www.facebook.com/mantraindianfolsom"}' --pretty

Example — resolve URL to profile ID, then get posts:

# Step 1: resolve URL to numeric profile_id
node scripts/run.js --platform facebook --tool get_profile_id \
  --params '{"url":"https://www.facebook.com/mantraindianfolsom"}' --pretty

# Step 2: get posts using numeric profile_id
node scripts/run.js --platform facebook --tool profile_posts \
  --params '{"profile_id":"100063669491743"}' --pretty

Example — get next page of posts using cursor:

node scripts/run.js --platform facebook --tool profile_posts \
  --params '{"profile_id":"100063669491743","cursor":"<cursor_from_previous_response>"}' --pretty

Example — get profile Reels (requires reels_profile_id from profile details):

# Step 1: get profile details to obtain reels_profile_id
node scripts/run.js --platform facebook --tool profile_details_by_url \
  --params '{"url":"https://www.facebook.com/examplepage"}' --pretty
# Extract reels_profile_id from response

# Step 2: get reels using reels_profile_id
node scripts/run.js --platform facebook --tool profile_reels \
  --params '{"reels_profile_id":"<reels_profile_id_from_response>"}' --pretty

Example — resolve group URL, then get posts:

# Step 1: resolve group URL to numeric group_id
node scripts/run.js --platform facebook --tool get_group_id \
  --params '{"url":"https://www.facebook.com/groups/1270525996445602/"}' --pretty

# Step 2: get group posts
node scripts/run.js --platform facebook --tool get_group_posts \
  --params '{"group_id":"1439220986320043","sorting_order":"CHRONOLOGICAL"}' --pretty

Example — get group details and future events:

node scripts/run.js --platform facebook --tool get_group_details \
  --params '{"url":"https://www.facebook.com/groups/1270525996445602/"}' --pretty

node scripts/run.js --platform facebook --tool get_group_future_events \
  --params '{"group_id":"1571965316444595"}' --pretty

Pagination:

EndpointPagination parameterNotes
---------
profile_posts, get_group_posts, get_group_future_eventscursor (string)Pass cursor from previous response; omit for first call
profiles_photoscursor (string)Also accepts optional collection_id to scope to a specific album
profile_reelscursor (string)Pass cursor from previous response; omit for first call
profile_details_by_url, profiles_details_by_id, get_profile_id, get_group_details, get_group_idSingle-call response

get_group_posts sorting options:

ValueDescription
------
CHRONOLOGICALMost recent posts first (default)
TOP_POSTSHighest engagement posts first
RECENT_ACTIVITYPosts with recent activity (comments/reactions)
CHRONOLOGICAL_LISTINGSChronological order for listing-type posts

Cache directory structure:

.keyapi-cache/
└── YYYY-MM-DD/
    ├── profile_details_by_url/
    │   └── {params_hash}.json
    ├── profile_posts/
    │   └── {params_hash}.json
    ├── profiles_photos/
    │   └── {params_hash}.json
    ├── profile_reels/
    │   └── {params_hash}.json
    ├── profiles_details_by_id/
    │   └── {params_hash}.json
    ├── get_profile_id/
    │   └── {params_hash}.json
    ├── get_group_posts/
    │   └── {params_hash}.json
    ├── get_group_details/
    │   └── {params_hash}.json
    ├── get_group_id/
    │   └── {params_hash}.json
    └── get_group_future_events/
        └── {params_hash}.json

Cache-first policy:

Before every API call, check whether a cached result already exists for the given parameters. If a valid cache file exists, load from disk and skip the API call.

Step 4 — Synthesize and Report Findings

After collecting all API responses, produce a structured intelligence report:

For profile/page analysis:

  1. Profile Overview — Name, numeric ID, profile type (personal/page), bio, follower count, verification status, category.
  2. Content Inventory — Post count, photo count, Reels count, posting frequency, content type distribution.
  3. Engagement Signals — Reaction counts, comment counts, share counts on posts.
  4. Visual Content — Photo collections, album topics, Reels themes.

For group analysis:

  1. Group Overview — Name, numeric group ID, member count, privacy type (public), description, creation date.
  2. Activity Profile — Post frequency, top contributors, discussion themes.
  3. Event Calendar — Upcoming events, event type, organizer, date/time distribution.

author: KeyAPI

license: MIT

repository: https://github.com/EchoSell/keyapi-skills


Common Rules

RuleDetail
--------------
Profile ID resolutionprofile_posts, profiles_photos, profiles_details_by_id require the numeric profile_id. Use get_profile_id or profile_details_by_url to obtain it from a URL.
profile_reels identifierRequires reels_profile_id (a base64 collection ID), NOT the numeric profile_id. Extract it from profile_details_by_url or profiles_details_by_id response.
Group ID resolutionget_group_posts and get_group_future_events require numeric group_id. Use get_group_id with the full group URL to obtain it.
Public content onlyAll endpoints return data from public profiles, pages, and groups only. Private content is inaccessible.
Cursor paginationUse cursor from the previous response for all paginated endpoints. Omit for the first call.
profiles_photos collectionPass optional collection_id to scope photo results to a specific album. Leave empty to fetch all photos.
Success checkcode = 0 → success. Any other value → failure. Always check the response code before processing data.
Retry on 500If code = 500, retry the identical request up to 3 times with a 2–3 second pause between attempts before reporting the error.
Cache firstAlways check the local .keyapi-cache/ directory before issuing a live API call.

author: KeyAPI

license: MIT

repository: https://github.com/EchoSell/keyapi-skills


Error Handling

CodeMeaningAction
-----------------------
0SuccessContinue workflow normally
400Bad request — invalid or missing parametersValidate URL format; ensure numeric IDs are strings, not integers; check reels_profile_id source
401Unauthorized — token missing or expiredConfirm KEYAPI_TOKEN is set correctly; visit keyapi.ai to renew
403Forbidden — plan quota exceeded or feature restrictedReview plan limits at keyapi.ai
404Resource not found — profile or group may be private or deletedVerify the URL; private profiles and groups cannot be accessed
429Rate limit exceededWait 60 seconds, then retry
500Internal server errorRetry up to 3 times with a 2–3 second pause; if it persists, log the full request and response and skip this node
Other non-0Unexpected errorLog the full response body and surface the error message to the user

版本历史

共 1 个版本

  • v1.0.0 当前
    2026-05-07 19:14 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

Keyapi Instagram Content Discovery

lycici
大规模探索和发现 Instagram 内容 — 搜索帖子、Reels、话题标签、音乐、地点和 Explore 版块,以获取趋势和受众信号。
★ 0 📥 287

Keyapi Amazon Ecommerce

lycici
大规模探索和分析亚马逊电商数据——产品搜索、类目浏览、商品详情、畅销榜、优惠、卖家情报、影响力...
★ 0 📥 298

Keyapi Instagram User Analysis

lycici
发现、分析和深入剖析 Instagram 用户 — 探索关注者/关注网络、帖子、Reels、Stories、精选、标记内容、转帖等。
★ 0 📥 279