home / skills / composiohq / awesome-claude-skills / facebook-automation

facebook-automation skill

/facebook-automation

This skill automates Facebook Page management by creating, scheduling posts and videos, and handling Messenger conversations via Composio.

npx playbooks add skill composiohq/awesome-claude-skills --skill facebook-automation

Review the files below or copy the command above to add this skill to your agents.

Files (1)
SKILL.md
7.1 KB
---
name: Facebook Automation
description: "Automate Facebook Page management including post creation, scheduling, video uploads, Messenger conversations, and audience engagement via Composio"
requires:
  mcp:
    - rube
---

# Facebook Automation

Automate Facebook Page operations -- create and schedule posts, upload videos, manage Messenger conversations, retrieve page insights, and handle scheduled content -- all orchestrated through the Composio MCP integration.

**Toolkit docs:** [composio.dev/toolkits/facebook](https://composio.dev/toolkits/facebook)

---

## Setup

1. Connect your Facebook account through the Composio MCP server at `https://rube.app/mcp`
2. The agent will prompt you with an authentication link if no active connection exists
3. Once connected, all `FACEBOOK_*` tools become available for execution
4. **Note:** This toolkit supports Facebook Pages only, not personal Facebook accounts

---

## Core Workflows

### 1. Discover Managed Pages
List all Facebook Pages you manage to get page IDs and access tokens for subsequent operations.

**Tool:** `FACEBOOK_LIST_MANAGED_PAGES`

| Parameter | Type | Required | Description |
|-----------|------|----------|-------------|
| `fields` | string | No | Comma-separated fields (default: `id,name,access_token,category,tasks,about,link,picture`) |
| `limit` | integer | No | Max pages per request (default: 25) |
| `user_id` | string | No | User ID (default: `me`) |

**Always run this first** to cache `page_id` values. Avoid repeating discovery calls -- cache the results.

---

### 2. Create & Schedule Posts
Publish or schedule text posts with optional links on a Facebook Page.

**Tool:** `FACEBOOK_CREATE_POST`

| Parameter | Type | Required | Description |
|-----------|------|----------|-------------|
| `page_id` | string | Yes | Numeric Page ID from managed pages |
| `message` | string | Yes | Text content of the post |
| `published` | boolean | No | `true` to publish immediately, `false` for draft/scheduled (default: true) |
| `scheduled_publish_time` | integer | No | Unix UTC timestamp; must be at least 10 minutes in the future |
| `link` | string | No | URL to include in the post |
| `targeting` | object | No | Audience targeting specifications |

**When scheduling:** Set `published=false` and provide `scheduled_publish_time` as a Unix UTC timestamp.

---

### 3. Create & Schedule Video Posts
Upload and schedule video content on a Facebook Page.

**Tool:** `FACEBOOK_CREATE_VIDEO_POST`

| Parameter | Type | Required | Description |
|-----------|------|----------|-------------|
| `page_id` | string | Yes | Numeric Page ID |
| `file_url` | string | Conditional | URL of the video file (provide `file_url` or `video`) |
| `video` | object | Conditional | Local file upload with `name`, `mimetype`, `s3key` |
| `title` | string | No | Video title |
| `description` | string | No | Video description |
| `published` | boolean | No | Publish immediately (default: true) |
| `scheduled_publish_time` | integer | No | Unix timestamp for scheduled publishing |

---

### 4. Manage Scheduled Posts
Review, reschedule, update, or publish scheduled content.

**Tools:**

- **`FACEBOOK_GET_SCHEDULED_POSTS`** -- List scheduled/unpublished posts for a page
  - `page_id` (required), `fields`, `limit` (max 100)
- **`FACEBOOK_RESCHEDULE_POST`** -- Change the scheduled publish time
- **`FACEBOOK_UPDATE_POST`** -- Edit caption/text on an existing post
- **`FACEBOOK_PUBLISH_SCHEDULED_POST`** -- Publish a scheduled post immediately

---

### 5. Read Page Messenger Conversations
Retrieve inbox conversations and message threads between users and your Page.

**Tool:** `FACEBOOK_GET_PAGE_CONVERSATIONS`

| Parameter | Type | Required | Description |
|-----------|------|----------|-------------|
| `page_id` | string | Yes | The Facebook Page ID |
| `fields` | string | No | Fields to return (default: `participants,updated_time,id`) |
| `limit` | integer | No | Conversations to return, max 25 |

Then retrieve full message threads:

**Tool:** `FACEBOOK_GET_CONVERSATION_MESSAGES`

| Parameter | Type | Required | Description |
|-----------|------|----------|-------------|
| `page_id` | string | Yes | Page ID that owns the conversation |
| `conversation_id` | string | Yes | Conversation ID in `t_` format (e.g., `t_3638640842939952`) |
| `fields` | string | No | Default: `id,created_time,from,to,message` |
| `limit` | integer | No | Messages to return, max 25 |

---

### 6. Send Messages & Mark as Seen
Respond to users via Messenger and mark messages as read.

**Tools:**

- **`FACEBOOK_SEND_MESSAGE`** -- Send a text message from the Page to a user via Messenger
- **`FACEBOOK_MARK_MESSAGE_SEEN`** -- Mark a user's message as seen by the Page

**Warning:** Both tools cause user-visible side effects. Only call after explicit confirmation.

---

## Known Pitfalls

| Pitfall | Details |
|---------|---------|
| **Scheduling too close to now** | `FACEBOOK_CREATE_POST` with `scheduled_publish_time` less than ~10 minutes in the future returns HTTP 400 -- enforce a larger buffer for bulk runs |
| **Unix UTC timestamps required** | `scheduled_publish_time` must be Unix UTC -- timezone conversion mistakes cause off-by-hours scheduling or validation failures |
| **Cursor-based pagination** | `FACEBOOK_GET_SCHEDULED_POSTS` and `FACEBOOK_GET_PAGE_CONVERSATIONS` return subsets -- follow paging cursors to get complete data |
| **Large conversation payloads** | Requesting embedded messages in conversations creates huge payloads -- use `FACEBOOK_GET_CONVERSATION_MESSAGES` for full threads instead |
| **Video processing delays** | Uploaded videos may remain in processing state -- only schedule via `FACEBOOK_CREATE_VIDEO_POST` after the upload is usable |
| **Cache page IDs** | Repeating `FACEBOOK_LIST_MANAGED_PAGES` calls adds latency -- cache `page_id` per workspace/run |
| **Pages only** | This toolkit does not support personal Facebook accounts -- only Facebook Pages |
| **Write operations need confirmation** | `FACEBOOK_SEND_MESSAGE` and `FACEBOOK_MARK_MESSAGE_SEEN` cause user-visible side effects -- only call after explicit user confirmation |

---

## Quick Reference

| Tool Slug | Purpose |
|-----------|---------|
| `FACEBOOK_LIST_MANAGED_PAGES` | List Pages you manage with access tokens |
| `FACEBOOK_GET_PAGE_DETAILS` | Get detailed info about a specific Page |
| `FACEBOOK_CREATE_POST` | Create or schedule a text/link post |
| `FACEBOOK_CREATE_VIDEO_POST` | Create or schedule a video post |
| `FACEBOOK_GET_SCHEDULED_POSTS` | List scheduled/unpublished posts |
| `FACEBOOK_RESCHEDULE_POST` | Change scheduled publish time |
| `FACEBOOK_UPDATE_POST` | Edit an existing post |
| `FACEBOOK_PUBLISH_SCHEDULED_POST` | Publish a scheduled post immediately |
| `FACEBOOK_UPLOAD_VIDEO` | Upload a video file to a Page |
| `FACEBOOK_GET_PAGE_CONVERSATIONS` | List Messenger inbox conversations |
| `FACEBOOK_GET_CONVERSATION_MESSAGES` | Retrieve messages from a conversation |
| `FACEBOOK_SEND_MESSAGE` | Send a Messenger message from the Page |
| `FACEBOOK_MARK_MESSAGE_SEEN` | Mark a message as seen |
| `FACEBOOK_GET_PAGE_POSTS` | Retrieve posts from a Page feed |
| `FACEBOOK_GET_USER_PAGES` | List Pages with tasks and tokens |

---

*Powered by [Composio](https://composio.dev)*

Overview

This skill automates Facebook Page management through the Composio MCP integration. It covers discovering managed Pages, creating and scheduling text and video posts, handling scheduled content, and managing Messenger conversations. The toolkit is Page-only and exposes tools for safe, repeatable automation.

How this skill works

Connect your Facebook account via the Composio MCP server. The agent discovers managed Pages and caches page_id and access tokens, then uses specific tool calls to create posts, upload videos, list and reschedule scheduled content, and read or respond to Messenger threads. Write operations require explicit confirmation to avoid user-visible side effects.

When to use it

  • Publish or schedule recurring posts across one or many Facebook Pages.
  • Upload and schedule video content while tracking processing state.
  • Automate inbox triage: list conversations and fetch message threads for review.
  • Reschedule or update many scheduled posts in bulk.
  • Send Messenger replies or mark messages seen after explicit approval.

Best practices

  • Always run FACEBOOK_LIST_MANAGED_PAGES first and cache page_id and access_token per workspace to avoid repeated discovery.
  • When scheduling, set published=false and provide a Unix UTC timestamp at least 10+ minutes in the future (use a larger buffer for bulk runs).
  • Use conversation pagination and FACEBOOK_GET_CONVERSATION_MESSAGES for full threads to avoid huge payloads.
  • Confirm any write actions that affect users (FACEBOOK_SEND_MESSAGE, FACEBOOK_MARK_MESSAGE_SEEN).
  • Wait for video uploads to finish processing before scheduling or publishing.

Example use cases

  • Schedule a month of posts across three managed Pages with staggered publish times.
  • Upload a product demo video, wait for processing, then schedule a premiere.
  • Automate daily inbox summaries: list recent conversations and fetch the latest messages for review.
  • Bulk-reschedule a set of postponed posts after a campaign date change.
  • Respond to a high-priority user message from the Page after human approval.

FAQ

Does this support personal Facebook profiles?

No. The toolkit works only with Facebook Pages, not personal accounts.

What timestamp format is required for scheduling?

Use Unix UTC timestamps. Convert local times to UTC to avoid off-by-hours errors.