| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 | 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();				}			}		);	});}
 |