fix: version should come from constants + fix stripe webhook error reporting
This commit is contained in:
@@ -31,7 +31,7 @@ class UpdateCoolify
|
|||||||
}
|
}
|
||||||
CleanupDocker::dispatch($this->server);
|
CleanupDocker::dispatch($this->server);
|
||||||
$this->latestVersion = get_latest_version_of_coolify();
|
$this->latestVersion = get_latest_version_of_coolify();
|
||||||
$this->currentVersion = config('version');
|
$this->currentVersion = config('constants.coolify.version');
|
||||||
if (! $manual_update) {
|
if (! $manual_update) {
|
||||||
if (! $settings->is_auto_update_enabled) {
|
if (! $settings->is_auto_update_enabled) {
|
||||||
return;
|
return;
|
||||||
|
@@ -200,7 +200,7 @@ class Init extends Command
|
|||||||
|
|
||||||
private function restore_coolify_db_backup()
|
private function restore_coolify_db_backup()
|
||||||
{
|
{
|
||||||
if (version_compare('4.0.0-beta.179', config('version'), '<=')) {
|
if (version_compare('4.0.0-beta.179', config('constants.coolify.version'), '<=')) {
|
||||||
try {
|
try {
|
||||||
$database = StandalonePostgresql::withTrashed()->find(0);
|
$database = StandalonePostgresql::withTrashed()->find(0);
|
||||||
if ($database && $database->trashed()) {
|
if ($database && $database->trashed()) {
|
||||||
@@ -228,7 +228,7 @@ class Init extends Command
|
|||||||
private function send_alive_signal()
|
private function send_alive_signal()
|
||||||
{
|
{
|
||||||
$id = config('app.id');
|
$id = config('app.id');
|
||||||
$version = config('version');
|
$version = config('constants.coolify.version');
|
||||||
$settings = instanceSettings();
|
$settings = instanceSettings();
|
||||||
$do_not_track = data_get($settings, 'do_not_track');
|
$do_not_track = data_get($settings, 'do_not_track');
|
||||||
if ($do_not_track == true) {
|
if ($do_not_track == true) {
|
||||||
@@ -264,7 +264,7 @@ class Init extends Command
|
|||||||
|
|
||||||
private function replace_slash_in_environment_name()
|
private function replace_slash_in_environment_name()
|
||||||
{
|
{
|
||||||
if (version_compare('4.0.0-beta.298', config('version'), '<=')) {
|
if (version_compare('4.0.0-beta.298', config('constants.coolify.version'), '<=')) {
|
||||||
$environments = Environment::all();
|
$environments = Environment::all();
|
||||||
foreach ($environments as $environment) {
|
foreach ($environments as $environment) {
|
||||||
if (str_contains($environment->name, '/')) {
|
if (str_contains($environment->name, '/')) {
|
||||||
|
@@ -37,7 +37,7 @@ class OtherController extends Controller
|
|||||||
)]
|
)]
|
||||||
public function version(Request $request)
|
public function version(Request $request)
|
||||||
{
|
{
|
||||||
return response(config('version'));
|
return response(config('constants.coolify.version'));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[OA\Get(
|
#[OA\Get(
|
||||||
|
@@ -27,7 +27,7 @@ class CheckForUpdatesJob implements ShouldBeEncrypted, ShouldQueue
|
|||||||
$versions = $response->json();
|
$versions = $response->json();
|
||||||
|
|
||||||
$latest_version = data_get($versions, 'coolify.v4.version');
|
$latest_version = data_get($versions, 'coolify.v4.version');
|
||||||
$current_version = config('version');
|
$current_version = config('constants.coolify.version');
|
||||||
|
|
||||||
if (version_compare($latest_version, $current_version, '>')) {
|
if (version_compare($latest_version, $current_version, '>')) {
|
||||||
// New version available
|
// New version available
|
||||||
|
@@ -25,218 +25,222 @@ class StripeProcessJob implements ShouldQueue
|
|||||||
|
|
||||||
public function handle(): void
|
public function handle(): void
|
||||||
{
|
{
|
||||||
$excludedPlans = config('subscription.stripe_excluded_plans');
|
try {
|
||||||
|
$excludedPlans = config('subscription.stripe_excluded_plans');
|
||||||
|
|
||||||
$type = data_get($this->event, 'type');
|
$type = data_get($this->event, 'type');
|
||||||
$this->type = $type;
|
$this->type = $type;
|
||||||
$data = data_get($this->event, 'data.object');
|
$data = data_get($this->event, 'data.object');
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
case 'radar.early_fraud_warning.created':
|
case 'radar.early_fraud_warning.created':
|
||||||
$stripe = new \Stripe\StripeClient(config('subscription.stripe_api_key'));
|
$stripe = new \Stripe\StripeClient(config('subscription.stripe_api_key'));
|
||||||
$id = data_get($data, 'id');
|
$id = data_get($data, 'id');
|
||||||
$charge = data_get($data, 'charge');
|
$charge = data_get($data, 'charge');
|
||||||
if ($charge) {
|
if ($charge) {
|
||||||
$stripe->refunds->create(['charge' => $charge]);
|
$stripe->refunds->create(['charge' => $charge]);
|
||||||
}
|
}
|
||||||
$pi = data_get($data, 'payment_intent');
|
$pi = data_get($data, 'payment_intent');
|
||||||
$piData = $stripe->paymentIntents->retrieve($pi, []);
|
$piData = $stripe->paymentIntents->retrieve($pi, []);
|
||||||
$customerId = data_get($piData, 'customer');
|
$customerId = data_get($piData, 'customer');
|
||||||
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
|
||||||
if ($subscription) {
|
|
||||||
$subscriptionId = data_get($subscription, 'stripe_subscription_id');
|
|
||||||
$stripe->subscriptions->cancel($subscriptionId, []);
|
|
||||||
$subscription->update([
|
|
||||||
'stripe_invoice_paid' => false,
|
|
||||||
]);
|
|
||||||
send_internal_notification("Early fraud warning created Refunded, subscription canceled. Charge: {$charge}, id: {$id}, pi: {$pi}");
|
|
||||||
} else {
|
|
||||||
send_internal_notification("Early fraud warning: subscription not found. Charge: {$charge}, id: {$id}, pi: {$pi}");
|
|
||||||
throw new \Exception("Early fraud warning: subscription not found. Charge: {$charge}, id: {$id}, pi: {$pi}");
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 'checkout.session.completed':
|
|
||||||
$clientReferenceId = data_get($data, 'client_reference_id');
|
|
||||||
if (is_null($clientReferenceId)) {
|
|
||||||
send_internal_notification('Checkout session completed without client reference id.');
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
$userId = Str::before($clientReferenceId, ':');
|
|
||||||
$teamId = Str::after($clientReferenceId, ':');
|
|
||||||
$subscriptionId = data_get($data, 'subscription');
|
|
||||||
$customerId = data_get($data, 'customer');
|
|
||||||
$team = Team::find($teamId);
|
|
||||||
$found = $team->members->where('id', $userId)->first();
|
|
||||||
if (! $found->isAdmin()) {
|
|
||||||
send_internal_notification("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}, subscriptionid: {$subscriptionId}.");
|
|
||||||
throw new \Exception("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}, subscriptionid: {$subscriptionId}.");
|
|
||||||
}
|
|
||||||
$subscription = Subscription::where('team_id', $teamId)->first();
|
|
||||||
if ($subscription) {
|
|
||||||
send_internal_notification('Old subscription activated for team: '.$teamId);
|
|
||||||
$subscription->update([
|
|
||||||
'stripe_subscription_id' => $subscriptionId,
|
|
||||||
'stripe_customer_id' => $customerId,
|
|
||||||
'stripe_invoice_paid' => true,
|
|
||||||
]);
|
|
||||||
} else {
|
|
||||||
send_internal_notification('New subscription for team: '.$teamId);
|
|
||||||
Subscription::create([
|
|
||||||
'team_id' => $teamId,
|
|
||||||
'stripe_subscription_id' => $subscriptionId,
|
|
||||||
'stripe_customer_id' => $customerId,
|
|
||||||
'stripe_invoice_paid' => true,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 'invoice.paid':
|
|
||||||
$customerId = data_get($data, 'customer');
|
|
||||||
$planId = data_get($data, 'lines.data.0.plan.id');
|
|
||||||
if (Str::contains($excludedPlans, $planId)) {
|
|
||||||
send_internal_notification('Subscription excluded.');
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
|
||||||
if ($subscription) {
|
|
||||||
$subscription->update([
|
|
||||||
'stripe_invoice_paid' => true,
|
|
||||||
]);
|
|
||||||
} else {
|
|
||||||
throw new \Exception("No subscription found for customer: {$customerId}");
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 'invoice.payment_failed':
|
|
||||||
$customerId = data_get($data, 'customer');
|
|
||||||
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
|
||||||
if (! $subscription) {
|
|
||||||
send_internal_notification('invoice.payment_failed failed but no subscription found in Coolify for customer: '.$customerId);
|
|
||||||
throw new \Exception("No subscription found for customer: {$customerId}");
|
|
||||||
}
|
|
||||||
$team = data_get($subscription, 'team');
|
|
||||||
if (! $team) {
|
|
||||||
send_internal_notification('invoice.payment_failed failed but no team found in Coolify for customer: '.$customerId);
|
|
||||||
throw new \Exception("No team found in Coolify for customer: {$customerId}");
|
|
||||||
}
|
|
||||||
if (! $subscription->stripe_invoice_paid) {
|
|
||||||
SubscriptionInvoiceFailedJob::dispatch($team);
|
|
||||||
send_internal_notification('Invoice payment failed: '.$customerId);
|
|
||||||
} else {
|
|
||||||
send_internal_notification('Invoice payment failed but already paid: '.$customerId);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 'payment_intent.payment_failed':
|
|
||||||
$customerId = data_get($data, 'customer');
|
|
||||||
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
|
||||||
if (! $subscription) {
|
|
||||||
send_internal_notification('payment_intent.payment_failed, no subscription found in Coolify for customer: '.$customerId);
|
|
||||||
throw new \Exception("No subscription found in Coolify for customer: {$customerId}");
|
|
||||||
}
|
|
||||||
if ($subscription->stripe_invoice_paid) {
|
|
||||||
send_internal_notification('payment_intent.payment_failed but invoice is active for customer: '.$customerId);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
send_internal_notification('Subscription payment failed for customer: '.$customerId);
|
|
||||||
break;
|
|
||||||
case 'customer.subscription.created':
|
|
||||||
$customerId = data_get($data, 'customer');
|
|
||||||
$subscriptionId = data_get($data, 'id');
|
|
||||||
$teamId = data_get($data, 'metadata.team_id');
|
|
||||||
$userId = data_get($data, 'metadata.user_id');
|
|
||||||
if (! $teamId || ! $userId) {
|
|
||||||
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
||||||
if ($subscription) {
|
if ($subscription) {
|
||||||
throw new \Exception("Subscription already exists for customer: {$customerId}");
|
$subscriptionId = data_get($subscription, 'stripe_subscription_id');
|
||||||
|
$stripe->subscriptions->cancel($subscriptionId, []);
|
||||||
|
$subscription->update([
|
||||||
|
'stripe_invoice_paid' => false,
|
||||||
|
]);
|
||||||
|
send_internal_notification("Early fraud warning created Refunded, subscription canceled. Charge: {$charge}, id: {$id}, pi: {$pi}");
|
||||||
|
} else {
|
||||||
|
send_internal_notification("Early fraud warning: subscription not found. Charge: {$charge}, id: {$id}, pi: {$pi}");
|
||||||
|
throw new \RuntimeException("Early fraud warning: subscription not found. Charge: {$charge}, id: {$id}, pi: {$pi}");
|
||||||
}
|
}
|
||||||
throw new \Exception('No team id or user id found');
|
|
||||||
}
|
|
||||||
$team = Team::find($teamId);
|
|
||||||
$found = $team->members->where('id', $userId)->first();
|
|
||||||
if (! $found->isAdmin()) {
|
|
||||||
send_internal_notification("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}.");
|
|
||||||
throw new \Exception("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}.");
|
|
||||||
}
|
|
||||||
$subscription = Subscription::where('team_id', $teamId)->first();
|
|
||||||
if ($subscription) {
|
|
||||||
send_internal_notification("Subscription already exists for team: {$teamId}");
|
|
||||||
throw new \Exception("Subscription already exists for team: {$teamId}");
|
|
||||||
} else {
|
|
||||||
Subscription::create([
|
|
||||||
'team_id' => $teamId,
|
|
||||||
'stripe_subscription_id' => $subscriptionId,
|
|
||||||
'stripe_customer_id' => $customerId,
|
|
||||||
'stripe_invoice_paid' => false,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
case 'customer.subscription.updated':
|
|
||||||
$teamId = data_get($data, 'metadata.team_id');
|
|
||||||
$userId = data_get($data, 'metadata.user_id');
|
|
||||||
$customerId = data_get($data, 'customer');
|
|
||||||
$status = data_get($data, 'status');
|
|
||||||
$subscriptionId = data_get($data, 'items.data.0.subscription');
|
|
||||||
$planId = data_get($data, 'items.data.0.plan.id');
|
|
||||||
if (Str::contains($excludedPlans, $planId)) {
|
|
||||||
send_internal_notification('Subscription excluded.');
|
|
||||||
break;
|
break;
|
||||||
}
|
case 'checkout.session.completed':
|
||||||
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
$clientReferenceId = data_get($data, 'client_reference_id');
|
||||||
if (! $subscription) {
|
if (is_null($clientReferenceId)) {
|
||||||
if ($status === 'incomplete_expired') {
|
send_internal_notification('Checkout session completed without client reference id.');
|
||||||
send_internal_notification('Subscription incomplete expired');
|
break;
|
||||||
throw new \Exception('Subscription incomplete expired');
|
|
||||||
}
|
}
|
||||||
if ($teamId) {
|
$userId = Str::before($clientReferenceId, ':');
|
||||||
$subscription = Subscription::create([
|
$teamId = Str::after($clientReferenceId, ':');
|
||||||
|
$subscriptionId = data_get($data, 'subscription');
|
||||||
|
$customerId = data_get($data, 'customer');
|
||||||
|
$team = Team::find($teamId);
|
||||||
|
$found = $team->members->where('id', $userId)->first();
|
||||||
|
if (! $found->isAdmin()) {
|
||||||
|
send_internal_notification("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}, subscriptionid: {$subscriptionId}.");
|
||||||
|
throw new \RuntimeException("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}, subscriptionid: {$subscriptionId}.");
|
||||||
|
}
|
||||||
|
$subscription = Subscription::where('team_id', $teamId)->first();
|
||||||
|
if ($subscription) {
|
||||||
|
send_internal_notification('Old subscription activated for team: '.$teamId);
|
||||||
|
$subscription->update([
|
||||||
|
'stripe_subscription_id' => $subscriptionId,
|
||||||
|
'stripe_customer_id' => $customerId,
|
||||||
|
'stripe_invoice_paid' => true,
|
||||||
|
]);
|
||||||
|
} else {
|
||||||
|
send_internal_notification('New subscription for team: '.$teamId);
|
||||||
|
Subscription::create([
|
||||||
|
'team_id' => $teamId,
|
||||||
|
'stripe_subscription_id' => $subscriptionId,
|
||||||
|
'stripe_customer_id' => $customerId,
|
||||||
|
'stripe_invoice_paid' => true,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'invoice.paid':
|
||||||
|
$customerId = data_get($data, 'customer');
|
||||||
|
$planId = data_get($data, 'lines.data.0.plan.id');
|
||||||
|
if (Str::contains($excludedPlans, $planId)) {
|
||||||
|
send_internal_notification('Subscription excluded.');
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
||||||
|
if ($subscription) {
|
||||||
|
$subscription->update([
|
||||||
|
'stripe_invoice_paid' => true,
|
||||||
|
]);
|
||||||
|
} else {
|
||||||
|
throw new \RuntimeException("No subscription found for customer: {$customerId}");
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'invoice.payment_failed':
|
||||||
|
$customerId = data_get($data, 'customer');
|
||||||
|
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
||||||
|
if (! $subscription) {
|
||||||
|
send_internal_notification('invoice.payment_failed failed but no subscription found in Coolify for customer: '.$customerId);
|
||||||
|
throw new \RuntimeException("No subscription found for customer: {$customerId}");
|
||||||
|
}
|
||||||
|
$team = data_get($subscription, 'team');
|
||||||
|
if (! $team) {
|
||||||
|
send_internal_notification('invoice.payment_failed failed but no team found in Coolify for customer: '.$customerId);
|
||||||
|
throw new \RuntimeException("No team found in Coolify for customer: {$customerId}");
|
||||||
|
}
|
||||||
|
if (! $subscription->stripe_invoice_paid) {
|
||||||
|
SubscriptionInvoiceFailedJob::dispatch($team);
|
||||||
|
send_internal_notification('Invoice payment failed: '.$customerId);
|
||||||
|
} else {
|
||||||
|
send_internal_notification('Invoice payment failed but already paid: '.$customerId);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'payment_intent.payment_failed':
|
||||||
|
$customerId = data_get($data, 'customer');
|
||||||
|
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
||||||
|
if (! $subscription) {
|
||||||
|
send_internal_notification('payment_intent.payment_failed, no subscription found in Coolify for customer: '.$customerId);
|
||||||
|
throw new \RuntimeException("No subscription found in Coolify for customer: {$customerId}");
|
||||||
|
}
|
||||||
|
if ($subscription->stripe_invoice_paid) {
|
||||||
|
send_internal_notification('payment_intent.payment_failed but invoice is active for customer: '.$customerId);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
send_internal_notification('Subscription payment failed for customer: '.$customerId);
|
||||||
|
break;
|
||||||
|
case 'customer.subscription.created':
|
||||||
|
$customerId = data_get($data, 'customer');
|
||||||
|
$subscriptionId = data_get($data, 'id');
|
||||||
|
$teamId = data_get($data, 'metadata.team_id');
|
||||||
|
$userId = data_get($data, 'metadata.user_id');
|
||||||
|
if (! $teamId || ! $userId) {
|
||||||
|
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
||||||
|
if ($subscription) {
|
||||||
|
throw new \RuntimeException("Subscription already exists for customer: {$customerId}");
|
||||||
|
}
|
||||||
|
throw new \RuntimeException('No team id or user id found');
|
||||||
|
}
|
||||||
|
$team = Team::find($teamId);
|
||||||
|
$found = $team->members->where('id', $userId)->first();
|
||||||
|
if (! $found->isAdmin()) {
|
||||||
|
send_internal_notification("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}.");
|
||||||
|
throw new \RuntimeException("User {$userId} is not an admin or owner of team {$team->id}, customerid: {$customerId}.");
|
||||||
|
}
|
||||||
|
$subscription = Subscription::where('team_id', $teamId)->first();
|
||||||
|
if ($subscription) {
|
||||||
|
send_internal_notification("Subscription already exists for team: {$teamId}");
|
||||||
|
throw new \RuntimeException("Subscription already exists for team: {$teamId}");
|
||||||
|
} else {
|
||||||
|
Subscription::create([
|
||||||
'team_id' => $teamId,
|
'team_id' => $teamId,
|
||||||
'stripe_subscription_id' => $subscriptionId,
|
'stripe_subscription_id' => $subscriptionId,
|
||||||
'stripe_customer_id' => $customerId,
|
'stripe_customer_id' => $customerId,
|
||||||
'stripe_invoice_paid' => false,
|
'stripe_invoice_paid' => false,
|
||||||
]);
|
]);
|
||||||
} else {
|
|
||||||
send_internal_notification('No subscription and team id found');
|
|
||||||
throw new \Exception('No subscription and team id found');
|
|
||||||
}
|
}
|
||||||
}
|
case 'customer.subscription.updated':
|
||||||
$cancelAtPeriodEnd = data_get($data, 'cancel_at_period_end');
|
$teamId = data_get($data, 'metadata.team_id');
|
||||||
$feedback = data_get($data, 'cancellation_details.feedback');
|
$userId = data_get($data, 'metadata.user_id');
|
||||||
$comment = data_get($data, 'cancellation_details.comment');
|
$customerId = data_get($data, 'customer');
|
||||||
$lookup_key = data_get($data, 'items.data.0.price.lookup_key');
|
$status = data_get($data, 'status');
|
||||||
if (str($lookup_key)->contains('dynamic')) {
|
$subscriptionId = data_get($data, 'items.data.0.subscription');
|
||||||
$quantity = data_get($data, 'items.data.0.quantity', 2);
|
$planId = data_get($data, 'items.data.0.plan.id');
|
||||||
$team = data_get($subscription, 'team');
|
if (Str::contains($excludedPlans, $planId)) {
|
||||||
if ($team) {
|
send_internal_notification('Subscription excluded.');
|
||||||
$team->update([
|
break;
|
||||||
'custom_server_limit' => $quantity,
|
}
|
||||||
|
$subscription = Subscription::where('stripe_customer_id', $customerId)->first();
|
||||||
|
if (! $subscription) {
|
||||||
|
if ($status === 'incomplete_expired') {
|
||||||
|
send_internal_notification('Subscription incomplete expired');
|
||||||
|
throw new \RuntimeException('Subscription incomplete expired');
|
||||||
|
}
|
||||||
|
if ($teamId) {
|
||||||
|
$subscription = Subscription::create([
|
||||||
|
'team_id' => $teamId,
|
||||||
|
'stripe_subscription_id' => $subscriptionId,
|
||||||
|
'stripe_customer_id' => $customerId,
|
||||||
|
'stripe_invoice_paid' => false,
|
||||||
|
]);
|
||||||
|
} else {
|
||||||
|
send_internal_notification('No subscription and team id found');
|
||||||
|
throw new \RuntimeException('No subscription and team id found');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$cancelAtPeriodEnd = data_get($data, 'cancel_at_period_end');
|
||||||
|
$feedback = data_get($data, 'cancellation_details.feedback');
|
||||||
|
$comment = data_get($data, 'cancellation_details.comment');
|
||||||
|
$lookup_key = data_get($data, 'items.data.0.price.lookup_key');
|
||||||
|
if (str($lookup_key)->contains('dynamic')) {
|
||||||
|
$quantity = data_get($data, 'items.data.0.quantity', 2);
|
||||||
|
$team = data_get($subscription, 'team');
|
||||||
|
if ($team) {
|
||||||
|
$team->update([
|
||||||
|
'custom_server_limit' => $quantity,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
ServerLimitCheckJob::dispatch($team);
|
||||||
|
}
|
||||||
|
$subscription->update([
|
||||||
|
'stripe_feedback' => $feedback,
|
||||||
|
'stripe_comment' => $comment,
|
||||||
|
'stripe_plan_id' => $planId,
|
||||||
|
'stripe_cancel_at_period_end' => $cancelAtPeriodEnd,
|
||||||
|
]);
|
||||||
|
if ($status === 'paused' || $status === 'incomplete_expired') {
|
||||||
|
$subscription->update([
|
||||||
|
'stripe_invoice_paid' => false,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
ServerLimitCheckJob::dispatch($team);
|
if ($feedback) {
|
||||||
}
|
$reason = "Cancellation feedback for {$customerId}: '".$feedback."'";
|
||||||
$subscription->update([
|
if ($comment) {
|
||||||
'stripe_feedback' => $feedback,
|
$reason .= ' with comment: \''.$comment."'";
|
||||||
'stripe_comment' => $comment,
|
}
|
||||||
'stripe_plan_id' => $planId,
|
|
||||||
'stripe_cancel_at_period_end' => $cancelAtPeriodEnd,
|
|
||||||
]);
|
|
||||||
if ($status === 'paused' || $status === 'incomplete_expired') {
|
|
||||||
$subscription->update([
|
|
||||||
'stripe_invoice_paid' => false,
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
if ($feedback) {
|
|
||||||
$reason = "Cancellation feedback for {$customerId}: '".$feedback."'";
|
|
||||||
if ($comment) {
|
|
||||||
$reason .= ' with comment: \''.$comment."'";
|
|
||||||
}
|
}
|
||||||
}
|
break;
|
||||||
break;
|
case 'customer.subscription.deleted':
|
||||||
case 'customer.subscription.deleted':
|
// End subscription
|
||||||
// End subscription
|
$customerId = data_get($data, 'customer');
|
||||||
$customerId = data_get($data, 'customer');
|
$subscription = Subscription::where('stripe_customer_id', $customerId)->firstOrFail();
|
||||||
$subscription = Subscription::where('stripe_customer_id', $customerId)->firstOrFail();
|
$team = data_get($subscription, 'team');
|
||||||
$team = data_get($subscription, 'team');
|
$team?->subscriptionEnded();
|
||||||
$team?->subscriptionEnded();
|
break;
|
||||||
break;
|
default:
|
||||||
default:
|
throw new \RuntimeException("Unhandled event type: {$type}");
|
||||||
// Unhandled event type
|
}
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
send_internal_notification('StripeProcessJob error: '.$e->getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -71,7 +71,7 @@ class EnvironmentVariable extends Model
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$environment_variable->update([
|
$environment_variable->update([
|
||||||
'version' => config('version'),
|
'version' => config('constants.coolify.version'),
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
static::saving(function (EnvironmentVariable $environmentVariable) {
|
static::saving(function (EnvironmentVariable $environmentVariable) {
|
||||||
|
@@ -46,7 +46,7 @@ class DiscordMessage
|
|||||||
|
|
||||||
public function toPayload(): array
|
public function toPayload(): array
|
||||||
{
|
{
|
||||||
$footerText = 'Coolify v'.config('version');
|
$footerText = 'Coolify v'.config('constants.coolify.version');
|
||||||
if (isCloud()) {
|
if (isCloud()) {
|
||||||
$footerText = 'Coolify Cloud';
|
$footerText = 'Coolify Cloud';
|
||||||
}
|
}
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$version = include 'config/version.php';
|
$version = include 'config/constants.php';
|
||||||
echo $version;
|
echo $version['coolify']['version'] ?: 'unknown';
|
||||||
|
@@ -192,7 +192,7 @@ function defaultLabels($id, $name, $pull_request_id = 0, string $type = 'applica
|
|||||||
{
|
{
|
||||||
$labels = collect([]);
|
$labels = collect([]);
|
||||||
$labels->push('coolify.managed=true');
|
$labels->push('coolify.managed=true');
|
||||||
$labels->push('coolify.version='.config('version'));
|
$labels->push('coolify.version='.config('constants.coolify.version'));
|
||||||
$labels->push('coolify.'.$type.'Id='.$id);
|
$labels->push('coolify.'.$type.'Id='.$id);
|
||||||
$labels->push("coolify.type=$type");
|
$labels->push("coolify.type=$type");
|
||||||
$labels->push('coolify.name='.$name);
|
$labels->push('coolify.name='.$name);
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
<a {{ $attributes->merge(['class' => 'text-xs cursor-pointer opacity-90 hover:opacity-100 dark:hover:text-white hover:text-black']) }}
|
<a {{ $attributes->merge(['class' => 'text-xs cursor-pointer opacity-90 hover:opacity-100 dark:hover:text-white hover:text-black']) }}
|
||||||
href="https://github.com/coollabsio/coolify/releases/tag/v{{ config('version') }}" target="_blank">
|
href="https://github.com/coollabsio/coolify/releases/tag/v{{ config('constants.coolify.version') }}" target="_blank">
|
||||||
v{{ config('version') }}
|
v{{ config('constants.coolify.version') }}
|
||||||
</a>
|
</a>
|
Reference in New Issue
Block a user