Download the PHP package gamers-geek/stripe without Composer
On this page you can find all versions of the php package gamers-geek/stripe. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download gamers-geek/stripe
More information about gamers-geek/stripe
Files in gamers-geek/stripe
Informations about the package stripe
This addon enables Stripe payments on your Lunar storefront.
Alpha Release
This addon is currently in Alpha, whilst every step is taken to ensure this is working as intended, it will not be considered out of Alpha until more tests have been added and proved.
Tests required:
- [ ] Successful charge response from Stripe.
- [ ] Unsuccessful charge response from Stripe.
- [ ] Test
manual
config reacts appropriately. - [x] Test
automatic
config reacts appropriately. - [ ] Ensure transactions are stored correctly in the database
- [x] Ensure that the payment intent is not duplicated when using the same Cart
- [ ] Ensure appropriate responses are returned based on Stripe's responses.
- [ ] Test refunds and partial refunds create the expected transactions
- [ ] Make sure we can manually release a payment or part payment and handle the different responses.
Requirements
- Lunar >=
0.1
- A Stripe account with secret and public keys
- Laravel Livewire (if using frontend components)
- Alpinejs (if using frontend components)
Installation
Require the composer package
Publish the configuration
This will publish the configuration under config/lunar/stripe.php
.
Publish the views (optional)
Lunar Stripe comes with some helper components for you to use on your checkout, if you intend to edit the views they provide, you can publish them.
Enable the driver
Set the driver in config/lunar/payments.php
Add your Stripe credentials
Make sure you have the Stripe credentials set in config/services.php
Keys can be found in your Stripe account https://dashboard.stripe.com/apikeys
Configuration
Below is a list of the available configuration options this package uses in config/getcandy/stripe.php
Key | Default | Description |
---|---|---|
policy |
automatic |
Determines the policy for taking payments and whether you wish to capture the payment manually later or take payment straight away. Available options manual or automatic |
Backend Usage
Creating a PaymentIntent
This method will create a Stripe PaymentIntent from a Cart and add the resulting ID to the meta for retrieval later. If a PaymentIntent already exists for a cart this will fetch it from Stripe and return that instead to avoid duplicate PaymentIntents being created.
Fetch an existing PaymentIntent
Both these methods will return a Stripe\PaymentIntent
object.
Storefront Usage
This addon provides some useful components you can use in your Storefront, they are built using Laravel Livewire and AlpineJs so bear that in mind.
If you are using the Demo Store, this is already set up for you so you can refer to the source code to see what's happening.
Set up the scripts
Place this in the <head>
of your Storefront.
Add the payment component
Wherever you want the payment form to appear, add this component:
The returnUrl
is where we want Stripe to redirect us afer they have processed the payment on their servers.
Do NOT point this to the order confirmation page, as you'll see below
Process the result
You'll notice above we've told Stripe to redirect back to the checkout page, this is because although Stripe has either taken payment or allocated funds based on your policy, we still need Lunar to process the result and create the transactions it needs against the order.
When Stripe redirects us we should have two parameters passed in the query string. payment_intent_client_secret
and payment_intent
. We can then check for these values and pass them off using Lunar's Payments driver.
So, assuming we are using Livewire and on a CheckoutPage
component (like on the Demo Store)
And that should be it, you should then see the order in Lunar with the correct Transactions.
If you have set your policy to manual
you'll need to go into the Hub and manually capture the payment.
Contributing
Contributions are welcome, if you are thinking of adding a feature, please submit an issue first so we can determine whether it should be included.
Testing
Currently we use a manual MockClient to mock the responses the Stripe API will return. This is likely to be improved upon as tests are written, but it should be apparent what this is doing, so feel free to add your own responses.
All versions of stripe with dependencies
lunarphp/lunar Version ^0.5
stripe/stripe-php Version ^10.14
livewire/livewire Version ^2.0