← Back to Skills Marketplace
sohamganatra

Canva Automation

by sohamganatra · GitHub ↗ · v0.1.0
cross-platform ✓ Security Clean
2196
Downloads
1
Stars
8
Active Installs
1
Versions
Install in OpenClaw
/install canva-automation
Description
Automate Canva tasks via Rube MCP (Composio): designs, exports, folders, brand templates, autofill. Always search tools first for current schemas.
README (SKILL.md)

Canva Automation via Rube MCP

Automate Canva design operations through Composio's Canva toolkit via Rube MCP.

Prerequisites

  • Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
  • Active Canva connection via RUBE_MANAGE_CONNECTIONS with toolkit canva
  • Always call RUBE_SEARCH_TOOLS first to get current tool schemas

Setup

Get Rube MCP: Add https://rube.app/mcp as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.

  1. Verify Rube MCP is available by confirming RUBE_SEARCH_TOOLS responds
  2. Call RUBE_MANAGE_CONNECTIONS with toolkit canva
  3. If connection is not ACTIVE, follow the returned auth link to complete Canva OAuth
  4. Confirm connection status shows ACTIVE before running any workflows

Core Workflows

1. List and Browse Designs

When to use: User wants to find existing designs or browse their Canva library

Tool sequence:

  1. CANVA_LIST_USER_DESIGNS - List all designs with optional filters [Required]

Key parameters:

  • query: Search term to filter designs by name
  • continuation: Pagination token from previous response
  • ownership: Filter by 'owned', 'shared', or 'any'
  • sort_by: Sort field (e.g., 'modified_at', 'title')

Pitfalls:

  • Results are paginated; follow continuation token until absent
  • Deleted designs may still appear briefly; check design status
  • Search is substring-based, not fuzzy matching

2. Create and Design

When to use: User wants to create a new Canva design from scratch or from a template

Tool sequence:

  1. CANVA_ACCESS_USER_SPECIFIC_BRAND_TEMPLATES_LIST - Browse available brand templates [Optional]
  2. CANVA_CREATE_CANVA_DESIGN_WITH_OPTIONAL_ASSET - Create a new design [Required]

Key parameters:

  • design_type: Type of design (e.g., 'Presentation', 'Poster', 'SocialMedia')
  • title: Name for the new design
  • asset_id: Optional asset to include in the design
  • width / height: Custom dimensions in pixels

Pitfalls:

  • Design type must match Canva's predefined types exactly
  • Custom dimensions have minimum and maximum limits
  • Asset must be uploaded first via CANVA_CREATE_ASSET_UPLOAD_JOB before referencing

3. Upload Assets

When to use: User wants to upload images or files to Canva for use in designs

Tool sequence:

  1. CANVA_CREATE_ASSET_UPLOAD_JOB - Initiate the asset upload [Required]
  2. CANVA_FETCH_ASSET_UPLOAD_JOB_STATUS - Poll until upload completes [Required]

Key parameters:

  • name: Display name for the asset
  • url: Public URL of the file to upload (for URL-based uploads)
  • job_id: Upload job ID returned from step 1 (for status polling)

Pitfalls:

  • Upload is asynchronous; you MUST poll the job status until it completes
  • Supported formats include PNG, JPG, SVG, MP4, GIF
  • File size limits apply; large files may take longer to process
  • The job_id from CREATE returns the ID needed for status polling
  • Status values: 'in_progress', 'success', 'failed'

4. Export Designs

When to use: User wants to download or export a Canva design as PDF, PNG, or other format

Tool sequence:

  1. CANVA_LIST_USER_DESIGNS - Find the design to export [Prerequisite]
  2. CANVA_CREATE_CANVA_DESIGN_EXPORT_JOB - Start the export process [Required]
  3. CANVA_GET_DESIGN_EXPORT_JOB_RESULT - Poll until export completes and get download URL [Required]

Key parameters:

  • design_id: ID of the design to export
  • format: Export format ('pdf', 'png', 'jpg', 'svg', 'mp4', 'gif', 'pptx')
  • pages: Specific page numbers to export (array)
  • quality: Export quality ('regular', 'high')
  • job_id: Export job ID for polling status

Pitfalls:

  • Export is asynchronous; you MUST poll the job result until it completes
  • Download URLs from completed exports expire after a limited time
  • Large designs with many pages take longer to export
  • Not all formats support all design types (e.g., MP4 only for animations)
  • Poll interval: wait 2-3 seconds between status checks

5. Organize with Folders

When to use: User wants to create folders or organize designs into folders

Tool sequence:

  1. CANVA_POST_FOLDERS - Create a new folder [Required]
  2. CANVA_MOVE_ITEM_TO_SPECIFIED_FOLDER - Move designs into folders [Optional]

Key parameters:

  • name: Folder name
  • parent_folder_id: Parent folder for nested organization
  • item_id: ID of the design or asset to move
  • folder_id: Target folder ID

Pitfalls:

  • Folder names must be unique within the same parent folder
  • Moving items between folders updates their location immediately
  • Root-level folders have no parent_folder_id

6. Autofill from Brand Templates

When to use: User wants to generate designs by filling brand template placeholders with data

Tool sequence:

  1. CANVA_ACCESS_USER_SPECIFIC_BRAND_TEMPLATES_LIST - List available brand templates [Required]
  2. CANVA_INITIATE_CANVA_DESIGN_AUTOFILL_JOB - Start autofill with data [Required]

Key parameters:

  • brand_template_id: ID of the brand template to use
  • title: Title for the generated design
  • data: Key-value mapping of placeholder names to replacement values

Pitfalls:

  • Template placeholders must match exactly (case-sensitive)
  • Autofill is asynchronous; poll for completion
  • Only brand templates support autofill, not regular designs
  • Data values must match the expected type for each placeholder (text, image URL)

Common Patterns

Async Job Pattern

Many Canva operations are asynchronous:

1. Initiate job (upload, export, autofill) -> get job_id
2. Poll status endpoint with job_id every 2-3 seconds
3. Check for 'success' or 'failed' status
4. On success, extract result (asset_id, download_url, design_id)

ID Resolution

Design name -> Design ID:

1. Call CANVA_LIST_USER_DESIGNS with query=design_name
2. Find matching design in results
3. Extract id field

Brand template name -> Template ID:

1. Call CANVA_ACCESS_USER_SPECIFIC_BRAND_TEMPLATES_LIST
2. Find template by name
3. Extract brand_template_id

Pagination

  • Check response for continuation token
  • Pass token in next request's continuation parameter
  • Continue until continuation is absent or empty

Known Pitfalls

Async Operations:

  • Uploads, exports, and autofills are all asynchronous
  • Always poll job status; do not assume immediate completion
  • Download URLs from exports expire; use them promptly

Asset Management:

  • Assets must be uploaded before they can be used in designs
  • Upload job must reach 'success' status before the asset_id is valid
  • Supported formats vary; check Canva documentation for current limits

Rate Limits:

  • Canva API has rate limits per endpoint
  • Implement exponential backoff for bulk operations
  • Batch operations where possible to reduce API calls

Response Parsing:

  • Response data may be nested under data key
  • Job status responses include different fields based on completion state
  • Parse defensively with fallbacks for optional fields

Quick Reference

