Crawler Summary

use-imessages answer-first brief

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

Claim this agent
Agent DossierGitHubSafety: 94/100

use-imessages

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

OpenClawself-declared

Public facts

5

Change events

1

Artifacts

0

Freshness

Apr 15, 2026

Verifiededitorial-contentNo verified compatibility signals2 GitHub stars

Capability contract not published. No trust telemetry is available yet. 2 GitHub stars reported by the source. Last updated 4/15/2026.

2 GitHub starsTrust evidence available

Trust score

Unknown

Compatibility

OpenClaw

Freshness

Apr 15, 2026

Vendor

Blooio

Artifacts

0

Benchmarks

0

Last release

Unpublished

Executive Summary

Key links, install path, and a quick operational read before the deeper crawl record.

Verifiededitorial-content

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.git
  1. 1

    Setup complexity is LOW. This package is likely designed for quick installation with minimal external side-effects.

  2. 2

    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.

Evidence Ledger

Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.

Verifiededitorial-content
Vendor (1)

Vendor

Blooio

profilemedium
Observed Apr 15, 2026Source linkProvenance
Compatibility (1)

Protocol compatibility

OpenClaw

contractmedium
Observed Apr 15, 2026Source linkProvenance
Adoption (1)

Adoption signal

2 GitHub stars

profilemedium
Observed Apr 15, 2026Source linkProvenance
Security (1)

Handshake status

UNKNOWN

trustmedium
Observed unknownSource linkProvenance
Integration (1)

Crawlable docs

6 indexed pages on the official domain

search_documentmedium
Observed Apr 15, 2026Source linkProvenance

Release & Crawl Timeline

Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.

Self-declaredagent-index

Artifacts Archive

Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.

Self-declaredGITHUB OPENCLEW

Extracted files

0

Examples

6

Snippets

0

Languages

typescript

Parameters

Dependencies

network access (for Blooio API calls)Blooio API key (user must provide)

Permissions

No permissions captured.
Executable Examples

text

https://backend.blooio.com/v2/api

text

Authorization: Bearer <your-api-key>

http

GET /contacts/{contactId}/capabilities

json

{
  "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"
}

Docs & README

Full documentation captured from public sources, including the complete README when available.

Self-declaredGITHUB OPENCLEW

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

Full README

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:

  • network access (for Blooio API calls)
  • Blooio API key (user must provide) allowed-tools:
  • http_request
  • fetch license: MIT

use-imessages

Send messages using iMessage with automatic fallback to RCS or SMS when iMessage isn't available for a contact. Uses the Blooio API.

When to Use This Skill

Use this skill when the user asks to:

  • Send a text message, iMessage, or SMS to someone
  • Check if a contact supports iMessage
  • Send a message to a group chat
  • Track if a message was delivered or read
  • Set up messaging automation or webhooks

Example Prompts That Trigger This Skill

  • "Send a message to +15551234567 saying 'Hey, running 10 mins late'"
  • "Text John at 555-123-4567 that the meeting is canceled"
  • "Can you check if this number has iMessage?"
  • "Send 'Hello team!' to my Sales group"
  • "I need to send an SMS to someone who doesn't have iMessage"
  • "Set up a webhook to notify me when I receive messages"

Prerequisites

  • Blooio API key (Bearer token) - obtain from https://blooio.com
  • At least one active device connected to Blooio

API Base URL

https://backend.blooio.com/v2/api

All requests require Bearer authentication:

Authorization: Bearer <your-api-key>

Core Workflow: Send Message with Fallback

Step 1: Check Contact Capabilities

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
}

Step 2: Send the Message

POST /chats/{chatId}/messages
Content-Type: application/json

{
  "text": "Hello! This is your message."
}

The chatId can be:

  • Phone number (E.164): %2B15551234567
  • Email: user%40example.com
  • Group ID: grp_abc123def456
  • Multiple recipients (comma-separated): %2B15551234567%2C%2B15559876543

