const { v4: uuid } = require("uuid"); module.exports = { /** * @param{import("sequelize").QueryInterface} queryInterface * @return {Promise} */ async up(queryInterface) { const createdAt = new Date(); const updatedAt = new Date(); /** @type {Map} */ const idMap = new Map(); /** * @param {string} key * @return {string} */ function getId(key) { if (idMap.has(key)) { return idMap.get(key); } const id = uuid(); idMap.set(key, id); return id; } await queryInterface.bulkInsert("roles", [ { id: getId("Administrator"), name: "Administrator", createdAt, updatedAt }, { id: getId("SystemOwner"), name: "System Owner", createdAt, updatedAt }, { id: getId("AcademicRegistrar"), name: "Academic Registrar", createdAt, updatedAt }, { id: getId("FacultyLead"), name: "Faculty Lead", createdAt, updatedAt }, { id: getId("Instructor"), name: "Instructor", createdAt, updatedAt }, { id: getId("Student"), name: "Student", createdAt, updatedAt }, { id: getId("Public"), name: "Public", createdAt, updatedAt }, ]); /** * @param {string} name */ function createPermissions(name) { return [ { id: getId(`CREATE_${name.toUpperCase()}`), createdAt, updatedAt, name: `CREATE_${name.toUpperCase()}` }, { id: getId(`READ_${name.toUpperCase()}`), createdAt, updatedAt, name: `READ_${name.toUpperCase()}` }, { id: getId(`UPDATE_${name.toUpperCase()}`), createdAt, updatedAt, name: `UPDATE_${name.toUpperCase()}` }, { id: getId(`DELETE_${name.toUpperCase()}`), createdAt, updatedAt, name: `DELETE_${name.toUpperCase()}` } ]; } const entities = [ "users","roles","permissions","departments","courses","groups","group_memberships","course_offerings","class_sessions","qr_tokens","attendance_records",, ]; await queryInterface.bulkInsert("permissions", entities.flatMap(createPermissions)); await queryInterface.bulkInsert("permissions", [{ id: getId(`READ_API_DOCS`), createdAt, updatedAt, name: `READ_API_DOCS` }]); await queryInterface.bulkInsert("permissions", [{ id: getId(`CREATE_SEARCH`), createdAt, updatedAt, name: `CREATE_SEARCH`}]); await queryInterface.sequelize.query(`create table "rolesPermissionsPermissions" ( "createdAt" timestamp with time zone not null, "updatedAt" timestamp with time zone not null, "roles_permissionsId" uuid not null, "permissionId" uuid not null, primary key ("roles_permissionsId", "permissionId") );`); await queryInterface.bulkInsert("rolesPermissionsPermissions", [ { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('CREATE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('CREATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('CREATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('CREATE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('CREATE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('CREATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('CREATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('UPDATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('CREATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('CREATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('UPDATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('CREATE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('CREATE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('UPDATE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('READ_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('UPDATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('DELETE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('READ_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('UPDATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('READ_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('UPDATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('CREATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('READ_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('UPDATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('CREATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('READ_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("SystemOwner"), permissionId: getId('CREATE_SEARCH') }, { createdAt, updatedAt, roles_permissionsId: getId("AcademicRegistrar"), permissionId: getId('CREATE_SEARCH') }, { createdAt, updatedAt, roles_permissionsId: getId("FacultyLead"), permissionId: getId('CREATE_SEARCH') }, { createdAt, updatedAt, roles_permissionsId: getId("Instructor"), permissionId: getId('CREATE_SEARCH') }, { createdAt, updatedAt, roles_permissionsId: getId("Student"), permissionId: getId('CREATE_SEARCH') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_USERS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_ROLES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_ROLES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_ROLES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_ROLES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_PERMISSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_PERMISSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_PERMISSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_PERMISSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_DEPARTMENTS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_COURSES') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_GROUPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_GROUP_MEMBERSHIPS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_COURSE_OFFERINGS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_CLASS_SESSIONS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_QR_TOKENS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_ATTENDANCE_RECORDS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_API_DOCS') }, { createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_SEARCH') }, ]); await queryInterface.sequelize.query(`UPDATE "users" SET "app_roleId"='${getId("SuperAdmin")}' WHERE "email"='super_admin@flatlogic.com'`); await queryInterface.sequelize.query(`UPDATE "users" SET "app_roleId"='${getId("Administrator")}' WHERE "email"='admin@flatlogic.com'`); await queryInterface.sequelize.query(`UPDATE "users" SET "app_roleId"='${getId("SystemOwner")}' WHERE "email"='client@hello.com'`); await queryInterface.sequelize.query(`UPDATE "users" SET "app_roleId"='${getId("AcademicRegistrar")}' WHERE "email"='john@doe.com'`); } };