123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- import async from "async";
- /**
- * Migration 5
- *
- * Migration for song status property.
- *
- * @param {object} MigrationModule - the MigrationModule
- * @returns {Promise} - returns promise
- */
- export default async function migrate(MigrationModule) {
- const songModel = await MigrationModule.runJob("GET_MODEL", { modelName: "song" }, this);
- const playlistModel = await MigrationModule.runJob("GET_MODEL", { modelName: "playlist" }, this);
- const stationModel = await MigrationModule.runJob("GET_MODEL", { modelName: "station" }, this);
- return new Promise((resolve, reject) => {
- async.waterfall(
- [
- next => {
- this.log("INFO", `Migration 5. Finding unverified songs with document version 2.`);
- songModel.updateMany(
- { documentVersion: 2, verified: false },
- { $set: { documentVersion: 3, status: "unverified" }, $unset: { verified: "" } },
- (err, res) => {
- if (err) next(err);
- else {
- this.log(
- "INFO",
- `Migration 5 (unverified songs). Matched: ${res.n}, modified: ${res.nModified}, ok: ${res.ok}.`
- );
- next();
- }
- }
- );
- },
- next => {
- this.log("INFO", `Migration 5. Finding verified songs with document version 2.`);
- songModel.updateMany(
- { documentVersion: 2, verified: true },
- { $set: { documentVersion: 3, status: "verified" }, $unset: { verified: "" } },
- (err, res) => {
- if (err) next(err);
- else {
- this.log(
- "INFO",
- `Migration 5 (verified songs). Matched: ${res.n}, modified: ${res.nModified}, ok: ${res.ok}.`
- );
- next();
- }
- }
- );
- },
- next => {
- this.log("INFO", `Migration 5. Updating playlist songs and queue songs.`);
- songModel.find({ documentVersion: 3 }, (err, songs) => {
- if (err) next(err);
- else {
- async.eachLimit(
- songs.map(song => song._doc),
- 1,
- (song, next) => {
- const { _id, songId, title, artists, thumbnail, duration, status } = song;
- const trimmedSong = {
- _id,
- songId,
- title,
- artists,
- thumbnail,
- duration,
- status
- };
- async.waterfall(
- [
- next => {
- playlistModel.updateMany(
- { "songs._id": song._id, documentVersion: 1 },
- { $set: { "songs.$": trimmedSong } },
- next
- );
- },
- (res, next) => {
- stationModel.updateMany(
- { "queue._id": song._id, documentVersion: 3 },
- { $set: { "queue.$": trimmedSong } },
- next
- );
- },
- (res, next) => {
- stationModel.updateMany(
- { "currentSong._id": song._id, documentVersion: 3 },
- { $set: { currentSong: null } },
- next
- );
- }
- ],
- err => {
- next(err);
- }
- );
- },
- err => {
- next(err);
- }
- );
- }
- });
- },
- next => {
- playlistModel.updateMany({ documentVersion: 1 }, { $set: { documentVersion: 2 } }, (err, res) => {
- if (err) next(err);
- else {
- this.log(
- "INFO",
- `Migration 5 (playlist). Matched: ${res.n}, modified: ${res.nModified}, ok: ${res.ok}.`
- );
- next();
- }
- });
- },
- next => {
- stationModel.updateMany({ documentVersion: 3 }, { $set: { documentVersion: 4 } }, (err, res) => {
- if (err) next(err);
- else {
- this.log(
- "INFO",
- `Migration 5 (station). Matched: ${res.n}, modified: ${res.nModified}, ok: ${res.ok}.`
- );
- next();
- }
- });
- }
- ],
- err => {
- if (err) {
- reject(new Error(err));
- } else {
- resolve();
- }
- }
- );
- });
- }
|