From 7b6c7aeecbbab00cb9670e285bb3e50eff146fe9 Mon Sep 17 00:00:00 2001 From: Valtteri Kantanen Date: Mon, 24 Jun 2024 13:10:58 +0300 Subject: [PATCH] [Course stats] Remove duplicated code --- .../backend/src/services/courses/index.js | 83 ++++++++++++++++++- .../src/services/courses/parseCredits.js | 64 -------------- .../src/services/courses/parseEnrollments.js | 44 ---------- 3 files changed, 81 insertions(+), 110 deletions(-) delete mode 100644 services/backend/src/services/courses/parseCredits.js delete mode 100644 services/backend/src/services/courses/parseEnrollments.js diff --git a/services/backend/src/services/courses/index.js b/services/backend/src/services/courses/index.js index e80756b4da..b3276aed7e 100644 --- a/services/backend/src/services/courses/index.js +++ b/services/backend/src/services/courses/index.js @@ -1,3 +1,4 @@ +const crypto = require('crypto') const { Op } = require('sequelize') const { Course, Credit, Enrollment, Organization } = require('../../models') @@ -9,8 +10,86 @@ const { enrollmentsForCourses, getStudentNumberToSrElementsMap, } = require('./creditsAndEnrollmentsOfCourse') -const { parseCredit } = require('./parseCredits') -const { parseEnrollment } = require('./parseEnrollments') + +const formatStudyrightElement = ({ code, element_detail, startdate, studyright: sr }) => { + const studyright = sr.get({ plain: true }) + return { + code, + name: element_detail.name, + startdate, + faculty_code: studyright.faculty_code || null, + organization: studyright.organization + ? { + name: studyright.organization.name, + code: studyright.organization.code, + } + : null, + } +} + +const parseCredit = (credit, anonymizationSalt, studentNumberToSrElementsMap) => { + const { semester, grade, course_code, credits, attainment_date, student_studentnumber: studentnumber } = credit + const { yearcode, yearname, semestercode, name: semestername } = semester + + const studyrightElements = studentNumberToSrElementsMap[studentnumber] || [] + + const formattedCredit = { + yearcode, + yearname, + semestercode, + semestername, + attainment_date, + coursecode: course_code, + grade, + passed: !Credit.failed(credit) || Credit.passed(credit) || Credit.improved(credit), + studentnumber, + programmes: studyrightElements.map(formatStudyrightElement), + credits, + } + + if (anonymizationSalt) { + const anonymizedStudentNumber = crypto + .createHash('sha256') + .update(`${studentnumber}${anonymizationSalt}`) + .digest('hex') + + formattedCredit.obfuscated = true + formattedCredit.studentnumber = anonymizedStudentNumber + } + + return formattedCredit +} + +const parseEnrollment = (enrollment, anonymizationSalt, studentNumberToSrElementsMap) => { + const { studentnumber, semester, state, enrollment_date_time, course_code } = enrollment + const { yearcode, yearname, semestercode, name: semestername } = semester + + const studyrightElements = studentNumberToSrElementsMap[studentnumber] || [] + + const formattedEnrollment = { + yearcode, + yearname, + semestercode, + semestername, + coursecode: course_code, + state, + enrollment_date_time, + studentnumber, + programmes: studyrightElements.map(formatStudyrightElement), + } + + if (anonymizationSalt) { + const anonymizedStudentNumber = crypto + .createHash('sha256') + .update(`${studentnumber}${anonymizationSalt}`) + .digest('hex') + + formattedEnrollment.obfuscated = true + formattedEnrollment.studentnumber = anonymizedStudentNumber + } + + return formattedEnrollment +} const isOpenUniCourseCode = code => code.match(/^AY?(.+?)(?:en|fi|sv)?$/) diff --git a/services/backend/src/services/courses/parseCredits.js b/services/backend/src/services/courses/parseCredits.js deleted file mode 100644 index 225648fd1b..0000000000 --- a/services/backend/src/services/courses/parseCredits.js +++ /dev/null @@ -1,64 +0,0 @@ -const crypto = require('crypto') - -const { Credit } = require('../../models') - -const formatStudyrightElement = ({ code, element_detail, startdate, studyright: sr }) => { - const studyright = sr.get({ plain: true }) - return { - code, - name: element_detail.name, - startdate, - faculty_code: studyright.faculty_code || null, - organization: studyright.organization - ? { - name: studyright.organization.name, - code: studyright.organization.code, - } - : null, - } -} - -const parseCredit = (credit, anonymizationSalt, studentNumberToSrElementsMap) => { - const { semester, grade, course_code, credits, attainment_date, student_studentnumber: studentnumber } = credit - const { yearcode, yearname, semestercode, name: semestername } = semester - - const studyrightElements = studentNumberToSrElementsMap[studentnumber] || [] - - if (anonymizationSalt) { - const anonymizedStudentNumber = crypto - .createHash('sha256') - .update(`${studentnumber}${anonymizationSalt}`) - .digest('hex') - - return { - obfuscated: true, - yearcode, - yearname, - semestercode, - semestername, - attainment_date, - coursecode: course_code, - grade, - passed: !Credit.failed(credit) || Credit.passed(credit) || Credit.improved(credit), - studentnumber: anonymizedStudentNumber, - programmes: studyrightElements.map(formatStudyrightElement), - credits, - } - } - - return { - yearcode, - yearname, - semestercode, - semestername, - attainment_date, - coursecode: course_code, - grade, - passed: !Credit.failed(credit) || Credit.passed(credit) || Credit.improved(credit), - studentnumber, - programmes: studyrightElements.map(formatStudyrightElement), - credits, - } -} - -module.exports = { parseCredit, formatStudyrightElement } diff --git a/services/backend/src/services/courses/parseEnrollments.js b/services/backend/src/services/courses/parseEnrollments.js deleted file mode 100644 index 625de10aa3..0000000000 --- a/services/backend/src/services/courses/parseEnrollments.js +++ /dev/null @@ -1,44 +0,0 @@ -const crypto = require('crypto') - -const { formatStudyrightElement } = require('./parseCredits') - -const parseEnrollment = (enrollment, anonymizationSalt, studentNumberToSrElementsMap) => { - const { studentnumber, semester, state, enrollment_date_time, course_code } = enrollment - const { yearcode, yearname, semestercode, name: semestername } = semester - - const studyrightElements = studentNumberToSrElementsMap[studentnumber] || [] - - if (anonymizationSalt) { - const anonymizedStudentNumber = crypto - .createHash('sha256') - .update(`${studentnumber}${anonymizationSalt}`) - .digest('hex') - - return { - obfuscated: true, - yearcode, - yearname, - semestercode, - semestername, - coursecode: course_code, - state, - enrollment_date_time, - studentnumber: anonymizedStudentNumber, - programmes: studyrightElements.map(formatStudyrightElement), - } - } - - return { - yearcode, - yearname, - semestercode, - semestername, - coursecode: course_code, - state, - enrollment_date_time, - studentnumber, - programmes: studyrightElements.map(formatStudyrightElement), - } -} - -module.exports = { parseEnrollment }