Create: Backend branch
This commit is contained in:
parent
f91febf919
commit
76ac0c292c
260 changed files with 10 additions and 12964 deletions
290
controllers/ad.controller.js
Normal file
290
controllers/ad.controller.js
Normal file
|
|
@ -0,0 +1,290 @@
|
|||
const db = require("../models/mongodb.model");
|
||||
const {sendError, sendMessage} = require ("../config/response.config");
|
||||
const {checkLogin} = require("../config/sessionJWT.config");
|
||||
const ObjectId = require('mongoose').Types.ObjectId;
|
||||
const roles = require("../models/objects/role.model");
|
||||
const Ad = db.ads;
|
||||
|
||||
// Create a new Ad
|
||||
exports.create = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.Advertiser);
|
||||
if(token && req.body.title){
|
||||
Ad.exists({title: req.body.title, userId: token.id, isActive: true}, function (err, docs){
|
||||
if(err){
|
||||
sendError(res, 500,100,err.message || "Some error occurred while checking if the Ad already exists.", token);
|
||||
} else{
|
||||
if(docs === null) {
|
||||
let ad;
|
||||
|
||||
ad = new Ad({
|
||||
userId: token.id,
|
||||
title: req.body.title,
|
||||
images: req.body.images ? req.body.images : undefined,
|
||||
url: req.body.url ? req.body.url : undefined,
|
||||
interests: req.body.interests ? req.body.interests : undefined,
|
||||
comment: req.body.comment ? req.body.comment : undefined,
|
||||
isVisible: req.body.isVisible ? req.body.isVisible : undefined,
|
||||
isActive: req.body.isActive ? req.body.isActive : undefined
|
||||
});
|
||||
|
||||
// Save User in the database
|
||||
ad
|
||||
.save(ad)
|
||||
.then(data => {
|
||||
return sendMessage(res, 41, data, token)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500,100,err.message || "Some error occurred while creating the Ad.", token);
|
||||
});
|
||||
} else{
|
||||
return sendError(res, 500, 104, err || `Ad ${req.body.title} already exists.`, token);
|
||||
}
|
||||
}
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No title given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Retrieve all Ad from id if admin or session id
|
||||
exports.findAll = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.Advertiser);
|
||||
if(token){
|
||||
let query = {};
|
||||
let condition;
|
||||
|
||||
const adId = req.query.adId;
|
||||
condition = adId ? adId : undefined;
|
||||
query._id = condition;
|
||||
|
||||
let userId;
|
||||
if(typeof token.role !== 'undefined' &&
|
||||
typeof token.role.permission !== 'undefined' &&
|
||||
typeof token.role.isAccepted !== 'undefined' &&
|
||||
token.role.isAccepted === true &&
|
||||
token.role.permission >= roles.Admin.permission) {
|
||||
userId = req.query.userId;
|
||||
} else {
|
||||
userId = token.id;
|
||||
}
|
||||
condition = userId ? userId : undefined;
|
||||
query.userId = condition;
|
||||
|
||||
const title = req.query.title;
|
||||
condition = title ? { $regex: new RegExp(title), $options: "i" } : undefined;
|
||||
query.title = condition;
|
||||
|
||||
const url = req.query.url;
|
||||
condition = url ? { $regex: new RegExp(url), $options: "i" } : undefined;
|
||||
query.url = condition;
|
||||
|
||||
const interests = req.query.interests;
|
||||
condition = interests ? {$in: interests.split(',')} : undefined;
|
||||
query["interests.interest"] = condition
|
||||
|
||||
const comment = req.query.comment;
|
||||
condition = comment ? { $regex: new RegExp(comment), $options: "i" } : undefined;
|
||||
query.comment = condition;
|
||||
|
||||
const isVisible = req.query.isVisible;
|
||||
condition = isVisible ? isVisible : undefined;
|
||||
query.isVisible = condition;
|
||||
|
||||
const isActive = req.query.isActive;
|
||||
condition = isActive ? isActive : undefined;
|
||||
query.isActive = condition;
|
||||
|
||||
const sort = req.query.sort;
|
||||
if(sort !== 'undefined'){
|
||||
switch (sort){
|
||||
case 'asc':
|
||||
condition = {title: 1};
|
||||
break;
|
||||
case 'desc':
|
||||
condition = {title: -1};
|
||||
break;
|
||||
case 'createdAtAsc':
|
||||
condition = {createdAt: 1};
|
||||
break;
|
||||
case 'createdAtDesc':
|
||||
condition = {createdAt: -1};
|
||||
break;
|
||||
case 'updatedAtAsc':
|
||||
condition = {updatedAt: 1};
|
||||
break;
|
||||
case 'updatedAtDesc':
|
||||
condition = {updatedAt: -1};
|
||||
break;
|
||||
default:
|
||||
condition = {title: 1};
|
||||
}
|
||||
}
|
||||
const query_sort = {sort: condition};
|
||||
|
||||
// Remove undefined key
|
||||
Object.keys(query).forEach(key => query[key] === undefined ? delete query[key] : {});
|
||||
console.log(query);
|
||||
|
||||
Ad.find(query, {}, query_sort)
|
||||
.then(data => {
|
||||
if(data){
|
||||
return sendMessage(res, 42, data, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || "Some error occurred while finding the Ads.", token);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
// Find single Ad from id if admin or session id
|
||||
exports.findOne = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.Advertiser);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(id && ObjectId.isValid(id)){
|
||||
Ad.findById(id, {})
|
||||
.then(data => {
|
||||
if(data){
|
||||
return sendMessage(res, 43, data, token);
|
||||
} else {
|
||||
return sendError(res,404,105,`Ad not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || `Some error occurred while finding the Ad with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Update a Ad with ad id
|
||||
exports.update = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.Advertiser);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(typeof req.body._id !== 'undefined' || typeof req.body.id !== 'undefined'){
|
||||
return sendError(res, 500, -1, `User do not have the permission to modify id or _id`, token);
|
||||
} else{
|
||||
let update = {};
|
||||
let condition;
|
||||
|
||||
const title = req.body.title;
|
||||
condition = title ? title : undefined;
|
||||
update.title = condition;
|
||||
|
||||
const images = req.body.images;
|
||||
condition = images ? images : undefined;
|
||||
update.images = condition;
|
||||
|
||||
const url = req.body.url;
|
||||
condition = url ? url : undefined;
|
||||
update.url = condition;
|
||||
|
||||
let interests = req.body.interests;
|
||||
condition = interests ? {interests: [...new Map(interests.map(v => [v.id, v])).values()]} : undefined;
|
||||
update.$addToSet = condition;
|
||||
|
||||
const comment = req.body.comment;
|
||||
condition = comment ? comment : undefined;
|
||||
update.comment = condition;
|
||||
|
||||
const isVisible = req.body.isVisible;
|
||||
if(typeof isVisible !== 'undefined'){
|
||||
condition = isVisible;
|
||||
} else{
|
||||
condition = undefined;
|
||||
}
|
||||
update.isVisible = condition;
|
||||
|
||||
const isActive = req.body.isActive;
|
||||
if(typeof isActive !== 'undefined'){
|
||||
condition = isActive;
|
||||
} else{
|
||||
condition = undefined;
|
||||
}
|
||||
update.isActive = condition;
|
||||
|
||||
// Remove undefined key
|
||||
Object.keys(update).forEach(key => update[key] === undefined ? delete update[key] : {});
|
||||
|
||||
if(id && ObjectId.isValid(id)){
|
||||
Ad.updateOne({_id: id, userId: token.id}, update)
|
||||
.then(data => {
|
||||
if(data) {
|
||||
//Object.keys(update).forEach(key => data[key] = update[key]);
|
||||
return sendMessage(res, 44, update, token);
|
||||
} else {
|
||||
return sendError(res, 404, -1, `Ad not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, -1, err.message || `Some error occurred while updating the Ad with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Delete an Ad with ad id
|
||||
exports.delete = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.Advertiser);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
let match = null;
|
||||
const id = req.params.id;
|
||||
if(id && ObjectId.isValid(id)){
|
||||
if(typeof token.role !== 'undefined' &&
|
||||
typeof token.role.permission !== 'undefined' &&
|
||||
typeof token.role.isAccepted !== 'undefined' &&
|
||||
token.role.isAccepted === true &&
|
||||
token.role.permission >= roles.Admin.permission) {
|
||||
match = {_id: id, isActive: true};
|
||||
} else {
|
||||
match = {_id: id, userId: token.id, isActive: true};
|
||||
}
|
||||
Ad.findOneAndUpdate(match, {isActive: false}, {useFindAndModify: false, new: true})
|
||||
.then(data => {
|
||||
if(data) {
|
||||
if(data.isActive !== true){
|
||||
return sendMessage(res, 45, {message: `Ad ${id} was successfully deleted.`}, token);
|
||||
} else {
|
||||
return sendError(res, 404, 105, `Ad ${id} was not deleted.`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 404, 105, `Ad not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, 100, err.message || `Some error occurred while deleting the Ad with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Delete all Ad from session id
|
||||
exports.deleteAll = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.Advertiser);
|
||||
if(token) {
|
||||
Ad.updateMany({userId: {$eq: token.id}, isActive: true}, {isActive: false})
|
||||
.then(data => {
|
||||
return sendMessage(res, 46, {
|
||||
message: `${data.modifiedCount} Ads were deleted successfully.`
|
||||
});
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, -1, err.message || "Some error occurred while removing all Ads.");
|
||||
});
|
||||
}
|
||||
};
|
||||
7
controllers/misc.controller.js
Normal file
7
controllers/misc.controller.js
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
const {sendMessage} = require ("../config/response.config");
|
||||
const interests = require("../models/objects/video.categories.model");
|
||||
|
||||
// Get all interests available
|
||||
exports.getInterests = (req, res) => {
|
||||
return sendMessage(res, 51, interests, null)
|
||||
};
|
||||
407
controllers/playlist.controller.js
Normal file
407
controllers/playlist.controller.js
Normal file
|
|
@ -0,0 +1,407 @@
|
|||
const db = require("../models/mongodb.model");
|
||||
const {sendError, sendMessage} = require ("../config/response.config");
|
||||
const {checkLogin} = require("../config/sessionJWT.config");
|
||||
const {youtube, dailymotion} = require("../config/host.config");
|
||||
const {asyncRequest, asyncInterest} = require("../config/functions.config");
|
||||
const ObjectId = require('mongoose').Types.ObjectId;
|
||||
const Playlist = db.playlists;
|
||||
const Video = db.videos;
|
||||
|
||||
// Create a new Playlist
|
||||
exports.create = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && req.body.name){
|
||||
const video = req.body.video;
|
||||
if(typeof video !== 'undefined' &&
|
||||
video !== null &&
|
||||
typeof video.videoId !== 'undefined' &&
|
||||
video.videoId !== null &&
|
||||
typeof video.source !== 'undefined' &&
|
||||
video.source !== null &&
|
||||
typeof video.interest !== 'undefined' &&
|
||||
video.interest !== null
|
||||
){
|
||||
Video.exists({userId: token.id, videoId: video.videoId, source: video.source, isActive: true}, function (err, docs){
|
||||
if(err){
|
||||
sendError(res, 500,100,err.message || "Some error occurred while checking if the Video already exists.", token);
|
||||
} else{
|
||||
if(docs === null) {
|
||||
let video;
|
||||
|
||||
video = new Video({
|
||||
userId: token.id,
|
||||
videoId: id,
|
||||
source: req.body.source,
|
||||
interest: req.body.interest,
|
||||
watchedDates: [new Date()]
|
||||
});
|
||||
|
||||
// Save Video in the database
|
||||
video
|
||||
.save(video)
|
||||
.then(data => {
|
||||
if(data) {
|
||||
Playlist.exists({name: req.body.name, isActive: true}, function (err, docs){
|
||||
if(err){
|
||||
sendError(res, 500,100,err.message || "Some error occurred while checking if the Playlist already exists.", token);
|
||||
} else{
|
||||
if(docs === null) {
|
||||
let playlist;
|
||||
|
||||
playlist = new Playlist({
|
||||
userId: token.id,
|
||||
name: req.body.name,
|
||||
videoIds: data._id ? [data._id] : undefined,
|
||||
isActive: true
|
||||
});
|
||||
|
||||
// Save User in the database
|
||||
playlist
|
||||
.save(playlist)
|
||||
.then(data => {
|
||||
return sendMessage(res, 21, data, token)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500,100,err.message || "Some error occurred while creating the Playlist.", token);
|
||||
});
|
||||
} else{
|
||||
return sendError(res, 500, 104, err || `Playlist ${req.body.name} already exists.`, token);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500,100,err.message || "Some error occurred while creating the Video.", token);
|
||||
});
|
||||
} else{
|
||||
const id = docs._id.toString();
|
||||
Playlist.exists({name: req.body.name, isActive: true}, function (err, docs){
|
||||
if(err){
|
||||
sendError(res, 500,100,err.message || "Some error occurred while checking if the Playlist already exists.", token);
|
||||
} else{
|
||||
if(docs === null) {
|
||||
let playlist;
|
||||
|
||||
playlist = new Playlist({
|
||||
userId: token.id,
|
||||
name: req.body.name,
|
||||
videoIds: [id],
|
||||
isActive: true
|
||||
});
|
||||
|
||||
// Save User in the database
|
||||
playlist
|
||||
.save(playlist)
|
||||
.then(data => {
|
||||
return sendMessage(res, 21, data, token)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500,100,err.message || "Some error occurred while creating the Playlist.", token);
|
||||
});
|
||||
} else{
|
||||
return sendError(res, 500, 104, err || `Playlist ${req.body.name} already exists.`, token);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
} else {
|
||||
Playlist.exists({name: req.body.name, isActive: true}, function (err, docs){
|
||||
if(err){
|
||||
sendError(res, 500,100,err.message || "Some error occurred while checking if the Playlist already exists.", token);
|
||||
} else{
|
||||
if(docs === null) {
|
||||
let playlist;
|
||||
|
||||
playlist = new Playlist({
|
||||
userId: token.id,
|
||||
name: req.body.name,
|
||||
videoIds: req.body.videoIds ? req.body.videoIds : undefined,
|
||||
isActive: req.body.isActive ? req.body.isActive : undefined
|
||||
});
|
||||
|
||||
// Save User in the database
|
||||
playlist
|
||||
.save(playlist)
|
||||
.then(data => {
|
||||
return sendMessage(res, 21, data, token)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500,100,err.message || "Some error occurred while creating the Playlist.", token);
|
||||
});
|
||||
} else{
|
||||
return sendError(res, 500, 104, err || `Playlist ${req.body.name} already exists.`, token);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
// Retrieve all Playlist from id if admin or session id
|
||||
exports.findAll = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token){
|
||||
let query = {};
|
||||
let condition;
|
||||
|
||||
const playlistId = req.query.playlistId;
|
||||
condition = playlistId ? playlistId : undefined;
|
||||
query._id = condition;
|
||||
|
||||
const userId = token.id;
|
||||
condition = userId ? userId : undefined;
|
||||
query.userId = condition;
|
||||
|
||||
const videoIds = req.query.videoIds;
|
||||
condition = videoIds ? {$in: videoIds} : undefined;
|
||||
query.videoIds = condition;
|
||||
|
||||
const name = req.query.name;
|
||||
condition = name ? { $regex: new RegExp(name), $options: "i" } : undefined;
|
||||
query.name = condition;
|
||||
|
||||
const isActive = req.query.isActive;
|
||||
condition = isActive ? isActive : undefined;
|
||||
query.isActive = condition;
|
||||
|
||||
const sort = req.query.sort;
|
||||
if(sort !== 'undefined'){
|
||||
switch (sort){
|
||||
case 'asc':
|
||||
condition = {name: 1};
|
||||
break;
|
||||
case 'desc':
|
||||
condition = {name: -1};
|
||||
break;
|
||||
case 'createdAtAsc':
|
||||
condition = {createdAt: 1};
|
||||
break;
|
||||
case 'createdAtDesc':
|
||||
condition = {createdAt: -1};
|
||||
break;
|
||||
case 'updatedAtAsc':
|
||||
condition = {updatedAt: 1};
|
||||
break;
|
||||
case 'updatedAtDesc':
|
||||
condition = {updatedAt: -1};
|
||||
break;
|
||||
default:
|
||||
condition = {name: 1};
|
||||
}
|
||||
}
|
||||
const query_sort = {sort: condition};
|
||||
|
||||
// Remove undefined key
|
||||
Object.keys(query).forEach(key => query[key] === undefined ? delete query[key] : {});
|
||||
console.log(query);
|
||||
|
||||
Playlist.find(query, {}, query_sort)
|
||||
.then(data => {
|
||||
return sendMessage(res, 22, data, token);
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || "Some error occurred while finding the Playlists.", token);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
// Find single Playlist from session id
|
||||
exports.findOne = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(id && ObjectId.isValid(id)){
|
||||
Playlist.aggregate([
|
||||
{$match: {_id: new ObjectId(id), userId: token.id, isActive: true}},
|
||||
{$unwind: '$videoIds'},
|
||||
{$project: {
|
||||
userId: true,
|
||||
name: true,
|
||||
isActive: true,
|
||||
createdAt: true,
|
||||
updatedAt: true,
|
||||
videoIds: {$toObjectId: '$videoIds'}
|
||||
}},
|
||||
{$lookup: {
|
||||
from: 'videos',
|
||||
localField: 'videoIds',
|
||||
foreignField: '_id',
|
||||
as: 'videos'
|
||||
}},
|
||||
{$unwind: '$videos'},
|
||||
{$group: {
|
||||
_id: '$_id',
|
||||
userId: {$first: "$userId"},
|
||||
name: {$first: "$name"},
|
||||
isActive: {$first: "$isActive"},
|
||||
createdAt: {$first: "$createdAt"},
|
||||
updatedAt: {$first: "$updatedAt"},
|
||||
videos: {$push: "$videos"}
|
||||
}}
|
||||
])
|
||||
.then(async data => {
|
||||
let yt_results = [];
|
||||
let dm_results = [];
|
||||
let yt_videoIds = "";
|
||||
let dm_videoIds = "";
|
||||
|
||||
for (const i in data[0].videos) {
|
||||
if (data[0].videos[i].source === youtube.name) {
|
||||
yt_videoIds = yt_videoIds + data[0].videos[i].videoId + ",";
|
||||
} else if (data[0].videos[i].source === dailymotion.name) {
|
||||
dm_videoIds = dm_videoIds + data[0].videos[i].videoId + ",";
|
||||
}
|
||||
}
|
||||
if (yt_videoIds !== "") {
|
||||
const uri = youtube.baseAPIUrl + '/videos' + '?part=snippet&part=statistics&id=' + yt_videoIds.slice(0, -1) + '&key=' + youtube.YOUTUBE_API_KEY;
|
||||
const dataVideos = await asyncRequest(uri, {});
|
||||
if (dataVideos.response.statusCode === 200 && dataVideos.body.items.length > 0) {
|
||||
yt_results = dataVideos.body.items;
|
||||
}
|
||||
}
|
||||
|
||||
if (dm_videoIds !== "") {
|
||||
const uri = dailymotion.baseAPIUrl + '/videos?ids=' + dm_videoIds.slice(0, -1) + '&fields=thumbnail_480_url%2Ctitle%2Cid';
|
||||
const data = await asyncRequest(uri, {});
|
||||
const response = data.response;
|
||||
const jsonBody = data.body;
|
||||
if (response.statusCode === 200) {
|
||||
dm_results = jsonBody.list;
|
||||
}
|
||||
}
|
||||
for (const i in data[0].videos) {
|
||||
if (data[0].videos[i].source === youtube.name) {
|
||||
const obj = yt_results.filter(obj => obj.id === data[0].videos[i].videoId);
|
||||
data[0].videos[i].imageUrl = obj[0].snippet.thumbnails.medium.url ? obj[0].snippet.thumbnails.medium.url : null;
|
||||
data[0].videos[i].interest = obj[0].snippet.categoryId ? await asyncInterest(obj[0].snippet.categoryId, youtube.name): null;
|
||||
data[0].videos[i].title = obj[0].snippet.title ? obj[0].snippet.title : null;
|
||||
data[0].videos[i].views = obj[0].statistics.viewCount ? parseInt(obj[0].statistics.viewCount) : null;
|
||||
data[0].videos[i].publishedAt = obj[0].snippet.publishedAt ? obj[0].snippet.publishedAt : null;
|
||||
} else if (data[0].videos[i].source === dailymotion.name) {
|
||||
const obj = dm_results.filter(obj => obj.id === data[0].videos[i].videoId);
|
||||
data[0].videos[i].imageUrl = obj[0].thumbnail_480_url ? obj[0].thumbnail_480_url : null;
|
||||
data[0].videos[i].interest = obj[0]['channel.name'] ? await asyncInterest( obj[0]['channel.name'], dailymotion.name) : null;
|
||||
data[0].videos[i].title = obj[0].title ? obj[0].title : null;
|
||||
data[0].videos[i].views = obj[0].views_total ? parseInt(obj[0].views_total) : null;
|
||||
data[0].videos[i].publishedAt = obj[0].created_time ? new Date(obj[0].created_time * 1000) : null
|
||||
}
|
||||
}
|
||||
return sendMessage(res, 12, data[0], token)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || `Some error occurred while finding the Playlist with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Update a Playlist with playlist id
|
||||
exports.update = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(typeof req.body._id !== 'undefined' || typeof req.body.id !== 'undefined'){
|
||||
return sendError(res, 500, -1, `User do not have the permission to modify id or _id`, token);
|
||||
} else{
|
||||
const ids = id.split(',');
|
||||
let update = {};
|
||||
let condition;
|
||||
|
||||
const name = req.body.name;
|
||||
condition = name ? name : undefined;
|
||||
update.name = condition;
|
||||
|
||||
const videoIds = req.body.videoIds;
|
||||
condition = videoIds ? videoIds : undefined;
|
||||
update.videoIds = condition;
|
||||
|
||||
const videoId = req.body.videoId;
|
||||
if(typeof videoId !== 'undefined' && typeof videoId.id !== 'undefined' && typeof videoId.action !== 'undefined'){
|
||||
if(videoId.action === 'add'){
|
||||
condition = videoId.id ? {videoIds: videoId.id} : undefined;
|
||||
update.$addToSet = condition;
|
||||
} else if(videoId.action === 'delete'){
|
||||
condition = videoId.id ? {videoIds: videoId.id} : undefined;
|
||||
update.$pull = condition;
|
||||
}
|
||||
}
|
||||
|
||||
const isActive = req.body.isActive;
|
||||
if(typeof isActive !== 'undefined'){
|
||||
condition = isActive;
|
||||
} else{
|
||||
condition = undefined;
|
||||
}
|
||||
update.isActive = condition;
|
||||
|
||||
// Remove undefined key
|
||||
Object.keys(update).forEach(key => update[key] === undefined ? delete update[key] : {});
|
||||
|
||||
Playlist.updateMany({_id: {$in: ids}, userId: token.id, isActive: true}, update, {new: false})
|
||||
.then(data => {
|
||||
if(data) {
|
||||
if(data.modifiedCount > 0){
|
||||
return sendMessage(res, 24, update, token);
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Video in Playlist ${data} already exists.`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 404, -1, `Playlist not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, -1, err.message || `Some error occurred while updating the Playlist with id=${id}`, token);
|
||||
});
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Delete a Playlist with playlist id
|
||||
exports.delete = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(id && ObjectId.isValid(id)){
|
||||
Playlist.findByIdAndUpdate(id, {isActive: false}, {useFindAndModify: false})
|
||||
.then(data => {
|
||||
if(data) {
|
||||
return sendMessage(res, 25, {message: `Playlist ${id} was successfully deleted.`}, token);
|
||||
} else {
|
||||
return sendError(res, 404, 105, `Playlist not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, 100, err.message || `Some error occurred while deleting the Playlist with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Delete all Playlists from session id
|
||||
exports.deleteAll = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token) {
|
||||
Playlist.updateMany({userId: {$eq: token.id}, isActive: true}, {isActive: false})
|
||||
.then(data => {
|
||||
return sendMessage(res, 26, {
|
||||
message: `${data.modifiedCount} Playlists were deleted successfully.`
|
||||
});
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, -1, err.message || "Some error occurred while removing all Playlists.");
|
||||
});
|
||||
}
|
||||
};
|
||||
546
controllers/user.controller.js
Normal file
546
controllers/user.controller.js
Normal file
|
|
@ -0,0 +1,546 @@
|
|||
const db = require("../models/mongodb.model");
|
||||
const {sendError, sendMessage} = require ("../config/response.config");
|
||||
const {checkLogin, setSessionCookie} = require("../config/sessionJWT.config");
|
||||
const ObjectId = require('mongoose').Types.ObjectId;
|
||||
const roles = require("../models/objects/role.model");
|
||||
const {youtube, dailymotion} = require("../config/host.config");
|
||||
const {asyncRequest} = require("../config/functions.config");
|
||||
const User = db.users;
|
||||
const Video = db.videos;
|
||||
const Ad = db.ads;
|
||||
|
||||
// Authenticate a User
|
||||
exports.auth = (req, res) => {
|
||||
// Validate request
|
||||
if (!req.body.email || !req.body.hashPass) {
|
||||
sendError(res, 400,-1,"Content can not be empty . (email and hashPass needed)");
|
||||
} else{
|
||||
// Check User in the database
|
||||
User
|
||||
.findOne({email: req.body.email, hashPass: req.body.hashPass, isActive: true, "role.isAccepted": true}, {role: true, profileImageUrl: true})
|
||||
.then(data => {
|
||||
if (data !== null){
|
||||
User.findByIdAndUpdate(data._id.toString(), {lastConnexion: new Date()}, {useFindAndModify: false},
|
||||
function (err) {
|
||||
if (err){
|
||||
return sendError(res, 400, 100,err.message || "Some error occurred while updating the User.");
|
||||
}
|
||||
else{
|
||||
const dataRes = {id: data._id.toString(), email: req.body.email, profileImageUrl: data.profileImageUrl, role: data.role};
|
||||
setSessionCookie(req, res, dataRes);
|
||||
return sendMessage(res, 1, dataRes);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
setSessionCookie(req, res, {id: -1, email: -1, profileImageUrl: -1, role: -1});
|
||||
return sendError(res, 500, 101, "Invalid login or password.");
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 400, 100,err.message || "Some error occurred while authenticating the User.");
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
// Logout a User
|
||||
exports.logout = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token){
|
||||
setSessionCookie(req, res, {id: -1, email: -1, profileImageUrl: -1, role: -1});
|
||||
return sendMessage(res, 2, {message: "User disconnected"});
|
||||
}
|
||||
};
|
||||
|
||||
// Request password reset with email
|
||||
exports.resetPass = (req, res) => {
|
||||
return sendError(res, 501, -1, "User.resetPass not Implemented", null);
|
||||
};
|
||||
|
||||
// Create and Save a new User
|
||||
exports.create = (req, res) => {
|
||||
// Validate request
|
||||
if (!req.body.email || !req.body.hashPass || !req.body.login) {
|
||||
sendError(res, 400,-1,"Content can not be empty . (email, hashPass and login needed");
|
||||
}
|
||||
else{
|
||||
User.exists({email: req.body.email}, function (err, docs){
|
||||
if(err){
|
||||
sendError(res, 500,100,err.message || "Some error occurred while checking if the User already exists.");
|
||||
} else{
|
||||
if(docs === null) {
|
||||
let user;
|
||||
let var_role;
|
||||
if(typeof req.body.role !== 'undefined'){
|
||||
switch(req.body.role){
|
||||
case 'admin':
|
||||
var_role = roles.Admin;
|
||||
break;
|
||||
case 'advertiser':
|
||||
var_role = roles.Advertiser;
|
||||
break;
|
||||
default:
|
||||
var_role = roles.User;
|
||||
}
|
||||
} else{
|
||||
var_role = roles.User;
|
||||
}
|
||||
|
||||
user = new User({
|
||||
email: req.body.email,
|
||||
hashPass: req.body.hashPass,
|
||||
login: req.body.login,
|
||||
role: var_role,
|
||||
company: req.body.company ? req.body.company : null,
|
||||
dateOfBirth: req.body.dateOfBirth ? req.body.dateOfBirth : null,
|
||||
gender: req.body.gender ? req.body.gender : null,
|
||||
interests: req.body.interests ? req.body.interests : null,
|
||||
});
|
||||
|
||||
// Save User in the database
|
||||
user
|
||||
.save(user)
|
||||
.then(data => {
|
||||
data.hashPass = undefined; // Hiding hashPass on return
|
||||
return sendMessage(res, 4, data)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500,100,err.message || "Some error occurred while creating the User.");
|
||||
});
|
||||
} else{
|
||||
return sendError(res, 500, 104, err || `Email ${req.body.email} already exists.`);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
// Retrieve all Users from the database if at least admin.
|
||||
exports.findAll = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.Admin);
|
||||
if(token){
|
||||
let query = {};
|
||||
let condition;
|
||||
|
||||
const ids = req.query.userId;
|
||||
condition = ids ? {$in: ids} : undefined;
|
||||
query._id = condition;
|
||||
|
||||
const email = req.query.email;
|
||||
condition = email ? { $regex: new RegExp(email), $options: "i" } : undefined;
|
||||
query.email = condition;
|
||||
|
||||
const login = req.query.login;
|
||||
condition = login ? { $regex: new RegExp(login), $options: "i" } : undefined;
|
||||
query.login = condition;
|
||||
|
||||
const role = req.query.role;
|
||||
condition = role ? role : undefined;
|
||||
query["role.name"] = condition;
|
||||
|
||||
const company = req.query.company;
|
||||
condition = company ? { $regex: new RegExp(company), $options: "i" } : undefined;
|
||||
query.company = condition;
|
||||
|
||||
const dateOfBirth = req.query.dateOfBirth;
|
||||
condition = dateOfBirth ? new Date(dateOfBirth) : undefined;
|
||||
query.dateOfBirth = condition;
|
||||
|
||||
const gender = req.query.gender;
|
||||
condition = gender ? gender : undefined;
|
||||
query.gender = condition;
|
||||
|
||||
const isActive = req.query.isActive;
|
||||
condition = isActive ? isActive : undefined;
|
||||
query.isActive = condition;
|
||||
|
||||
const isAccepted = req.query.isAccepted;
|
||||
if(isAccepted !== 'undefined'){
|
||||
switch (isAccepted){
|
||||
case 'true':
|
||||
condition = true;
|
||||
break;
|
||||
case 'false':
|
||||
condition = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
query["role.isAccepted"] = condition;
|
||||
|
||||
const sort = req.query.sort;
|
||||
if(sort !== 'undefined'){
|
||||
switch (sort){
|
||||
case 'asc':
|
||||
condition = {email: 1};
|
||||
break;
|
||||
case 'desc':
|
||||
condition = {email: -1};
|
||||
break;
|
||||
case 'lastConnexionAsc':
|
||||
condition = {lastConnexion: 1};
|
||||
break;
|
||||
case 'lastConnexionDesc':
|
||||
condition = {lastConnexion: -1};
|
||||
break;
|
||||
case 'createdAtAsc':
|
||||
condition = {createdAt: 1};
|
||||
break;
|
||||
case 'createdAtDesc':
|
||||
condition = {createdAt: -1};
|
||||
break;
|
||||
case 'updatedAtAsc':
|
||||
condition = {updatedAt: 1};
|
||||
break;
|
||||
case 'updatedAtDesc':
|
||||
condition = {updatedAt: -1};
|
||||
break;
|
||||
default:
|
||||
condition = {email: 1};
|
||||
}
|
||||
}
|
||||
const query_sort = {sort: condition};
|
||||
|
||||
// Remove undefined key
|
||||
Object.keys(query).forEach(key => query[key] === undefined ? delete query[key] : {});
|
||||
console.log(query);
|
||||
|
||||
User.find(query, {hashPass: false}, query_sort)
|
||||
.then(data => {
|
||||
return sendMessage(res, 5, data, token);
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || "Some error occurred while retrieving users.", token);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
// Find a single User by session id
|
||||
exports.findOne = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
let id = null;
|
||||
if(typeof token.id !== 'undefined' && token.id === req.params.id){
|
||||
id = req.params.id;
|
||||
} else {
|
||||
if(typeof token.role !== 'undefined' &&
|
||||
typeof token.role.permission !== 'undefined' &&
|
||||
typeof token.role.isAccepted !== 'undefined' &&
|
||||
token.role.isAccepted === true &&
|
||||
token.role.permission >= roles.Admin.permission) {
|
||||
id = req.params.id;
|
||||
} else {
|
||||
return sendError(res, 500, 106, `User do not have the permission.`, token);
|
||||
}
|
||||
}
|
||||
if(id && ObjectId.isValid(id)){
|
||||
User.findById(id, {hashPass: false})
|
||||
.then(data => {
|
||||
if(data){
|
||||
return sendMessage(res, 6, data, token);
|
||||
} else {
|
||||
return sendError(res,404,105,`User not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || `Some error occurred while finding the User with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Update a User by the id in the request
|
||||
exports.update = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
let id = null;
|
||||
if(typeof token.id !== 'undefined' && token.id === req.params.id){
|
||||
id = req.params.id;
|
||||
} else {
|
||||
if(typeof token.role !== 'undefined' &&
|
||||
typeof token.role.permission !== 'undefined' &&
|
||||
typeof token.role.isAccepted !== 'undefined' &&
|
||||
token.role.isAccepted === true &&
|
||||
token.role.permission >= roles.Admin.permission) {
|
||||
id = req.params.id;
|
||||
} else {
|
||||
return sendError(res, 500, 106, `User do not have the permission.`, token);
|
||||
}
|
||||
}
|
||||
if(id && ObjectId.isValid(id)){
|
||||
let update = null;
|
||||
if(typeof req.body._id !== 'undefined' || typeof req.body.id !== 'undefined'){
|
||||
return sendError(res, 500, -1, `User do not have the permission to modify id or _id`, token);
|
||||
} else{
|
||||
if(typeof req.body.role !== 'undefined' ||
|
||||
typeof req.body.isActive !== 'undefined' ||
|
||||
typeof req.body.lastConnexion !== 'undefined' ||
|
||||
typeof req.body.createdAt !== 'undefined'||
|
||||
typeof req.body.updatedAt !== 'undefined'){
|
||||
if(typeof token.role !== 'undefined' &&
|
||||
typeof token.role.permission !== 'undefined' &&
|
||||
typeof token.role.isAccepted !== 'undefined' &&
|
||||
token.role.isAccepted === true &&
|
||||
token.role.permission >= roles.Admin.permission) {
|
||||
update = true;
|
||||
} else{
|
||||
return sendError(res, 500, 106, `User do not have the permission to modify these keys.`, token);
|
||||
}
|
||||
} else{
|
||||
update = true;
|
||||
}
|
||||
}
|
||||
if(update === true){
|
||||
User.findByIdAndUpdate(id, req.body, {useFindAndModify: false})
|
||||
.then(data => {
|
||||
if(data) {
|
||||
data.hashPass = undefined;
|
||||
Object.keys(req.body).forEach(key => data[key] = req.body[key]);
|
||||
sendMessage(res, 7, data, token);
|
||||
} else {
|
||||
sendError(res, 404, -1, `User not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
sendError(res, 500, -1, err.message || `Some error occurred while updating the User with id=${id}`, token);
|
||||
});
|
||||
}
|
||||
} else {
|
||||
sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
// Delete a User with the specified id in the request
|
||||
exports.delete = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
let id = null;
|
||||
if(typeof token.id !== 'undefined' && token.id === req.params.id){
|
||||
id = req.params.id;
|
||||
} else {
|
||||
if(typeof token.role !== 'undefined' &&
|
||||
typeof token.role.permission !== 'undefined' &&
|
||||
typeof token.role.isAccepted !== 'undefined' &&
|
||||
token.role.isAccepted === true &&
|
||||
token.role.permission >= roles.Admin.permission) {
|
||||
id = req.params.id;
|
||||
} else {
|
||||
return sendError(res, 500, 106, `User do not have the permission.`, token);
|
||||
}
|
||||
}
|
||||
if(id && ObjectId.isValid(id)){
|
||||
User.findByIdAndUpdate(id, {isActive: false}, {useFindAndModify: false})
|
||||
.then(data => {
|
||||
if(data) {
|
||||
return sendMessage(res, 8, {message: `User ${id} was successfully deleted.`}, token);
|
||||
} else {
|
||||
return sendError(res, 404, 105, `User not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, 100, err.message || `Some error occurred while deleting the User with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Delete all Users from the database except superAdmin
|
||||
exports.deleteAll = (req, res) => {
|
||||
const token = checkLogin(req, res, roles.SuperAdmin);
|
||||
if(token) {
|
||||
User.deleteMany({login: {$ne: "superAdmin"}})
|
||||
.then(data => {
|
||||
return sendMessage(res, 9, {
|
||||
message: `${data.deletedCount} Users were deleted successfully.`
|
||||
});
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, 100, err.message || "Some error occurred while removing all Users.");
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
// Get all Roles depending on the role of the User
|
||||
exports.roles = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token){
|
||||
return sendMessage(res, 10, roles, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Get 1 or multiple ad adapted to the User session id
|
||||
exports.ad = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.query.quantity !== 'undefined'){
|
||||
const id = token.id;
|
||||
const quantity = req.query.quantity;
|
||||
// Interests from the user and from last 20 videos viewed if no ad matches -> find x ad from these interests + add date view to the ad
|
||||
let interests = [];
|
||||
const maxInterests = 20;
|
||||
let limit = maxInterests;
|
||||
User.findById(id, {_id: false, interests: true})
|
||||
.then(data => {
|
||||
if(typeof data.interests !== 'undefined' && data.interests !== null){
|
||||
interests = interests.concat(data.interests);
|
||||
limit = maxInterests-data.interests.length;
|
||||
}
|
||||
Video.aggregate([
|
||||
{$match: {userId: id}},
|
||||
{$project: {_id: false, interest: true}},
|
||||
{$sort: {watchedDates: -1}},
|
||||
{$limit: limit},
|
||||
{$unwind: '$interest'},
|
||||
{$group: {_id: null, interests: {$push: '$interest'}}}
|
||||
])
|
||||
.then(data => {
|
||||
if(typeof data[0] !== 'undefined' &&
|
||||
typeof data[0].interests !== 'undefined' &&
|
||||
data[0].interests !== [] &&
|
||||
data[0].interests !== null){
|
||||
interests = interests.concat(data[0].interests);
|
||||
}
|
||||
let match, pick;
|
||||
if(interests.length > 0){
|
||||
match = {$match: {isVisible: true, isActive: true, interests: {$elemMatch: {interest: {$in: interests}}}}};
|
||||
pick = {$limit: parseInt(quantity, 10)}
|
||||
} else {
|
||||
match = {$match: {isVisible: true, isActive: true}};
|
||||
pick = {$sample: {size: parseInt(quantity, 10)}};
|
||||
}
|
||||
|
||||
Ad.aggregate([
|
||||
match,
|
||||
pick
|
||||
])
|
||||
.then(data => {
|
||||
if(data.length > 0){
|
||||
let ids = []
|
||||
for(const i in data){ids.push(data[i]._id);}
|
||||
Ad.updateMany({_id: {$in: ids}}, {$push: {views: [new Date()]}}, {timestamps: false})
|
||||
.then(dataUpdate => {
|
||||
if(dataUpdate && dataUpdate.modifiedCount > 0){
|
||||
return sendMessage(res, 11, data, token);
|
||||
} else {
|
||||
return sendError(res,500,101,`Some error occurred while updating ${quantity} ad(s) for the User.`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,101,err.message || `Some error occurred while updating ${quantity} ad(s) for the User.`, token);
|
||||
});
|
||||
} else {
|
||||
Ad.aggregate([{$match: {isVisible: true, isActive: true}}, {$sample: {size: parseInt(quantity, 10)}}])
|
||||
.then(data => {
|
||||
let ids = []
|
||||
for(const i in data){ids.push(data[i]._id);}
|
||||
Ad.updateMany({_id: {$in: ids}}, {$push: {views: [new Date()]}}, {timestamps: false})
|
||||
.then(dataUpdate => {
|
||||
if(dataUpdate && dataUpdate.modifiedCount > 0){
|
||||
return sendMessage(res, 11, data, token);
|
||||
} else {
|
||||
return sendError(res,500,101,`Some error occurred while updating ${quantity} ad(s) for the User.`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,101,err.message || `Some error occurred while updating ${quantity} ad(s) for the User.`, token);
|
||||
});
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,101,err.message || `Some error occurred while getting ${quantity} ad(s) for the User.`, token);
|
||||
});
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,101,err.message || `Some error occurred while getting ${quantity} ad(s) for the User.`, token);
|
||||
});
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,102,err.message || `Some error occurred while getting ${quantity} ad(s) for the User.`, token);
|
||||
});
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || `Some error occurred while getting ${quantity} ad(s) for the User.`, token);
|
||||
});
|
||||
} else {
|
||||
sendError(res, 500, -1, `No quantity given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Get History
|
||||
exports.history = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token){
|
||||
const id = token.id;
|
||||
|
||||
Video.aggregate([
|
||||
{$match: {userId: id, $expr: {$gt: [{$size: "$watchedDates"}, 0]}}},
|
||||
{$limit: 300},
|
||||
{$project: {
|
||||
videoId: true,
|
||||
source: true,
|
||||
tags: true,
|
||||
interest: true,
|
||||
views: {$size: '$watchedDates'},
|
||||
watchedDate: {$arrayElemAt: ["$watchedDates", -1]},
|
||||
createdAt: true,
|
||||
updatedAt: true
|
||||
}},
|
||||
{$sort: {watchedDate: -1}}])
|
||||
.then(async data => {
|
||||
let yt_results = [];
|
||||
let dm_results = [];
|
||||
let yt_videoIds = "";
|
||||
let dm_videoIds = "";
|
||||
|
||||
for(const i in data) {
|
||||
if(data[i].source === youtube.name) {
|
||||
yt_videoIds = yt_videoIds + data[i].videoId + ",";
|
||||
} else if (data[i].source === dailymotion.name) {
|
||||
dm_videoIds = dm_videoIds + data[i].videoId + ",";
|
||||
}
|
||||
}
|
||||
if(yt_videoIds !== ""){
|
||||
const uri = youtube.baseAPIUrl + '/videos' + '?part=snippet&part=statistics&id=' + yt_videoIds.slice(0, -1) + '&key=' + youtube.YOUTUBE_API_KEY;
|
||||
const dataVideos = await asyncRequest(uri, {});
|
||||
if (dataVideos.response.statusCode === 200 && dataVideos.body.items.length > 0) {
|
||||
yt_results = dataVideos.body.items;
|
||||
}
|
||||
}
|
||||
|
||||
if(dm_videoIds !== ""){
|
||||
const uri = dailymotion.baseAPIUrl + '/videos?ids='+dm_videoIds.slice(0, -1)+'&fields=thumbnail_480_url%2Ctitle%2Cid';
|
||||
const data = await asyncRequest(uri, {});
|
||||
const response = data.response;
|
||||
const jsonBody = data.body;
|
||||
if(response.statusCode === 200){
|
||||
dm_results = jsonBody.list;
|
||||
}
|
||||
}
|
||||
for(const i in data) {
|
||||
if(data[i].source === youtube.name) {
|
||||
const obj = yt_results.filter(obj => obj.id === data[i].videoId);
|
||||
data[i].imageUrl = obj[0].snippet.thumbnails.medium.url ? obj[0].snippet.thumbnails.medium.url : null;
|
||||
data[i].title = obj[0].snippet.title ? obj[0].snippet.title : null;
|
||||
} else if (data[i].source === dailymotion.name) {
|
||||
const obj = dm_results.filter(obj => obj.id === data[i].videoId);
|
||||
data[i].imageUrl = obj[0].thumbnail_480_url ? obj[0].thumbnail_480_url : null;
|
||||
data[i].title = obj[0].title ? obj[0].title : null;
|
||||
}
|
||||
}
|
||||
return sendMessage(res, 12, data, token)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || "Some error occurred while getting the User history.", token);
|
||||
});
|
||||
}
|
||||
};
|
||||
474
controllers/video.controller.js
Normal file
474
controllers/video.controller.js
Normal file
|
|
@ -0,0 +1,474 @@
|
|||
const db = require("../models/mongodb.model");
|
||||
const request = require('request');
|
||||
const {sendError, sendMessage} = require ("../config/response.config");
|
||||
const {checkLogin} = require("../config/sessionJWT.config");
|
||||
const {youtube, dailymotion} = require("../config/host.config");
|
||||
const {asyncRequest, asyncInterest} = require("../config/functions.config");
|
||||
const ObjectId = require('mongoose').Types.ObjectId;
|
||||
const Video = db.videos;
|
||||
|
||||
|
||||
// Search Videos
|
||||
exports.search = async (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.query.q !== 'undefined'){
|
||||
const query = req.query.q;
|
||||
const maxResults = req.query.maxResults ? req.query.maxResults : 45;
|
||||
const pageToken = req.query.pageToken ? req.query.pageToken : undefined;
|
||||
let sources;
|
||||
if(typeof req.query.sources !== 'undefined' && req.query.sources !== ''){
|
||||
sources = req.query.sources.split(',');
|
||||
} else {
|
||||
sources = ["yt", "dm"];
|
||||
}
|
||||
let yt_results = [];
|
||||
let dm_results = [];
|
||||
for(const i in sources){
|
||||
if(sources[i] === youtube.shortname){
|
||||
if(youtube.YOUTUBE_API_KEY !== 'undefined' && youtube.YOUTUBE_API_KEY !== ''){
|
||||
let uri;
|
||||
if(query !== ''){
|
||||
if(typeof pageToken !== 'undefined'){
|
||||
uri = youtube.baseAPIUrl+'/search'+'?part=snippet&maxResults='+maxResults+'&q='+query+'&pageToken='+pageToken+'&key='+youtube.YOUTUBE_API_KEY;
|
||||
} else{
|
||||
uri = youtube.baseAPIUrl+'/search'+'?part=snippet&maxResults='+maxResults+'&q='+query+'&key='+youtube.YOUTUBE_API_KEY;
|
||||
}
|
||||
const dataIds = await asyncRequest(uri, {});
|
||||
if(dataIds.response.statusCode === 200 && dataIds.body.items.length > 0){
|
||||
let yt_videoIds = "";
|
||||
dataIds.body.items.forEach(item => yt_videoIds = yt_videoIds+item.id.videoId+",");
|
||||
uri = youtube.baseAPIUrl+'/videos'+'?part=snippet&part=statistics&id='+yt_videoIds.slice(0, -1)+'&key='+youtube.YOUTUBE_API_KEY;
|
||||
const dataVideos = await asyncRequest(uri, {});
|
||||
if(dataVideos.response.statusCode === 200 && dataVideos.body.items.length > 0){
|
||||
yt_results = dataVideos.body.items;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
uri = youtube.baseAPIUrl+'/videos'+'?part=snippet&part=statistics&chart=mostPopular&maxResults='+maxResults+'&key='+youtube.YOUTUBE_API_KEY;
|
||||
const dataVideos = await asyncRequest(uri, {});
|
||||
if(dataVideos.response.statusCode === 200 && dataVideos.body.items.length > 0){
|
||||
yt_results = dataVideos.body.items;
|
||||
}
|
||||
}
|
||||
} else{
|
||||
return sendError(res, 500, -1, `Error Env Variable DAILYMOTION_API_KEY missing, please contact the admin.`, token);
|
||||
}
|
||||
} else if(sources[i] === dailymotion.shortname){
|
||||
if(dailymotion.DAILYMOTION_API_KEY !== 'undefined' && dailymotion.DAILYMOTION_API_KEY !== '') {
|
||||
let uri;
|
||||
if(query !== ''){
|
||||
uri = dailymotion.baseAPIUrl + '/videos?limit='+maxResults+'&search='+query+'&fields=created_time%2Cdescription%2Cthumbnail_480_url%2Clikes_total%2Ctitle%2Cid%2Cembed_url%2Cviews_total%2Cowner.username%2Cowner.id%2Cchannel.name';
|
||||
} else {
|
||||
uri = dailymotion.baseAPIUrl + '/videos?limit='+maxResults+'&sort=trending&fields=created_time%2Cdescription%2Cthumbnail_480_url%2Clikes_total%2Ctitle%2Cid%2Cembed_url%2Cviews_total%2Cowner.username%2Cowner.id%2Cchannel.name';
|
||||
}
|
||||
const data = await asyncRequest(uri, {});
|
||||
const response = data.response;
|
||||
const jsonBody = data.body;
|
||||
if(response.statusCode === 200){
|
||||
dm_results = jsonBody.list;
|
||||
}
|
||||
} else{
|
||||
return sendError(res, 500, -1, `Error Env Variable DAILYMOTION_API_KEY missing, please contact the admin.`, token);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
let results = [];
|
||||
for(let i = 0; i < Math.max(dm_results.length, yt_results.length); i++){
|
||||
|
||||
// Youtube
|
||||
if(yt_results.length > i){
|
||||
const yt_data = {
|
||||
videoId: yt_results[i].id,
|
||||
source: youtube.name,
|
||||
imageUrl: yt_results[i].snippet.thumbnails.medium.url ? yt_results[i].snippet.thumbnails.medium.url : null,
|
||||
title: yt_results[i].snippet.title ? yt_results[i].snippet.title : null,
|
||||
channelTitle: yt_results[i].snippet.channelTitle ? yt_results[i].snippet.channelTitle : null,
|
||||
channelUrl: youtube.baseChannelUrl+yt_results[i].snippet.channelId ? yt_results[i].snippet.channelId : null,
|
||||
description: yt_results[i].snippet.description ? yt_results[i].snippet.description : null,
|
||||
embedUrl: 'https://www.youtube.com/embed/'+yt_results[i].id,
|
||||
interest: await asyncInterest(yt_results[i].snippet.categoryId, youtube.name),
|
||||
views: yt_results[i].statistics.viewCount ? parseInt(yt_results[i].statistics.viewCount) : null,
|
||||
likes: yt_results[i].statistics.likeCount ? parseInt(yt_results[i].statistics.likeCount) : null,
|
||||
dislikes: yt_results[i].statistics.dislikeCount ? parseInt(yt_results[i].statistics.dislikeCount) : null,
|
||||
publishedAt: yt_results[i].snippet.publishedAt ? yt_results[i].snippet.publishedAt : null
|
||||
};
|
||||
results.push(yt_data);
|
||||
}
|
||||
|
||||
// Dailymotion
|
||||
if(dm_results.length > i) {
|
||||
const channelTitle = dm_results[i]['owner.username'] ? dm_results[i]['owner.username'] : null;
|
||||
const dm_data = {
|
||||
videoId: dm_results[i].id ? dm_results[i].id : null,
|
||||
source: dailymotion.name,
|
||||
imageUrl: dm_results[i].thumbnail_480_url ? dm_results[i].thumbnail_480_url : null,
|
||||
title: dm_results[i].title ? dm_results[i].title : null,
|
||||
channelTitle: channelTitle.charAt(0).toUpperCase() + channelTitle.slice(1),
|
||||
channelUrl: dailymotion.baseChannelUrl + channelTitle,
|
||||
description: dm_results[i].description ? dm_results[i].description : null,
|
||||
embedUrl: dm_results[i].embed_url ? dm_results[i].embed_url : null,
|
||||
interest: await asyncInterest(dm_results[i]['channel.name'], dailymotion.name),
|
||||
views: dm_results[i].views_total ? parseInt(dm_results[i].views_total) : null,
|
||||
likes: dm_results[i].likes_total ? parseInt(dm_results[i].likes_total) : null,
|
||||
dislikes: null,
|
||||
publishedAt: dm_results[i].created_time ? new Date(dm_results[i].created_time * 1000) : null
|
||||
};
|
||||
results.push(dm_data);
|
||||
}
|
||||
}
|
||||
return sendMessage(res, 31, results, token);
|
||||
} else{
|
||||
return sendError(res, 500, -1, `No q given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Get Video with id of source
|
||||
exports.get = (req, res) => {
|
||||
if(typeof req.query.source !== 'undefined' && typeof req.params.id !== 'undefined'){
|
||||
const source = req.query.source;
|
||||
const id = req.params.id;
|
||||
if(source === youtube.shortname){
|
||||
if(youtube.YOUTUBE_API_KEY !== 'undefined' && youtube.YOUTUBE_API_KEY !== ''){
|
||||
const uri = youtube.baseAPIUrl+'/videos'+'?part=snippet&part=statistics&id='+id+'&key='+youtube.YOUTUBE_API_KEY;
|
||||
request(uri,{},async function (error, response, body){
|
||||
if(typeof body !== 'undefined'){
|
||||
const jsonBody = JSON.parse(body);
|
||||
if(jsonBody.items.length !== 0 &&
|
||||
typeof jsonBody.items[0] !== 'undefined' &&
|
||||
typeof jsonBody.items[0].id !== 'undefined' &&
|
||||
jsonBody.items[0].id === id){
|
||||
const imageUrl = jsonBody.items[0].snippet.thumbnails.standard.url ? jsonBody.items[0].snippet.thumbnails.standard.url : null;
|
||||
const title = jsonBody.items[0].snippet.title ? jsonBody.items[0].snippet.title : null;
|
||||
const channelId = jsonBody.items[0].snippet.channelId ? jsonBody.items[0].snippet.channelId : null;
|
||||
const channelTitle = jsonBody.items[0].snippet.channelTitle ? jsonBody.items[0].snippet.channelTitle : null;
|
||||
const description = jsonBody.items[0].snippet.description ? jsonBody.items[0].snippet.description : null;
|
||||
//const embedUrl = jsonBody.embed_url ? jsonBody.embed_url : null;
|
||||
const publishedAt = jsonBody.items[0].snippet.publishedAt ? jsonBody.items[0].snippet.publishedAt : null;
|
||||
const interest = jsonBody.items[0].snippet.categoryId ? await asyncInterest(jsonBody.items[0].snippet.categoryId, youtube.name): null;
|
||||
const views = jsonBody.items[0].statistics.viewCount ? parseInt(jsonBody.items[0].statistics.viewCount) : null;
|
||||
const likes = jsonBody.items[0].statistics.likeCount ? parseInt(jsonBody.items[0].statistics.likeCount) : null;
|
||||
const dislikes = jsonBody.items[0].statistics.dislikeCount ? parseInt(jsonBody.items[0].statistics.dislikeCount) : null;
|
||||
const data = {
|
||||
videoId: id,
|
||||
source: youtube.name,
|
||||
imageUrl: imageUrl,
|
||||
title: title,
|
||||
channelTitle: channelTitle,
|
||||
channelUrl: youtube.baseChannelUrl+channelId,
|
||||
description: description,
|
||||
embedUrl: 'https://www.youtube.com/embed/'+id,
|
||||
interest: interest,
|
||||
views: views,
|
||||
likes: likes,
|
||||
dislikes: dislikes,
|
||||
publishedAt: publishedAt
|
||||
};
|
||||
return sendMessage(res, 32, data);
|
||||
} else{
|
||||
return sendError(res, 404, -1, `No result`);
|
||||
}
|
||||
} else{
|
||||
return sendError(res, 500, -1, error);
|
||||
}
|
||||
});
|
||||
} else{
|
||||
return sendError(res, 500, -1, `Error Env Variable YOUTUBE_API_KEY missing, please contact the admin.`);
|
||||
}
|
||||
} else if(source === dailymotion.shortname){
|
||||
if(dailymotion.DAILYMOTION_API_KEY !== 'undefined' && dailymotion.DAILYMOTION_API_KEY !== ''){
|
||||
const uri = dailymotion.baseAPIUrl+'/video/'+id+'?fields=created_time%2Cdescription%2Cthumbnail_480_url%2Clikes_total%2Ctitle%2Cid%2Cembed_url%2Cviews_total%2Cowner.username%2Cowner.id%2Cchannel.name';
|
||||
request(uri,{},async function (error, response, body) {
|
||||
if (typeof body !== 'undefined') {
|
||||
const jsonBody = JSON.parse(body);
|
||||
if(response.statusCode === 200 &&
|
||||
typeof jsonBody.id !== 'undefined' &&
|
||||
jsonBody.id === id){
|
||||
const imageUrl = jsonBody.thumbnail_480_url ? jsonBody.thumbnail_480_url : null;
|
||||
const title = jsonBody.title ? jsonBody.title : null;
|
||||
//const channelId = jsonBody['owner.id'] ? jsonBody['owner.id'] : null;
|
||||
const channelTitle = jsonBody['owner.username'] ? jsonBody['owner.username'] : null;
|
||||
const description = jsonBody.description ? jsonBody.description : null;
|
||||
const embedUrl = jsonBody.embed_url ? jsonBody.embed_url : null;
|
||||
const publishedAt = jsonBody.created_time ? new Date(jsonBody.created_time * 1000) : null;
|
||||
const interest = jsonBody['channel.name'] ? await asyncInterest(jsonBody['channel.name'], dailymotion.name) : null;
|
||||
const views = jsonBody.views_total ? parseInt(jsonBody.views_total) : null;
|
||||
const likes = jsonBody.likes_total ? parseInt(jsonBody.likes_total) : null;
|
||||
const dislikes = null;
|
||||
const data = {
|
||||
videoId: id,
|
||||
source: dailymotion.name,
|
||||
imageUrl: imageUrl,
|
||||
title: title,
|
||||
channelTitle: channelTitle.charAt(0).toUpperCase() + channelTitle.slice(1),
|
||||
channelUrl: dailymotion.baseChannelUrl+channelTitle,
|
||||
description: description,
|
||||
embedUrl: embedUrl,
|
||||
interest: interest,
|
||||
views: views,
|
||||
likes: likes,
|
||||
dislikes: dislikes,
|
||||
publishedAt: publishedAt
|
||||
};
|
||||
return sendMessage(res, 32, data);
|
||||
} else{
|
||||
return sendError(res, 404, -1, jsonBody.error.message);
|
||||
}
|
||||
}
|
||||
});
|
||||
} else{
|
||||
return sendError(res, 500, -1, `Error Env Variable DAILYMOTION_API_KEY missing, please contact the admin.`);
|
||||
}
|
||||
} else{
|
||||
return sendError(res, 500, -1, `Wrong source name`);
|
||||
}
|
||||
} else{
|
||||
return sendError(res, 500, -1, `No source or/and id given`);
|
||||
}
|
||||
};
|
||||
|
||||
// Create a new Video
|
||||
exports.create = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token &&
|
||||
typeof req.body.source !== 'undefined' &&
|
||||
typeof req.body.interest !== 'undefined' &&
|
||||
typeof req.params.id !== 'undefined'){
|
||||
const id = req.params.id;
|
||||
Video.exists({userId: token.id, videoId: id, source: req.body.source, isActive: true}, function (err, docs){
|
||||
if(err){
|
||||
sendError(res, 500,100,err.message || "Some error occurred while checking if the Video already exists.", token);
|
||||
} else{
|
||||
if(docs === null) {
|
||||
let video;
|
||||
|
||||
video = new Video({
|
||||
userId: token.id,
|
||||
videoId: id,
|
||||
source: req.body.source,
|
||||
interest: req.body.interest,
|
||||
watchedDates: [new Date()]
|
||||
});
|
||||
|
||||
// Save Video in the database
|
||||
video
|
||||
.save(video)
|
||||
.then(data => {
|
||||
return sendMessage(res, 33, data, token)
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500,100,err.message || "Some error occurred while creating the Video.", token);
|
||||
});
|
||||
} else{
|
||||
const id = docs._id.toString();
|
||||
Video.findByIdAndUpdate(id, {$push: {watchedDates: [new Date()]}}, {useFindAndModify: false, new: true})
|
||||
.then(data => {
|
||||
if(data) {
|
||||
return sendMessage(res, 33, data, token);
|
||||
} else {
|
||||
return sendError(res, 404, 105, `Video not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, 100, err.message || `Some error occurred while updating the Video with id=${id}`, token);
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No source or interest or id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Retrieve all Videos
|
||||
exports.findAll = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token){
|
||||
let query = {};
|
||||
let condition;
|
||||
|
||||
const userId = req.query.userId;
|
||||
condition = userId ? userId : undefined;
|
||||
query.userId = condition;
|
||||
|
||||
const videoId = req.query.videoId;
|
||||
condition = videoId ? videoId : undefined;
|
||||
query.videoId = condition;
|
||||
|
||||
const source = req.query.source;
|
||||
condition = source ? source : undefined;
|
||||
query.source = condition;
|
||||
|
||||
const interests = req.query.interests;
|
||||
condition = interests ? {$in: interests} : undefined;
|
||||
query["interests.interest"] = condition
|
||||
|
||||
const isActive = req.query.isActive;
|
||||
condition = isActive ? isActive : undefined;
|
||||
query.isActive = condition;
|
||||
|
||||
const sort = req.query.sort;
|
||||
if(sort !== 'undefined'){
|
||||
switch (sort){
|
||||
case 'asc':
|
||||
condition = {videoId: 1};
|
||||
break;
|
||||
case 'desc':
|
||||
condition = {videoId: -1};
|
||||
break;
|
||||
case 'createdAtAsc':
|
||||
condition = {createdAt: 1};
|
||||
break;
|
||||
case 'createdAtDesc':
|
||||
condition = {createdAt: -1};
|
||||
break;
|
||||
case 'updatedAtAsc':
|
||||
condition = {updatedAt: 1};
|
||||
break;
|
||||
case 'updatedAtDesc':
|
||||
condition = {updatedAt: -1};
|
||||
break;
|
||||
default:
|
||||
condition = {createdAt: -1};
|
||||
}
|
||||
}
|
||||
const query_sort = {sort: condition};
|
||||
|
||||
// Remove undefined key
|
||||
Object.keys(query).forEach(key => query[key] === undefined ? delete query[key] : {});
|
||||
console.log(query);
|
||||
|
||||
Video.find(query, {}, query_sort)
|
||||
.then(data => {
|
||||
return sendMessage(res, 34, data, token);
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || "Some error occurred while finding the Videos.", token);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
// Find single Video with id
|
||||
exports.findOne = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(id && ObjectId.isValid(id)){
|
||||
Video.findById(id, {})
|
||||
.then(data => {
|
||||
if(data){
|
||||
return sendMessage(res, 35, data, token);
|
||||
} else {
|
||||
return sendError(res,404,105,`Video not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res,500,100,err.message || `Some error occurred while finding the Video with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Update Video with id
|
||||
exports.update = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(typeof req.body._id !== 'undefined' || typeof req.body.id !== 'undefined'){
|
||||
return sendError(res, 500, -1, `User do not have the permission to modify id or _id`, token);
|
||||
} else{
|
||||
let update = {};
|
||||
let condition;
|
||||
|
||||
const watchedDate = req.body.watchedDate;
|
||||
if(typeof watchedDate !== 'undefined'){
|
||||
if(watchedDate){
|
||||
condition = {watchedDates: [new Date()]}
|
||||
} else {
|
||||
condition = undefined;
|
||||
}
|
||||
} else{
|
||||
condition = undefined;
|
||||
}
|
||||
update.$push = condition;
|
||||
|
||||
const watchedDates = req.body.watchedDates;
|
||||
condition = watchedDates ? watchedDates : undefined;
|
||||
update.watchedDates = condition;
|
||||
|
||||
const isActive = req.body.isActive;
|
||||
if(typeof isActive !== 'undefined'){
|
||||
condition = isActive;
|
||||
} else{
|
||||
condition = undefined;
|
||||
}
|
||||
update.isActive = condition;
|
||||
|
||||
// Remove undefined key
|
||||
Object.keys(update).forEach(key => update[key] === undefined ? delete update[key] : {});
|
||||
|
||||
if(id && ObjectId.isValid(id)){
|
||||
Video.updateOne({_id: id, userId: token.id, isActive: true}, update)
|
||||
.then(data => {
|
||||
if(data) {
|
||||
return sendMessage(res, 36, update, token);
|
||||
} else {
|
||||
return sendError(res, 404, -1, `Video not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, -1, err.message || `Some error occurred while updating the Video with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Delete Video with id
|
||||
exports.delete = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token && typeof req.params.id !== 'undefined') {
|
||||
const id = req.params.id;
|
||||
if(id && ObjectId.isValid(id)){
|
||||
Video.updateOne({_id: id, userId: token.id, isActive: true}, {isActive: false}, {useFindAndModify: false})
|
||||
.then(data => {
|
||||
if(data.modifiedCount > 0) {
|
||||
return sendMessage(res, 37, {message: `Video ${id} was successfully deleted.`}, token);
|
||||
} else {
|
||||
return sendError(res, 404, 105, `Video not found with id=${id}`, token);
|
||||
}
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, 100, err.message || `Some error occurred while deleting the Video with id=${id}`, token);
|
||||
});
|
||||
} else {
|
||||
return sendError(res, 500, -1, `Error id is not valid`, token);
|
||||
}
|
||||
} else {
|
||||
return sendError(res, 500, -1, `No id given`, token);
|
||||
}
|
||||
};
|
||||
|
||||
// Delete all Videos
|
||||
exports.deleteAll = (req, res) => {
|
||||
const token = checkLogin(req, res);
|
||||
if(token) {
|
||||
Video.updateMany({userId: {$eq: token.id}, isActive: true}, {isActive: false})
|
||||
.then(data => {
|
||||
return sendMessage(res, 38, {
|
||||
message: `${data.modifiedCount} Videos were deleted successfully.`,
|
||||
});
|
||||
})
|
||||
.catch(err => {
|
||||
return sendError(res, 500, 100, err.message || "Some error occurred while removing all Videos.");
|
||||
});
|
||||
}
|
||||
};
|
||||
Reference in a new issue