feat(cloud-check): enhance subscription reporting in CloudCheckSubscription command
- Added CSV output for active subscribers, including detailed information on subscription status and invoice status. - Implemented checks for missing subscription IDs and provided appropriate logging in the CSV for visibility. - Improved handling of non-active subscriptions with detailed output for better tracking and analysis.
This commit is contained in:
@@ -28,22 +28,69 @@ class CloudCheckSubscription extends Command
|
|||||||
{
|
{
|
||||||
$stripe = new \Stripe\StripeClient(config('subscription.stripe_api_key'));
|
$stripe = new \Stripe\StripeClient(config('subscription.stripe_api_key'));
|
||||||
$activeSubscribers = Team::whereRelation('subscription', 'stripe_invoice_paid', true)->get();
|
$activeSubscribers = Team::whereRelation('subscription', 'stripe_invoice_paid', true)->get();
|
||||||
|
|
||||||
|
$out = fopen('php://output', 'w');
|
||||||
|
// CSV header
|
||||||
|
fputcsv($out, [
|
||||||
|
'team_id',
|
||||||
|
'invoice_status',
|
||||||
|
'stripe_customer_url',
|
||||||
|
'stripe_subscription_id',
|
||||||
|
'subscription_status',
|
||||||
|
'subscription_url',
|
||||||
|
'note',
|
||||||
|
]);
|
||||||
|
|
||||||
foreach ($activeSubscribers as $team) {
|
foreach ($activeSubscribers as $team) {
|
||||||
$stripeSubscriptionId = $team->subscription->stripe_subscription_id;
|
$stripeSubscriptionId = $team->subscription->stripe_subscription_id;
|
||||||
$stripeInvoicePaid = $team->subscription->stripe_invoice_paid;
|
$stripeInvoicePaid = $team->subscription->stripe_invoice_paid;
|
||||||
$stripeCustomerId = $team->subscription->stripe_customer_id;
|
$stripeCustomerId = $team->subscription->stripe_customer_id;
|
||||||
if (! $stripeSubscriptionId) {
|
|
||||||
echo "Team {$team->id} has no subscription, but invoice status is: {$stripeInvoicePaid}\n";
|
if (! $stripeSubscriptionId && str($stripeInvoicePaid)->lower() != 'past_due') {
|
||||||
echo "Link on Stripe: https://dashboard.stripe.com/customers/{$stripeCustomerId}\n";
|
fputcsv($out, [
|
||||||
|
$team->id,
|
||||||
|
$stripeInvoicePaid,
|
||||||
|
$stripeCustomerId ? "https://dashboard.stripe.com/customers/{$stripeCustomerId}" : null,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
'Missing subscription ID while invoice not past_due',
|
||||||
|
]);
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (! $stripeSubscriptionId) {
|
||||||
|
// No subscription ID and invoice is past_due, still record for visibility
|
||||||
|
fputcsv($out, [
|
||||||
|
$team->id,
|
||||||
|
$stripeInvoicePaid,
|
||||||
|
$stripeCustomerId ? "https://dashboard.stripe.com/customers/{$stripeCustomerId}" : null,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
null,
|
||||||
|
'Missing subscription ID',
|
||||||
|
]);
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
$subscription = $stripe->subscriptions->retrieve($stripeSubscriptionId);
|
$subscription = $stripe->subscriptions->retrieve($stripeSubscriptionId);
|
||||||
if ($subscription->status === 'active') {
|
if ($subscription->status === 'active') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
echo "Subscription {$stripeSubscriptionId} is not active ({$subscription->status})\n";
|
|
||||||
echo "Link on Stripe: https://dashboard.stripe.com/subscriptions/{$stripeSubscriptionId}\n";
|
fputcsv($out, [
|
||||||
|
$team->id,
|
||||||
|
$stripeInvoicePaid,
|
||||||
|
$stripeCustomerId ? "https://dashboard.stripe.com/customers/{$stripeCustomerId}" : null,
|
||||||
|
$stripeSubscriptionId,
|
||||||
|
$subscription->status,
|
||||||
|
"https://dashboard.stripe.com/subscriptions/{$stripeSubscriptionId}",
|
||||||
|
'Subscription not active',
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fclose($out);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user