Viewing file: Checkout.php (4.16 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Laravel\Cashier;
use Illuminate\Contracts\Support\Arrayable; use Illuminate\Contracts\Support\Jsonable; use Illuminate\Contracts\Support\Responsable; use Illuminate\Support\Facades\Redirect; use Illuminate\Support\Facades\View; use JsonSerializable; use Stripe\Checkout\Session;
class Checkout implements Arrayable, Jsonable, JsonSerializable, Responsable { /** * The Stripe model instance. * * @var \Illuminate\Database\Eloquent\Model */ protected $owner;
/** * The Stripe checkout session instance. * * @var \Stripe\Checkout\Session */ protected $session;
/** * Create a new checkout session instance. * * @param \Illuminate\Database\Eloquent\Model $owner * @param \Stripe\Checkout\Session $session * @return void */ public function __construct($owner, Session $session) { $this->owner = $owner; $this->session = $session; }
/** * Begin a new checkout session. * * @param \Illuminate\Database\Eloquent\Model $owner * @param array $sessionOptions * @param array $customerOptions * @return \Laravel\Cashier\Checkout */ public static function create($owner, array $sessionOptions = [], array $customerOptions = []) { $customer = $owner->createOrGetStripeCustomer($customerOptions);
// Make sure to collect address and name when Tax ID collection is enabled... if ($sessionOptions['tax_id_collection']['enabled'] ?? false) { $sessionOptions['customer_update']['address'] = 'auto'; $sessionOptions['customer_update']['name'] = 'auto'; }
$session = $owner->stripe()->checkout->sessions->create(array_merge([ 'customer' => $customer->id, 'mode' => 'payment', 'success_url' => $sessionOptions['success_url'] ?? route('home').'?checkout=success', 'cancel_url' => $sessionOptions['cancel_url'] ?? route('home').'?checkout=cancelled', 'payment_method_types' => ['card'], ], $sessionOptions));
return new static($owner, $session); }
/** * Get the view instance for the button. * * @param string $label * @param array $options * @return \Illuminate\Contracts\View\View * * @deprecated Use the redirect method instead. */ public function button($label = 'Check out', array $options = []) { return View::make('cashier::checkout', array_merge([ 'label' => $label, 'sessionId' => $this->session->id, 'stripeKey' => config('cashier.key'), ], $options)); }
/** * Redirect to the checkout session. * * @return \Illuminate\Http\RedirectResponse */ public function redirect() { return Redirect::to($this->session->url, 303); }
/** * Create an HTTP response that represents the object. * * @param \Illuminate\Http\Request $request * @return \Symfony\Component\HttpFoundation\Response */ public function toResponse($request) { return $this->redirect(); }
/** * Get the Checkout Session as a Stripe Checkout Session object. * * @return \Stripe\Checkout\Session */ public function asStripeCheckoutSession() { return $this->session; }
/** * Get the instance as an array. * * @return array */ public function toArray() { return $this->asStripeCheckoutSession()->toArray(); }
/** * Convert the object to its JSON representation. * * @param int $options * @return string */ public function toJson($options = 0) { return json_encode($this->jsonSerialize(), $options); }
/** * Convert the object into something JSON serializable. * * @return array */ #[\ReturnTypeWillChange] public function jsonSerialize() { return $this->toArray(); }
/** * Dynamically get values from the Stripe object. * * @param string $key * @return mixed */ public function __get($key) { return $this->session->{$key}; } }
|