2015-06-30 02:14:43 +00:00
|
|
|
'use strict';
|
2015-06-29 22:51:29 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Module dependencies.
|
|
|
|
*/
|
|
|
|
var mongoose = require('mongoose'),
|
|
|
|
errorHandler = require('./errors.server.controller'),
|
|
|
|
Form = mongoose.model('Form'),
|
|
|
|
FormSubmission = mongoose.model('FormSubmission'),
|
|
|
|
config = require('../../config/config'),
|
2016-07-06 01:48:25 +00:00
|
|
|
diff = require('deep-diff'),
|
2017-10-29 21:04:13 +00:00
|
|
|
_ = require('lodash'),
|
|
|
|
helpers = require('./helpers.server.controller');
|
2015-06-29 22:51:29 +00:00
|
|
|
|
2015-07-27 18:11:43 +00:00
|
|
|
/**
|
|
|
|
* Delete a forms submissions
|
|
|
|
*/
|
|
|
|
exports.deleteSubmissions = function(req, res) {
|
2015-08-07 21:02:44 +00:00
|
|
|
|
2015-07-27 18:11:43 +00:00
|
|
|
var submission_id_list = req.body.deleted_submissions,
|
|
|
|
form = req.form;
|
|
|
|
|
|
|
|
FormSubmission.remove({ form: req.form, admin: req.user, _id: {$in: submission_id_list} }, function(err){
|
2016-03-30 03:45:16 +00:00
|
|
|
|
2015-07-27 18:11:43 +00:00
|
|
|
if(err){
|
|
|
|
res.status(400).send({
|
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
});
|
2016-06-07 00:37:09 +00:00
|
|
|
return;
|
2015-07-27 18:11:43 +00:00
|
|
|
}
|
|
|
|
|
2016-06-07 00:37:09 +00:00
|
|
|
form.analytics.visitors = [];
|
2017-04-21 04:54:02 +00:00
|
|
|
form.save(function(formSaveErr){
|
|
|
|
if(formSaveErr){
|
2016-06-07 00:37:09 +00:00
|
|
|
res.status(400).send({
|
2017-04-21 04:54:02 +00:00
|
|
|
message: errorHandler.getErrorMessage(formSaveErr)
|
2016-06-07 00:37:09 +00:00
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
res.status(200).send('Form submissions successfully deleted');
|
|
|
|
|
|
|
|
});
|
2015-07-27 18:11:43 +00:00
|
|
|
});
|
|
|
|
};
|
2015-10-30 18:40:02 +00:00
|
|
|
|
2015-06-29 22:51:29 +00:00
|
|
|
/**
|
|
|
|
* Submit a form entry
|
|
|
|
*/
|
|
|
|
exports.createSubmission = function(req, res) {
|
2017-03-06 20:30:31 +00:00
|
|
|
|
2017-03-06 19:43:42 +00:00
|
|
|
var timeElapsed = 0;
|
2017-10-05 08:19:13 +00:00
|
|
|
|
2017-06-23 17:54:28 +00:00
|
|
|
if(typeof req.body.timeElapsed === 'number'){
|
2017-03-06 19:43:42 +00:00
|
|
|
timeElapsed = req.body.timeElapsed;
|
|
|
|
}
|
2015-08-07 21:02:44 +00:00
|
|
|
var submission = new FormSubmission({
|
2017-10-05 08:19:13 +00:00
|
|
|
form: req.body._id,
|
2015-07-27 18:11:43 +00:00
|
|
|
form_fields: req.body.form_fields,
|
2017-03-06 19:43:42 +00:00
|
|
|
timeElapsed: timeElapsed,
|
2017-03-06 21:45:11 +00:00
|
|
|
percentageComplete: req.body.percentageComplete,
|
|
|
|
ipAddr: req.body.ipAddr,
|
|
|
|
geoLocation: req.body.geoLocation,
|
|
|
|
device: req.body.device
|
2015-07-27 18:11:43 +00:00
|
|
|
});
|
2017-03-06 20:30:31 +00:00
|
|
|
|
2015-08-07 21:02:44 +00:00
|
|
|
submission.save(function(err, submission){
|
2016-11-09 18:02:12 +00:00
|
|
|
if (err) {
|
|
|
|
console.error(err.message);
|
|
|
|
return res.status(500).send({
|
2015-07-27 18:11:43 +00:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
});
|
|
|
|
}
|
2017-10-05 08:19:13 +00:00
|
|
|
res.status(200).send('Form submission successfully saved');
|
2015-07-27 18:11:43 +00:00
|
|
|
});
|
2015-06-29 22:51:29 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2015-06-30 06:12:32 +00:00
|
|
|
* Get List of Submissions for a given Form
|
2015-06-29 22:51:29 +00:00
|
|
|
*/
|
|
|
|
exports.listSubmissions = function(req, res) {
|
|
|
|
var _form = req.form;
|
|
|
|
|
2017-10-28 09:13:56 +00:00
|
|
|
FormSubmission.find({ form: _form._id }).sort('created').lean().exec(function(err, _submissions) {
|
2015-11-12 21:37:36 +00:00
|
|
|
if (err) {
|
2016-11-09 18:02:12 +00:00
|
|
|
console.error(err);
|
2017-10-05 08:19:13 +00:00
|
|
|
res.status(500).send({
|
2015-11-12 21:37:36 +00:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
});
|
|
|
|
}
|
2016-11-09 18:02:12 +00:00
|
|
|
res.json(_submissions);
|
2015-11-12 21:37:36 +00:00
|
|
|
});
|
2015-06-29 22:51:29 +00:00
|
|
|
};
|
|
|
|
|
2015-07-03 01:40:57 +00:00
|
|
|
/**
|
|
|
|
* Create a new form
|
|
|
|
*/
|
|
|
|
exports.create = function(req, res) {
|
2017-10-29 19:44:12 +00:00
|
|
|
|
2016-08-26 20:43:37 +00:00
|
|
|
if(!req.body.form){
|
2017-10-29 21:04:13 +00:00
|
|
|
return res.status(400).send({
|
2017-06-23 17:54:28 +00:00
|
|
|
message: 'Invalid Input'
|
2016-08-26 20:43:37 +00:00
|
|
|
});
|
|
|
|
}
|
2015-07-07 01:21:43 +00:00
|
|
|
var form = new Form(req.body.form);
|
|
|
|
|
2015-08-07 21:02:44 +00:00
|
|
|
form.admin = req.user._id;
|
2015-07-03 01:40:57 +00:00
|
|
|
|
2017-10-29 21:04:13 +00:00
|
|
|
form.save(function(err, createdForm) {
|
2015-07-03 01:40:57 +00:00
|
|
|
if (err) {
|
2017-10-11 05:07:13 +00:00
|
|
|
return res.status(500).send({
|
2015-07-03 01:40:57 +00:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
});
|
|
|
|
}
|
2016-08-26 20:43:37 +00:00
|
|
|
|
2017-10-29 21:04:13 +00:00
|
|
|
createdForm = helpers.removeSensitiveModelData('private_form', createdForm);
|
|
|
|
return res.json(createdForm);
|
2015-07-03 01:40:57 +00:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the current form
|
|
|
|
*/
|
|
|
|
exports.read = function(req, res) {
|
2017-07-27 02:53:02 +00:00
|
|
|
if(!req.user || (req.form.admin.id !== req.user.id) ){
|
2017-07-26 22:55:33 +00:00
|
|
|
readForRender(req, res);
|
|
|
|
} else {
|
2017-10-30 03:05:52 +00:00
|
|
|
if(!req.form){
|
2017-07-28 21:47:09 +00:00
|
|
|
return res.status(404).send({
|
|
|
|
message: 'Form Does Not Exist'
|
|
|
|
});
|
2016-11-09 18:02:12 +00:00
|
|
|
}
|
2017-10-29 21:04:13 +00:00
|
|
|
|
2017-10-30 03:05:52 +00:00
|
|
|
var newForm = req.form.toJSON();
|
|
|
|
|
|
|
|
if(newForm.admin._id === req.user._id){
|
|
|
|
return res.json(newForm);
|
|
|
|
}
|
|
|
|
|
2017-10-29 21:04:13 +00:00
|
|
|
newForm = helpers.removeSensitiveModelData('private_form', newForm);
|
2017-07-28 21:47:09 +00:00
|
|
|
return res.json(newForm);
|
2017-07-26 22:55:33 +00:00
|
|
|
}
|
2015-07-03 01:40:57 +00:00
|
|
|
};
|
2015-06-29 22:51:29 +00:00
|
|
|
|
2017-03-06 20:30:31 +00:00
|
|
|
/**
|
|
|
|
* Show the current form for rendering form live
|
|
|
|
*/
|
2017-07-26 22:55:33 +00:00
|
|
|
var readForRender = exports.readForRender = function(req, res) {
|
2017-09-21 06:08:45 +00:00
|
|
|
var newForm = req.form;
|
2017-04-03 21:26:35 +00:00
|
|
|
if (!newForm.isLive && !req.user) {
|
2017-07-25 22:08:25 +00:00
|
|
|
return res.status(401).send({
|
|
|
|
message: 'Form is Not Public'
|
2017-03-06 20:30:31 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-10-29 21:04:13 +00:00
|
|
|
newForm = helpers.removeSensitiveModelData('public_form', newForm);
|
2017-03-06 20:30:31 +00:00
|
|
|
|
2017-10-07 07:27:03 +00:00
|
|
|
if(newForm.startPage && !newForm.startPage.showStart){
|
2017-03-11 19:57:55 +00:00
|
|
|
delete newForm.startPage;
|
|
|
|
}
|
|
|
|
|
2017-03-06 20:30:31 +00:00
|
|
|
return res.json(newForm);
|
|
|
|
};
|
|
|
|
|
2015-06-29 22:51:29 +00:00
|
|
|
/**
|
|
|
|
* Update a form
|
|
|
|
*/
|
2016-03-30 03:45:16 +00:00
|
|
|
exports.update = function(req, res) {
|
2017-10-07 07:27:03 +00:00
|
|
|
|
2017-10-05 08:19:13 +00:00
|
|
|
var form = req.form;
|
2017-08-02 20:05:17 +00:00
|
|
|
var updatedForm = req.body.form;
|
2017-10-29 21:04:13 +00:00
|
|
|
|
|
|
|
if(!form.analytics){
|
2017-10-07 07:27:03 +00:00
|
|
|
form.analytics = {
|
|
|
|
visitors: [],
|
|
|
|
gaCode: ''
|
|
|
|
}
|
|
|
|
}
|
2016-11-02 18:30:04 +00:00
|
|
|
|
2016-11-09 18:02:12 +00:00
|
|
|
if (req.body.changes) {
|
2016-08-26 22:34:29 +00:00
|
|
|
var formChanges = req.body.changes;
|
2015-07-21 23:25:45 +00:00
|
|
|
|
2016-08-26 22:34:29 +00:00
|
|
|
formChanges.forEach(function (change) {
|
2017-10-07 07:27:03 +00:00
|
|
|
diff.applyChange(form._doc, true, change);
|
2016-08-26 22:34:29 +00:00
|
|
|
});
|
|
|
|
} else {
|
2017-10-07 07:27:03 +00:00
|
|
|
|
|
|
|
delete updatedForm.__v;
|
|
|
|
delete updatedForm.created;
|
|
|
|
//Unless we have 'admin' privileges, updating the form's admin is disabled
|
2017-08-02 20:05:17 +00:00
|
|
|
if(updatedForm && req.user.roles.indexOf('admin') === -1) {
|
|
|
|
delete updatedForm.admin;
|
2017-03-01 20:11:20 +00:00
|
|
|
}
|
2017-03-10 19:26:07 +00:00
|
|
|
|
2016-08-26 22:34:29 +00:00
|
|
|
//Do this so we can create duplicate fields
|
|
|
|
var checkForValidId = new RegExp('^[0-9a-fA-F]{24}$');
|
2017-10-07 07:27:03 +00:00
|
|
|
for(var i=0; i < req.body.form.form_fields.length; i++){
|
2016-08-26 22:34:29 +00:00
|
|
|
var field = req.body.form.form_fields[i];
|
|
|
|
if(!checkForValidId.exec(field._id+'')){
|
|
|
|
delete field._id;
|
|
|
|
}
|
2015-11-13 00:52:14 +00:00
|
|
|
}
|
2017-08-02 20:05:17 +00:00
|
|
|
form = _.extend(form, updatedForm);
|
2015-11-13 00:52:14 +00:00
|
|
|
}
|
2016-03-30 03:45:16 +00:00
|
|
|
|
2017-04-21 04:54:02 +00:00
|
|
|
form.save(function(err, savedForm) {
|
2015-06-29 22:51:29 +00:00
|
|
|
if (err) {
|
2017-10-11 05:07:13 +00:00
|
|
|
res.status(500).send({
|
2015-06-29 22:51:29 +00:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
});
|
|
|
|
} else {
|
2017-10-29 21:04:13 +00:00
|
|
|
savedForm = helpers.removeSensitiveModelData('private_form', savedForm);
|
2017-04-21 04:54:02 +00:00
|
|
|
res.json(savedForm);
|
2015-06-29 22:51:29 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Delete a form
|
|
|
|
*/
|
|
|
|
exports.delete = function(req, res) {
|
|
|
|
var form = req.form;
|
2015-07-02 03:50:57 +00:00
|
|
|
Form.remove({_id: form._id}, function(err) {
|
2015-06-29 22:51:29 +00:00
|
|
|
if (err) {
|
2015-08-07 21:02:44 +00:00
|
|
|
res.status(400).send({
|
2015-07-03 19:25:02 +00:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
2015-06-29 22:51:29 +00:00
|
|
|
});
|
|
|
|
} else {
|
2015-08-07 21:02:44 +00:00
|
|
|
res.json(form);
|
2015-06-29 22:51:29 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2015-07-02 02:49:35 +00:00
|
|
|
* Get All of Users' Forms
|
2015-06-29 22:51:29 +00:00
|
|
|
*/
|
|
|
|
exports.list = function(req, res) {
|
2015-07-02 02:49:35 +00:00
|
|
|
//Allow 'admin' user to view all forms
|
|
|
|
var searchObj = {admin: req.user};
|
2015-07-02 03:50:57 +00:00
|
|
|
if(req.user.isAdmin()) searchObj = {};
|
|
|
|
|
2017-09-21 03:53:50 +00:00
|
|
|
Form.find(searchObj)
|
2017-10-02 15:41:34 +00:00
|
|
|
.sort('-created')
|
2017-10-28 09:13:56 +00:00
|
|
|
.select('title language admin submissions isLive')
|
2017-09-21 03:53:50 +00:00
|
|
|
.populate('admin.username', 'admin._id')
|
|
|
|
.lean()
|
|
|
|
.exec(function(err, forms) {
|
2015-06-29 22:51:29 +00:00
|
|
|
if (err) {
|
2015-07-02 03:50:57 +00:00
|
|
|
res.status(400).send({
|
2015-06-29 22:51:29 +00:00
|
|
|
message: errorHandler.getErrorMessage(err)
|
|
|
|
});
|
|
|
|
} else {
|
2017-10-02 15:41:34 +00:00
|
|
|
for(var i=0; i<forms.length; i++){
|
2017-10-29 21:04:13 +00:00
|
|
|
forms[i] = helpers.removeSensitiveModelData('private_form', forms[i]);
|
|
|
|
|
2017-10-02 15:41:34 +00:00
|
|
|
forms[i].numberOfResponses = 0;
|
|
|
|
if(forms[i].submissions){
|
|
|
|
forms[i].numberOfResponses = forms[i].submissions.length;
|
|
|
|
delete forms[i].submissions;
|
|
|
|
}
|
|
|
|
}
|
2015-07-02 03:50:57 +00:00
|
|
|
res.json(forms);
|
2015-06-29 22:51:29 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Form middleware
|
|
|
|
*/
|
|
|
|
exports.formByID = function(req, res, next, id) {
|
|
|
|
if (!mongoose.Types.ObjectId.isValid(id)) {
|
2015-09-15 22:21:49 +00:00
|
|
|
return res.status(400).send({
|
2015-06-29 22:51:29 +00:00
|
|
|
message: 'Form is invalid'
|
|
|
|
});
|
2015-09-15 22:21:49 +00:00
|
|
|
}
|
2017-10-29 21:04:13 +00:00
|
|
|
|
2017-09-21 03:53:50 +00:00
|
|
|
Form.findById(id)
|
|
|
|
.populate('admin')
|
|
|
|
.exec(function(err, form) {
|
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
} else if (!form || form === null) {
|
|
|
|
res.status(404).send({
|
|
|
|
message: 'Form not found'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
//Remove sensitive information from User object
|
2017-10-29 21:04:13 +00:00
|
|
|
req.form = helpers.removeSensitiveModelData('private_form', form);
|
2017-09-21 03:53:50 +00:00
|
|
|
return next();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* FastForm middleware
|
|
|
|
*/
|
|
|
|
exports.formByIDFast = function(req, res, next, id) {
|
|
|
|
if (!mongoose.Types.ObjectId.isValid(id)) {
|
|
|
|
return res.status(400).send({
|
|
|
|
message: 'Form is invalid'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
Form.findById(id)
|
|
|
|
.lean()
|
2017-10-05 08:19:13 +00:00
|
|
|
.select('title language form_fields startPage endPage hideFooter isLive design analytics.gaCode')
|
2017-09-21 03:53:50 +00:00
|
|
|
.exec(function(err, form) {
|
2017-04-21 04:54:02 +00:00
|
|
|
if (err) {
|
|
|
|
return next(err);
|
|
|
|
} else if (!form || form === null) {
|
|
|
|
res.status(404).send({
|
|
|
|
message: 'Form not found'
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
//Remove sensitive information from User object
|
2017-10-29 21:04:13 +00:00
|
|
|
req.form = helpers.removeSensitiveModelData('public_form', form);
|
2017-04-21 04:54:02 +00:00
|
|
|
return next();
|
|
|
|
}
|
|
|
|
});
|
2015-06-29 22:51:29 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Form authorization middleware
|
|
|
|
*/
|
|
|
|
exports.hasAuthorization = function(req, res, next) {
|
|
|
|
var form = req.form;
|
2015-07-02 03:50:57 +00:00
|
|
|
if (req.form.admin.id !== req.user.id && req.user.roles.indexOf('admin') === -1) {
|
|
|
|
res.status(403).send({
|
2015-08-07 21:02:44 +00:00
|
|
|
message: 'User '+req.user.username+' is not authorized to edit Form: '+form.title
|
2015-06-29 22:51:29 +00:00
|
|
|
});
|
|
|
|
}
|
2016-04-29 06:00:41 +00:00
|
|
|
return next();
|
2015-06-29 22:51:29 +00:00
|
|
|
};
|