From 86430e12e141693767a41f3d68b58d41696dd7be Mon Sep 17 00:00:00 2001 From: Valtteri Kantanen Date: Fri, 13 Sep 2024 13:05:35 +0300 Subject: [PATCH] [Study programmes] Fix irrelevant programmes data being saved to Redis --- .../backend/src/services/analyticsService.ts | 17 ++++++++--------- .../studyProgramme/studyProgrammeHelpers.ts | 8 +------- 2 files changed, 9 insertions(+), 16 deletions(-) diff --git a/services/backend/src/services/analyticsService.ts b/services/backend/src/services/analyticsService.ts index 0795dc4a82..d90094b0bc 100644 --- a/services/backend/src/services/analyticsService.ts +++ b/services/backend/src/services/analyticsService.ts @@ -3,9 +3,8 @@ import moment from 'moment' import { facultyCodes, ignoredFacultyCodes } from '../config/organizationConstants' import { Graduated, SpecialGroups, YearType } from '../types' import { redisClient } from './redis' +import { isRelevantProgramme } from './studyProgramme/studyProgrammeHelpers' -// Only new bachelor, masters and doctoral programmes get their data updated in redis every night, use redis for them -const isUpdatedNewProgramme = (code: string) => code.includes('KH') || code.includes('MH') || /^(T)[0-9]{6}$/.test(code) const filteredFacultyCodes = facultyCodes.filter(item => !ignoredFacultyCodes.includes(item)) const isFaculty = (code: string) => filteredFacultyCodes.includes(code) @@ -28,7 +27,7 @@ export const getBasicStats = async ( yearType: YearType, specialGroups: SpecialGroups ) => { - if (!isUpdatedNewProgramme(id)) { + if (!isRelevantProgramme(id)) { return null } const searchkey = combinedProgramme ? `${id}-${combinedProgramme}` : id @@ -48,7 +47,7 @@ export const setBasicStats = async (data, yearType: YearType, specialGroups: Spe status: 'DONE', lastUpdated: moment().format(), } - if (!isUpdatedNewProgramme(id)) { + if (!isRelevantProgramme(id)) { return dataToRedis } const setOperationStatus = await redisClient.setAsync(redisKey, JSON.stringify(dataToRedis)) @@ -83,7 +82,7 @@ export const setCreditStats = async (data, isAcademicYear: boolean, specialGroup status: 'DONE', lastUpdated: moment().format(), } - if (!isUpdatedNewProgramme(data.id) && !isFaculty(data.id)) { + if (!isRelevantProgramme(id) && !isFaculty(id)) { return dataToRedis } const setOperationStatus = await redisClient.setAsync(redisKey, JSON.stringify(dataToRedis)) @@ -99,7 +98,7 @@ export const getGraduationStats = async ( yearType: YearType, specialGroups: SpecialGroups ) => { - if (!isUpdatedNewProgramme(id)) { + if (!isRelevantProgramme(id)) { return null } const searchkey = combinedProgramme ? `${id}-${combinedProgramme}` : id @@ -119,7 +118,7 @@ export const setGraduationStats = async (data, yearType: YearType, specialGroups status: 'DONE', lastUpdated: moment().format(), } - if (!isUpdatedNewProgramme(id)) { + if (!isRelevantProgramme(id)) { return dataToRedis } const setOperationStatus = await redisClient.setAsync(redisKey, JSON.stringify(dataToRedis)) @@ -135,7 +134,7 @@ export const getStudytrackStats = async ( graduated: Graduated, specialGroups: SpecialGroups ) => { - if (!isUpdatedNewProgramme(id)) { + if (!isRelevantProgramme(id)) { return null } const searchkey = combinedProgramme ? `${id}-${combinedProgramme}` : id @@ -155,7 +154,7 @@ export const setStudytrackStats = async (data, graduated: Graduated, specialGrou status: 'DONE', lastUpdated: moment().format(), } - if (!isUpdatedNewProgramme(id)) { + if (!isRelevantProgramme(id)) { return dataToRedis } const setOperationStatus = await redisClient.setAsync(redisKey, JSON.stringify(dataToRedis)) diff --git a/services/backend/src/services/studyProgramme/studyProgrammeHelpers.ts b/services/backend/src/services/studyProgramme/studyProgrammeHelpers.ts index e0a25cc609..41f3f2c91a 100644 --- a/services/backend/src/services/studyProgramme/studyProgrammeHelpers.ts +++ b/services/backend/src/services/studyProgramme/studyProgrammeHelpers.ts @@ -192,13 +192,7 @@ export const getGoal = (programme?: string) => { return 48 // unknown, likely old doctor or licentiate } -export const isRelevantProgramme = (code: string) => { - return ( - (code.includes('KH') && !code.startsWith('2_KH') && !code.endsWith('_2')) || - (code.includes('MH') && !code.startsWith('2_MH') && !code.endsWith('_2')) || - /^(T)[0-9]{6}$/.test(code) - ) -} +export const isRelevantProgramme = (code: string) => /^(KH|MH)\d{2}_\d{3}$/.test(code) || /^T\d{6}$/.test(code) export const getStudyRightElementsWithPhase = (studyRight: InferAttributes, phase: Phase) => { return orderBy(