Files
outline/server/migrations/20250207120103-add-collectionId-to-subscriptions.js
T
Hemachandar 6a1f2399db feat: Collection subscription (#8392)
* feat: Collection subscription

* refactor to use latest impl

* load subscriptions only once

* tests, type rename, migration index

* all users in publish flow

* tsc

* remove SubscriptionType.Collection enum

* review
2025-02-22 06:53:19 -08:00

45 lines
1.1 KiB
JavaScript

"use strict";
/** @type {import('sequelize-cli').Migration} */
module.exports = {
async up(queryInterface, Sequelize) {
await queryInterface.sequelize.transaction(async transaction => {
await queryInterface.addColumn(
"subscriptions",
"collectionId",
{
type: Sequelize.UUID,
allowNull: true,
onDelete: "cascade",
references: {
model: "collections",
},
},
{ transaction }
);
await queryInterface.addIndex(
"subscriptions",
["userId", "collectionId", "event"],
{
name: "subscriptions_user_id_collection_id_event",
type: "UNIQUE",
transaction,
}
);
});
},
async down(queryInterface, Sequelize) {
await queryInterface.sequelize.transaction(async transaction => {
await queryInterface.removeIndex(
"subscriptions",
["userId", "collectionId", "event"],
{ transaction }
);
await queryInterface.removeColumn("subscriptions", "collectionId", {
transaction,
});
});
},
};