Rippling MCP Server

Rippling MCP Server

Provides 50+ tools for interacting with Rippling's HR platform, including employee management, payroll, time tracking, benefits, recruiting, learning, devices, groups, and custom objects, all through natural language.

Category
Visit Server

README

Rippling MCP Server

Complete Model Context Protocol (MCP) server for the Rippling HR Platform API.

Overview

This MCP server provides comprehensive integration with Rippling's HR platform, enabling AI assistants to interact with employee data, payroll, time tracking, benefits, recruiting (ATS), learning management, device inventory, and more.

Features

šŸ”§ 50+ Tools Across 10 Categories

Employees (7 tools)

  • rippling_list_employees - List all employees with filters
  • rippling_get_employee - Get detailed employee information
  • rippling_create_employee - Create new employee records
  • rippling_update_employee - Update employee information
  • rippling_terminate_employee - Terminate an employee
  • rippling_list_employee_custom_fields - List custom fields
  • rippling_get_org_chart - Get organizational chart

Companies (5 tools)

  • rippling_get_company - Get company information
  • rippling_list_departments - List all departments
  • rippling_create_department - Create new department
  • rippling_list_locations - List work locations
  • rippling_list_teams - List all teams

Payroll (4 tools)

  • rippling_list_pay_runs - List payroll runs
  • rippling_get_pay_run - Get pay run details
  • rippling_list_pay_statements - List pay statements
  • rippling_get_pay_statement - Get detailed pay statement

Time Tracking (11 tools)

  • rippling_list_time_entries - List time clock entries
  • rippling_create_time_entry - Create time entry
  • rippling_update_time_entry - Update time entry
  • rippling_delete_time_entry - Delete time entry
  • rippling_get_timesheet - Get timesheet
  • rippling_approve_timesheet - Approve timesheet
  • rippling_list_time_off_requests - List PTO requests
  • rippling_create_time_off_request - Create PTO request
  • rippling_approve_time_off_request - Approve PTO
  • rippling_deny_time_off_request - Deny PTO

Benefits (4 tools)

  • rippling_list_benefits_plans - List benefits plans
  • rippling_get_benefits_plan - Get plan details
  • rippling_list_benefits_enrollments - List enrollments
  • rippling_get_benefits_enrollment - Get enrollment details

ATS/Recruiting (6 tools)

  • rippling_list_candidates - List candidates
  • rippling_get_candidate - Get candidate details
  • rippling_list_jobs - List job postings
  • rippling_get_job - Get job details
  • rippling_list_applications - List applications
  • rippling_update_application_stage - Move candidate through pipeline

Learning (4 tools)

  • rippling_list_courses - List training courses
  • rippling_get_course - Get course details
  • rippling_list_course_assignments - List assignments
  • rippling_assign_course - Assign course to employee

Devices (4 tools)

  • rippling_list_devices - List hardware devices
  • rippling_get_device - Get device details
  • rippling_list_apps - List software/app licenses
  • rippling_get_app - Get app license details

Groups (6 tools)

  • rippling_list_groups - List groups
  • rippling_get_group - Get group details
  • rippling_create_group - Create new group
  • rippling_update_group - Update group
  • rippling_add_group_member - Add member to group
  • rippling_remove_group_member - Remove member from group

Custom Objects (5 tools)

  • rippling_list_custom_objects - List custom objects
  • rippling_get_custom_object - Get custom object
  • rippling_create_custom_object - Create custom object
  • rippling_update_custom_object - Update custom object
  • rippling_query_custom_objects - Query custom objects with filters

šŸŽØ 16 React UI Components

  1. EmployeeDashboard - Overview of employee metrics and departments
  2. EmployeeDetail - Detailed employee profile view
  3. EmployeeDirectory - Searchable employee directory with filters
  4. OrgChart - Visual organizational chart
  5. PayrollDashboard - Payroll overview and recent runs
  6. PayrollDetail - Detailed pay statement breakdown
  7. TimeTracker - Clock in/out interface and time entry viewer
  8. TimesheetApprovals - Approve/reject employee timesheets
  9. TimeOffCalendar - PTO calendar and requests
  10. BenefitsOverview - Benefits plans and enrollments
  11. ATSPipeline - Recruiting pipeline visualization
  12. JobBoard - Job postings board
  13. LearningDashboard - Training and course completion dashboard
  14. DeviceInventory - Hardware and device management
  15. TeamOverview - Team composition and management
  16. DepartmentGrid - Department overview and headcount

Installation

npm install

Configuration

Set the following environment variables:

# Option 1: API Key authentication
export RIPPLING_API_KEY="your_api_key_here"

