forked from pencilblue/pencilblue
-
Notifications
You must be signed in to change notification settings - Fork 0
/
form_controller.js
executable file
·108 lines (94 loc) · 3.29 KB
/
form_controller.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
/*
Copyright (C) 2015 PencilBlue, LLC
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
//dependencies
var util = require('../include/util.js');
module.exports = function(pb) {
/**
* Provides the basic functionality for implementing a controller that
* needs access to a posted form.
* @class FormController
* @extends BaseController
* @constructor
*/
function FormController(){}
util.inherits(FormController, pb.BaseController);
/**
* Instructs the controller to automatically sanitize any incoming post data
* when set to TRUE.
* @property autoSanitize
* @type {Boolean}
*/
FormController.prototype.autoSanitize = true;
/**
* Responsible for gathering the payload data from the request and parsing it.
* The result is passed down to the controller's onPostParamsRetrieved function.
* In addition and the <i>autoSanitize</i> property is TRUE, the posted
* parameters will be sanitized.
* @see BaseController#render
* @method render
* @param {Function} cb
*/
FormController.prototype.render = function(cb) {
var self = this;
this.getPostParams(function(err, params) {
if (util.isError(err)) {
self.onPostParamsError(err, cb);
return;
}
if (self.getAutoSanitize()) {
self.sanitizeObject(params);
}
self.onPostParamsRetrieved(params, cb);
});
};
/**
*
* @method getAutoSanitize
* @return {Boolean}
*/
FormController.prototype.getAutoSanitize = function() {
return this.autoSanitize;
};
/**
*
* @method setAutoSanitize
* @param {Boolean} val
*/
FormController.prototype.setAutoSanitize = function(val) {
this.autoSanitize = !!val;
};
/**
*
* @method onPostParamsError
* @param {Error} err
* @param {Function} cb
*/
FormController.prototype.onPostParamsError = function(err, cb) {
pb.log.silly("FormController: Error processing form parameters"+err);
cb({content: err, code: 400});
};
/**
* Called after the posted parameters have been received and parsed. The
* function should be overriden in order to continue processing and render the
* result of the request. The default implementation echoes the received
* parameters as JSON.
* @method onPostParamsRetrieved
* @param {Object} params
* @param {Function} cb
*/
FormController.prototype.onPostParamsRetrieved = function(params, cb) {
cb({content: JSON.stringify(params), content_type:'application/json'});
};
return FormController;
};