This is a SaaS boilerplate built on top of the Laravel framework. Built to provide developers with a template to kickoff their SaaS application, without the hustle for repetitive tasks such as user account setup, subscriptions and role management.
- Authentication
- Login / Registration
- Email Activation
- Two Factor Login (only when enabled)
- Subscription with Stripe
- User plans
- Team plans
- Account (User Account)
- Profile Update
- Change Password
- Two Factor Authentication
- Subscription
- Cancel Subscription
- Resume Subscription
- Swap Plan
- Update Card
- API Tokens
- Single Database Multi-tenancy
- Admin
- User Management
- Manage User Roles
- Role & Permissions Management
- User Management
- Developer Panel
- Manage OAuth Clients
- Manage Personal Access Tokens
- Other features
- Filtering (extendable)
- API access (starter template)
Note: Some features may be subjected to change. Other features may not be listed since they are under development or do not qualify as a standard / main SaaS feature. Some common features will not be listed as well.
- Fork, clone or download this repository.
- Run
composer install
if its the initial setup orcomposer update
. - Setup your environment keys in .env (If .env does not exist then copy / rename .env.example as .env)
- Run
php artisan app:name
to set the name (namespace) of your app. (Remember not to live any spaces) - Run
php artisan migrate
for initial tables setup. Optional
Runphp artisan db:seed --class=RoleTableSeeder
to set the initial roles and permissions if you opt to use the initial user and roles management.
To start using single databse multi-tenancy call ForTenants
trait on a model
use SAASBoilerplate\App\Tenant\Traits\ForTenants;
class Project extends Model
{
use ForTenants;
}
Once you have setup the model as show above. Just call CRUD operations directly
.
Tenant
relationships are handled automatically.
$projects = Project::create([
'name' => 'Project 1'
]);
$projects = Project::get();
To perform CRUD operations on models with ForTenants
trait can be done by
adding withoutForTenants
scope when fetching records associated with that model.
$projects = Project::withoutForTenants()->get();
This comes in handy for example in: admin or moderation operations
All tenant
routes are under the routes folder in the tenant.php
file.
Note: Tenant routes follow the same structure as other routes
The main reason we place all tenant routes separately is to handle route binding and its much easier to know which routes are for tenants.
- Main
- PHP (>=7.1.3)
- Laravel (Minimal 5.6)
- Laravel Cashier (can be switched)
- UI (can be switched)
- Bootstrap (v4)
- Font awesome
- Simple Line Icons
- jQuery
- VueJs
- Development
- nodejs
- npm
- Stripe (payment gateway)
- Authy by Twilio (two factor authentication)
- Mailtrap (email testing)