mirror of
https://github.com/arnaucube/openEventsPlatformServer.git
synced 2026-02-06 19:26:39 +01:00
implemented add image to event, and sent it to the goImgServer
This commit is contained in:
@@ -3,7 +3,7 @@ module.exports = {
|
||||
'database': process.env.MONGO_DSN,*/
|
||||
'secret': 'secretfortoken',// local version
|
||||
'database': 'mongodb://localhost/openeventsplatform',
|
||||
"port" : process.env.PORT || 3000,
|
||||
"port" : process.env.PORT || 3001,
|
||||
"pageSize": 20
|
||||
|
||||
};
|
||||
|
||||
@@ -9,10 +9,10 @@ var eventModel = mongoose.model('eventModel');
|
||||
|
||||
var pageSize = config.pageSize;
|
||||
|
||||
var request = require('request');
|
||||
|
||||
exports.getCategoriesList = function(req, res) {
|
||||
var categoriesList=[
|
||||
{
|
||||
var categoriesList = [{
|
||||
name: "esport"
|
||||
},
|
||||
{
|
||||
@@ -35,8 +35,12 @@ exports.getCategoriesList = function(req, res) {
|
||||
};
|
||||
exports.getAllEvents = function(req, res) {
|
||||
eventModel.find({
|
||||
date: {$gte: new Date()},
|
||||
type: {$nin: ["alert"]}//cal filtrar per type d'event, aquí només agafem els type: alert
|
||||
date: {
|
||||
$gte: new Date()
|
||||
},
|
||||
type: {
|
||||
$nin: ["alert"]
|
||||
} //cal filtrar per type d'event, aquí només agafem els type: alert
|
||||
})
|
||||
.lean()
|
||||
.populate('user', 'username img shortDescription')
|
||||
@@ -50,7 +54,9 @@ exports.getAllEvents = function(req, res) {
|
||||
};
|
||||
exports.getAllAlerts = function(req, res) {
|
||||
eventModel.find({
|
||||
date: {$gte: new Date()},
|
||||
date: {
|
||||
$gte: new Date()
|
||||
},
|
||||
type: "alert"
|
||||
})
|
||||
.lean()
|
||||
@@ -65,13 +71,18 @@ exports.getAllAlerts = function(req, res) {
|
||||
};
|
||||
|
||||
exports.getEventById = function(req, res) {
|
||||
eventModel.findOne({_id: req.params.eventid})
|
||||
eventModel.findOne({
|
||||
_id: req.params.eventid
|
||||
})
|
||||
.lean()
|
||||
.populate('user', 'username img shortDescription')
|
||||
.exec(function(err, event) {
|
||||
if (err) return res.send(500, err.message);
|
||||
if (!event) {
|
||||
res.json({success: false, message: 'event not found.'});
|
||||
res.json({
|
||||
success: false,
|
||||
message: 'event not found.'
|
||||
});
|
||||
} else if (event) {
|
||||
|
||||
res.status(200).jsonp(event);
|
||||
@@ -80,14 +91,33 @@ exports.getEventById = function (req, res) {
|
||||
};
|
||||
|
||||
|
||||
exports.addEvent = function(req, res) {
|
||||
userModel.findOne({'tokens.token': req.headers['x-access-token']})
|
||||
.exec(function(err, user){
|
||||
if (err) return res.send(500, err.message);
|
||||
if (!user) {
|
||||
console.log("user not found");
|
||||
res.json({success: false, message: 'User not found.'});
|
||||
} else if (user) {
|
||||
function getRandomInt(min, max) {
|
||||
min = Math.ceil(min);
|
||||
max = Math.floor(max);
|
||||
return Math.floor(Math.random() * (max - min)) + min; //The maximum is exclusive and the minimum is inclusive
|
||||
}
|
||||
|
||||
function postImage(req, res, user, filename, fileImg) {
|
||||
url = "http://127.0.0.1:3050/image";
|
||||
var importFile = function(fileImg) {
|
||||
var decodedFile = new Buffer(fileImg, 'base64');
|
||||
var r = request.post(url, function(err, httpResponse, body) {
|
||||
if (err) {
|
||||
console.log(err);
|
||||
}
|
||||
//console.log(body);
|
||||
addNewEvent(req, res, user, body);
|
||||
});
|
||||
var form = r.form();
|
||||
form.append('file', decodedFile, {
|
||||
filename: filename + '.png'
|
||||
});
|
||||
}
|
||||
importFile(fileImg);
|
||||
}
|
||||
function addNewEvent(req, res, user, imgUrl){
|
||||
//adding random number to the url, to force ionic reload the image
|
||||
req.body.img = imgUrl+ "?" + getRandomInt(1, 9999);
|
||||
var event = new eventModel({
|
||||
title: req.body.title,
|
||||
description: req.body.description,
|
||||
@@ -98,26 +128,51 @@ exports.addEvent = function(req, res) {
|
||||
location: req.body.location,
|
||||
user: user._id
|
||||
});
|
||||
|
||||
event.save(function(err, event) {
|
||||
if (err) return res.send(500, err.message);
|
||||
|
||||
user.events.push(event._id);
|
||||
user.save(function(err, user) {
|
||||
if (err) return res.send(500, err.message);
|
||||
exports.getAllEvents(req, res);
|
||||
req.params.eventid=event._id;
|
||||
exports.getEventById(req, res);
|
||||
});
|
||||
}); //end of event.save
|
||||
}
|
||||
});//end of usermodel.find
|
||||
};
|
||||
exports.addAlert = function(req, res) {
|
||||
userModel.findOne({'tokens.token': req.headers['x-access-token']})
|
||||
exports.addEvent = function(req, res) {
|
||||
userModel.findOne({
|
||||
'tokens.token': req.headers['x-access-token']
|
||||
})
|
||||
.exec(function(err, user) {
|
||||
if (err) return res.send(500, err.message);
|
||||
if (!user) {
|
||||
console.log("user not found");
|
||||
res.json({success: false, message: 'User not found.'});
|
||||
res.json({
|
||||
success: false,
|
||||
message: 'User not found.'
|
||||
});
|
||||
} else if (user) {
|
||||
if (req.body.img) {
|
||||
imgname = getRandomInt(1, 9999) + "_" + getRandomInt(1, 9999);
|
||||
postImage(req, res, user, "event_" + imgname, req.body.img);
|
||||
}else{
|
||||
addNewEvent(req, res, user, "");
|
||||
}
|
||||
}
|
||||
}); //end of usermodel.find
|
||||
};
|
||||
exports.addAlert = function(req, res) {
|
||||
userModel.findOne({
|
||||
'tokens.token': req.headers['x-access-token']
|
||||
})
|
||||
.exec(function(err, user) {
|
||||
if (err) return res.send(500, err.message);
|
||||
if (!user) {
|
||||
console.log("user not found");
|
||||
res.json({
|
||||
success: false,
|
||||
message: 'User not found.'
|
||||
});
|
||||
} else if (user) {
|
||||
var event = new eventModel({
|
||||
title: req.body.title,
|
||||
@@ -141,7 +196,9 @@ exports.addAlert = function(req, res) {
|
||||
}); //end of usermodel.find
|
||||
};
|
||||
exports.deleteEvent = function(req, res) {
|
||||
userModel.findOne({'tokens.token': req.headers['x-access-token']})
|
||||
userModel.findOne({
|
||||
'tokens.token': req.headers['x-access-token']
|
||||
})
|
||||
.exec(function(err, user) {
|
||||
if (err) return res.send(500, err.message);
|
||||
eventModel.findOne({
|
||||
@@ -150,8 +207,7 @@ exports.deleteEvent = function(req, res) {
|
||||
})
|
||||
.exec(function(err, event) {
|
||||
if (err) return res.send(500, err.message);
|
||||
if(event.user.equals(user._id))
|
||||
{
|
||||
if (event.user.equals(user._id)) {
|
||||
event.remove(function(err) {
|
||||
if (err) return res.send(500, err.message);
|
||||
|
||||
@@ -175,14 +231,17 @@ això retorna els events d'aquests users que segueixes
|
||||
*/
|
||||
|
||||
exports.getEventsByFollowingArray = function(req, res) {
|
||||
if(req.body.users==null)
|
||||
{
|
||||
res.status(200).jsonp(null);
|
||||
}
|
||||
/*if (req.body.users == null) {
|
||||
res.status(200).jsonp([]);
|
||||
}*/
|
||||
eventModel.find({
|
||||
date: {$gte: new Date()},
|
||||
date: {
|
||||
$gte: new Date()
|
||||
},
|
||||
'user': req.body.users,
|
||||
type: {$nin: ["alert"]}//cal filtrar per type d'event, aquí només agafem els type: alert
|
||||
type: {
|
||||
$nin: ["alert"]
|
||||
} //cal filtrar per type d'event, aquí només agafem els type: alert
|
||||
})
|
||||
.lean()
|
||||
.populate('user', 'username img shortDescription')
|
||||
@@ -191,6 +250,8 @@ exports.getEventsByFollowingArray = function(req, res) {
|
||||
.skip(pageSize * Number(req.query.page))
|
||||
.exec(function(err, events) {
|
||||
if (err) return res.send(500, err.message);
|
||||
|
||||
console.log(events);
|
||||
res.status(200).jsonp(events);
|
||||
});
|
||||
};
|
||||
@@ -202,7 +263,9 @@ això retorna els events d'aquests users que segueixes
|
||||
*/
|
||||
exports.getEventsByCategory = function(req, res) {
|
||||
eventModel.find({
|
||||
date: {$gte: new Date()},
|
||||
date: {
|
||||
$gte: new Date()
|
||||
},
|
||||
'categories.name': req.params.category
|
||||
})
|
||||
.lean()
|
||||
|
||||
@@ -15,6 +15,7 @@
|
||||
"method-override": "^2.1.2",
|
||||
"mongoose": "latest",
|
||||
"morgan": "latest",
|
||||
"mongoose-unique-validator": "^1.0.2"
|
||||
"mongoose-unique-validator": "^1.0.2",
|
||||
"request": "^2.81.0"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -17,10 +17,13 @@ mongoose.connect(config.database, function(err, res) {
|
||||
app.set('superSecret', config.secret); // secret variable
|
||||
|
||||
// Middlewares
|
||||
app.use(bodyParser.urlencoded({
|
||||
/*app.use(bodyParser.urlencoded({
|
||||
extended: false
|
||||
}));
|
||||
app.use(bodyParser.json());
|
||||
app.use(bodyParser.json());*/
|
||||
|
||||
app.use(bodyParser.json({limit: '2mb'}));
|
||||
app.use(bodyParser.urlencoded({limit: '2mb', extended: true}));
|
||||
app.use(methodOverride());
|
||||
|
||||
// use morgan to log requests to the console
|
||||
|
||||
Reference in New Issue
Block a user