Skip to content

Commit

Permalink
🐞 fix: parse user id
Browse files Browse the repository at this point in the history
  • Loading branch information
tyler-dane committed Nov 27, 2023
1 parent 8d7637b commit e11b93a
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { invalidSyncTokenError } from "./__mocks__/error.invalidSyncToken";
import { invalidValueError } from "./__mocks__/error.google.invalidValue";
import { invalidGrant400Error } from "./__mocks__/error.google.invalidGrant";
import {
getEmailFromUrl,
isFullSyncRequired,
isGoogleTokenExpired,
isInvalidValue,
Expand All @@ -14,8 +15,15 @@ describe("Google Error Parsing", () => {
it("recognizes invalid (sync)value error", () => {
expect(isInvalidValue(invalidValueError)).toBe(true);
});

it("recognizes expired refresh token", () => {
expect(isGoogleTokenExpired(invalidGrant400Error)).toBe(true);
});
});

describe("Gaxios response parsing", () => {
it("returns email with @", () => {
const url =
"https://www.googleapis.com/calendar/v3/calendars/foo%40bar.com/events?syncToken=!!!!!!!!!!!!!!!jqgYQwNWZ_QyyHyycChpiZHJvaGl1aHyyyyyyymxvZmMwaXZodjN2ZxoMCO7Xj6sGEICGncADwD4B";
expect(getEmailFromUrl(url)).toBe("foo@bar.com");
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,12 @@ import {
isFullSyncRequired,
isGoogleError,
isInvalidValue,
getEmailFromUrl,
} from "@backend/common/services/gcal/gcal.utils";
import compassAuthService from "@backend/auth/services/compass.auth.service";
import { getSyncByToken } from "@backend/sync/util/sync.queries";
import userService from "@backend/user/services/user.service";
import compassAuthService from "@backend/auth/services/compass.auth.service";
import { findCompassUserBy } from "@backend/user/queries/user.queries";

import { errorHandler } from "./error.handler";

Expand Down Expand Up @@ -46,6 +48,16 @@ const parseUserId = async (res: SessionResponse, e: Error) => {
if (sync) {
return sync.user;
}

if (e.config.url) {
const email = getEmailFromUrl(e.config.url);
if (email) {
const user = await findCompassUserBy("email", email);
if (user) {
return user._id.toString();
}
}
}
}
}

Expand All @@ -66,7 +78,7 @@ export const handleExpressError = async (
const userId = await parseUserId(res, e);
if (!userId) {
logger.error(
"Express error occured, but couldnt handle due to missing userId"
"Express error occured, but couldn't handle due to missing userId"
);
res.status(Status.UNSURE).send(UserError.MissingUserIdField);
return;
Expand Down
10 changes: 10 additions & 0 deletions packages/backend/src/common/services/gcal/gcal.utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,16 @@ export const cancelledEventsIds = (events: gSchema$Event[]) => {
return cancelledIds;
};

export const getEmailFromUrl = (url: string) => {
const emailMatch = url.match(/\/calendars\/([^/]+)\/events/);

if (emailMatch && emailMatch[1]) {
return emailMatch[1].replace("%40", "@");
}

return null;
};

export const getPrimaryGcalId = (calendarList: Schema_CalendarList) => {
const primaryGCal = calendarList.google.items[0];
const gCalendarId = primaryGCal!.id as string;
Expand Down

0 comments on commit e11b93a

Please sign in to comment.