KS
Killer-Skills

upgrade-stripe — AI agent skill

Verified
v1.0.0
GitHub

About this Skill

Perfect for Payment Processing Agents needing seamless Stripe API version upgrades and SDK management. upgrade-stripe is a skill that assists developers in upgrading Stripe API versions and SDKs, providing a smooth transition and minimizing potential disruptions.

Features

Upgrading Stripe API versions using Python
Managing SDK versions for server-side integration
Handling backward-compatible changes and breaking changes
Configuring global API versions for dynamic typing languages

# Core Topics

stripe stripe
[1.4k]
[242]
Updated: 3/30/2026

Quality Score

Top 5%
86
Excellent
Based on code quality & docs
Installation
SYS Universal Install (Auto-Detect)
Cursor IDE Windsurf IDE VS Code IDE
> npx killer-skills add stripe/ai

Agent Capability Analysis

The upgrade-stripe MCP Server by stripe is an open-source Categories.official integration for Claude and other AI agents, enabling seamless task automation and capability expansion. Optimized for AI agent skill, for Claude Code, Stripe API upgrade.

Ideal Agent Persona

Perfect for Payment Processing Agents needing seamless Stripe API version upgrades and SDK management.

Core Value

Empowers agents to dynamically manage Stripe API versions, ensuring backward compatibility and handling breaking changes through flexible version control using Stripe.js, server-side SDKs, and mobile SDKs. It provides API version pairing, per-request overrides, and global configuration using libraries like Stripe.js and protocols like date-based API versioning.

Capabilities Granted for upgrade-stripe MCP Server

Upgrading Stripe API versions to leverage new features and improvements
Managing server-side SDK versions for dynamically-typed languages like Ruby, Python, PHP, and Node.js
Debugging Stripe.js versioning issues and ensuring compatibility with corresponding API versions

! Prerequisites & Limits

  • Requires Stripe account and API keys
  • Must specify API version in code to avoid relying on account default
  • Strongly-typed languages like Java, Go, and .NET require SDK updates to target new API versions
Project
SKILL.md
5.4 KB
.cursorrules
1.2 KB
package.json
240 B
Ready
UTF-8
SKILL.md
Readonly

The latest Stripe API version is 2026-03-25.dahlia - use this version when upgrading unless the user specifies a different target version.

Upgrading Stripe Versions

This guide covers upgrading Stripe API versions, server-side SDKs, Stripe.js, and mobile SDKs.

Understanding Stripe API Versioning

Stripe uses date-based API versions (e.g., 2026-03-25.dahlia, 2025-08-27.basil, 2024-12-18.acacia). Your account’s API version determines request/response behavior.

Types of Changes

Backward-Compatible Changes (don’t require code updates):

  • New API resources
  • New optional request parameters
  • New properties in existing responses
  • Changes to opaque string lengths (e.g., object IDs)
  • New webhook event types

Breaking Changes (require code updates):

  • Field renames or removals
  • Behavioral modifications
  • Removed endpoints or parameters

Review the API Changelog for all changes between versions.

Server-Side SDK Versioning

See SDK Version Management for details.

Dynamically-Typed Languages (Ruby, Python, PHP, Node.js)

These SDKs offer flexible version control:

Global Configuration:

python
1import stripe 2stripe.api_version = '2026-03-25.dahlia'
ruby
1Stripe.api_version = '2026-03-25.dahlia'
javascript
1const stripe = require('stripe')('sk_test_xxx', { 2 apiVersion: '2026-03-25.dahlia' 3});

Per-Request Override:

python
1stripe.Customer.create( 2 email="customer@example.com", 3 stripe_version='2026-03-25.dahlia' 4)

Strongly-Typed Languages (Java, Go, .NET)

These use a fixed API version matching the SDK release date. Don’t set a different API version for strongly-typed languages because response objects might not match the strong types in the SDK. Instead, update the SDK to target a new API version.

Best Practice