# Option 2: OAuth2 Bearer token
export RIPPLING_ACCESS_TOKEN="your_access_token_here"

# Optional: Custom API base URL
export RIPPLING_BASE_URL="https://api.rippling.com"

Usage

As MCP Server

Add to your MCP settings configuration:

{
  "mcpServers": {
    "rippling": {
      "command": "node",
      "args": ["/path/to/rippling/dist/index.js"],
      "env": {
        "RIPPLING_API_KEY": "your_api_key_here"
      }
    }
  }
}

Development

# Build TypeScript
npm run build

# Run in development mode
npm run dev

API Client

The RipplingClient class provides:

  • āœ… Automatic authentication (API key or OAuth2)
  • āœ… Cursor-based pagination support
  • āœ… Comprehensive error handling
  • āœ… Type-safe requests and responses
  • āœ… Automatic retry logic
  • āœ… Request/response interceptors

Example Usage

import { RipplingClient } from './clients/rippling.js';

const client = new RipplingClient({
  apiKey: process.env.RIPPLING_API_KEY,
});

// List employees with pagination
const employees = await client.listEmployees({
  status: 'ACTIVE',
  departmentId: 'dept_123',
  limit: 100,
});

// Get all pages automatically
const allEmployees = await client.getAllPaginated('/v1/employees');

// Create a new employee
const newEmployee = await client.createEmployee({
  firstName: 'John',
  lastName: 'Doe',
  email: 'john.doe@company.com',
  title: 'Software Engineer',
});

Architecture

rippling/
ā”œā”€ā”€ src/
│   ā”œā”€ā”€ clients/
│   │   └── rippling.ts          # API client with auth & pagination
│   ā”œā”€ā”€ tools/
│   │   ā”œā”€ā”€ employees-tools.ts   # Employee management (7 tools)
│   │   ā”œā”€ā”€ companies-tools.ts   # Company/dept/location (5 tools)
│   │   ā”œā”€ā”€ payroll-tools.ts     # Payroll operations (4 tools)
│   │   ā”œā”€ā”€ time-tools.ts        # Time tracking & PTO (11 tools)
│   │   ā”œā”€ā”€ benefits-tools.ts    # Benefits management (4 tools)
│   │   ā”œā”€ā”€ ats-tools.ts         # Recruiting/ATS (6 tools)
│   │   ā”œā”€ā”€ learning-tools.ts    # Learning management (4 tools)
│   │   ā”œā”€ā”€ devices-tools.ts     # Device/app inventory (4 tools)
│   │   ā”œā”€ā”€ groups-tools.ts      # Group management (6 tools)
│   │   └── custom-objects-tools.ts # Custom objects (5 tools)
│   ā”œā”€ā”€ types/
│   │   └── index.ts             # TypeScript type definitions
│   ā”œā”€ā”€ ui/
│   │   └── react-app/           # 16 React UI components
│   ā”œā”€ā”€ server.ts                # MCP server setup
│   └── index.ts                 # Entry point
ā”œā”€ā”€ package.json
ā”œā”€ā”€ tsconfig.json
└── README.md

Type Safety

All API interactions are fully typed with TypeScript interfaces including:

  • Employee, Department, Location, Team
  • PayRun, PayStatement, EarningsLine, TaxLine, DeductionLine
  • TimeEntry, Timesheet, TimeOffRequest
  • BenefitsPlan, BenefitsEnrollment, Dependent
  • Candidate, Job, Application, Interview
  • Course, CourseAssignment
  • Device, AppLicense
  • Group, CustomObject
  • PaginatedResponse, RipplingError

Error Handling

The client automatically handles:

  • HTTP errors with detailed messages
  • Rate limiting (with retry logic)
  • Invalid authentication
  • Malformed requests
  • Network errors

Errors are returned in a consistent format:

{
  message: string;
  code?: string;
  statusCode?: number;
  details?: any;
}

Pagination

All list endpoints support cursor-based pagination:

// Manual pagination
let cursor: string | undefined;
do {
  const response = await client.listEmployees({ cursor, limit: 100 });
  // Process response.data
  cursor = response.nextCursor;
} while (response.hasMore);

// Automatic pagination (gets all pages)
const allEmployees = await client.getAllPaginated('/v1/employees');

License

MIT

Support

For issues or questions:

  • Check the Rippling API Documentation
  • Review the type definitions in src/types/index.ts
  • Examine the client implementation in src/clients/rippling.ts

Contributing

Contributions welcome! Please ensure:

  • All new tools have proper Zod schemas
  • Type definitions are updated
  • Error handling is comprehensive
  • Tests are added (when test suite is created)

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured