obs-portal/routes/api/tracks.js

566 lines
15 KiB
JavaScript
Raw Normal View History

var router = require('express').Router();
var mongoose = require('mongoose');
2020-08-14 10:37:34 +00:00
var TrackData = mongoose.model('TrackData');
var Track = mongoose.model('Track');
var Comment = mongoose.model('Comment');
var User = mongoose.model('User');
var auth = require('../auth');
2020-07-03 11:50:07 +00:00
var currentTracks = new Map();
2020-08-14 20:15:12 +00:00
class trackInfo {
constructor (track,trackData)
{
this.track = track;
this.trackData = trackData;
}
}
2020-07-03 11:50:07 +00:00
2020-08-14 20:15:12 +00:00
function addPointsToTrack(track,body)
2020-07-03 11:50:07 +00:00
{
var num = 0;
var start = 0;
var end = 0;
2020-08-15 22:27:11 +00:00
//console.log("len"+body.length);
2020-08-14 10:37:34 +00:00
while (end < body.length) {
2020-07-03 11:50:07 +00:00
start = end;
2020-08-14 10:37:34 +00:00
while (body[end] != ";" && body[end] != "$" && end < body.length) {
2020-07-03 11:50:07 +00:00
end++;
}
2020-08-14 10:37:34 +00:00
if(body[end] == "$") // $ is replacing \n as newlines are not allowed in json strings
2020-07-03 23:27:47 +00:00
{
num=0;
}
2020-08-14 10:37:34 +00:00
if(end < body.length)
2020-07-03 23:27:47 +00:00
{
2020-08-14 10:37:34 +00:00
var token = body.substr(start, end - start);
2020-07-03 23:27:47 +00:00
end++;
if(token.length>0)
{
2020-07-03 11:50:07 +00:00
//console.log(token);
//console.log("num:"+num);
//console.log("end:"+end);
2020-08-14 20:15:12 +00:00
if((num == 0) && (token == "Date"))
{
// we have a header line, ignore it for now, TODO parse it
if (end < body.length) {
while (body[end] != ";" && body[end] != "$" && end < body.length) {
end++;
}
start = end;
num=100;
}
2020-07-03 11:50:07 +00:00
}
if (num == 0) {
2020-08-14 20:15:12 +00:00
track.trackData.points.push({ date: "dummy", time: "", latitude: "", longitude: "", course: "", speed: "", d1: "", d2: "", flag: "", private: ""});
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].date = token;
2020-07-03 11:50:07 +00:00
num++;
}
else if (num == 1) {
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].time = token;
2020-07-03 11:50:07 +00:00
num++;
}
else if (num == 2) {
2020-07-03 23:27:47 +00:00
var f = parseFloat(token);
if(isNaN(f))
{
f = parseFloat(token.substring(0,10));
}
2020-09-08 08:33:19 +00:00
if(isNaN(f))
{
f=0.0;
}
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].latitude = f;
2020-07-03 11:50:07 +00:00
num++;
}
else if (num == 3) {
2020-07-03 23:27:47 +00:00
var f = parseFloat(token);
if(isNaN(f))
{
f = parseFloat(token.substring(0,10));
}
2020-09-08 08:33:19 +00:00
if(isNaN(f))
{
f=0.0;
}
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].longitude = f;
2020-07-03 11:50:07 +00:00
num++;
}
else if (num == 4) {
2020-07-25 20:45:34 +00:00
var f = parseFloat(token);
if(isNaN(f))
{
f = parseFloat(token.substring(0,10));
}
2020-09-08 08:33:19 +00:00
if(isNaN(f))
{
f=0.0;
}
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].course = f;
2020-07-03 11:50:07 +00:00
num++;
}
else if (num == 5) {
2020-07-25 20:45:34 +00:00
var f = parseFloat(token);
if(isNaN(f))
{
f = parseFloat(token.substring(0,10));
}
2020-09-08 08:33:19 +00:00
if(isNaN(f))
{
f=0.0;
}
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].speed = f;
2020-07-03 11:50:07 +00:00
num++;
}
else if (num == 6) {
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].d1 = token;
2020-07-25 20:45:34 +00:00
num++;
}
else if (num == 7) {
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].d2 = token;
2020-07-25 20:45:34 +00:00
num++;
}
else if (num == 8) {
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].flag = token;
2020-07-03 23:27:47 +00:00
num++;
}
2020-07-25 20:45:34 +00:00
else if (num == 9) {
2020-08-14 10:37:34 +00:00
track.trackData.points[track.trackData.points.length - 1].private = token;
2020-07-25 20:45:34 +00:00
num++;
}
2020-07-03 23:27:47 +00:00
}
2020-07-03 11:50:07 +00:00
}
}
}
// Preload track objects on routes with ':track'
router.param('track', function(req, res, next, slug) {
Track.findOne({ slug: slug})
.populate('author')
.then(function (track) {
if (!track) { return res.sendStatus(404); }
req.track = track;
return next();
}).catch(next);
});
router.param('comment', function(req, res, next, id) {
Comment.findById(id).then(function(comment){
if(!comment) { return res.sendStatus(404); }
req.comment = comment;
return next();
}).catch(next);
});
router.get('/', auth.optional, function(req, res, next) {
var query = {};
var limit = 20;
var offset = 0;
if(typeof req.query.limit !== 'undefined'){
limit = req.query.limit;
}
if(typeof req.query.offset !== 'undefined'){
offset = req.query.offset;
}
if( typeof req.query.tag !== 'undefined' ){
query.tagList = {"$in" : [req.query.tag]};
}
Promise.all([
req.query.author ? User.findOne({username: req.query.author}) : null,
req.query.favorited ? User.findOne({username: req.query.favorited}) : null
]).then(function(results){
var author = results[0];
var favoriter = results[1];
if(author){
query.author = author._id;
}
if(favoriter){
query._id = {$in: favoriter.favorites};
} else if(req.query.favorited){
query._id = {$in: []};
}
return Promise.all([
Track.find(query)
.limit(Number(limit))
.skip(Number(offset))
.sort({createdAt: 'desc'})
.populate('author')
2020-08-28 19:50:53 +00:00
.where('visible').equals(true)
.exec(),
2020-07-03 23:27:47 +00:00
Track.countDocuments(query).exec(),
req.payload ? User.findById(req.payload.id) : null,
]).then(function(results){
var tracks = results[0];
var tracksCount = results[1];
var user = results[2];
2020-08-15 22:27:11 +00:00
//console.log(tracks);
2020-08-16 21:23:18 +00:00
var retTracks = [];
for (t of tracks) {
2020-08-28 19:50:53 +00:00
//console.log(t);
//if (t.author.areTracksVisibleForAll || t.author == user) {
2020-08-16 21:23:18 +00:00
retTracks.push(t);
2020-08-28 19:50:53 +00:00
//}
2020-08-16 21:23:18 +00:00
}
return res.json({
2020-08-16 21:23:18 +00:00
tracks: retTracks.map(function(track){
return track.toJSONFor(user);
}),
2020-08-16 21:23:18 +00:00
tracksCount: retTracks.length
});
});
}).catch(next);
});
router.get('/feed', auth.required, function(req, res, next) {
var limit = 20;
var offset = 0;
if(typeof req.query.limit !== 'undefined'){
limit = req.query.limit;
}
if(typeof req.query.offset !== 'undefined'){
offset = req.query.offset;
}
User.findById(req.payload.id).then(function(user){
if (!user) { return res.sendStatus(401); }
if(user.following != '')
{
Promise.all([
Track.find({ author: {$in: user.following}})
.limit(Number(limit))
.skip(Number(offset))
.populate('author')
.exec(),
2020-07-03 23:27:47 +00:00
Track.countDocuments({ author: {$in: user.following}})
]).then(function(results){
var tracks = results[0];
var tracksCount = results[1];
return res.json({
tracks: tracks.map(function(track){
return track.toJSONFor(user);
}),
tracksCount: tracksCount
});
}).catch(next);
}
else
{
Promise.all([
Track.find({ author: {$in: req.payload.id}})
.limit(Number(limit))
.skip(Number(offset))
.populate('author')
.exec(),
2020-07-03 23:27:47 +00:00
Track.countDocuments({ author: {$in: req.payload.id}})
]).then(function(results){
var tracks = results[0];
var tracksCount = results[1];
return res.json({
tracks: tracks.map(function(track){
return track.toJSONFor(user);
}),
tracksCount: tracksCount
});
}).catch(next);
}
});
});
router.post('/', auth.required, function(req, res, next) {
User.findById(req.payload.id).then(function(user){
if (!user) { return res.sendStatus(401); }
var track = new Track(req.body.track);
2020-08-14 20:15:12 +00:00
var trackData = new TrackData();
track.trackData = trackData._id;
track.author = user;
2020-08-28 19:50:53 +00:00
track.visible = track.author.areTracksVisibleForAll;
2020-08-14 20:15:12 +00:00
trackData.save(function (err){
2020-08-14 10:37:34 +00:00
if(err){
console.log("failed to save trackData");
}
});
return track.save().then(function(){
2020-08-15 22:27:11 +00:00
//console.log(track.author);
return res.json({track: track.toJSONFor(user)});
});
2020-08-14 10:37:34 +00:00
return res.json({track: track.toJSONFor(user)});
}).catch(next);
});
router.post('/add', auth.optional, function(req, res, next) {
2020-08-15 22:27:11 +00:00
//console.log("Add");
2020-07-03 11:50:07 +00:00
//console.log(req.payload);
User.findById(req.body.id).then(function (user) {
if (!user) { return res.sendStatus(401); }
2020-08-14 20:15:12 +00:00
var ti = null;
2020-07-03 11:50:07 +00:00
if (currentTracks.has(req.body.id))
2020-08-14 20:15:12 +00:00
ti = currentTracks.get(req.body.id);
2020-08-15 22:27:11 +00:00
//console.log("TI" + ti);
//console.log("TILen" + ti.trackData.points.length);
//console.log("TITrack" + ti.track);
//console.log("Body" + req.body.track.body);
2020-08-14 20:15:12 +00:00
if (ti.track) {
2020-08-15 22:27:11 +00:00
addPointsToTrack(ti, req.body.track.body);
//console.log("TLen" + ti.trackData.points.length);
ti.track.author = user;
2020-07-03 11:50:07 +00:00
}
//return track.save().then(function(){
// console.log(track.author);
2020-07-03 23:27:47 +00:00
//return res.json({ track: track.toJSONFor(user) });
return res.sendStatus(200);
2020-07-03 11:50:07 +00:00
//});
}).catch(next);
});
router.post('/begin', auth.optional, function (req, res, next) {
2020-08-15 22:27:11 +00:00
//console.log("Begin");
2020-07-03 11:50:07 +00:00
//console.log(req.payload);
User.findById(req.body.id).then(function (user) {
if (!user) { return res.sendStatus(401); }
2020-07-03 11:50:07 +00:00
if(currentTracks.has(req.body.id))
currentTracks.delete(req.body.id); // delete old parts if there are leftovers
2020-08-14 20:15:12 +00:00
var ti = new trackInfo(new Track(req.body.track),new TrackData());
ti.track.trackData = ti.trackData._id;
currentTracks.set(req.body.id, ti);
2020-04-14 01:05:07 +00:00
2020-08-15 22:27:11 +00:00
//console.log("addToTrack"+req.body);
2020-08-14 10:37:34 +00:00
2020-08-14 20:15:12 +00:00
addPointsToTrack(ti, ti.track.body);
2020-07-03 11:50:07 +00:00
2020-08-15 22:27:11 +00:00
//console.log("TLen" + ti.track);
//console.log("TLen" + ti.trackData);
//console.log("TLen" + ti.trackData.points.length);
2020-04-14 01:05:07 +00:00
2020-08-14 10:37:34 +00:00
//console.log(track.trackData.points[0].date);
2020-08-15 22:27:11 +00:00
ti.track.author = user;
2020-07-03 11:50:07 +00:00
//return track.save().then(function () {
// console.log(track.author);
2020-07-03 23:27:47 +00:00
return res.sendStatus(200);
2020-07-03 11:50:07 +00:00
//});
}).catch(next);
});
router.post('/end', auth.optional, function (req, res, next) {
2020-08-15 22:27:11 +00:00
//console.log("End");
2020-07-03 11:50:07 +00:00
//console.log(req.payload);
User.findById(req.body.id).then(function (user) {
if (!user) { return res.sendStatus(401); }
var track = null;
if (currentTracks.has(req.body.id))
2020-08-14 10:37:34 +00:00
{
2020-08-14 20:15:12 +00:00
ti = currentTracks.get(req.body.id);
2020-08-15 22:27:11 +00:00
addPointsToTrack(ti, req.body.track.body);
2020-08-14 10:37:34 +00:00
}
2020-07-03 23:27:47 +00:00
else
2020-08-14 10:37:34 +00:00
{
2020-08-14 20:15:12 +00:00
var ti = new trackInfo(new Track(req.body.track),new TrackData());
ti.track.trackData = ti.trackData._id;
addPointsToTrack(ti, ti.track.body);
2020-08-14 10:37:34 +00:00
}
2020-08-14 20:15:12 +00:00
if (ti.track) {
ti.track.author = user;
2020-07-03 11:50:07 +00:00
}
2020-07-03 23:27:47 +00:00
currentTracks.delete(req.body.id); // we are done with this track, it is complete
2020-08-14 20:15:12 +00:00
ti.track.author = user;
2020-07-03 11:50:07 +00:00
2020-07-03 23:27:47 +00:00
//console.log(track);
//console.log("user:"+user);
2020-08-14 20:15:12 +00:00
return ti.track.save().then(function () {
2020-08-15 22:27:11 +00:00
//console.log("TLen" + ti.track);
//console.log("TLen" + ti.trackData);
//console.log("TLen" + ti.trackData.points.length);
2020-08-14 20:15:12 +00:00
ti.trackData.save(function (err){
2020-08-14 10:37:34 +00:00
if(err){
2020-08-14 20:15:12 +00:00
console.log("failed to save trackData"+err.toString());
2020-08-14 10:37:34 +00:00
}
});
2020-07-03 23:27:47 +00:00
console.log("successfulSave:");
return res.sendStatus(200);
});
}).catch(next);
});
// return a track
router.get('/:track', auth.optional, function(req, res, next) {
Promise.all([
req.payload ? User.findById(req.payload.id) : null,
req.track.populate('author').execPopulate()
]).then(function(results){
var user = results[0];
return res.json({track: req.track.toJSONFor(user)});
}).catch(next);
});
// update track
router.put('/:track', auth.required, function(req, res, next) {
User.findById(req.payload.id).then(function(user){
if(req.track.author._id.toString() === req.payload.id.toString()){
if(typeof req.body.track.title !== 'undefined'){
req.track.title = req.body.track.title;
}
if(typeof req.body.track.description !== 'undefined'){
req.track.description = req.body.track.description;
}
if(typeof req.body.track.body !== 'undefined'){
req.track.body = req.body.track.body;
}
if(typeof req.body.track.tagList !== 'undefined'){
2020-08-28 19:50:53 +00:00
req.track.tagList = req.body.track.tagList;
}
2020-08-28 19:50:53 +00:00
req.track.visible = req.body.track.visible;
console.log("saving track");
2020-08-28 19:50:53 +00:00
req.track.save().then(function(track){
return res.json({track: track.toJSONFor(user)});
}).catch(next);
} else {
return res.sendStatus(403);
}
});
});
// delete track
router.delete('/:track', auth.required, function(req, res, next) {
User.findById(req.payload.id).then(function(user){
if (!user) { return res.sendStatus(401); }
if(req.track.author._id.toString() === req.payload.id.toString()){
2020-08-14 20:15:12 +00:00
TrackData.findByIdAndDelete(req.track.trackData, function (err, td) {console.log("doneDelete");}); // delet our track data
return req.track.remove().then(function(){
return res.sendStatus(204);
});
} else {
return res.sendStatus(403);
}
}).catch(next);
});
// Favorite an track
router.post('/:track/favorite', auth.required, function(req, res, next) {
var trackId = req.track._id;
User.findById(req.payload.id).then(function(user){
if (!user) { return res.sendStatus(401); }
return user.favorite(trackId).then(function(){
return req.track.updateFavoriteCount().then(function(track){
return res.json({track: track.toJSONFor(user)});
});
});
}).catch(next);
});
// Unfavorite an track
router.delete('/:track/favorite', auth.required, function(req, res, next) {
var trackId = req.track._id;
User.findById(req.payload.id).then(function (user){
if (!user) { return res.sendStatus(401); }
return user.unfavorite(trackId).then(function(){
return req.track.updateFavoriteCount().then(function(track){
return res.json({track: track.toJSONFor(user)});
});
});
}).catch(next);
});
// return an track's comments
router.get('/:track/comments', auth.optional, function(req, res, next){
Promise.resolve(req.payload ? User.findById(req.payload.id) : null).then(function(user){
return req.track.populate({
path: 'comments',
populate: {
path: 'author'
},
options: {
sort: {
createdAt: 'desc'
}
}
}).execPopulate().then(function(track) {
return res.json({comments: req.track.comments.map(function(comment){
return comment.toJSONFor(user);
})});
});
}).catch(next);
});
// create a new comment
router.post('/:track/comments', auth.required, function(req, res, next) {
User.findById(req.payload.id).then(function(user){
if(!user){ return res.sendStatus(401); }
var comment = new Comment(req.body.comment);
comment.track = req.track;
comment.author = user;
return comment.save().then(function(){
req.track.comments.push(comment);
return req.track.save().then(function(track) {
res.json({comment: comment.toJSONFor(user)});
});
});
}).catch(next);
});
router.delete('/:track/comments/:comment', auth.required, function(req, res, next) {
if(req.comment.author.toString() === req.payload.id.toString()){
req.track.comments.remove(req.comment._id);
req.track.save()
.then(Comment.find({_id: req.comment._id}).remove().exec())
.then(function(){
res.sendStatus(204);
});
} else {
res.sendStatus(403);
}
});
2020-08-14 20:15:12 +00:00
// return an track's trackData
router.get('/:track/TrackData', auth.optional, function(req, res, next){
Promise.resolve(req.payload ? User.findById(req.payload.id) : null).then(function(user){
2020-08-15 22:27:11 +00:00
//console.log("requestTrackData"+req.track);
2020-08-14 20:15:12 +00:00
TrackData.findById(req.track.trackData,function(err,trackData){
2020-08-15 22:27:11 +00:00
//console.log({trackData: trackData});
2020-08-14 20:15:12 +00:00
return res.json({trackData: trackData});
});
}).catch(next);
});
module.exports = router;