switched to paddle inline checkout, removed paypal and most of stripe. added product sync between app and paddle.
This commit is contained in:
@@ -15,16 +15,25 @@ class CheckoutSession extends Model
|
||||
use SoftDeletes;
|
||||
|
||||
public const STATUS_DRAFT = 'draft';
|
||||
|
||||
public const STATUS_AWAITING_METHOD = 'awaiting_payment_method';
|
||||
|
||||
public const STATUS_REQUIRES_CUSTOMER_ACTION = 'requires_customer_action';
|
||||
|
||||
public const STATUS_PROCESSING = 'processing';
|
||||
|
||||
public const STATUS_COMPLETED = 'completed';
|
||||
|
||||
public const STATUS_FAILED = 'failed';
|
||||
|
||||
public const STATUS_CANCELLED = 'cancelled';
|
||||
|
||||
public const PROVIDER_NONE = 'none';
|
||||
|
||||
public const PROVIDER_STRIPE = 'stripe';
|
||||
public const PROVIDER_PAYPAL = 'paypal';
|
||||
|
||||
public const PROVIDER_PADDLE = 'paddle';
|
||||
|
||||
public const PROVIDER_FREE = 'free';
|
||||
|
||||
/**
|
||||
@@ -103,4 +112,4 @@ class CheckoutSession extends Model
|
||||
{
|
||||
return $this->status === self::STATUS_REQUIRES_CUSTOMER_ACTION;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2,10 +2,10 @@
|
||||
|
||||
namespace App\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Casts\Attribute;
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Illuminate\Database\Eloquent\Relations\HasMany;
|
||||
use Illuminate\Database\Eloquent\Casts\Attribute;
|
||||
|
||||
class Package extends Model
|
||||
{
|
||||
@@ -29,6 +29,11 @@ class Package extends Model
|
||||
'description',
|
||||
'description_translations',
|
||||
'description_table',
|
||||
'paddle_product_id',
|
||||
'paddle_price_id',
|
||||
'paddle_sync_status',
|
||||
'paddle_synced_at',
|
||||
'paddle_snapshot',
|
||||
];
|
||||
|
||||
protected $casts = [
|
||||
@@ -45,9 +50,10 @@ class Package extends Model
|
||||
'name_translations' => 'array',
|
||||
'description_translations' => 'array',
|
||||
'description_table' => 'array',
|
||||
'paddle_synced_at' => 'datetime',
|
||||
'paddle_snapshot' => 'array',
|
||||
];
|
||||
|
||||
|
||||
protected function features(): Attribute
|
||||
{
|
||||
return Attribute::make(
|
||||
@@ -73,7 +79,6 @@ class Package extends Model
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
public function eventPackages(): HasMany
|
||||
{
|
||||
return $this->hasMany(EventPackage::class);
|
||||
@@ -104,12 +109,12 @@ class Package extends Model
|
||||
$locale = $locale ?: app()->getLocale();
|
||||
$translations = $this->name_translations ?? [];
|
||||
|
||||
if (!empty($translations[$locale])) {
|
||||
if (! empty($translations[$locale])) {
|
||||
return $translations[$locale];
|
||||
}
|
||||
|
||||
foreach (['en', 'de'] as $fallback) {
|
||||
if ($locale !== $fallback && !empty($translations[$fallback])) {
|
||||
if ($locale !== $fallback && ! empty($translations[$fallback])) {
|
||||
return $translations[$fallback];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -16,6 +16,7 @@ class PackagePurchase extends Model
|
||||
'tenant_id',
|
||||
'event_id',
|
||||
'package_id',
|
||||
'provider',
|
||||
'provider_id',
|
||||
'price',
|
||||
'type',
|
||||
@@ -78,14 +79,14 @@ class PackagePurchase extends Model
|
||||
parent::boot();
|
||||
|
||||
static::creating(function ($purchase) {
|
||||
if (!$purchase->tenant_id) {
|
||||
if (! $purchase->tenant_id) {
|
||||
throw new \Exception('Tenant ID is required for package purchases.');
|
||||
}
|
||||
|
||||
if (!$purchase->purchased_at) {
|
||||
if (! $purchase->purchased_at) {
|
||||
$purchase->purchased_at = now();
|
||||
}
|
||||
$purchase->refunded = false;
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -5,7 +5,6 @@ namespace App\Models;
|
||||
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
use Illuminate\Database\Eloquent\Relations\BelongsTo;
|
||||
use Carbon\Carbon;
|
||||
|
||||
class TenantPackage extends Model
|
||||
{
|
||||
@@ -16,6 +15,7 @@ class TenantPackage extends Model
|
||||
protected $fillable = [
|
||||
'tenant_id',
|
||||
'package_id',
|
||||
'paddle_subscription_id',
|
||||
'price',
|
||||
'purchased_at',
|
||||
'expires_at',
|
||||
@@ -43,30 +43,32 @@ class TenantPackage extends Model
|
||||
|
||||
public function isActive(): bool
|
||||
{
|
||||
return $this->active && (!$this->expires_at || $this->expires_at->isFuture());
|
||||
return $this->active && (! $this->expires_at || $this->expires_at->isFuture());
|
||||
}
|
||||
|
||||
public function canCreateEvent(): bool
|
||||
{
|
||||
if (!$this->isActive()) {
|
||||
if (! $this->isActive()) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!$this->package->isReseller()) {
|
||||
if (! $this->package->isReseller()) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$maxEvents = $this->package->max_events_per_year ?? 0;
|
||||
|
||||
return $this->used_events < $maxEvents;
|
||||
}
|
||||
|
||||
public function getRemainingEventsAttribute(): int
|
||||
{
|
||||
if (!$this->package->isReseller()) {
|
||||
if (! $this->package->isReseller()) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
$max = $this->package->max_events_per_year ?? 0;
|
||||
|
||||
return max(0, $max - $this->used_events);
|
||||
}
|
||||
|
||||
@@ -75,19 +77,23 @@ class TenantPackage extends Model
|
||||
parent::boot();
|
||||
|
||||
static::creating(function ($tenantPackage) {
|
||||
if (!$tenantPackage->purchased_at) {
|
||||
if (! $tenantPackage->purchased_at) {
|
||||
$tenantPackage->purchased_at = now();
|
||||
}
|
||||
if (!$tenantPackage->expires_at && $tenantPackage->package) {
|
||||
if (! $tenantPackage->expires_at && $tenantPackage->package) {
|
||||
$tenantPackage->expires_at = now()->addYear(); // Standard für Reseller
|
||||
}
|
||||
$tenantPackage->active = true;
|
||||
});
|
||||
|
||||
static::updating(function ($tenantPackage) {
|
||||
if ($tenantPackage->isDirty('expires_at') && $tenantPackage->expires_at->isPast()) {
|
||||
if (
|
||||
$tenantPackage->isDirty('expires_at')
|
||||
&& $tenantPackage->expires_at instanceof \Carbon\CarbonInterface
|
||||
&& $tenantPackage->expires_at->isPast()
|
||||
) {
|
||||
$tenantPackage->active = false;
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user