Files
AutoGPT/docs/integrations/misc.md
Nicholas Tindle c1a1767034 feat(docs): Add block documentation auto-generation system (#11707)
- Add generate_block_docs.py script that introspects block code to
generate markdown
- Support manual content preservation via <!-- MANUAL: --> markers
- Add migrate_block_docs.py to preserve existing manual content from git
HEAD
- Add CI workflow (docs-block-sync.yml) to fail if docs drift from code
- Add Claude PR review workflow (docs-claude-review.yml) for doc changes
- Add manual LLM enhancement workflow (docs-enhance.yml)
- Add GitBook configuration (.gitbook.yaml, SUMMARY.md)
- Fix non-deterministic category ordering (categories is a set)
- Add comprehensive test suite (32 tests)
- Generate docs for 444 blocks with 66 preserved manual sections

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>

<!-- Clearly explain the need for these changes: -->

### Changes 🏗️

<!-- Concisely describe all of the changes made in this pull request:
-->

### Checklist 📋

#### For code changes:
- [x] I have clearly listed my changes in the PR description
- [x] I have made a test plan
- [x] I have tested my changes according to the test plan:
  <!-- Put your test plan here: -->
  - [x] Extensively test code generation for the docs pages



<!-- CURSOR_SUMMARY -->
---

> [!NOTE]
> Introduces an automated documentation pipeline for blocks and
integrates it into CI.
> 
> - Adds `scripts/generate_block_docs.py` (+ tests) to introspect blocks
and generate `docs/integrations/**`, preserving `<!-- MANUAL: -->`
sections
> - New CI workflows: **docs-block-sync** (fails if docs drift),
**docs-claude-review** (AI review for block/docs PRs), and
**docs-enhance** (optional LLM improvements)
> - Updates existing Claude workflows to use `CLAUDE_CODE_OAUTH_TOKEN`
instead of `ANTHROPIC_API_KEY`
> - Improves numerous block descriptions/typos and links across backend
blocks to standardize docs output
> - Commits initial generated docs including
`docs/integrations/README.md` and many provider/category pages
> 
> <sup>Written by [Cursor
Bugbot](https://cursor.com/dashboard?tab=bugbot) for commit
631e53e0f6. This will update automatically
on new commits. Configure
[here](https://cursor.com/dashboard?tab=bugbot).</sup>
<!-- /CURSOR_SUMMARY -->

---------

Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-19 07:03:19 +00:00

39 KiB
Raw Blame History

Misc

Miscellaneous blocks including agent execution, scheduling, HTTP requests, webhooks, and other utility functions.

Agent Executor

What it is

Executes an existing agent inside your agent

How it works

This block runs another agent as a sub-agent within your workflow. You provide the agent's graph ID, version, and input data, and the block executes that agent and returns its outputs.

Input and output schemas define the expected data structure for communication between the parent and child agents, enabling modular, reusable agent composition.

Inputs

Input Description Type Required
user_id User ID str Yes
graph_id Graph ID str Yes
graph_version Graph Version int Yes
agent_name Name to display in the Builder UI str No
inputs Input data for the graph Dict[str, Any] Yes
input_schema Input schema for the graph Dict[str, Any] Yes
output_schema Output schema for the graph Dict[str, Any] Yes

Possible use case

Modular Workflows: Break complex workflows into smaller, reusable agents that can be composed together.

Specialized Agents: Call domain-specific agents (like a research agent or formatter) from a main orchestration agent.

Dynamic Routing: Execute different agents based on input type or user preferences.


Create Reddit Post

What it is

Create a new post on a subreddit. Can create text posts or link posts.

How it works

This block uses the Reddit API via PRAW to create a new post in the specified subreddit. Provide the title and either text content for a self-post or a URL for a link post. Optionally apply flair using a flair ID from the GetSubredditFlairsBlock.

The block returns the created post's ID and URL, which can be used for chaining with comment blocks or monitoring.

Inputs

Input Description Type Required
subreddit Subreddit to post to, excluding the /r/ prefix str Yes
title Title of the post str Yes
content Body text of the post (for text posts) str No
url URL to submit (for link posts). If provided, content is ignored. str No
flair_id Flair template ID to apply to the post (from GetSubredditFlairsBlock) str No
flair_text Custom flair text (only used if the flair template allows editing) str No

Outputs

Output Description Type
error Error message if the operation failed str
post_id ID of the created post str
post_url URL of the created post str
subreddit The subreddit name (pass-through for chaining) str

Possible use case

Content Distribution: Automatically share articles or content to relevant subreddits.

Community Engagement: Post updates or announcements to subreddit communities.

Automated Posting: Schedule and post content to Reddit based on workflow triggers.


Delete Reddit Comment

What it is

Delete a Reddit comment that you own.

How it works

This block uses the Reddit API via PRAW to delete a comment you previously posted. The deletion is permanent and removes the comment from the post thread. You can only delete your own comments.

Inputs

Input Description Type Required
comment_id The ID of the comment to delete (must be your own comment) str Yes

Outputs

Output Description Type
error Error message if deletion failed str
success Whether the deletion was successful bool
comment_id The comment ID (pass-through for chaining) str

Possible use case

Content Cleanup: Remove outdated or incorrect comments from discussions.

Automated Moderation: Delete comments that fail quality checks or receive negative feedback.


Delete Reddit Post

What it is

Delete a Reddit post that you own.

How it works

This block uses the Reddit API via PRAW to delete a post you previously created. The deletion is permanent and removes the post from the subreddit. You can only delete your own posts.

Inputs

Input Description Type Required
post_id The ID of the post to delete (must be your own post) str Yes

Outputs

Output Description Type
error Error message if deletion failed str
success Whether the deletion was successful bool
post_id The post ID (pass-through for chaining) str

Possible use case

Content Management: Remove posts that are no longer relevant or contain errors.

Automated Cleanup: Delete posts based on performance metrics or time-based rules.


Edit Reddit Post

What it is

Edit the body text of an existing Reddit post that you own. Only works for self/text posts.

How it works

This block uses the Reddit API via PRAW to edit the body text of a self-post you created. Link posts cannot be edited. The new content replaces the existing post body.

Inputs

Input Description Type Required
post_id The ID of the post to edit (must be your own post) str Yes
new_content The new body text for the post str Yes

Outputs

Output Description Type
error Error message if the edit failed str
success Whether the edit was successful bool
post_id The post ID (pass-through for chaining) str
post_url URL of the edited post str

Possible use case

Content Updates: Update posts with new information or corrections.

Dynamic Content: Modify post content based on changing data or feedback.


Execute Code

What it is

Executes code in a sandbox environment with internet access.

How it works

This block executes Python, JavaScript, or Bash code in an isolated E2B sandbox with internet access. Use setup_commands to install dependencies before running your code.

The sandbox includes pip and npm pre-installed. Set timeout to limit execution time, and use dispose_sandbox to clean up after execution or keep the sandbox running for follow-up steps.

Inputs

Input Description Type Required
setup_commands Shell commands to set up the sandbox before running the code. You can use curl or git to install your desired Debian based package manager. pip and npm are pre-installed. These commands are executed with sh, in the foreground. List[str] No
code Code to execute in the sandbox str No
language Programming language to execute "python" | "js" | "bash" | "r" | "java" No
timeout Execution timeout in seconds int No
dispose_sandbox Whether to dispose of the sandbox immediately after execution. If disabled, the sandbox will run until its timeout expires. bool No
template_id You can use an E2B sandbox template by entering its ID here. Check out the E2B docs for more details: E2B - Sandbox template str No

Outputs

Output Description Type
error Error message if the operation failed str
main_result The main result from the code execution Main Result
results List of results from the code execution List[CodeExecutionResult]
response Text output (if any) of the main execution result str
stdout_logs Standard output logs from execution str
stderr_logs Standard error logs from execution str

Possible use case

Data Processing: Run Python scripts to transform, analyze, or visualize data that can't be handled by standard blocks.

Custom Integrations: Execute code to call APIs or services not covered by built-in blocks.

Dynamic Computation: Generate and execute code based on AI suggestions for flexible problem-solving.


Execute Code Step

What it is

Execute code in a previously instantiated sandbox.

How it works

This block executes additional code in a sandbox that was previously created with the Instantiate Code Sandbox block. The sandbox maintains state between steps, so variables and installed packages persist.

Use this for multi-step code execution where each step builds on previous results. Set dispose_sandbox to true on the final step to clean up.

Inputs

Input Description Type Required
sandbox_id ID of the sandbox instance to execute the code in str Yes
step_code Code to execute in the sandbox str No
language Programming language to execute "python" | "js" | "bash" | "r" | "java" No
dispose_sandbox Whether to dispose of the sandbox after executing this code. bool No

Outputs

Output Description Type
error Error message if the operation failed str
main_result The main result from the code execution Main Result
results List of results from the code execution List[CodeExecutionResult]
response Text output (if any) of the main execution result str
stdout_logs Standard output logs from execution str
stderr_logs Standard error logs from execution str

Possible use case

Iterative Processing: Load data in one step, transform it in another, and export in a third.

Stateful Computation: Build up results across multiple code executions with shared variables.

Interactive Analysis: Run exploratory data analysis steps sequentially in the same environment.


Get Reddit Comment

What it is

Get details about a specific Reddit comment by its ID.

How it works

This block uses the Reddit API via PRAW to retrieve detailed information about a specific comment by its ID. Returns the comment content, author, score, timestamp, and other metadata.

Inputs

Input Description Type Required
comment_id The ID of the comment to fetch str Yes

Outputs

Output Description Type
error Error message if comment couldn't be fetched str
comment The comment details RedditComment

Possible use case

Comment Analysis: Analyze specific comments for sentiment or content moderation.

Thread Tracking: Monitor specific comments for engagement or replies.


Get Reddit Comment Replies

What it is

Get replies to a specific Reddit comment.

How it works

This block uses the Reddit API via PRAW to fetch replies to a specific comment. Returns a list of direct replies with their content, authors, and metadata.

Inputs

Input Description Type Required
comment_id The ID of the comment to get replies from str Yes
post_id The ID of the post containing the comment str Yes
limit Maximum number of replies to fetch (max 50) int No

Outputs

Output Description Type
error Error message if replies couldn't be fetched str
reply A reply to the comment RedditComment
replies All replies List[RedditComment]
comment_id The parent comment ID (pass-through for chaining) str
post_id The post ID (pass-through for chaining) str

Possible use case

Conversation Threading: Build complete comment threads for analysis or display.

Response Monitoring: Track replies to your comments for engagement purposes.


Get Reddit Inbox

What it is

Get messages, mentions, and comment replies from your Reddit inbox.

How it works

This block uses the Reddit API via PRAW to fetch items from your Reddit inbox. Filter by type to get all items, unread only, direct messages, username mentions, or replies to your comments.

Inputs

Input Description Type Required
inbox_type Type of inbox items to fetch "all" | "unread" | "messages" | "mentions" | "comment_replies" No
limit Maximum number of items to fetch int No
mark_read Whether to mark fetched items as read bool No

Outputs

Output Description Type
error Error message if fetch failed str
item An inbox item RedditInboxItem
items All fetched items List[RedditInboxItem]

Possible use case

Inbox Monitoring: Check for new messages or mentions to respond to.

Engagement Tracking: Monitor comment replies to stay engaged with discussions.


Get Reddit Post

What it is

Get detailed information about a specific Reddit post by its ID.

How it works

This block uses the Reddit API via PRAW to retrieve complete details about a specific post by its ID. Returns the post title, content, author, score, comment count, and other metadata.

Inputs

Input Description Type Required
post_id The ID of the post to fetch (e.g., 'abc123' or full ID 't3_abc123') str Yes

Outputs

Output Description Type
error Error message if the post couldn't be fetched str
post Detailed post information RedditPostDetails

Possible use case

Post Analysis: Analyze specific posts for content quality or engagement metrics.

Content Verification: Verify post details before interacting with it programmatically.


Get Reddit Post Comments

What it is

Get top-level comments on a Reddit post.

How it works

This block uses the Reddit API via PRAW to fetch top-level comments on a post. Configure the sort order and limit to control which comments are returned.

Inputs

Input Description Type Required
post_id The ID of the post to get comments from str Yes
limit Maximum number of top-level comments to fetch (max 100) int No
sort Sort order for comments "best" | "top" | "new" | "controversial" | "old" | "qa" No

Outputs

Output Description Type
error Error message if comments couldn't be fetched str
comment A comment on the post RedditComment
comments All fetched comments List[RedditComment]
post_id The post ID (pass-through for chaining) str

Possible use case

Sentiment Analysis: Analyze comments to gauge community sentiment on a topic.

Content Moderation: Review comments for compliance with community guidelines.


Get Reddit Posts

What it is

This block fetches Reddit posts from a defined subreddit name.

How it works

The block connects to Reddit using provided credentials, accesses the specified subreddit, and retrieves posts based on the given parameters. It can limit the number of posts, stop at a specific post, or fetch posts within a certain time frame.

Inputs

Input Description Type Required
subreddit Subreddit name, excluding the /r/ prefix str No
last_minutes Post time to stop minutes ago while fetching posts int No
last_post Post ID to stop when reached while fetching posts str No
post_limit Number of posts to fetch int No

Outputs

Output Description Type
error Error message if the operation failed str
post Reddit post RedditPost
posts List of all Reddit posts List[RedditPost]

Possible use case

A content curator could use this block to gather recent posts from a specific subreddit for analysis, summarization, or inclusion in a newsletter.


Get Reddit User Info

What it is

Get information about a Reddit user including karma, account age, and verification status.

How it works

This block uses the Reddit API via PRAW to retrieve public profile information about a Reddit user, including karma scores, account age, and verification status.

Inputs

Input Description Type Required
username The Reddit username to look up (without /u/ prefix) str Yes

Outputs

Output Description Type
error Error message if user lookup failed str
user User information RedditUserInfo
username The username (pass-through for chaining) str

Possible use case

User Verification: Check user account age and karma before engaging.

User Research: Gather user profile data for analysis or outreach decisions.


Get Subreddit Flairs

What it is

Get available link flair options for a subreddit.

How it works

This block uses the Reddit API via PRAW to retrieve available link flair options for a subreddit. Use the flair IDs with the Create Reddit Post block to apply flair to your posts.

Inputs

Input Description Type Required
subreddit Subreddit name (without /r/ prefix) str Yes

Outputs

Output Description Type
error Error message if fetch failed str
flair A flair option SubredditFlair
flairs All available flairs List[SubredditFlair]
subreddit The subreddit name (pass-through for chaining) str

Possible use case

Post Preparation: Get available flairs before creating posts to ensure proper categorization.

Flair Selection: Present flair options to users or select appropriate flair programmatically.


Get Subreddit Info

What it is

Get information about a subreddit including subscriber count, description, and rules.

How it works

This block uses the Reddit API via PRAW to retrieve metadata about a subreddit including subscriber count, description, creation date, and posting rules.

Inputs

Input Description Type Required
subreddit Subreddit name (without /r/ prefix) str Yes

Outputs

Output Description Type
error Error message if the subreddit couldn't be fetched str
info Subreddit information SubredditInfo
subreddit The subreddit name (pass-through for chaining) str

Possible use case

Subreddit Research: Analyze subreddits before deciding to post or engage.

Community Analysis: Compare subreddit sizes and activity for market research.


Get Subreddit Rules

What it is

Get the rules for a subreddit to ensure compliance before posting.

How it works

This block uses the Reddit API via PRAW to retrieve the posting rules for a subreddit. Review these rules before posting to ensure compliance.

Inputs

Input Description Type Required
subreddit Subreddit name (without /r/ prefix) str Yes

Outputs

Output Description Type
error Error message if fetch failed str
rule A subreddit rule SubredditRule
rules All subreddit rules List[SubredditRule]
subreddit The subreddit name (pass-through for chaining) str

Possible use case

Compliance Check: Review rules before automated posting to avoid violations.

Content Guidelines: Display rules to users before they submit content to a subreddit.


Get User Posts

What it is

Fetch posts by a specific Reddit user.

How it works

This block uses the Reddit API via PRAW to fetch posts submitted by a specific user. Configure sort order and limit to control which posts are returned.

Inputs

Input Description Type Required
username Reddit username to fetch posts from (without /u/ prefix) str Yes
post_limit Maximum number of posts to fetch int No
sort Sort order for user posts "new" | "hot" | "top" | "controversial" No

Outputs

Output Description Type
error Error message if posts couldn't be fetched str
post A post by the user RedditPost
posts All posts by the user List[RedditPost]

Possible use case

User Analysis: Analyze a user's posting history for content patterns or topics.

Influencer Research: Research prolific posters in specific communities.


Instantiate Code Sandbox

What it is

Instantiate a sandbox environment with internet access in which you can execute code with the Execute Code Step block.

How it works

This block creates a persistent E2B sandbox environment that can be used for multiple code execution steps. Run setup_commands and setup_code to prepare the environment with dependencies and initial state.

The sandbox persists until its timeout expires or it's explicitly disposed. Use the returned sandbox_id with Execute Code Step blocks for subsequent code execution.

Inputs

Input Description Type Required
setup_commands Shell commands to set up the sandbox before running the code. You can use curl or git to install your desired Debian based package manager. pip and npm are pre-installed. These commands are executed with sh, in the foreground. List[str] No
setup_code Code to execute in the sandbox str No
language Programming language to execute "python" | "js" | "bash" | "r" | "java" No
timeout Execution timeout in seconds int No
template_id You can use an E2B sandbox template by entering its ID here. Check out the E2B docs for more details: E2B - Sandbox template str No

Outputs

Output Description Type
error Error message if the operation failed str
sandbox_id ID of the sandbox instance str
response Text result (if any) of the setup code execution str
stdout_logs Standard output logs from execution str
stderr_logs Standard error logs from execution str

Possible use case

Complex Pipelines: Set up an environment with data science libraries for multi-step analysis.

Persistent State: Create a sandbox with loaded models or data that multiple workflow branches can access.

Custom Environments: Configure specialized environments with specific package versions for reproducible execution.


Post Reddit Comment

What it is

This block posts a Reddit comment on a specified Reddit post.

How it works

The block connects to Reddit using the provided credentials, locates the specified post, and then adds the given comment to that post.

Inputs

Input Description Type Required
post_id The ID of the post to comment on str Yes
comment The content of the comment to post str Yes

Outputs

Output Description Type
error Error message if the operation failed str
comment_id Posted comment ID str
post_id The post ID (pass-through for chaining) str

Possible use case

An automated moderation system could use this block to post pre-defined responses or warnings on Reddit posts that violate community guidelines.


Publish To Medium

What it is

Publishes a post to Medium.

How it works

This block publishes articles to Medium using their API. Provide the content in HTML or Markdown format along with a title, tags, and publishing options. The author_id can be obtained from Medium's /me API endpoint.

Configure publish_status to publish immediately, save as draft, or make unlisted. The block returns the published post's ID and URL.

Inputs

Input Description Type Required
author_id The Medium AuthorID of the user. You can get this by calling the /me endpoint of the Medium API. curl -H "Authorization: Bearer YOUR_ACCESS_TOKEN" https://api.medium.com/v1/me The response will contain the authorId field. str No
title The title of your Medium post str Yes
content The main content of your Medium post str Yes
content_format The format of the content: 'html' or 'markdown' str Yes
tags List of tags for your Medium post (up to 5) List[str] Yes
canonical_url The original home of this content, if it was originally published elsewhere str No
publish_status The publish status "public" | "draft" | "unlisted" Yes
license The license of the post: 'all-rights-reserved', 'cc-40-by', 'cc-40-by-sa', 'cc-40-by-nd', 'cc-40-by-nc', 'cc-40-by-nc-nd', 'cc-40-by-nc-sa', 'cc-40-zero', 'public-domain' str No
notify_followers Whether to notify followers that the user has published bool No

Outputs

Output Description Type
error Error message if the post creation failed str
post_id The ID of the created Medium post str
post_url The URL of the created Medium post str
published_at The timestamp when the post was published int

Possible use case

Content Syndication: Automatically publish blog posts or newsletters to Medium to reach a wider audience.

AI Content Publishing: Generate articles with AI and publish them directly to Medium.

Cross-Posting: Republish existing content from other platforms to Medium with proper canonical URL attribution.


Read RSS Feed

What it is

Reads RSS feed entries from a given URL.

How it works

This block fetches and parses RSS or Atom feeds from a URL. Filter entries by time_period to only get recent items. When run_continuously is enabled, the block polls the feed at the specified polling_rate interval.

Each entry is output individually, enabling processing of new content as it appears. The block also outputs all entries as a list for batch processing.

Inputs

Input Description Type Required
rss_url The URL of the RSS feed to read str Yes
time_period The time period to check in minutes relative to the run block runtime, e.g. 60 would check for new entries in the last hour. int No
polling_rate The number of seconds to wait between polling attempts. int Yes
run_continuously Whether to run the block continuously or just once. bool No

Outputs

Output Description Type
error Error message if the operation failed str
entry The RSS item RSSEntry
entries List of all RSS entries List[RSSEntry]

Possible use case

News Monitoring: Track industry news feeds and process new articles for summarization or alerts.

Content Aggregation: Collect posts from multiple RSS feeds for a curated digest or newsletter.

Blog Triggers: Monitor a competitor's blog feed to trigger analysis or response workflows.


Reddit Get My Posts

What it is

Fetch posts created by the authenticated Reddit user (you).

How it works

This block uses the Reddit API via PRAW to fetch posts you've submitted to Reddit. Useful for managing or analyzing your own posting history.

Inputs

Input Description Type Required
post_limit Maximum number of posts to fetch int No
sort Sort order for posts "new" | "hot" | "top" | "controversial" No

Outputs

Output Description Type
error Error message if posts couldn't be fetched str
post A post by you RedditPost
posts All your posts List[RedditPost]

Possible use case

Content Management: Review and manage your Reddit posting history.

Performance Tracking: Analyze the engagement of your previous posts.


Reply To Reddit Comment

What it is

Reply to a specific Reddit comment. Useful for threaded conversations.

How it works

This block uses the Reddit API via PRAW to post a reply to an existing comment. The reply appears as a nested response in the comment thread.

Inputs

Input Description Type Required
comment_id The ID of the comment to reply to str Yes
reply_text The text content of the reply str Yes

Outputs

Output Description Type
error Error message if reply failed str
comment_id ID of the newly created reply str
parent_comment_id The parent comment ID (pass-through for chaining) str

Possible use case

Automated Responses: Reply to comments that mention your product or brand.

Conversation Engagement: Participate in discussions by responding to relevant comments.


Search Reddit

What it is

Search Reddit for posts matching a query. Can search all of Reddit or a specific subreddit.

How it works

This block uses the Reddit API via PRAW to search for posts matching your query. Optionally limit the search to a specific subreddit and configure sort order and time filters.

Inputs

Input Description Type Required
query Search query string str Yes
subreddit Limit search to a specific subreddit (without /r/ prefix) str No
sort Sort order for search results "relevance" | "hot" | "top" | "new" | "comments" No
time_filter Time filter for search results "all" | "day" | "hour" | "month" | "week" | "year" No
limit Maximum number of results to return int No

Outputs

Output Description Type
error Error message if search failed str
result A search result RedditSearchResult
results All search results List[RedditSearchResult]

Possible use case

Brand Monitoring: Search for mentions of your product or company across Reddit.

Topic Research: Find discussions about specific topics or keywords.


Send Authenticated Web Request

What it is

Make an authenticated HTTP request with host-scoped credentials (JSON / form / multipart).

How it works

This block makes HTTP requests with automatic credential injection based on the request URL's host. Credentials are managed separately and applied when the URL matches a configured host pattern.

Supports JSON, form-encoded, and multipart requests with file uploads. The response is parsed and returned along with separate error outputs for client (4xx) and server (5xx) errors.

Inputs

Input Description Type Required
url The URL to send the request to str Yes
method The HTTP method to use for the request "GET" | "POST" | "PUT" | "DELETE" | "PATCH" | "OPTIONS" | "HEAD" No
headers The headers to include in the request Dict[str, str] No
json_format If true, send the body as JSON (unless files are also present). bool No
body Form/JSON body payload. If files are supplied, this must be a mapping of formfields. Dict[str, Any] No
files_name The name of the file field in the form data. str No
files Mapping of form field name → Image url / path / base64 url. List[str (file)] No

Outputs

Output Description Type
error Errors for all other exceptions str
response The response from the server Response
client_error Errors on 4xx status codes Client Error
server_error Errors on 5xx status codes Server Error

Possible use case

Private API Access: Call APIs that require authentication without exposing credentials in the workflow.

OAuth Integrations: Access protected resources using pre-configured OAuth tokens.

Multi-Tenant APIs: Make requests to APIs where credentials vary by host or endpoint.


Send Email

What it is

This block sends an email using the provided SMTP credentials.

How it works

This block sends emails via SMTP using your configured email server credentials. Provide the recipient address, subject, and body content. The SMTP configuration includes server host, port, username, and password.

The block handles connection, authentication, and message delivery, returning a status indicating success or failure.

Inputs

Input Description Type Required
to_email Recipient email address str Yes
subject Subject of the email str Yes
body Body of the email str Yes
config SMTP Config SMTP Config Yes

Outputs

Output Description Type
error Error message if the email sending failed str
status Status of the email sending operation str

Possible use case

Notification Emails: Send automated notifications when workflow events occur.

Report Delivery: Email generated reports or summaries to stakeholders.

Alert System: Send email alerts when monitoring workflows detect issues or thresholds.


Send Reddit Message

What it is

Send a private message (DM) to a Reddit user.

How it works

This block uses the Reddit API via PRAW to send a private message to another Reddit user. The message appears in their inbox.

Inputs

Input Description Type Required
username The Reddit username to send a message to (without /u/ prefix) str Yes
subject The subject line of the message str Yes
message The body content of the message str Yes

Outputs

Output Description Type
error Error message if sending failed str
success Whether the message was sent bool
username The username (pass-through for chaining) str

Possible use case

Outreach: Send direct messages to users for collaboration or feedback requests.

Support: Provide private support or follow-up to users who engaged with your content.


Send Web Request

What it is

Make an HTTP request (JSON / form / multipart).

How it works

This block makes HTTP requests to any URL. Configure the method (GET, POST, PUT, DELETE, PATCH), headers, and request body. Supports JSON, form-encoded, and multipart content types with file uploads.

The response body is parsed and returned. Separate error outputs distinguish between client errors (4xx), server errors (5xx), and other failures.

Inputs

Input Description Type Required
url The URL to send the request to str Yes
method The HTTP method to use for the request "GET" | "POST" | "PUT" | "DELETE" | "PATCH" | "OPTIONS" | "HEAD" No
headers The headers to include in the request Dict[str, str] No
json_format If true, send the body as JSON (unless files are also present). bool No
body Form/JSON body payload. If files are supplied, this must be a mapping of formfields. Dict[str, Any] No
files_name The name of the file field in the form data. str No
files Mapping of form field name → Image url / path / base64 url. List[str (file)] No

Outputs

Output Description Type
error Errors for all other exceptions str
response The response from the server Response
client_error Errors on 4xx status codes Client Error
server_error Errors on 5xx status codes Server Error

Possible use case

API Integration: Call REST APIs to fetch data, trigger actions, or send updates.

Webhook Delivery: Send webhook notifications to external services when events occur.

Custom Services: Integrate with services that don't have dedicated blocks using their HTTP APIs.


Transcribe Youtube Video

What it is

Transcribes a YouTube video using a proxy.

How it works

This block extracts transcripts from YouTube videos using a proxy service. It parses the YouTube URL to get the video ID and retrieves the available transcript, typically the auto-generated or manually uploaded captions.

The transcript text is returned as a single string, suitable for summarization, analysis, or other text processing.

Inputs

Input Description Type Required
youtube_url The URL of the YouTube video to transcribe str Yes

Outputs

Output Description Type
error Any error message if the transcription fails str
video_id The extracted YouTube video ID str
transcript The transcribed text of the video str

Possible use case

Video Summarization: Extract video transcripts for AI summarization or key point extraction.

Content Repurposing: Convert YouTube content into written articles, social posts, or documentation.

Research Automation: Transcribe educational or informational videos for analysis and note-taking.