Alejandro Akbal
Posted on October 10, 2021
Introduction
I'm going to explain how to build a free plan for your Laravel Spark Next application.
I will be using Paddle as the payment gateway, but the steps are almost identical with Stripe.
Best of all? No credit card required for the free plan.
Before we start
Preface
You should know that Laravel Spark is built on top of Laravel Cashier, so know that the process is very similar with both.
Requirements
- Laravel 8 with Spark Next
Laravel Spark installation
Before starting the tutorial, you should have followed the official installation guide.
Laravel Spark plan configuration
Let's imagine that we are building a new application which offers a free plan and a paid plan.
- The "Free" plan will have a limit of 1 project.
- The "Paid" plan will have a limit of 5 projects.
We need to configure both plans in the config/spark.php
file, like so:
// ...
'plans' => [
[
'name' => 'Free',
'short_description' => 'This is the free plan',
// Random _(not used by other plans)_ ID
'monthly_id' => 1000,
'features' => [
'1 Project',
],
'options' => [
'projects' => 1,
],
// IMPORTANT
'archived' => true,
],
[
'name' => 'Paid',
'short_description' => 'This is the paid plan',
'monthly_id' => 999990,
'yearly_id' => 999991,
'yearly_incentive' => 'Save 20%!',
'features' => [
'5 Projects',
],
'options' => [
'projects' => 5,
],
'archived' => false,
],
]
// ...
As you can see, the limits are actually set in the options
array.
It's important that the "Free" plan is set to archived
to prevent users from selecting that plan on the billing page.
The "Free" plan has to have a random monthly_id
, so the plan can be used internally.
It doesn't need to be a working product ID, nor do you have to create it on Paddle/Stripe.
Modify User model
Now that we have created a "Free" plan, we need to modify the User
model to add a getPlan
method.
This method will get the current users plan, or the "Free" plan if the user has no active plan.
// ...
public function getPlan()
{
$plan = $this->sparkPlan();
if ($plan !== null) {
return $plan;
}
// Fallback to "Free" plan
$plan = Spark::plans('user')->firstWhere('name', '=', 'Free');
return $plan;
}
// ...
Note: As mentioned in the steps before, you need to add a monthly_id
to the "Free" plan, otherwise it will be skipped by the Spark::plans('user')
call and will not be found.
The ID can be random, don't worry.
Getting the User's plan
Through your application you can access a user plan and limits like so:
$user = User::find(1);
$plan = $user->getPlan();
$plan->name; // "Free"
$plan->options['projects']; // 1
End
As you can see, what we actually do is fallback to the "Free" plan if the user has no active plan.
And this plan doesn't actually go through the payment process, so you don't need to ask the users with a credit card.
Self-promotion
If you have found this useful, then you should follow me, I will be posting more interesting content! 🥰
Or support me financially. 💸
Conclusion
Congratulations, today you have learned how to build a free plan in Laravel Spark.
Let me know if the tutorial was useful to you in the comments!
Posted on October 10, 2021
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.