forked from angular-fullstack/generator-angular-fullstack
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbasename.controller.js
125 lines (113 loc) · 3.76 KB
/
basename.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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/**
* Using Rails-like standard naming convention for endpoints.
* GET <%= route %> -> index<% if (filters.models) { %>
* POST <%= route %> -> create
* GET <%= route %>/:id -> show
* PUT <%= route %>/:id -> update
* DELETE <%= route %>/:id -> destroy<% } %>
*/
'use strict';<% if (filters.models) { %>
var _ = require('lodash');<% if (filters.mongooseModels) { %>
var <%= classedName %> = require('./<%= basename %>.model');<% } if (filters.sequelizeModels) { %>
var sqldb = require('<%= relativeRequire(config.get('registerModelsFile')) %>');
var <%= classedName %> = sqldb.<%= classedName %>;<% } %>
function handleError(res, statusCode) {
statusCode = statusCode || 500;
return function(err) {
res.status(statusCode).send(err);
};
}
function responseWithResult(res, statusCode) {
statusCode = statusCode || 200;
return function(entity) {
if (entity) {
res.status(statusCode).json(entity);
}
};
}
function handleEntityNotFound(res) {
return function(entity) {
if (!entity) {
res.status(404).end();
return null;
}
return entity;
};
}
function saveUpdates(updates) {
return function(entity) {
<% if (filters.mongooseModels) { %>var updated = _.merge(entity, updates);
return updated.saveAsync()
.spread(function(updated) {<% }
if (filters.sequelizeModels) { %>return entity.updateAttributes(updates)
.then(function(updated) {<% } %>
return updated;
});
};
}
function removeEntity(res) {
return function(entity) {
if (entity) {
<% if (filters.mongooseModels) { %>return entity.removeAsync()<% }
if (filters.sequelizeModels) { %>return entity.destroy()<% } %>
.then(function() {
res.status(204).end();
});
}
};
}<% } %>
// Gets a list of <%= classedName %>s
exports.index = function(req, res) {<% if (!filters.models) { %>
res.json([]);<% } else { %>
<% if (filters.mongooseModels) { %><%= classedName %>.findAsync()<% }
if (filters.sequelizeModels) { %><%= classedName %>.findAll()<% } %>
.then(responseWithResult(res))
.catch(handleError(res));<% } %>
};<% if (filters.models) { %>
// Gets a single <%= classedName %> from the DB
exports.show = function(req, res) {
<% if (filters.mongooseModels) { %><%= classedName %>.findByIdAsync(req.params.id)<% }
if (filters.sequelizeModels) { %><%= classedName %>.find({
where: {
_id: req.params.id
}
})<% } %>
.then(handleEntityNotFound(res))
.then(responseWithResult(res))
.catch(handleError(res));
};
// Creates a new <%= classedName %> in the DB
exports.create = function(req, res) {
<% if (filters.mongooseModels) { %><%= classedName %>.createAsync(req.body)<% }
if (filters.sequelizeModels) { %><%= classedName %>.create(req.body)<% } %>
.then(responseWithResult(res, 201))
.catch(handleError(res));
};
// Updates an existing <%= classedName %> in the DB
exports.update = function(req, res) {
if (req.body._id) {
delete req.body._id;
}
<% if (filters.mongooseModels) { %><%= classedName %>.findByIdAsync(req.params.id)<% }
if (filters.sequelizeModels) { %><%= classedName %>.find({
where: {
_id: req.params.id
}
})<% } %>
.then(handleEntityNotFound(res))
.then(saveUpdates(req.body))
.then(responseWithResult(res))
.catch(handleError(res));
};
// Deletes a <%= classedName %> from the DB
exports.destroy = function(req, res) {
<% if (filters.mongooseModels) { %><%= classedName %>.findByIdAsync(req.params.id)<% }
if (filters.sequelizeModels) { %><%= classedName %>.find({
where: {
_id: req.params.id
}
})<% } %>
.then(handleEntityNotFound(res))
.then(removeEntity(res))
.catch(handleError(res));
};<% } %>