UNPKG

@chimanos/sequelize-replace-enum-postgres

Version:

This package provides the methods needed to replace a PostgreSQL ENUM in Sequelize migrations.

89 lines 3.49 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; var __exportStar = (this && this.__exportStar) || function(m, exports) { for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.replaceEnum = void 0; const helpers = __importStar(require("./helpers")); /** * Since PostgreSQL still does not support remove values from an ENUM, * the workaround is to create a new ENUM with the new values and use it * to replace the other. */ const replaceEnum = (queryInterface) => async (args) => { const { sequelize } = queryInterface; const { tableName, columnName, newValues, defaultValue = null } = args; const enumName = args.enumName ?? `enum_${tableName}_${columnName}`; const transactionOptions = args.transactionOptions ?? {}; const _queryOptions = args.queryOptions ?? {}; const newEnumName = `${enumName}_new`; await sequelize.transaction(transactionOptions, async (t) => { const queryOptions = { ..._queryOptions, transaction: t, }; await helpers.createEnum(queryInterface)({ name: newEnumName, values: newValues, queryOptions: queryOptions, }); if (defaultValue != null) { await helpers.unsetDefaultValueFromEnum(queryInterface)({ tableName, columnName, queryOptions: queryOptions, }); } await helpers.setColumnTypeToEnum(queryInterface)({ tableName, columnName, enumName: newEnumName, queryOptions: queryOptions, }); await helpers.dropEnum(queryInterface)({ name: enumName, queryOptions: queryOptions, }); await helpers.renameEnum(queryInterface)({ oldEnumName: newEnumName, newEnumName: enumName, queryOptions: queryOptions, }); if (defaultValue != null) { await helpers.setColumnDefault(queryInterface)({ tableName, columnName, defaultValue, defaultValueType: enumName, queryOptions: queryOptions, }); } }); }; exports.replaceEnum = replaceEnum; __exportStar(require("./helpers"), exports); exports.default = exports.replaceEnum; //# sourceMappingURL=index.js.map