Always specify the API version you’re integrating against in your code instead of relying on your account’s default API version:

javascript
1// Good: Explicit version 2const stripe = require('stripe')('sk_test_xxx', { 3 apiVersion: '2026-03-25.dahlia' 4}); 5 6// Avoid: Relying on account default 7const stripe = require('stripe')('sk_test_xxx');

Stripe.js Versioning

See Stripe.js Versioning for details.

Stripe.js uses an evergreen model with major releases (Acacia, Basil, Clover, Dahlia) on a biannual basis.

Loading Versioned Stripe.js

Via Script Tag:

html
1<script src="https://js.stripe.com/dahlia/stripe.js"></script>

Via npm:

bash
1npm install @stripe/stripe-js

Major npm versions correspond to specific Stripe.js versions.

API Version Pairing

Each Stripe.js version automatically pairs with its corresponding API version. For instance:

  • Dahlia Stripe.js uses 2026-03-25.dahlia API
  • Acacia Stripe.js uses 2024-12-18.acacia API

You can’t override this association.

Migrating from v3

  1. Identify your current API version in code
  2. Review the changelog for relevant changes
  3. Consider gradually updating your API version before switching Stripe.js versions
  4. Stripe continues supporting v3 indefinitely

Mobile SDK Versioning

See Mobile SDK Versioning for details.

iOS and Android SDKs

Both platforms follow semantic versioning (MAJOR.MINOR.PATCH):

  • MAJOR: Breaking API changes
  • MINOR: New functionality (backward-compatible)
  • PATCH: Bug fixes (backward-compatible)

New features and fixes release only on the latest major version. Upgrade regularly to access improvements.

React Native SDK

Uses a different model (0.x.y schema):

  • Minor version changes (x): Breaking changes AND new features
  • Patch updates (y): Critical bug fixes only

Backend Compatibility

All mobile SDKs work with any Stripe API version you use on your backend unless documentation specifies otherwise.

Upgrade Checklist

  1. Review the API Changelog for changes between your current and target versions
  2. Check Upgrades Guide for migration guidance
  3. Update server-side SDK package version (e.g., npm update stripe, pip install --upgrade stripe)
  4. Update the apiVersion parameter in your Stripe client initialization
  5. Test your integration against the new API version using the Stripe-Version header
  6. Update webhook handlers to handle new event structures
  7. Update Stripe.js script tag or npm package version if needed
  8. Update mobile SDK versions in your package manager if needed
  9. Store Stripe object IDs in databases that accommodate up to 255 characters (case-sensitive collation)

Testing API Version Changes

Use the Stripe-Version header to test your code against a new version without changing your default:

bash
1curl https://api.stripe.com/v1/customers \ 2 -u sk_test_xxx: \ 3 -H "Stripe-Version: 2026-03-25.dahlia"

Or in code:

javascript
1const stripe = require('stripe')('sk_test_xxx', { 2 apiVersion: '2026-03-25.dahlia' // Test with new version 3});

Important Notes

  • Your webhook listener should handle unfamiliar event types gracefully
  • Test webhooks with the new version structure before upgrading
  • Breaking changes are tagged by affected product areas (Payments, Billing, Connect, etc.)
  • Multiple API versions coexist simultaneously, enabling staged adoption

Related Skills

Looking for an alternative to upgrade-stripe or building a Categories.official AI Agent? Explore these related open-source MCP Servers.

View All

flags

Logo of facebook
facebook

Use when you need to check feature flag states, compare channels, or debug why a feature behaves differently across release channels.

243.6k
0
Design

extract-errors

Logo of facebook
facebook

Use when adding new error messages to React, or seeing unknown error code warnings.

243.6k
0
Design

fix

Logo of facebook
facebook

Use when you have lint errors, formatting issues, or before committing code to ensure it passes CI.

243.6k
0
Design

flow

Logo of facebook
facebook

Use when you need to run Flow type checking, or when seeing Flow type errors in React code.

243.6k
0
Design