38433-vm/backend/src/db/seeders/20200430130760-user-roles.js
2026-02-14 20:46:34 +00:00

1133 lines
38 KiB
JavaScript

const { v4: uuid } = require("uuid");
module.exports = {
/**
* @param{import("sequelize").QueryInterface} queryInterface
* @return {Promise<void>}
*/
async up(queryInterface) {
const createdAt = new Date();
const updatedAt = new Date();
/** @type {Map<string, string>} */
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("PlatformOwner"), name: "Platform Owner", createdAt, updatedAt },
{ id: getId("OperationsManager"), name: "Operations Manager", createdAt, updatedAt },
{ id: getId("PaymentsAuditor"), name: "Payments Auditor", createdAt, updatedAt },
{ id: getId("SupportAgent"), name: "Support Agent", createdAt, updatedAt },
{ id: getId("CatalogEditor"), name: "Catalog Editor", 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","vpn_plans","vpn_servers","orders","payments","vpn_accounts","support_tickets","ticket_messages","discount_codes","app_settings",,
];
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("PlatformOwner"), permissionId: getId('CREATE_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('READ_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_USERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('READ_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('CREATE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('READ_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('UPDATE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('READ_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('UPDATE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('READ_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('UPDATE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('READ_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('READ_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('UPDATE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('READ_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('UPDATE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('READ_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('READ_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('CREATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('UPDATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('CREATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('READ_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('UPDATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('CREATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('READ_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), permissionId: getId('UPDATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('READ_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('UPDATE_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('DELETE_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('READ_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('UPDATE_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("PlatformOwner"), permissionId: getId('CREATE_SEARCH') },
{ createdAt, updatedAt, roles_permissionsId: getId("OperationsManager"), permissionId: getId('CREATE_SEARCH') },
{ createdAt, updatedAt, roles_permissionsId: getId("PaymentsAuditor"), permissionId: getId('CREATE_SEARCH') },
{ createdAt, updatedAt, roles_permissionsId: getId("SupportAgent"), permissionId: getId('CREATE_SEARCH') },
{ createdAt, updatedAt, roles_permissionsId: getId("CatalogEditor"), 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_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_VPN_PLANS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_VPN_SERVERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_ORDERS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_PAYMENTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_VPN_ACCOUNTS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_SUPPORT_TICKETS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_TICKET_MESSAGES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_DISCOUNT_CODES') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('CREATE_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('READ_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('UPDATE_APP_SETTINGS') },
{ createdAt, updatedAt, roles_permissionsId: getId("Administrator"), permissionId: getId('DELETE_APP_SETTINGS') },
{ 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("PlatformOwner")}' WHERE "email"='client@hello.com'`);
await queryInterface.sequelize.query(`UPDATE "users" SET "app_roleId"='${getId("OperationsManager")}' WHERE "email"='john@doe.com'`);
}
};