PeerTube/server/models/videos.js

162 lines
3.9 KiB
JavaScript
Raw Normal View History

'use strict'
const async = require('async')
2016-03-16 16:29:27 -05:00
const config = require('config')
const mongoose = require('mongoose')
2016-03-16 16:29:27 -05:00
const logger = require('../helpers/logger')
2016-03-16 16:29:27 -05:00
const http = config.get('webserver.https') === true ? 'https' : 'http'
const host = config.get('webserver.host')
const port = config.get('webserver.port')
// ---------------------------------------------------------------------------
2016-03-16 16:29:27 -05:00
const videosSchema = mongoose.Schema({
name: String,
namePath: String,
description: String,
magnetUri: String,
podUrl: String,
2016-05-03 15:41:46 -05:00
author: String,
duration: Number,
2016-05-13 13:42:11 -05:00
thumbnail: String,
2016-06-06 07:15:03 -05:00
tags: [ String ],
2016-05-13 13:42:11 -05:00
createdDate: {
type: Date,
default: Date.now
}
})
2016-03-16 16:29:27 -05:00
const VideosDB = mongoose.model('videos', videosSchema)
// ---------------------------------------------------------------------------
2016-03-16 16:29:27 -05:00
const Videos = {
add: add,
addRemotes: addRemotes,
get: get,
list: list,
listFromUrl: listFromUrl,
listFromUrls: listFromUrls,
listFromUrlAndMagnets: listFromUrlAndMagnets,
listFromRemotes: listFromRemotes,
listOwned: listOwned,
removeOwned: removeOwned,
removeByIds: removeByIds,
search: search
}
function add (video, callback) {
logger.info('Adding %s video to database.', video.name)
2016-03-16 16:29:27 -05:00
const params = video
params.podUrl = http + '://' + host + ':' + port
2016-05-13 13:42:11 -05:00
VideosDB.create(params, function (err, insertedVideo) {
if (err) {
logger.error('Cannot insert this video into database.')
return callback(err)
}
2016-05-13 13:42:11 -05:00
callback(null, insertedVideo)
2016-02-04 14:10:33 -06:00
})
}
2015-06-09 10:41:40 -05:00
function addRemotes (videos, callback) {
videos.forEach(function (video) {
// Ensure they are remote videos
video.namePath = null
})
VideosDB.create(videos, callback)
}
2016-01-31 04:23:52 -06:00
function get (id, callback) {
VideosDB.findById(id, function (err, video) {
if (err) {
logger.error('Cannot get this video.')
return callback(err)
}
2016-02-04 14:10:33 -06:00
return callback(null, video)
})
}
2016-02-04 14:10:33 -06:00
2016-05-17 14:03:00 -05:00
function list (start, count, sort, callback) {
const query = {}
return findWithCount(query, start, count, sort, callback)
}
2016-01-31 04:23:52 -06:00
function listFromUrl (fromUrl, callback) {
VideosDB.find({ podUrl: fromUrl }, callback)
}
function listFromUrls (fromUrls, callback) {
VideosDB.find({ podUrl: { $in: fromUrls } }, callback)
}
function listFromUrlAndMagnets (fromUrl, magnets, callback) {
VideosDB.find({ podUrl: fromUrl, magnetUri: { $in: magnets } }, callback)
}
function listFromRemotes (callback) {
VideosDB.find({ namePath: null }, callback)
}
function listOwned (callback) {
// If namePath is not null this is *our* video
VideosDB.find({ namePath: { $ne: null } }, function (err, videosList) {
if (err) {
logger.error('Cannot get the list of owned videos.')
return callback(err)
}
return callback(null, videosList)
})
}
// Return the video in the callback
function removeOwned (id, callback) {
VideosDB.findByIdAndRemove(id, callback)
}
// Use the magnet Uri because the _id field is not the same on different servers
function removeByIds (ids, callback) {
VideosDB.remove({ _id: { $in: ids } }, callback)
}
2015-06-09 10:41:40 -05:00
function search (value, field, start, count, sort, callback) {
const query = {}
// Make an exact search with the magnet
2016-06-06 07:54:52 -05:00
if (field === 'magnetUri' || field === 'tags') {
query[field] = value
} else {
query[field] = new RegExp(value)
}
findWithCount(query, start, count, sort, callback)
}
2015-06-09 10:41:40 -05:00
// ---------------------------------------------------------------------------
2016-01-31 04:23:52 -06:00
module.exports = Videos
// ---------------------------------------------------------------------------
function findWithCount (query, start, count, sort, callback) {
async.parallel([
function (asyncCallback) {
VideosDB.find(query).skip(start).limit(start + count).sort(sort).exec(asyncCallback)
},
function (asyncCallback) {
VideosDB.count(query, asyncCallback)
}
], function (err, results) {
if (err) return callback(err)
const videos = results[0]
const totalVideos = results[1]
return callback(null, videos, totalVideos)
})
}