MCP Server LogoMCP Server
MCPsCategoriesDirectorySubmit
Submit
MCPsCategoriesDirectorySubmit
Submit

MCP Servers

A curated list of MCP Servers, featuring Awesome MCP Servers and Claude MCP integration.

Contact Us

[email protected]

About

Privacy PolicyTerms of Service

Resources

Model Context ProtocolMCP Starter GuideClaude MCP Servers

Community

GitHub

© 2025 mcpserver.cc © 2025 MCP Server. All rights reserved.

Privacy PolicyTerms of Service
  1. Home
  2. /Categories
  3. /Communication & Collaboration
  4. /Onesignal Mcp
Onesignal Mcp

Onesignal Mcp

Created by WeirdBrains•a day ago
Visit Website

A Model Context Protocol (MCP) server for interacting with the OneSignal API

Communication & Collaboration
OneSignalMCPserverpush-notificationsAPI

OneSignal MCP Server

A comprehensive Model Context Protocol (MCP) server for interacting with the OneSignal API. This server provides a complete interface for managing push notifications, emails, SMS, users, devices, segments, templates, analytics, and more through OneSignal’s REST API.

Overview

This MCP server provides comprehensive access to the OneSignal REST API, offering 57 tools that cover all major OneSignal operations:

🚀 Key Features

  • Multi-channel Messaging: Send push notifications, emails, SMS, and transactional messages
  • User & Device Management: Complete CRUD operations for users, devices, and subscriptions
  • Advanced Segmentation: Create and manage user segments with complex filters
  • Template System: Create, update, and manage message templates
  • iOS Live Activities: Full support for iOS Live Activities
  • Analytics & Export: View outcomes data and export to CSV
  • Multi-App Support: Manage multiple OneSignal applications seamlessly
  • API Key Management: Create, update, rotate, and delete API keys
  • Organization-level Operations: Manage apps across your entire organization

Requirements

  • Python 3.7 or higher
  • python-dotenv package
  • requests package
  • mcp package
  • OneSignal account with API credentials

Installation

Option 1: Clone from GitHub

## Clone the repository
git clone https://github.com/weirdbrains/onesignal-mcp.git
cd onesignal-mcp

## Install dependencies
pip install -r requirements.txt

Option 2: Install as a Package (Coming Soon)

pip install onesignal-mcp

Configuration

  1. Create a .env file in the root directory with your OneSignal credentials:

    # Default app credentials (optional, you can also add apps via the API)
    ONESIGNAL_APP_ID=your_app_id_here
    ONESIGNAL_API_KEY=your_rest_api_key_here
    
    # Organization API key (for org-level operations)
    ONESIGNAL_ORG_API_KEY=your_organization_api_key_here
    
    # Optional: Multiple app configurations
    ONESIGNAL_MANDIBLE_APP_ID=mandible_app_id
    ONESIGNAL_MANDIBLE_API_KEY=mandible_api_key
    
    ONESIGNAL_WEIRDBRAINS_APP_ID=weirdbrains_app_id
    ONESIGNAL_WEIRDBRAINS_API_KEY=weirdbrains_api_key
    
    # Logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL)
    LOG_LEVEL=INFO
    
  2. Find your OneSignal credentials:

    • App ID: Settings > Keys & IDs > OneSignal App ID
    • REST API Key: Settings > Keys & IDs > REST API Key
    • Organization API Key: Organization Settings > API Keys

Usage

Running the Server

python onesignal_server.py

The server will start and register itself with the MCP system, making all 57 tools available for use.

Complete Tools Reference (57 Tools)

📱 App Management (5 tools)

  • list_apps - List all configured OneSignal apps
  • add_app - Add a new OneSignal app configuration locally
  • update_local_app_config - Update an existing local app configuration
  • remove_app - Remove a local OneSignal app configuration
  • switch_app - Switch the current app to use for API requests

📨 Messaging (8 tools)

  • send_push_notification - Send a push notification
  • send_email - Send an email through OneSignal
  • send_sms - Send an SMS/MMS through OneSignal
  • send_transactional_message - Send immediate delivery messages
  • view_messages - View recent messages sent
  • view_message_details - Get detailed information about a message
  • view_message_history - View message history/recipients
  • cancel_message - Cancel a scheduled message

📱 Devices/Players (6 tools)

  • view_devices - View devices subscribed to your app
  • view_device_details - Get detailed information about a device
  • add_player - Add a new player/device
  • edit_player - Edit an existing player/device
  • delete_player - Delete a player/device record
  • edit_tags_with_external_user_id - Bulk edit tags by external ID

🎯 Segments (3 tools)

  • view_segments - List all segments
  • create_segment - Create a new segment
  • delete_segment - Delete a segment

📄 Templates (6 tools)

  • view_templates - List all templates
  • view_template_details - Get template details
  • create_template - Create a new template
  • update_template - Update an existing template
  • delete_template - Delete a template
  • copy_template_to_app - Copy template to another app

🏢 Apps (6 tools)

  • view_app_details - Get details about configured app
  • view_apps - List all organization apps
  • create_app - Create a new OneSignal application
  • update_app - Update an existing application
  • view_app_api_keys - View API keys for an app
  • create_app_api_key - Create a new API key

🔑 API Key Management (3 tools)

  • delete_app_api_key - Delete an API key
  • update_app_api_key - Update an API key
  • rotate_app_api_key - Rotate an API key

👤 Users (6 tools)

  • create_user - Create a new user
  • view_user - View user details
  • update_user - Update user information
  • delete_user - Delete a user
  • view_user_identity - Get user identity information
  • view_user_identity_by_subscription - Get identity by subscription

🏷️ Aliases (3 tools)

  • create_or_update_alias - Create or update user alias
  • delete_alias - Delete a user alias
  • create_alias_by_subscription - Create alias by subscription ID

📬 Subscriptions (5 tools)

  • create_subscription - Create a new subscription
  • update_subscription - Update a subscription
  • delete_subscription - Delete a subscription
  • transfer_subscription - Transfer subscription between users
  • unsubscribe_email - Unsubscribe using email token

🎯 Live Activities (3 tools)

  • start_live_activity - Start iOS Live Activity
  • update_live_activity - Update iOS Live Activity
  • end_live_activity - End iOS Live Activity

📊 Analytics & Export (3 tools)

  • view_outcomes - View outcomes/conversion data
  • export_players_csv - Export player data to CSV
  • export_messages_csv - Export messages to CSV

Usage Examples

Multi-Channel Messaging

## Send a push notification
await send_push_notification(
    title="Hello World",
    message="This is a test notification",
    segments=["Subscribed Users"]
)

## Send an email
await send_email(
    subject="Welcome!",
    body="Thank you for joining us",
    email_body="<html><body><h1>Welcome!</h1></body></html>",
    include_emails=["[email protected]"]
)

## Send an SMS
await send_sms(
    message="Your verification code is 12345",
    phone_numbers=["+15551234567"]
)

## Send a transactional message
await send_transactional_message(
    channel="email",
    content={"subject": "Order Confirmation", "body": "Your order has been confirmed"},
    recipients={"include_external_user_ids": ["user123"]}
)

User and Device Management

## Create a user
user = await create_user(
    name="John Doe",
    email="[email protected]",
    external_id="user123",
    tags={"plan": "premium", "joined": "2024-01-01"}
)

## Add a device
device = await add_player(
    device_type=1,  # Android
    identifier="device_token_here",
    language="en",
    tags={"app_version": "1.0.0"}
)

## Update user tags across all devices
await edit_tags_with_external_user_id(
    external_user_id="user123",
    tags={"last_active": "2024-01-15", "purchases": "5"}
)

iOS Live Activities

## Start a Live Activity
await start_live_activity(
    activity_id="delivery_123",
    push_token="live_activity_push_token",
    subscription_id="user_subscription_id",
    activity_attributes={"order_number": "12345"},
    content_state={"status": "preparing", "eta": "15 mins"}
)

## Update the Live Activity
await update_live_activity(
    activity_id="delivery_123",
    name="delivery_update",
    event="update",
    content_state={"status": "on_the_way", "eta": "5 mins"}
)

Analytics and Export

## View conversion outcomes
outcomes = await view_outcomes(
    outcome_names=["purchase", "session_duration"],
    outcome_time_range="7d",
    outcome_platforms=["ios", "android"]
)

## Export player data
export = await export_players_csv(
    start_date="2024-01-01T00:00:00Z",
    end_date="2024-01-31T23:59:59Z",
    segment_names=["Active Users"]
)

Testing

The server includes a comprehensive test suite. To run tests:

## Run the test script
python test_onesignal_mcp.py

## Or use unittest
python -m unittest discover tests

Error Handling

The server provides consistent error handling:

  • All errors are returned in a standardized format
  • Detailed error messages help identify issues
  • Automatic retry logic for transient failures
  • Proper authentication error messages

Rate Limiting

OneSignal enforces rate limits on API requests:

  • Standard limit: 10 requests per second
  • Bulk operations: May have lower limits
  • The server includes guidance on handling rate limits

Contributing

We welcome contributions! Please see CONTRIBUTING.md{:target=“_blank”} for guidelines.

License

This project is licensed under the MIT License - see the LICENSE{:target=“_blank”} file for details.

Acknowledgements

  • OneSignal for their excellent notification service
  • The MCP community for the Model Context Protocol
  • All contributors to this project

Prerequisites

  • •Familiarity with the server domain
  • •Basic understanding of related technologies
  • •Knowledge of Communication & Collaboration

Recommended Server

Mac Shell Mcp

Mac Shell Mcp

An MCP (Model Context Protocol) server for executing macOS terminal commands with ZSH shell. This server provides a secure way to execute shell commands with built-in whitelisting and approval mechanisms.

System_information_mcp

System_information_mcp

DevEnvInfoServer - Cursor MCP Server for Development Environment Information

Python Docs Server Mcp Server

Python Docs Server Mcp Server

Get Python Docs

View more → →

Details

Created

September 01, 2025

Last Updated

September 01, 2025

Category

Communication & Collaboration

Author

WeirdBrains

Share

More Server

Audius Mcp Atris

Audius Mcp Atris

Model Context Protocol server for Audius. Perform market research, purchase premium tracks, upload songs, and much more!

Mcp Name Origin Server

Mcp Name Origin Server

A Python-based MCP (Model Context Protocol) server that predicts the origin

Cve Search_mcp

Cve Search_mcp

A Model Context Protocol (MCP) server for querying the CVE-Search API

Mcp Jira Python

Mcp Jira Python

JIRA MCP Server Implementation in Python