Task Tool Slug Key Params
List designs CANVA_LIST_USER_DESIGNS query, continuation
Create design CANVA_CREATE_CANVA_DESIGN_WITH_OPTIONAL_ASSET design_type, title
Upload asset CANVA_CREATE_ASSET_UPLOAD_JOB name, url
Check upload CANVA_FETCH_ASSET_UPLOAD_JOB_STATUS job_id
Export design CANVA_CREATE_CANVA_DESIGN_EXPORT_JOB design_id, format
Get export CANVA_GET_DESIGN_EXPORT_JOB_RESULT job_id
Create folder CANVA_POST_FOLDERS name, parent_folder_id
Move to folder CANVA_MOVE_ITEM_TO_SPECIFIED_FOLDER item_id, folder_id
List templates CANVA_ACCESS_USER_SPECIFIC_BRAND_TEMPLATES_LIST (none)
Autofill template CANVA_INITIATE_CANVA_DESIGN_AUTOFILL_JOB brand_template_id, data
Usage Guidance
This skill is internally coherent for automating Canva via a third‑party MCP, but you should verify and trust the MCP provider before enabling it. Specifically: (1) Confirm rube.app is a legitimate service and review its privacy/security docs; (2) When you run RUBE_MANAGE_CONNECTIONS, check the OAuth consent screen and scopes requested from Canva and limit access if possible; (3) Prefer testing with a non-production or throwaway Canva account to observe what the MCP/tool calls actually do and what data is exposed; (4) Use the recommended RUBE_SEARCH_TOOLS call to inspect tool schemas before executing actions so you understand what inputs/outputs the MCP supplies; (5) If you require higher assurance, request the skill author/source code or an official homepage and avoid adding unknown MCP endpoints to clients used for sensitive accounts.
Capability Analysis
Type: OpenClaw Skill Name: canva-automation Version: 0.1.0 The skill bundle is designed for automating Canva tasks via the Rube MCP. It instructs the agent to connect to an external MCP server at `https://rube.app/mcp` and utilize various Canva-related tools. While the skill enables the agent to perform actions like fetching assets from arbitrary URLs for upload (via `CANVA_CREATE_ASSET_UPLOAD_JOB` in SKILL.md), these capabilities are aligned with the stated purpose of Canva automation. There is no evidence of intentional harmful behavior, prompt injection attempts to subvert the agent, or other malicious instructions within the provided files. The risks are primarily related to the inherent capabilities of the tools and the supply chain dependency on the external Rube MCP, rather than malicious intent in the skill itself.
Capability Assessment
Purpose & Capability
The name/description (Canva automation) match the instructions: all actions reference Canva tool calls via Rube MCP (list designs, create, upload, export, folders, autofill). Nothing requested (no env vars, no unrelated binaries) is out of scope for a connector-style skill.
Instruction Scope
Instructions are narrowly scoped to using Rube MCP tool calls and OAuth-managed Canva connections; they do not ask the agent to read local files or unrelated environment variables. Note: the skill tells you to add an external MCP endpoint (https://rube.app/mcp) and to follow returned auth links — that grants the MCP server the ability to provide tool schemas and trigger OAuth flows, which is expected but worth vetting.
Install Mechanism
No install spec and no code files — instruction-only. That minimizes on-disk installation risk; the only runtime behavior is use of the platform's MCP/tool APIs.
Credentials
No environment variables, credentials, or config paths are requested by the skill itself. OAuth for Canva is handled via RUBE_MANAGE_CONNECTIONS as described, which is appropriate for this integration.
Persistence & Privilege
always:false (default) and no self-modifying/install actions. The skill does rely on the agent invoking external tools (normal for skills). No requests to change other skills or system-wide settings are present.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install canva-automation
  3. After installation, invoke the skill by name or use /canva-automation
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v0.1.0
Initial release: Automate Canva tasks via Rube MCP (Composio) - Supports creating, listing, and exporting Canva designs, brand templates, and assets. - Enables asset uploads (with async job handling and polling). - Organize designs using folders and move assets between folders. - Autofill designs using brand templates with structured data input. - Detailed tool usage patterns, parameter keys, and known pitfalls for seamless API workflows.
Metadata
Slug canva-automation
Version 0.1.0
License
All-time Installs 8
Active Installs 8
Total Versions 1
Frequently Asked Questions

What is Canva Automation?

Automate Canva tasks via Rube MCP (Composio): designs, exports, folders, brand templates, autofill. Always search tools first for current schemas. It is an AI Agent Skill for Claude Code / OpenClaw, with 2196 downloads so far.

How do I install Canva Automation?

Run "/install canva-automation" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Canva Automation free?

Yes, Canva Automation is completely free (open-source). You can download, install and use it at no cost.

Which platforms does Canva Automation support?

Canva Automation is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created Canva Automation?

It is built and maintained by sohamganatra (@sohamganatra); the current version is v0.1.0.

💬 Comments