# Adds support for ad-hoc products and prices when creating Payment Links

## What’s new

You can now generate a new [Price](https://docs.stripe.com/api/prices/object.md?api-version=2025-07-30.basil) when you create a [Payment Link](https://docs.stripe.com/api/payment-link.md?api-version=2025-07-30.basil) by specifying the [price_data](https://docs.stripe.com/api/payment-link/create.md?api-version=2025-07-30.basil#create_payment_link-line_items-price_data) parameter for its [line_items](https://docs.stripe.com/api/payment-link/create.md?api-version=2025-07-30.basil#create_payment_link-line_items).

## Impact

Instead of needing two API requests to separately create a Price and a Payment Link, using `price_data` allows you to create them both with just one API request.

## Changes

#### REST API

| Parameter    | Change | Resources or endpoints                                                                                                  |
| ------------ | ------ | ----------------------------------------------------------------------------------------------------------------------- |
| `price_data` | Added  | [PaymentLink#create.line_items[]](/api/payment-link/create?api-version=2025-07-30.basil#create_payment_link-line_items) |

| Field                                   | Change  | From → to             |
| --------------------------------------- | ------- | --------------------- |
| `PaymentLink#create.line_items[].price` | Changed | `required → optional` |

#### Ruby

| Parameter    | Change | Resources or methods                                                                                                        |
| ------------ | ------ | --------------------------------------------------------------------------------------------------------------------------- |
| `price_data` | Added  | [PaymentLink::CreateParams::LineItem](/api/payment-link/create?api-version=2025-07-30.basil#create_payment_link-line_items) |

| Field                                       | Change  | From → to             |
| ------------------------------------------- | ------- | --------------------- |
| `PaymentLink::CreateParams::LineItem.price` | Changed | `required → optional` |

#### Python

| Parameter    | Change | Resources or methods                                                                                                     |
| ------------ | ------ | ------------------------------------------------------------------------------------------------------------------------ |
| `price_data` | Added  | [PaymentLink.CreateParamsLineItem](/api/payment-link/create?api-version=2025-07-30.basil#create_payment_link-line_items) |

| Field                                    | Change  | From → to             |
| ---------------------------------------- | ------- | --------------------- |
| `PaymentLink.CreateParamsLineItem.price` | Changed | `required → optional` |

#### PHP

This change does not affect the PHP SDK.

#### Java

| Parameter   | Change | Resources or methods                                                                                                         |
| ----------- | ------ | ---------------------------------------------------------------------------------------------------------------------------- |
| `priceData` | Added  | [PaymentLinkCreateParams.line_items[]](/api/payment-link/create?api-version=2025-07-30.basil#create_payment_link-line_items) |

| Field                                        | Change  | From → to             |
| -------------------------------------------- | ------- | --------------------- |
| `PaymentLinkCreateParams.line_items[].price` | Changed | `required → optional` |

#### Node.js

| Parameter    | Change | Resources or methods                                                                                                         |
| ------------ | ------ | ---------------------------------------------------------------------------------------------------------------------------- |
| `price_data` | Added  | [PaymentLinkCreateParams.line_items[]](/api/payment-link/create?api-version=2025-07-30.basil#create_payment_link-line_items) |

| Field                                        | Change  | From → to             |
| -------------------------------------------- | ------- | --------------------- |
| `PaymentLinkCreateParams.line_items[].price` | Changed | `required → optional` |

#### Go

| Parameter   | Change | Resources or methods                                                                                              |
| ----------- | ------ | ----------------------------------------------------------------------------------------------------------------- |
| `PriceData` | Added  | [PaymentLinkLineItemParams](/api/payment-link/create?api-version=2025-07-30.basil#create_payment_link-line_items) |

#### .NET

| Parameter   | Change | Resources or methods                                                                                               |
| ----------- | ------ | ------------------------------------------------------------------------------------------------------------------ |
| `PriceData` | Added  | [PaymentLinkLineItemOptions](/api/payment-link/create?api-version=2025-07-30.basil#create_payment_link-line_items) |

## Upgrade

#### REST API

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. If you use an SDK, upgrade to the corresponding SDK version for this API version.
   - If you don’t use an SDK, update your [API requests](https://docs.stripe.com/api/versioning.md) to include `Stripe-Version: 2025-07-30.basil`
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).

#### Ruby

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. Upgrade your Ruby SDK to [v15.4.0](https://github.com/stripe/stripe-ruby/releases/tag/v15.4.0)
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).

#### Python

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. Upgrade your Python SDK to [v12.4.0](https://github.com/stripe/stripe-python/releases/tag/v12.4.0)
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).

#### PHP

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. Upgrade your PHP SDK to [v17.5.0](https://github.com/stripe/stripe-php/releases/tag/v17.5.0)
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).

#### Java

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. Upgrade your Java SDK to [v29.4.0](https://github.com/stripe/stripe-java/releases/tag/v29.4.0)
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).

#### Node.js

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. Upgrade your Node SDK to [v18.4.0](https://github.com/stripe/stripe-node/releases/tag/v18.4.0)
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).

#### Go

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. Upgrade your Go SDK to [v82.4.0](https://github.com/stripe/stripe-go/releases/tag/v82.4.0)
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).

#### .NET

1. [View your current API version](https://docs.stripe.com/upgrades.md#view-your-api-version-and-the-latest-available-upgrade-in-workbench) in Workbench.
1. Upgrade your .NET SDK to [v48.4.0](https://github.com/stripe/stripe-dotnet/releases/tag/v48.4.0)
1. Upgrade the API version used for [webhook endpoints](https://docs.stripe.com/webhooks/versioning.md).
1. [Test your integration](https://docs.stripe.com/testing.md) against the new version.
1. If you use Connect, [test your Connect integration](https://docs.stripe.com/connect/testing.md).
1. In Workbench, [perform the upgrade](https://docs.stripe.com/upgrades.md#perform-the-upgrade). You can [roll back the version](https://docs.stripe.com/upgrades.md#roll-back-your-api-version) for 72 hours.

Learn more about [Stripe API upgrades](https://docs.stripe.com/upgrades.md).