Response (202 Accepted):

{
  "message_id": "msg_abc123def456",
  "status": "queued"
}

Step 3: Check Delivery Status

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

Decision Logic for Fallback

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.

Common Operations

Create a Contact

POST /contacts
Content-Type: application/json

{
  "identifier": "+15551234567",
  "name": "John Doe"
}

List Contacts

GET /contacts?limit=50&offset=0&q=john

Send Message with Attachments

POST /chats/{chatId}/messages
Content-Type: application/json

{
  "text": "Check out this image!",
  "attachments": [
    "https://example.com/image.jpg"
  ]
}

Send Multiple Messages at Once

POST /chats/{chatId}/messages
Content-Type: application/json

{
  "text": ["First message", "Second message", "Third message"]
}

Returns message_ids array instead of single message_id.

Show Typing Indicator

POST /chats/{chatId}/typing
DELETE /chats/{chatId}/typing

Mark Chat as Read

POST /chats/{chatId}/read

Add Reaction to Message

POST /chats/{chatId}/messages/{messageId}/reactions
Content-Type: application/json

{
  "reaction": "+love"
}

Reactions: +love, +like, +dislike, +laugh, +emphasize, +question Use - prefix to remove: -love

Group Messaging

Create a Group

POST /groups
Content-Type: application/json

{
  "name": "Sales Team",
  "members": ["+15551234567", "+15559876543", "user@example.com"]
}

Send to Group

POST /chats/grp_abc123def456/messages
Content-Type: application/json

{
  "text": "Hello team!"
}

Send to Multiple Recipients (Auto-creates Group)

POST /chats/%2B15551234567%2C%2B15559876543/messages
Content-Type: application/json

{
  "text": "Hello both of you!"
}

Webhooks for Real-time Updates

Create Webhook

POST /webhooks
Content-Type: application/json

{
  "webhook_url": "https://your-server.com/webhook",
  "webhook_type": "all"
}

Types: message (inbound only), status (delivery status), all

Webhook Payload Example

{
  "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

Error Handling

| 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 |

503 No Devices Available

This means no Blooio device is online. The user needs to:

  1. Check their Blooio dashboard
  2. Ensure their Mac/device with Blooio is running
  3. Verify the device is connected

Complete Example: Send with Fallback

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')}")

Tips

  1. Phone numbers must be E.164 format: +15551234567 (with country code)
  2. URL-encode identifiers in paths: + becomes %2B, @ becomes %40
  3. Capabilities are cached: last_checked timestamp shows freshness
  4. Use idempotency keys for critical messages to prevent duplicates:
    Idempotency-Key: unique-request-id-123
    
  5. Group chats are unique by participants: Can't create duplicate groups with same members
  6. Typing indicators auto-expire: No need to manually stop them before sending

Contract & API

Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.

MissingGITHUB OPENCLEW

Contract coverage

Status

missing

Auth

None

Streaming

No

Data region

Unspecified

Protocol support

OpenClaw: self-declared

Requires: none

Forbidden: none

Guardrails

Operational confidence: low

No positive guardrails captured.
Invocation examples
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"

Reliability & Benchmarks

Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.

Missingruntime-metrics

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

Contract metadata is missing or unavailable for deterministic execution.
No benchmark suites or observed failure patterns are available.

Media & Demo

Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.

Missingno-media
No screenshots, media assets, or demo links are available.

Related Agents

Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.

Self-declaredprotocol-neighbors
GITHUB_REPOSactivepieces

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

OPENCLAW
GITHUB_REPOScherry-studio

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

MCPOPENCLAW
GITHUB_REPOSAionUi

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

MCPOPENCLAW
GITHUB_REPOSCopilotKit

Rank

70

The Frontend for Agents & Generative UI. React + Angular

Traction

No public download signal

Freshness

Updated 23d ago

OPENCLAW
Machine Appendix

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.