lasthourcloud/bootstrap/helpers/subscriptions.php

150 lines
3.6 KiB
PHP
Raw Normal View History

2023-07-13 22:03:27 +02:00
<?php
2023-08-24 16:14:09 +02:00
use App\Models\Team;
2023-07-13 22:03:27 +02:00
use Illuminate\Support\Carbon;
2023-08-24 16:14:09 +02:00
use Stripe\Stripe;
2023-07-13 22:03:27 +02:00
2023-08-14 14:00:10 +02:00
function getSubscriptionLink($type)
2023-07-13 22:03:27 +02:00
{
2023-08-23 16:40:59 +02:00
$checkout_id = config("subscription.lemon_squeezy_checkout_id_$type");
2023-07-27 16:22:13 +02:00
if (!$checkout_id) {
return null;
}
2023-07-13 22:03:27 +02:00
$user_id = auth()->user()->id;
2023-08-22 17:44:49 +02:00
$team_id = currentTeam()->id ?? null;
2023-07-13 22:03:27 +02:00
$email = auth()->user()->email ?? null;
$name = auth()->user()->name ?? null;
2023-07-14 13:58:05 +02:00
$url = "https://store.coollabs.io/checkout/buy/$checkout_id?";
2023-07-13 22:03:27 +02:00
if ($user_id) {
$url .= "&checkout[custom][user_id]={$user_id}";
}
if (isset($team_id)) {
$url .= "&checkout[custom][team_id]={$team_id}";
}
if ($email) {
$url .= "&checkout[email]={$email}";
}
if ($name) {
$url .= "&checkout[name]={$name}";
}
return $url;
}
2023-07-14 11:27:08 +02:00
function getPaymentLink()
{
2023-08-22 17:44:49 +02:00
return currentTeam()->subscription->lemon_update_payment_menthod_url;
2023-07-13 22:03:27 +02:00
}
2023-07-14 11:27:08 +02:00
function getRenewDate()
{
2023-08-22 17:44:49 +02:00
return Carbon::parse(currentTeam()->subscription->lemon_renews_at)->format('Y-M-d H:i:s');
2023-07-13 22:03:27 +02:00
}
2023-07-14 11:27:08 +02:00
function getEndDate()
{
2023-08-22 17:44:49 +02:00
return Carbon::parse(currentTeam()->subscription->lemon_renews_at)->format('Y-M-d H:i:s');
2023-07-14 11:27:08 +02:00
}
2023-08-24 16:14:09 +02:00
function isSubscriptionActive()
2023-07-14 11:27:08 +02:00
{
2023-09-02 15:37:25 +02:00
if (!isCloud()) {
return false;
}
2023-08-22 17:44:49 +02:00
$team = currentTeam();
2023-08-14 15:22:29 +02:00
if (!$team) {
return false;
}
$subscription = $team?->subscription;
2023-08-14 16:56:13 +02:00
2023-09-15 11:19:36 +02:00
if (is_null($subscription)) {
2023-08-14 15:22:29 +02:00
return false;
}
2023-08-30 18:23:55 +02:00
if (isLemon()) {
2023-08-24 16:14:09 +02:00
return $subscription->lemon_status === 'active';
}
2023-08-30 18:23:55 +02:00
// if (isPaddle()) {
// return $subscription->paddle_status === 'active';
// }
if (isStripe()) {
2023-08-24 16:14:09 +02:00
return $subscription->stripe_invoice_paid === true && $subscription->stripe_cancel_at_period_end === false;
}
return false;
2023-08-14 15:22:29 +02:00
}
2023-08-24 16:14:09 +02:00
function isSubscriptionOnGracePeriod()
2023-08-14 15:22:29 +02:00
{
2023-08-22 17:44:49 +02:00
$team = currentTeam();
2023-08-14 15:22:29 +02:00
if (!$team) {
return false;
}
$subscription = $team?->subscription;
if (!$subscription) {
return false;
}
2023-08-30 18:23:55 +02:00
if (isLemon()) {
2023-08-24 16:14:09 +02:00
$is_still_grace_period = $subscription->lemon_ends_at &&
Carbon::parse($subscription->lemon_ends_at) > Carbon::now();
return $is_still_grace_period;
}
2023-08-30 18:23:55 +02:00
if (isStripe()) {
2023-08-24 16:14:09 +02:00
return $subscription->stripe_cancel_at_period_end;
}
return false;
}
function subscriptionProvider()
{
return config('subscription.provider');
}
2023-08-31 15:00:59 +02:00
function isLemon()
{
2023-08-30 18:23:55 +02:00
return config('subscription.provider') === 'lemon';
}
2023-08-31 15:00:59 +02:00
function isStripe()
{
2023-08-30 18:23:55 +02:00
return config('subscription.provider') === 'stripe';
}
2023-08-31 15:00:59 +02:00
function isPaddle()
{
2023-08-30 18:23:55 +02:00
return config('subscription.provider') === 'paddle';
}
2023-08-24 16:14:09 +02:00
function getStripeCustomerPortalSession(Team $team)
{
Stripe::setApiKey(config('subscription.stripe_api_key'));
2023-08-30 16:01:38 +02:00
$return_url = route('team.index');
2023-08-24 16:14:09 +02:00
$stripe_customer_id = $team->subscription->stripe_customer_id;
$session = \Stripe\BillingPortal\Session::create([
'customer' => $stripe_customer_id,
'return_url' => $return_url,
]);
return $session;
}
2023-08-24 17:41:11 +02:00
function allowedPathsForUnsubscribedAccounts()
2023-08-24 16:14:09 +02:00
{
return [
'subscription',
'login',
2023-10-09 14:20:55 +02:00
'logout',
2023-08-24 16:14:09 +02:00
'waitlist',
'force-password-reset',
'livewire/message/force-password-reset',
'livewire/message/check-license',
'livewire/message/switch-team',
2023-10-09 14:20:55 +02:00
'livewire/message/subscription.pricing-plans',
2023-08-24 16:14:09 +02:00
];
2023-07-14 11:27:08 +02:00
}
2023-08-24 17:41:11 +02:00
function allowedPathsForBoardingAccounts()
{
return [
...allowedPathsForUnsubscribedAccounts(),
'boarding',
2023-08-30 18:23:55 +02:00
'livewire/message/boarding.index',
2023-09-18 14:41:31 +02:00
'livewire/message/activity-monitor'
2023-08-24 17:41:11 +02:00
];
}
2023-10-09 14:20:55 +02:00
function allowedPathsForInvalidAccounts() {
return [
'logout',
'verify',
'livewire/message/verify-email',
];
}