97 lines
1.7 KiB
JavaScript

import { Track, TrackLike } from "@db_models"
async function fullfillData(list, { user_id = null }) {
if (!Array.isArray(list)) {
list = [list]
}
const trackIds = list.map((track) => {
return track._id
})
// if user_id is provided, fetch likes
if (user_id) {
const tracksLikes = await TrackLike.find({
user_id: user_id,
track_id: { $in: trackIds },
})
list = list.map(async (track) => {
const trackLike = tracksLikes.find((trackLike) => {
return trackLike.track_id.toString() === track._id.toString()
})
if (trackLike) {
track.liked_at = trackLike.created_at
track.liked = true
}
return track
})
list = await Promise.all(list)
}
// process some metadata
list = list.map(async (track) => {
if (track.metadata) {
if (track.metadata.bitrate && track.metadata.bitrate > 9000) {
track.metadata.lossless = true
}
}
return track
})
list = await Promise.all(list)
return list
}
export default async (track_id, { user_id = null, onlyList = false } = {}) => {
if (!track_id) {
throw new OperationError(400, "Missing track_id")
}
const isMultiple = Array.isArray(track_id) || track_id.includes(",")
if (isMultiple) {
const track_ids = Array.isArray(track_id)
? track_id
: track_id.split(",")
let tracks = await Track.find({
_id: { $in: track_ids },
}).lean()
tracks = await fullfillData(tracks, {
user_id,
})
if (onlyList) {
return tracks
}
return {
total_count: await Track.countDocuments({
_id: { $in: track_ids },
}),
list: tracks,
}
}
let track = await Track.findOne({
_id: track_id,
}).lean()
if (!track) {
throw new OperationError(404, "Track not found")
}
track = await fullfillData(track, {
user_id,
})
return track[0]
}