summaryrefslogtreecommitdiff
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/lib/api/projects.js19
-rw-r--r--server/lib/util.js2
2 files changed, 12 insertions, 9 deletions
diff --git a/server/lib/api/projects.js b/server/lib/api/projects.js
index 61a6e10..5bd3d0f 100644
--- a/server/lib/api/projects.js
+++ b/server/lib/api/projects.js
@@ -67,14 +67,6 @@ var projects = {
return docs.create(req, res)
}
- var data = util.cleanQuery(req.body)
-
- // data.user_id = req.user._id
- data.name = util.sanitize(data.name)
- data.slug = util.slugify(data.name)
- data.description = util.sanitize(data.description)
- data.updated_at = new Date ()
-
if (req.files.thumbnail) {
upload.put("projects", req.files.thumbnail, {
unacceptable: function(err){
@@ -93,6 +85,17 @@ var projects = {
function done() {
Project.findOne({ _id: _id }, function(err, doc){
if (err || ! doc) { return res.json({ error: err }) }
+
+ var data = util.cleanQuery(req.body)
+
+ // data.user_id = req.user._id
+ data.name = util.sanitize(data.name)
+ if (data.name != doc.name) {
+ data.slug = util.slugify(data.name)
+ }
+ data.description = util.sanitize(data.description)
+ data.updated_at = new Date ()
+
_.extend(doc, data)
doc.rooms = JSON.parse(data.rooms)
diff --git a/server/lib/util.js b/server/lib/util.js
index 791d3e2..2841cc5 100644
--- a/server/lib/util.js
+++ b/server/lib/util.js
@@ -13,7 +13,7 @@ var util = {}
util.trim = function (s){ return (s || "").replace(whitespaceHead,"").replace(whitespaceTail,"") }
util.slugify = function (s){
- return (s || "").toLowerCase().replace(whitespace,"-").replace(nonAlphanumerics, '-').replace(consecutiveDashes,"-")
+ return (s + "-" + (+new Date) || "").toLowerCase().replace(whitespace,"-").replace(nonAlphanumerics, '-').replace(consecutiveDashes,"-")
}
util.sanitize = function (s){
return (s || "").replace(entities, "")