| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- <?php
- // File generated from our OpenAPI spec
- namespace Stripe\Service;
- /**
- * @phpstan-import-type RequestOptionsArray from \Stripe\Util\RequestOptions
- * @psalm-import-type RequestOptionsArray from \Stripe\Util\RequestOptions
- */
- class PaymentMethodService extends \Stripe\Service\AbstractService
- {
- /**
- * Returns a list of PaymentMethods for Treasury flows. If you want to list the
- * PaymentMethods attached to a Customer for payments, you should use the <a
- * href="/docs/api/payment_methods/customer_list">List a Customer’s
- * PaymentMethods</a> API instead.
- *
- * @param null|array $params
- * @param null|RequestOptionsArray|\Stripe\Util\RequestOptions $opts
- *
- * @throws \Stripe\Exception\ApiErrorException if the request fails
- *
- * @return \Stripe\Collection<\Stripe\PaymentMethod>
- */
- public function all($params = null, $opts = null)
- {
- return $this->requestCollection('get', '/v1/payment_methods', $params, $opts);
- }
- /**
- * Attaches a PaymentMethod object to a Customer.
- *
- * To attach a new PaymentMethod to a customer for future payments, we recommend
- * you use a <a href="/docs/api/setup_intents">SetupIntent</a> or a PaymentIntent
- * with <a
- * href="/docs/api/payment_intents/create#create_payment_intent-setup_future_usage">setup_future_usage</a>.
- * These approaches will perform any necessary steps to set up the PaymentMethod
- * for future payments. Using the <code>/v1/payment_methods/:id/attach</code>
- * endpoint without first using a SetupIntent or PaymentIntent with
- * <code>setup_future_usage</code> does not optimize the PaymentMethod for future
- * use, which makes later declines and payment friction more likely. See <a
- * href="/docs/payments/payment-intents#future-usage">Optimizing cards for future
- * payments</a> for more information about setting up future payments.
- *
- * To use this PaymentMethod as the default for invoice or subscription payments,
- * set <a
- * href="/docs/api/customers/update#update_customer-invoice_settings-default_payment_method"><code>invoice_settings.default_payment_method</code></a>,
- * on the Customer to the PaymentMethod’s ID.
- *
- * @param string $id
- * @param null|array $params
- * @param null|RequestOptionsArray|\Stripe\Util\RequestOptions $opts
- *
- * @throws \Stripe\Exception\ApiErrorException if the request fails
- *
- * @return \Stripe\PaymentMethod
- */
- public function attach($id, $params = null, $opts = null)
- {
- return $this->request('post', $this->buildPath('/v1/payment_methods/%s/attach', $id), $params, $opts);
- }
- /**
- * Creates a PaymentMethod object. Read the <a
- * href="/docs/stripe-js/reference#stripe-create-payment-method">Stripe.js
- * reference</a> to learn how to create PaymentMethods via Stripe.js.
- *
- * Instead of creating a PaymentMethod directly, we recommend using the <a
- * href="/docs/payments/accept-a-payment">PaymentIntents</a> API to accept a
- * payment immediately or the <a
- * href="/docs/payments/save-and-reuse">SetupIntent</a> API to collect payment
- * method details ahead of a future payment.
- *
- * @param null|array $params
- * @param null|RequestOptionsArray|\Stripe\Util\RequestOptions $opts
- *
- * @throws \Stripe\Exception\ApiErrorException if the request fails
- *
- * @return \Stripe\PaymentMethod
- */
- public function create($params = null, $opts = null)
- {
- return $this->request('post', '/v1/payment_methods', $params, $opts);
- }
- /**
- * Detaches a PaymentMethod object from a Customer. After a PaymentMethod is
- * detached, it can no longer be used for a payment or re-attached to a Customer.
- *
- * @param string $id
- * @param null|array $params
- * @param null|RequestOptionsArray|\Stripe\Util\RequestOptions $opts
- *
- * @throws \Stripe\Exception\ApiErrorException if the request fails
- *
- * @return \Stripe\PaymentMethod
- */
- public function detach($id, $params = null, $opts = null)
- {
- return $this->request('post', $this->buildPath('/v1/payment_methods/%s/detach', $id), $params, $opts);
- }
- /**
- * Retrieves a PaymentMethod object attached to the StripeAccount. To retrieve a
- * payment method attached to a Customer, you should use <a
- * href="/docs/api/payment_methods/customer">Retrieve a Customer’s
- * PaymentMethods</a>.
- *
- * @param string $id
- * @param null|array $params
- * @param null|RequestOptionsArray|\Stripe\Util\RequestOptions $opts
- *
- * @throws \Stripe\Exception\ApiErrorException if the request fails
- *
- * @return \Stripe\PaymentMethod
- */
- public function retrieve($id, $params = null, $opts = null)
- {
- return $this->request('get', $this->buildPath('/v1/payment_methods/%s', $id), $params, $opts);
- }
- /**
- * Updates a PaymentMethod object. A PaymentMethod must be attached a customer to
- * be updated.
- *
- * @param string $id
- * @param null|array $params
- * @param null|RequestOptionsArray|\Stripe\Util\RequestOptions $opts
- *
- * @throws \Stripe\Exception\ApiErrorException if the request fails
- *
- * @return \Stripe\PaymentMethod
- */
- public function update($id, $params = null, $opts = null)
- {
- return $this->request('post', $this->buildPath('/v1/payment_methods/%s', $id), $params, $opts);
- }
- }
|