Skip to content

Commit

Permalink
take into account expired paid licenses in getSubscriptionFromCheckIn
Browse files Browse the repository at this point in the history
  • Loading branch information
sergiolms committed Sep 19, 2024
1 parent 758423a commit d439669
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 6 deletions.
2 changes: 1 addition & 1 deletion src/plus/gk/account/subscriptionService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -872,7 +872,7 @@ export class SubscriptionService implements Disposable {
if (
!options?.force &&
this._lastValidatedDate != null &&
Date.now() - this._lastValidatedDate.getTime() < 12 * 60 * 60 * 1000 &&
Date.now() - this._lastValidatedDate.getTime() < 1000 &&
!isSubscriptionExpired(this._subscription)
) {
setLogScopeExit(scope, ` (${fromNow(this._lastValidatedDate.getTime(), true)})...`, 'skipped');
Expand Down
25 changes: 20 additions & 5 deletions src/plus/gk/checkin.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
import type { Organization } from './account/organization';
import type { Subscription } from './account/subscription';
import { getSubscriptionPlan, getSubscriptionPlanPriority, SubscriptionPlanId } from './account/subscription';
import {
computeSubscriptionState,
getSubscriptionPlan,
getSubscriptionPlanPriority,
SubscriptionPlanId,
SubscriptionState,
} from './account/subscription';

export interface GKCheckInResponse {
readonly user: GKUser;
Expand Down Expand Up @@ -66,9 +72,7 @@ export function getSubscriptionFromCheckIn(

let effectiveLicenses = Object.entries(data.licenses.effectiveLicenses) as [GKLicenseType, GKLicense][];
let paidLicenses = Object.entries(data.licenses.paidLicenses) as [GKLicenseType, GKLicense][];
paidLicenses = paidLicenses.filter(
license => license[1].latestStatus !== 'expired' && license[1].latestStatus !== 'cancelled',
);
paidLicenses = paidLicenses.filter(license => license[1].latestStatus !== 'cancelled');
if (paidLicenses.length > 1) {
paidLicenses.sort(
(a, b) =>
Expand Down Expand Up @@ -176,7 +180,18 @@ export function getSubscriptionFromCheckIn(
);
}

if (effective == null || getSubscriptionPlanPriority(actual.id) >= getSubscriptionPlanPriority(effective.id)) {
const isActualLicenseExpired =
computeSubscriptionState({
plan: {
actual: actual,
effective: actual,
},
account: account,
}) === SubscriptionState.PaidExpired;
if (
effective == null ||
(getSubscriptionPlanPriority(actual.id) >= getSubscriptionPlanPriority(effective.id) && !isActualLicenseExpired)
) {
effective = { ...actual };
}

Expand Down

0 comments on commit d439669

Please sign in to comment.