2023-06-06 18:30:29 +00:00
|
|
|
import type { SelectedCalendar } from "@prisma/client";
|
|
|
|
|
|
|
|
import { getCalendar } from "@calcom/app-store/_utils/getCalendar";
|
2023-09-30 13:28:52 +00:00
|
|
|
import logger from "@calcom/lib/logger";
|
|
|
|
import { getPiiFreeCredential, getPiiFreeSelectedCalendar } from "@calcom/lib/piiFreeData";
|
2023-10-02 10:51:04 +00:00
|
|
|
import { safeStringify } from "@calcom/lib/safeStringify";
|
2023-06-06 18:30:29 +00:00
|
|
|
import { performance } from "@calcom/lib/server/perfObserver";
|
|
|
|
import type { EventBusyDate } from "@calcom/types/Calendar";
|
|
|
|
import type { CredentialPayload } from "@calcom/types/Credential";
|
|
|
|
|
2023-10-17 19:00:48 +00:00
|
|
|
const log = logger.getSubLogger({ prefix: ["getCalendarsEvents"] });
|
2023-06-06 18:30:29 +00:00
|
|
|
const getCalendarsEvents = async (
|
|
|
|
withCredentials: CredentialPayload[],
|
|
|
|
dateFrom: string,
|
|
|
|
dateTo: string,
|
|
|
|
selectedCalendars: SelectedCalendar[]
|
|
|
|
): Promise<EventBusyDate[][]> => {
|
2023-08-03 12:17:38 +00:00
|
|
|
const calendarCredentials = withCredentials
|
|
|
|
.filter((credential) => credential.type.endsWith("_calendar"))
|
|
|
|
// filter out invalid credentials - these won't work.
|
|
|
|
.filter((credential) => !credential.invalid);
|
2023-09-30 13:28:52 +00:00
|
|
|
|
2023-06-06 18:30:29 +00:00
|
|
|
const calendars = await Promise.all(calendarCredentials.map((credential) => getCalendar(credential)));
|
|
|
|
performance.mark("getBusyCalendarTimesStart");
|
|
|
|
const results = calendars.map(async (c, i) => {
|
|
|
|
/** Filter out nulls */
|
|
|
|
if (!c) return [];
|
|
|
|
/** We rely on the index so we can match credentials with calendars */
|
|
|
|
const { type, appId } = calendarCredentials[i];
|
|
|
|
/** We just pass the calendars that matched the credential type,
|
|
|
|
* TODO: Migrate credential type or appId
|
|
|
|
*/
|
|
|
|
const passedSelectedCalendars = selectedCalendars.filter((sc) => sc.integration === type);
|
|
|
|
if (!passedSelectedCalendars.length) return [];
|
|
|
|
/** We extract external Ids so we don't cache too much */
|
|
|
|
const selectedCalendarIds = passedSelectedCalendars.map((sc) => sc.externalId);
|
|
|
|
/** If we don't then we actually fetch external calendars (which can be very slow) */
|
|
|
|
performance.mark("eventBusyDatesStart");
|
2023-10-02 10:51:04 +00:00
|
|
|
log.debug(
|
|
|
|
`Getting availability for`,
|
|
|
|
safeStringify({
|
|
|
|
calendarService: c.constructor.name,
|
|
|
|
selectedCalendars: passedSelectedCalendars.map(getPiiFreeSelectedCalendar),
|
|
|
|
})
|
|
|
|
);
|
2023-06-06 18:30:29 +00:00
|
|
|
const eventBusyDates = await c.getAvailability(dateFrom, dateTo, passedSelectedCalendars);
|
|
|
|
performance.mark("eventBusyDatesEnd");
|
|
|
|
performance.measure(
|
|
|
|
`[getAvailability for ${selectedCalendarIds.join(", ")}][$1]'`,
|
|
|
|
"eventBusyDatesStart",
|
|
|
|
"eventBusyDatesEnd"
|
|
|
|
);
|
|
|
|
|
|
|
|
return eventBusyDates.map((a) => ({ ...a, source: `${appId}` }));
|
|
|
|
});
|
|
|
|
const awaitedResults = await Promise.all(results);
|
|
|
|
performance.mark("getBusyCalendarTimesEnd");
|
|
|
|
performance.measure(
|
|
|
|
`getBusyCalendarTimes took $1 for creds ${calendarCredentials.map((cred) => cred.id)}`,
|
|
|
|
"getBusyCalendarTimesStart",
|
|
|
|
"getBusyCalendarTimesEnd"
|
|
|
|
);
|
2023-10-02 10:51:04 +00:00
|
|
|
log.debug(
|
|
|
|
"Result",
|
|
|
|
safeStringify({
|
|
|
|
calendarCredentials: calendarCredentials.map(getPiiFreeCredential),
|
|
|
|
selectedCalendars: selectedCalendars.map(getPiiFreeSelectedCalendar),
|
|
|
|
calendarEvents: awaitedResults,
|
|
|
|
})
|
|
|
|
);
|
2023-06-06 18:30:29 +00:00
|
|
|
return awaitedResults;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default getCalendarsEvents;
|