Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Crawler Summary
Use when the user wants to send an iMessage, text message, or SMS to a phone number or email. Sends messages via iMessage with automatic fallback to RCS or SMS when iMessage is unavailable. Use for: sending texts, checking if someone has iMessage, group messaging, message delivery status. Keywords: iMessage, SMS, RCS, text message, send message, Blooio, messaging API. --- name: use-imessages description: > Use when the user wants to send an iMessage, text message, or SMS to a phone number or email. Sends messages via iMessage with automatic fallback to RCS or SMS when iMessage is unavailable. Use for: sending texts, checking if someone has iMessage, group messaging, message delivery status. Keywords: iMessage, SMS, RCS, text message, send message, Blooio, messaging API. dependenci Capability contract not published. No trust telemetry is available yet. 2 GitHub stars reported by the source. Last updated 4/15/2026.
Freshness
Last checked 4/15/2026
Best For
use-imessages is best for you, be, imessage workflows where OpenClaw compatibility matters.
Not Ideal For
Contract metadata is missing or unavailable for deterministic execution.
Evidence Sources Checked
editorial-content, GITHUB OPENCLEW, runtime-metrics, public facts pack
Use when the user wants to send an iMessage, text message, or SMS to a phone number or email. Sends messages via iMessage with automatic fallback to RCS or SMS when iMessage is unavailable. Use for: sending texts, checking if someone has iMessage, group messaging, message delivery status. Keywords: iMessage, SMS, RCS, text message, send message, Blooio, messaging API. --- name: use-imessages description: > Use when the user wants to send an iMessage, text message, or SMS to a phone number or email. Sends messages via iMessage with automatic fallback to RCS or SMS when iMessage is unavailable. Use for: sending texts, checking if someone has iMessage, group messaging, message delivery status. Keywords: iMessage, SMS, RCS, text message, send message, Blooio, messaging API. dependenci
Public facts
5
Change events
1
Artifacts
0
Freshness
Apr 15, 2026
Capability contract not published. No trust telemetry is available yet. 2 GitHub stars reported by the source. Last updated 4/15/2026.
Trust score
Unknown
Compatibility
OpenClaw
Freshness
Apr 15, 2026
Vendor
Blooio
Artifacts
0
Benchmarks
0
Last release
Unpublished
Key links, install path, and a quick operational read before the deeper crawl record.
Summary
Capability contract not published. No trust telemetry is available yet. 2 GitHub stars reported by the source. Last updated 4/15/2026.
Setup snapshot
git clone https://github.com/Blooio/use-imessages.gitSetup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.
Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.
Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.
Vendor
Blooio
Protocol compatibility
OpenClaw
Adoption signal
2 GitHub stars
Handshake status
UNKNOWN
Crawlable docs
6 indexed pages on the official domain
Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.
Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.
Extracted files
0
Examples
6
Snippets
0
Languages
typescript
Parameters
Dependencies
network access (for Blooio API calls)Blooio API key (user must provide)Permissions
text
https://backend.blooio.com/v2/api
text
Authorization: Bearer <your-api-key>
http
GET /contacts/{contactId}/capabilitiesjson
{
"contact": "+15551234567",
"type": "phone",
"capabilities": {
"imessage": true,
"sms": true
},
"last_checked": 1706123456789
}http
POST /chats/{chatId}/messages
Content-Type: application/json
{
"text": "Hello! This is your message."
}json
{
"message_id": "msg_abc123def456",
"status": "queued"
}Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB OPENCLEW
Editorial quality
ready
Use when the user wants to send an iMessage, text message, or SMS to a phone number or email. Sends messages via iMessage with automatic fallback to RCS or SMS when iMessage is unavailable. Use for: sending texts, checking if someone has iMessage, group messaging, message delivery status. Keywords: iMessage, SMS, RCS, text message, send message, Blooio, messaging API. --- name: use-imessages description: > Use when the user wants to send an iMessage, text message, or SMS to a phone number or email. Sends messages via iMessage with automatic fallback to RCS or SMS when iMessage is unavailable. Use for: sending texts, checking if someone has iMessage, group messaging, message delivery status. Keywords: iMessage, SMS, RCS, text message, send message, Blooio, messaging API. dependenci
name: use-imessages description: > Use when the user wants to send an iMessage, text message, or SMS to a phone number or email. Sends messages via iMessage with automatic fallback to RCS or SMS when iMessage is unavailable. Use for: sending texts, checking if someone has iMessage, group messaging, message delivery status. Keywords: iMessage, SMS, RCS, text message, send message, Blooio, messaging API. dependencies:
Send messages using iMessage with automatic fallback to RCS or SMS when iMessage isn't available for a contact. Uses the Blooio API.
Use this skill when the user asks to:
https://backend.blooio.com/v2/api
All requests require Bearer authentication:
Authorization: Bearer <your-api-key>
Before sending, determine what protocols the contact supports:
GET /contacts/{contactId}/capabilities
Where contactId is URL-encoded phone (E.164 format like %2B15551234567) or email.
Response:
{
"contact": "+15551234567",
"type": "phone",
"capabilities": {
"imessage": true,
"sms": true
},
"last_checked": 1706123456789
}
POST /chats/{chatId}/messages
Content-Type: application/json
{
"text": "Hello! This is your message."
}
The chatId can be:
%2B15551234567user%40example.comgrp_abc123def456%2B15551234567%2C%2B15559876543Response (202 Accepted):
{
"message_id": "msg_abc123def456",
"status": "queued"
}
GET /chats/{chatId}/messages/{messageId}/status
Response:
{
"message_id": "msg_abc123def456",
"chat_id": "+15551234567",
"direction": "outbound",
"status": "delivered",
"protocol": "imessage",
"time_sent": 1706123456789,
"time_delivered": 1706123457123
}
Protocol values: imessage, sms, rcs, non-imessage
Status values: pending, queued, sent, delivered, failed, read
1. Check capabilities for contact
2. If capabilities.imessage == true:
→ Send message (will use iMessage)
3. Else if capabilities.sms == true:
→ Send message (will use SMS/RCS)
4. Else:
→ Report error: "Cannot send - no supported channel"
5. After sending, check status to confirm protocol used
Note: Blooio handles protocol selection automatically based on capabilities. You send to the same endpoint; the system chooses the best available protocol.
POST /contacts
Content-Type: application/json
{
"identifier": "+15551234567",
"name": "John Doe"
}
GET /contacts?limit=50&offset=0&q=john
POST /chats/{chatId}/messages
Content-Type: application/json
{
"text": "Check out this image!",
"attachments": [
"https://example.com/image.jpg"
]
}
POST /chats/{chatId}/messages
Content-Type: application/json
{
"text": ["First message", "Second message", "Third message"]
}
Returns message_ids array instead of single message_id.
POST /chats/{chatId}/typing
DELETE /chats/{chatId}/typing
POST /chats/{chatId}/read
POST /chats/{chatId}/messages/{messageId}/reactions
Content-Type: application/json
{
"reaction": "+love"
}
Reactions: +love, +like, +dislike, +laugh, +emphasize, +question
Use - prefix to remove: -love
POST /groups
Content-Type: application/json
{
"name": "Sales Team",
"members": ["+15551234567", "+15559876543", "user@example.com"]
}
POST /chats/grp_abc123def456/messages
Content-Type: application/json
{
"text": "Hello team!"
}
POST /chats/%2B15551234567%2C%2B15559876543/messages
Content-Type: application/json
{
"text": "Hello both of you!"
}
POST /webhooks
Content-Type: application/json
{
"webhook_url": "https://your-server.com/webhook",
"webhook_type": "all"
}
Types: message (inbound only), status (delivery status), all
{
"event": "message.received",
"message_id": "msg_abc123",
"external_id": "+15551234567",
"status": "received",
"protocol": "imessage",
"timestamp": 1706123456789,
"text": "Hey there!",
"is_group": false
}
Events: message.received, message.sent, message.delivered, message.failed, message.read
| Status | Meaning | Action | |--------|---------|--------| | 400 | Invalid request | Check phone format (E.164), URL encoding | | 401 | Unauthorized | Verify API key | | 404 | Not found | Contact/chat doesn't exist | | 503 | No devices | Ensure device is connected and active |
This means no Blooio device is online. The user needs to:
import requests
API_KEY = "your-api-key"
BASE_URL = "https://backend.blooio.com/v2/api"
HEADERS = {"Authorization": f"Bearer {API_KEY}"}
def send_message_with_fallback(phone: str, text: str) -> dict:
# URL encode the phone number
encoded_phone = phone.replace("+", "%2B")
# 1. Check capabilities
cap_resp = requests.get(
f"{BASE_URL}/contacts/{encoded_phone}/capabilities",
headers=HEADERS
)
if cap_resp.status_code == 503:
return {"error": "No devices available"}
caps = cap_resp.json().get("capabilities", {})
if not caps.get("imessage") and not caps.get("sms"):
return {"error": "Contact has no supported messaging channel"}
# 2. Send message (Blooio auto-selects best protocol)
send_resp = requests.post(
f"{BASE_URL}/chats/{encoded_phone}/messages",
headers=HEADERS,
json={"text": text}
)
if send_resp.status_code not in [200, 202]:
return {"error": send_resp.json().get("error")}
result = send_resp.json()
# 3. Optionally check what protocol was used
status_resp = requests.get(
f"{BASE_URL}/chats/{encoded_phone}/messages/{result['message_id']}/status",
headers=HEADERS
)
if status_resp.ok:
result["protocol"] = status_resp.json().get("protocol")
return result
# Usage
result = send_message_with_fallback("+15551234567", "Hello from the agent!")
print(f"Sent via {result.get('protocol', 'unknown')}: {result.get('message_id')}")
+15551234567 (with country code)+ becomes %2B, @ becomes %40last_checked timestamp shows freshnessIdempotency-Key: unique-request-id-123
Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
missing
Auth
None
Streaming
No
Data region
Unspecified
Protocol support
Requires: none
Forbidden: none
Guardrails
Operational confidence: low
curl -s "https://xpersona.co/api/v1/agents/blooio-use-imessages/snapshot"
curl -s "https://xpersona.co/api/v1/agents/blooio-use-imessages/contract"
curl -s "https://xpersona.co/api/v1/agents/blooio-use-imessages/trust"
Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.
Trust signals
Handshake
UNKNOWN
Confidence
unknown
Attempts 30d
unknown
Fallback rate
unknown
Runtime metrics
Observed P50
unknown
Observed P95
unknown
Rate limit
unknown
Estimated cost
unknown
Do not use if
Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.
Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.
Rank
70
AI Agents & MCPs & AI Workflow Automation • (~400 MCP servers for AI agents) • AI Automation / AI Agent with MCPs • AI Workflows & AI Agents • MCPs for AI Agents
Traction
No public download signal
Freshness
Updated 2d ago
Rank
70
AI productivity studio with smart chat, autonomous agents, and 300+ assistants. Unified access to frontier LLMs
Traction
No public download signal
Freshness
Updated 5d ago
Rank
70
Free, local, open-source 24/7 Cowork app and OpenClaw for Gemini CLI, Claude Code, Codex, OpenCode, Qwen Code, Goose CLI, Auggie, and more | 🌟 Star if you like it!
Traction
No public download signal
Freshness
Updated 6d ago
Rank
70
The Frontend for Agents & Generative UI. React + Angular
Traction
No public download signal
Freshness
Updated 23d ago
Contract JSON
{
"contractStatus": "missing",
"authModes": [],
"requires": [],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": false,
"inputSchemaRef": null,
"outputSchemaRef": null,
"dataRegion": null,
"contractUpdatedAt": null,
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/blooio-use-imessages/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/blooio-use-imessages/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/blooio-use-imessages/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/blooio-use-imessages/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/blooio-use-imessages/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/blooio-use-imessages/trust\""
],
"jsonRequestTemplate": {
"query": "summarize this repo",
"constraints": {
"maxLatencyMs": 2000,
"protocolPreference": [
"OPENCLEW"
]
}
},
"jsonResponseTemplate": {
"ok": true,
"result": {
"summary": "...",
"confidence": 0.9
},
"meta": {
"source": "GITHUB_OPENCLEW",
"generatedAt": "2026-04-17T00:58:30.393Z"
}
},
"retryPolicy": {
"maxAttempts": 3,
"backoffMs": [
500,
1500,
3500
],
"retryableConditions": [
"HTTP_429",
"HTTP_503",
"NETWORK_TIMEOUT"
]
}
}Trust JSON
{
"status": "unavailable",
"handshakeStatus": "UNKNOWN",
"verificationFreshnessHours": null,
"reputationScore": null,
"p95LatencyMs": null,
"successRate30d": null,
"fallbackRate": null,
"attempts30d": null,
"trustUpdatedAt": null,
"trustConfidence": "unknown",
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Capability Matrix
{
"rows": [
{
"key": "OPENCLEW",
"type": "protocol",
"support": "unknown",
"confidenceSource": "profile",
"notes": "Listed on profile"
},
{
"key": "you",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "be",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "imessage",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
}
],
"flattenedTokens": "protocol:OPENCLEW|unknown|profile capability:you|supported|profile capability:be|supported|profile capability:imessage|supported|profile"
}Facts JSON
[
{
"factKey": "docs_crawl",
"category": "integration",
"label": "Crawlable docs",
"value": "6 indexed pages on the official domain",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Blooio",
"href": "https://github.com/Blooio/use-imessages",
"sourceUrl": "https://github.com/Blooio/use-imessages",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-04-15T03:15:49.405Z",
"isPublic": true
},
{
"factKey": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "OpenClaw",
"href": "https://xpersona.co/api/v1/agents/blooio-use-imessages/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/blooio-use-imessages/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-04-15T03:15:49.405Z",
"isPublic": true
},
{
"factKey": "traction",
"category": "adoption",
"label": "Adoption signal",
"value": "2 GitHub stars",
"href": "https://github.com/Blooio/use-imessages",
"sourceUrl": "https://github.com/Blooio/use-imessages",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-04-15T03:15:49.405Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/blooio-use-imessages/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/blooio-use-imessages/trust",
"sourceType": "trust",
"confidence": "medium",
"observedAt": null,
"isPublic": true
}
]Change Events JSON
[
{
"eventType": "docs_update",
"title": "Docs refreshed: Sign in to GitHub · GitHub",
"description": "Fresh crawlable documentation was indexed for the official domain.",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
}
]Sponsored
Ads related to use-imessages and adjacent AI workflows.