Route separation
							parent
							
								
									fc93acb085
								
							
						
					
					
						commit
						a3e2a6c7c1
					
				
							
								
								
									
										750
									
								
								routes/admin.js
								
								
								
								
							
							
						
						
									
										750
									
								
								routes/admin.js
								
								
								
								
							|  | @ -3,8 +3,6 @@ const common = require('./common'); | ||||||
| const escape = require('html-entities').AllHtmlEntities; | const escape = require('html-entities').AllHtmlEntities; | ||||||
| const colors = require('colors'); | const colors = require('colors'); | ||||||
| const bcrypt = require('bcryptjs'); | const bcrypt = require('bcryptjs'); | ||||||
| const rimraf = require('rimraf'); |  | ||||||
| const url = require('url'); |  | ||||||
| const fs = require('fs'); | const fs = require('fs'); | ||||||
| const path = require('path'); | const path = require('path'); | ||||||
| const multer = require('multer'); | const multer = require('multer'); | ||||||
|  | @ -16,166 +14,6 @@ router.get('/', common.restrict, (req, res, next) => { | ||||||
|     res.redirect('/admin/orders'); |     res.redirect('/admin/orders'); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // Admin section
 |  | ||||||
| router.get('/orders', common.restrict, (req, res, next) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     // Top 10 products
 |  | ||||||
|     db.orders.find({}).sort({'orderDate': -1}).limit(10).toArray((err, orders) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         res.render('orders', { |  | ||||||
|             title: 'Cart', |  | ||||||
|             orders: orders, |  | ||||||
|             admin: true, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             session: req.session, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // Admin section
 |  | ||||||
| router.get('/orders/bystatus/:orderstatus', common.restrict, (req, res, next) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     if(typeof req.params.orderstatus === 'undefined'){ |  | ||||||
|         res.redirect('/admin/orders'); |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // case insensitive search
 |  | ||||||
|     let regex = new RegExp(['^', req.params.orderstatus, '$'].join(''), 'i'); |  | ||||||
|     db.orders.find({orderStatus: regex}).sort({'orderDate': -1}).limit(10).toArray((err, orders) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         res.render('orders', { |  | ||||||
|             title: 'Cart', |  | ||||||
|             orders: orders, |  | ||||||
|             admin: true, |  | ||||||
|             filteredOrders: true, |  | ||||||
|             filteredStatus: req.params.orderstatus, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             session: req.session, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // render the editor
 |  | ||||||
| router.get('/order/view/:id', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     db.orders.findOne({_id: common.getId(req.params.id)}, (err, result) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         let productOptions = ''; |  | ||||||
|         if(result.options !== {}){ |  | ||||||
|             productOptions = result.options; |  | ||||||
|         } |  | ||||||
|         res.render('order', { |  | ||||||
|             title: 'View order', |  | ||||||
|             result: result, |  | ||||||
|             productOptions: productOptions, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             session: req.session, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             editor: true, |  | ||||||
|             admin: true, |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // Admin section
 |  | ||||||
| router.get('/orders/filter/:search', common.restrict, (req, res, next) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     let searchTerm = req.params.search; |  | ||||||
|     let ordersIndex = req.app.ordersIndex; |  | ||||||
| 
 |  | ||||||
|     let lunrIdArray = []; |  | ||||||
|     ordersIndex.search(searchTerm).forEach((id) => { |  | ||||||
|         lunrIdArray.push(common.getId(id.ref)); |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     // we search on the lunr indexes
 |  | ||||||
|     db.orders.find({_id: {$in: lunrIdArray}}).toArray((err, orders) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         res.render('orders', { |  | ||||||
|             title: 'Order results', |  | ||||||
|             orders: orders, |  | ||||||
|             admin: true, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             session: req.session, |  | ||||||
|             searchTerm: searchTerm, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // order product
 |  | ||||||
| router.get('/order/delete/:id', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     // remove the article
 |  | ||||||
|     db.orders.remove({_id: common.getId(req.params.id)}, {}, (err, numRemoved) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         // remove the index
 |  | ||||||
|         common.indexOrders(req.app) |  | ||||||
|         .then(() => { |  | ||||||
|             // redirect home
 |  | ||||||
|             req.session.message = 'Order successfully deleted'; |  | ||||||
|             req.session.messageType = 'success'; |  | ||||||
|             res.redirect('/admin/orders'); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // update order status
 |  | ||||||
| router.post('/order/statusupdate', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     db.orders.update({_id: common.getId(req.body.order_id)}, {$set: {orderStatus: req.body.status}}, {multi: false}, (err, numReplaced) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         res.status(200).json({message: 'Status successfully updated'}); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // Admin section
 |  | ||||||
| router.get('/products', common.restrict, (req, res, next) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     // get the top results
 |  | ||||||
|     db.products.find({}).sort({'productAddedDate': -1}).limit(10).toArray((err, topResults) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         res.render('products', { |  | ||||||
|             title: 'Cart', |  | ||||||
|             top_results: topResults, |  | ||||||
|             session: req.session, |  | ||||||
|             admin: true, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // logout
 | // logout
 | ||||||
| router.get('/logout', (req, res) => { | router.get('/logout', (req, res) => { | ||||||
|     req.session.user = null; |     req.session.user = null; | ||||||
|  | @ -280,360 +118,6 @@ router.get('/setup', (req, res) => { | ||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // Admin section
 |  | ||||||
| router.get('/products/filter/:search', common.restrict, (req, res, next) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     let searchTerm = req.params.search; |  | ||||||
|     let productsIndex = req.app.productsIndex; |  | ||||||
| 
 |  | ||||||
|     let lunrIdArray = []; |  | ||||||
|     productsIndex.search(searchTerm).forEach((id) => { |  | ||||||
|         lunrIdArray.push(common.getId(id.ref)); |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     // we search on the lunr indexes
 |  | ||||||
|     db.products.find({_id: {$in: lunrIdArray}}).toArray((err, results) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.error(colors.red('Error searching', err)); |  | ||||||
|         } |  | ||||||
|         res.render('products', { |  | ||||||
|             title: 'Results', |  | ||||||
|             results: results, |  | ||||||
|             admin: true, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             session: req.session, |  | ||||||
|             searchTerm: searchTerm, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // insert form
 |  | ||||||
| router.get('/product/new', common.restrict, (req, res) => { |  | ||||||
|     res.render('product_new', { |  | ||||||
|         title: 'New product', |  | ||||||
|         session: req.session, |  | ||||||
|         productTitle: common.clearSessionValue(req.session, 'productTitle'), |  | ||||||
|         productDescription: common.clearSessionValue(req.session, 'productDescription'), |  | ||||||
|         productPrice: common.clearSessionValue(req.session, 'productPrice'), |  | ||||||
|         productPermalink: common.clearSessionValue(req.session, 'productPermalink'), |  | ||||||
|         message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|         messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|         editor: true, |  | ||||||
|         admin: true, |  | ||||||
|         helpers: req.handlebars.helpers, |  | ||||||
|         config: common.getConfig() |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // insert new product form action
 |  | ||||||
| router.post('/product/insert', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     let doc = { |  | ||||||
|         productPermalink: req.body.frmProductPermalink, |  | ||||||
|         productTitle: req.body.frmProductTitle, |  | ||||||
|         productPrice: req.body.frmProductPrice, |  | ||||||
|         productDescription: req.body.frmProductDescription, |  | ||||||
|         productPublished: req.body.frmProductPublished, |  | ||||||
|         productTags: req.body.frmProductTags, |  | ||||||
|         productOptions: req.body.productOptJson, |  | ||||||
|         productAddedDate: new Date() |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     db.products.count({'productPermalink': req.body.frmProductPermalink}, (err, product) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         if(product > 0 && req.body.frmProductPermalink !== ''){ |  | ||||||
|             // permalink exits
 |  | ||||||
|             req.session.message = 'Permalink already exists. Pick a new one.'; |  | ||||||
|             req.session.messageType = 'danger'; |  | ||||||
| 
 |  | ||||||
|             // keep the current stuff
 |  | ||||||
|             req.session.productTitle = req.body.frmProductTitle; |  | ||||||
|             req.session.productDescription = req.body.frmProductDescription; |  | ||||||
|             req.session.productPrice = req.body.frmProductPrice; |  | ||||||
|             req.session.productPermalink = req.body.frmProductPermalink; |  | ||||||
|             req.session.productPermalink = req.body.productOptJson; |  | ||||||
|             req.session.productTags = req.body.frmProductTags; |  | ||||||
| 
 |  | ||||||
|             // redirect to insert
 |  | ||||||
|             res.redirect('/admin/insert'); |  | ||||||
|         }else{ |  | ||||||
|             db.products.insert(doc, (err, newDoc) => { |  | ||||||
|                 if(err){ |  | ||||||
|                     console.log(colors.red('Error inserting document: ' + err)); |  | ||||||
| 
 |  | ||||||
|                     // keep the current stuff
 |  | ||||||
|                     req.session.productTitle = req.body.frmProductTitle; |  | ||||||
|                     req.session.productDescription = req.body.frmProductDescription; |  | ||||||
|                     req.session.productPrice = req.body.frmProductPrice; |  | ||||||
|                     req.session.productPermalink = req.body.frmProductPermalink; |  | ||||||
|                     req.session.productPermalink = req.body.productOptJson; |  | ||||||
|                     req.session.productTags = req.body.frmProductTags; |  | ||||||
| 
 |  | ||||||
|                     req.session.message = 'Error: Inserting product'; |  | ||||||
|                     req.session.messageType = 'danger'; |  | ||||||
| 
 |  | ||||||
|                     // redirect to insert
 |  | ||||||
|                     res.redirect('/admin/product/new'); |  | ||||||
|                 }else{ |  | ||||||
|                     // get the new ID
 |  | ||||||
|                     let newId = newDoc.insertedIds[0]; |  | ||||||
| 
 |  | ||||||
|                     // add to lunr index
 |  | ||||||
|                     common.indexProducts(req.app) |  | ||||||
|                     .then(() => { |  | ||||||
|                         req.session.message = 'New product successfully created'; |  | ||||||
|                         req.session.messageType = 'success'; |  | ||||||
| 
 |  | ||||||
|                         // redirect to new doc
 |  | ||||||
|                         res.redirect('/admin/product/edit/' + newId); |  | ||||||
|                     }); |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // render the editor
 |  | ||||||
| router.get('/product/edit/:id', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     common.getImages(req.params.id, req, res, (images) => { |  | ||||||
|         db.products.findOne({_id: common.getId(req.params.id)}, (err, result) => { |  | ||||||
|             if(err){ |  | ||||||
|                 console.info(err.stack); |  | ||||||
|             } |  | ||||||
|             let options = {}; |  | ||||||
|             if(result.productOptions){ |  | ||||||
|                 options = JSON.parse(result.productOptions); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             res.render('product_edit', { |  | ||||||
|                 title: 'Edit product', |  | ||||||
|                 result: result, |  | ||||||
|                 images: images, |  | ||||||
|                 options: options, |  | ||||||
|                 admin: true, |  | ||||||
|                 session: req.session, |  | ||||||
|                 message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|                 messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|                 config: common.getConfig(), |  | ||||||
|                 editor: true, |  | ||||||
|                 helpers: req.handlebars.helpers |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // Update an existing product form action
 |  | ||||||
| router.post('/product/update', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     db.products.findOne({_id: common.getId(req.body.frmProductId)}, (err, product) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|             req.session.message = 'Failed updating product.'; |  | ||||||
|             req.session.messageType = 'danger'; |  | ||||||
|             res.redirect('/admin/product/edit/' + req.body.frmProductId); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         db.products.count({'productPermalink': req.body.frmProductPermalink, _id: {$ne: common.getId(product._id)}}, (err, count) => { |  | ||||||
|             if(err){ |  | ||||||
|                 console.info(err.stack); |  | ||||||
|                 req.session.message = 'Failed updating product.'; |  | ||||||
|                 req.session.messageType = 'danger'; |  | ||||||
|                 res.redirect('/admin/product/edit/' + req.body.frmProductId); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             if(count > 0 && req.body.frmProductPermalink !== ''){ |  | ||||||
|                 // permalink exits
 |  | ||||||
|                 req.session.message = 'Permalink already exists. Pick a new one.'; |  | ||||||
|                 req.session.messageType = 'danger'; |  | ||||||
| 
 |  | ||||||
|                 // keep the current stuff
 |  | ||||||
|                 req.session.productTitle = req.body.frmProductTitle; |  | ||||||
|                 req.session.productDescription = req.body.frmProductDescription; |  | ||||||
|                 req.session.productPrice = req.body.frmProductPrice; |  | ||||||
|                 req.session.productPermalink = req.body.frmProductPermalink; |  | ||||||
|                 req.session.productTags = req.body.frmProductTags; |  | ||||||
|                 req.session.productOptions = req.body.productOptJson; |  | ||||||
| 
 |  | ||||||
|                 // redirect to insert
 |  | ||||||
|                 res.redirect('/admin/product/edit/' + req.body.frmProductId); |  | ||||||
|             }else{ |  | ||||||
|                 common.getImages(req.body.frmProductId, req, res, (images) => { |  | ||||||
|                     let productDoc = { |  | ||||||
|                         productTitle: req.body.frmProductTitle, |  | ||||||
|                         productDescription: req.body.frmProductDescription, |  | ||||||
|                         productPublished: req.body.frmProductPublished, |  | ||||||
|                         productPrice: req.body.frmProductPrice, |  | ||||||
|                         productPermalink: req.body.frmProductPermalink, |  | ||||||
|                         productTags: req.body.frmProductTags, |  | ||||||
|                         productOptions: req.body.productOptJson |  | ||||||
|                     }; |  | ||||||
| 
 |  | ||||||
|                     // if no featured image
 |  | ||||||
|                     if(!product.productImage){ |  | ||||||
|                         if(images.length > 0){ |  | ||||||
|                             productDoc['productImage'] = images[0].path; |  | ||||||
|                         }else{ |  | ||||||
|                             productDoc['productImage'] = '/uploads/placeholder.png'; |  | ||||||
|                         } |  | ||||||
|                     }else{ |  | ||||||
|                         productDoc['productImage'] = product.productImage; |  | ||||||
|                     } |  | ||||||
| 
 |  | ||||||
|                     db.products.update({_id: common.getId(req.body.frmProductId)}, {$set: productDoc}, {}, (err, numReplaced) => { |  | ||||||
|                         if(err){ |  | ||||||
|                             console.error(colors.red('Failed to save product: ' + err)); |  | ||||||
|                             req.session.message = 'Failed to save. Please try again'; |  | ||||||
|                             req.session.messageType = 'danger'; |  | ||||||
|                             res.redirect('/admin/product/edit/' + req.body.frmProductId); |  | ||||||
|                         }else{ |  | ||||||
|                             // Update the index
 |  | ||||||
|                             common.indexProducts(req.app) |  | ||||||
|                             .then(() => { |  | ||||||
|                                 req.session.message = 'Successfully saved'; |  | ||||||
|                                 req.session.messageType = 'success'; |  | ||||||
|                                 res.redirect('/admin/product/edit/' + req.body.frmProductId); |  | ||||||
|                             }); |  | ||||||
|                         } |  | ||||||
|                     }); |  | ||||||
|                 }); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // delete product
 |  | ||||||
| router.get('/product/delete/:id', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     // remove the article
 |  | ||||||
|     db.products.remove({_id: common.getId(req.params.id)}, {}, (err, numRemoved) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         // delete any images and folder
 |  | ||||||
|         rimraf('public/uploads/' + req.params.id, (err) => { |  | ||||||
|             if(err){ |  | ||||||
|                 console.info(err.stack); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             // remove the index
 |  | ||||||
|             common.indexProducts(req.app) |  | ||||||
|             .then(() => { |  | ||||||
|                 // redirect home
 |  | ||||||
|                 req.session.message = 'Product successfully deleted'; |  | ||||||
|                 req.session.messageType = 'success'; |  | ||||||
|                 res.redirect('/admin/products'); |  | ||||||
|             }); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // users
 |  | ||||||
| router.get('/users', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     db.users.find({}).toArray((err, users) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         res.render('users', { |  | ||||||
|             title: 'Users', |  | ||||||
|             users: users, |  | ||||||
|             admin: true, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             isAdmin: req.session.isAdmin, |  | ||||||
|             helpers: req.handlebars.helpers, |  | ||||||
|             session: req.session, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType') |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // edit user
 |  | ||||||
| router.get('/user/edit/:id', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     db.users.findOne({_id: common.getId(req.params.id)}, (err, user) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         // if the user we want to edit is not the current logged in user and the current user is not
 |  | ||||||
|         // an admin we render an access denied message
 |  | ||||||
|         if(user.userEmail !== req.session.user && req.session.isAdmin === 'false'){ |  | ||||||
|             req.session.message = 'Access denied'; |  | ||||||
|             req.session.messageType = 'danger'; |  | ||||||
|             res.redirect('/Users/'); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         res.render('user_edit', { |  | ||||||
|             title: 'User edit', |  | ||||||
|             user: user, |  | ||||||
|             admin: true, |  | ||||||
|             session: req.session, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             helpers: req.handlebars.helpers, |  | ||||||
|             config: common.getConfig() |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // update a user
 |  | ||||||
| router.post('/user/update', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     let isAdmin = req.body.user_admin === 'on' ? 'true' : 'false'; |  | ||||||
| 
 |  | ||||||
|     // get the user we want to update
 |  | ||||||
|     db.users.findOne({_id: common.getId(req.body.userId)}, (err, user) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         // if the user we want to edit is not the current logged in user and the current user is not
 |  | ||||||
|         // an admin we render an access denied message
 |  | ||||||
|         if(user.userEmail !== req.session.user && req.session.isAdmin === 'false'){ |  | ||||||
|             req.session.message = 'Access denied'; |  | ||||||
|             req.session.messageType = 'danger'; |  | ||||||
|             res.redirect('/admin/users/'); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // create the update doc
 |  | ||||||
|         let updateDoc = {}; |  | ||||||
|         updateDoc.isAdmin = isAdmin; |  | ||||||
|         updateDoc.usersName = req.body.usersName; |  | ||||||
|         if(req.body.userPassword){ |  | ||||||
|             updateDoc.userPassword = bcrypt.hashSync(req.body.userPassword); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         db.users.update({_id: common.getId(req.body.userId)}, |  | ||||||
|             { |  | ||||||
|                 $set: updateDoc |  | ||||||
|             }, {multi: false}, (err, numReplaced) => { |  | ||||||
|                 if(err){ |  | ||||||
|                     console.error(colors.red('Failed updating user: ' + err)); |  | ||||||
|                     req.session.message = 'Failed to update user'; |  | ||||||
|                     req.session.messageType = 'danger'; |  | ||||||
|                     res.redirect('/admin/user/edit/' + req.body.userId); |  | ||||||
|                 }else{ |  | ||||||
|                     // show the view
 |  | ||||||
|                     req.session.message = 'User account updated.'; |  | ||||||
|                     req.session.messageType = 'success'; |  | ||||||
|                     res.redirect('/admin/user/edit/' + req.body.userId); |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // insert a user
 | // insert a user
 | ||||||
| router.post('/setup_action', (req, res) => { | router.post('/setup_action', (req, res) => { | ||||||
|     const db = req.app.db; |     const db = req.app.db; | ||||||
|  | @ -671,172 +155,6 @@ router.post('/setup_action', (req, res) => { | ||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // insert a user
 |  | ||||||
| router.post('/user/insert', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     // set the account to admin if using the setup form. Eg: First user account
 |  | ||||||
|     let urlParts = url.parse(req.header('Referer')); |  | ||||||
| 
 |  | ||||||
|     let isAdmin = 'false'; |  | ||||||
|     if(urlParts.path === '/admin/setup'){ |  | ||||||
|         isAdmin = 'true'; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     let doc = { |  | ||||||
|         usersName: req.body.usersName, |  | ||||||
|         userEmail: req.body.userEmail, |  | ||||||
|         userPassword: bcrypt.hashSync(req.body.userPassword, 10), |  | ||||||
|         isAdmin: isAdmin |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     // check for existing user
 |  | ||||||
|     db.users.findOne({'userEmail': req.body.userEmail}, (err, user) => { |  | ||||||
|         if(user){ |  | ||||||
|             // user already exists with that email address
 |  | ||||||
|             console.error(colors.red('Failed to insert user, possibly already exists: ' + err)); |  | ||||||
|             req.session.message = 'A user with that email address already exists'; |  | ||||||
|             req.session.messageType = 'danger'; |  | ||||||
|             res.redirect('/admin/user/new'); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         // email is ok to be used.
 |  | ||||||
|         db.users.insert(doc, (err, doc) => { |  | ||||||
|             // show the view
 |  | ||||||
|             if(err){ |  | ||||||
|                 if(doc){ |  | ||||||
|                     console.error(colors.red('Failed to insert user: ' + err)); |  | ||||||
|                     req.session.message = 'User exists'; |  | ||||||
|                     req.session.messageType = 'danger'; |  | ||||||
|                     res.redirect('/admin/user/edit/' + doc._id); |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|                 console.error(colors.red('Failed to insert user: ' + err)); |  | ||||||
|                 req.session.message = 'New user creation failed'; |  | ||||||
|                 req.session.messageType = 'danger'; |  | ||||||
|                 res.redirect('/admin/user/new'); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             req.session.message = 'User account inserted'; |  | ||||||
|             req.session.messageType = 'success'; |  | ||||||
| 
 |  | ||||||
|             // if from setup we add user to session and redirect to login.
 |  | ||||||
|             // Otherwise we show users screen
 |  | ||||||
|             if(urlParts.path === '/admin/setup'){ |  | ||||||
|                 req.session.user = req.body.userEmail; |  | ||||||
|                 res.redirect('/admin/login'); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             res.redirect('/admin/users'); |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // render the customer view
 |  | ||||||
| router.get('/customer/view/:id?', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     console.log('here'); |  | ||||||
| 
 |  | ||||||
|     db.customers.findOne({_id: common.getId(req.params.id)}, (err, result) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         res.render('customer', { |  | ||||||
|             title: 'View customer', |  | ||||||
|             result: result, |  | ||||||
|             admin: true, |  | ||||||
|             session: req.session, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             editor: true, |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // customers list
 |  | ||||||
| router.get('/customers', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     db.customers.find({}).limit(20).sort({created: -1}).toArray((err, customers) => { |  | ||||||
|         res.render('customers', { |  | ||||||
|             title: 'Customers - List', |  | ||||||
|             admin: true, |  | ||||||
|             customers: customers, |  | ||||||
|             session: req.session, |  | ||||||
|             helpers: req.handlebars.helpers, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             config: common.getConfig() |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // Filtered customers list
 |  | ||||||
| router.get('/customers/filter/:search', common.restrict, (req, res, next) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     let searchTerm = req.params.search; |  | ||||||
|     let customersIndex = req.app.customersIndex; |  | ||||||
| 
 |  | ||||||
|     let lunrIdArray = []; |  | ||||||
|     customersIndex.search(searchTerm).forEach((id) => { |  | ||||||
|         lunrIdArray.push(common.getId(id.ref)); |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     // we search on the lunr indexes
 |  | ||||||
|     db.customers.find({_id: {$in: lunrIdArray}}).sort({created: -1}).toArray((err, customers) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.error(colors.red('Error searching', err)); |  | ||||||
|         } |  | ||||||
|         res.render('customers', { |  | ||||||
|             title: 'Customer results', |  | ||||||
|             customers: customers, |  | ||||||
|             admin: true, |  | ||||||
|             config: common.getConfig(), |  | ||||||
|             session: req.session, |  | ||||||
|             searchTerm: searchTerm, |  | ||||||
|             message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|             messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|             helpers: req.handlebars.helpers |  | ||||||
|         }); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // users new
 |  | ||||||
| router.get('/user/new', common.restrict, (req, res) => { |  | ||||||
|     res.render('user_new', { |  | ||||||
|         title: 'User - New', |  | ||||||
|         admin: true, |  | ||||||
|         session: req.session, |  | ||||||
|         helpers: req.handlebars.helpers, |  | ||||||
|         message: common.clearSessionValue(req.session, 'message'), |  | ||||||
|         messageType: common.clearSessionValue(req.session, 'messageType'), |  | ||||||
|         config: common.getConfig() |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // delete user
 |  | ||||||
| router.get('/user/delete/:id', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
|     if(req.session.isAdmin === 'true'){ |  | ||||||
|         db.users.remove({_id: common.getId(req.params.id)}, {}, (err, numRemoved) => { |  | ||||||
|             if(err){ |  | ||||||
|                 console.info(err.stack); |  | ||||||
|             } |  | ||||||
|             req.session.message = 'User deleted.'; |  | ||||||
|             req.session.messageType = 'success'; |  | ||||||
|             res.redirect('/admin/users'); |  | ||||||
|         }); |  | ||||||
|     }else{ |  | ||||||
|         req.session.message = 'Access denied.'; |  | ||||||
|         req.session.messageType = 'danger'; |  | ||||||
|         res.redirect('/admin/users'); |  | ||||||
|     } |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // settings update
 | // settings update
 | ||||||
| router.get('/settings', common.restrict, (req, res) => { | router.get('/settings', common.restrict, (req, res) => { | ||||||
|     res.render('settings', { |     res.render('settings', { | ||||||
|  | @ -1103,75 +421,7 @@ router.post('/api/validate_permalink', (req, res) => { | ||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // update the published state based on an ajax call from the frontend
 |  | ||||||
| router.post('/product/published_state', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     db.products.update({_id: common.getId(req.body.id)}, {$set: {productPublished: req.body.state}}, {multi: false}, (err, numReplaced) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.error(colors.red('Failed to update the published state: ' + err)); |  | ||||||
|             res.writeHead(400, {'Content-Type': 'application/text'}); |  | ||||||
|             res.end('Published state not updated'); |  | ||||||
|         }else{ |  | ||||||
|             res.writeHead(200, {'Content-Type': 'application/text'}); |  | ||||||
|             res.end('Published state updated'); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // set as main product image
 |  | ||||||
| router.post('/product/setasmainimage', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     // update the productImage to the db
 |  | ||||||
|     db.products.update({_id: common.getId(req.body.product_id)}, {$set: {productImage: req.body.productImage}}, {multi: false}, (err, numReplaced) => { |  | ||||||
|         if(err){ |  | ||||||
|             res.status(400).json({message: 'Unable to set as main image. Please try again.'}); |  | ||||||
|         }else{ |  | ||||||
|             res.status(200).json({message: 'Main image successfully set'}); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // deletes a product image
 |  | ||||||
| router.post('/product/deleteimage', common.restrict, (req, res) => { |  | ||||||
|     const db = req.app.db; |  | ||||||
| 
 |  | ||||||
|     // get the productImage from the db
 |  | ||||||
|     db.products.findOne({_id: common.getId(req.body.product_id)}, (err, product) => { |  | ||||||
|         if(err){ |  | ||||||
|             console.info(err.stack); |  | ||||||
|         } |  | ||||||
|         if(req.body.productImage === product.productImage){ |  | ||||||
|             // set the produt_image to null
 |  | ||||||
|             db.products.update({_id: common.getId(req.body.product_id)}, {$set: {productImage: null}}, {multi: false}, (err, numReplaced) => { |  | ||||||
|                 if(err){ |  | ||||||
|                     console.info(err.stack); |  | ||||||
|                 } |  | ||||||
|                 // remove the image from disk
 |  | ||||||
|                 fs.unlink(path.join('public', req.body.productImage), (err) => { |  | ||||||
|                     if(err){ |  | ||||||
|                         res.status(400).json({message: 'Image not removed, please try again.'}); |  | ||||||
|                     }else{ |  | ||||||
|                         res.status(200).json({message: 'Image successfully deleted'}); |  | ||||||
|                     } |  | ||||||
|                 }); |  | ||||||
|             }); |  | ||||||
|         }else{ |  | ||||||
|             // remove the image from disk
 |  | ||||||
|             fs.unlink(path.join('public', req.body.productImage), (err) => { |  | ||||||
|                 if(err){ |  | ||||||
|                     res.status(400).json({message: 'Image not removed, please try again.'}); |  | ||||||
|                 }else{ |  | ||||||
|                     res.status(200).json({message: 'Image successfully deleted'}); |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| 
 |  | ||||||
| // upload the file
 | // upload the file
 | ||||||
| 
 |  | ||||||
| let upload = multer({dest: 'public/uploads/'}); | let upload = multer({dest: 'public/uploads/'}); | ||||||
| router.post('/file/upload', common.restrict, upload.single('upload_file'), (req, res, next) => { | router.post('/file/upload', common.restrict, upload.single('upload_file'), (req, res, next) => { | ||||||
|     const db = req.app.db; |     const db = req.app.db; | ||||||
|  |  | ||||||
|  | @ -58,6 +58,77 @@ router.post('/customer/create', (req, res) => { | ||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | // render the customer view
 | ||||||
|  | router.get('/customer/view/:id?', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     db.customers.findOne({_id: common.getId(req.params.id)}, (err, result) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         res.render('customer', { | ||||||
|  |             title: 'View customer', | ||||||
|  |             result: result, | ||||||
|  |             admin: true, | ||||||
|  |             session: req.session, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             editor: true, | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // customers list
 | ||||||
|  | router.get('/customers', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     db.customers.find({}).limit(20).sort({created: -1}).toArray((err, customers) => { | ||||||
|  |         res.render('customers', { | ||||||
|  |             title: 'Customers - List', | ||||||
|  |             admin: true, | ||||||
|  |             customers: customers, | ||||||
|  |             session: req.session, | ||||||
|  |             helpers: req.handlebars.helpers, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             config: common.getConfig() | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // Filtered customers list
 | ||||||
|  | router.get('/customers/filter/:search', common.restrict, (req, res, next) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     let searchTerm = req.params.search; | ||||||
|  |     let customersIndex = req.app.customersIndex; | ||||||
|  | 
 | ||||||
|  |     let lunrIdArray = []; | ||||||
|  |     customersIndex.search(searchTerm).forEach((id) => { | ||||||
|  |         lunrIdArray.push(common.getId(id.ref)); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     // we search on the lunr indexes
 | ||||||
|  |     db.customers.find({_id: {$in: lunrIdArray}}).sort({created: -1}).toArray((err, customers) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.error(colors.red('Error searching', err)); | ||||||
|  |         } | ||||||
|  |         res.render('customers', { | ||||||
|  |             title: 'Customer results', | ||||||
|  |             customers: customers, | ||||||
|  |             admin: true, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             session: req.session, | ||||||
|  |             searchTerm: searchTerm, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| // login the customer and check the password
 | // login the customer and check the password
 | ||||||
| router.post('/customer/login_action', (req, res) => { | router.post('/customer/login_action', (req, res) => { | ||||||
|     let db = req.app.db; |     let db = req.app.db; | ||||||
|  |  | ||||||
|  | @ -5,6 +5,8 @@ const async = require('async'); | ||||||
| const _ = require('lodash'); | const _ = require('lodash'); | ||||||
| const common = require('./common'); | const common = require('./common'); | ||||||
| 
 | 
 | ||||||
|  | // These is the customer facing routes
 | ||||||
|  | 
 | ||||||
| router.get('/payment/:orderId', async (req, res, next) => { | router.get('/payment/:orderId', async (req, res, next) => { | ||||||
|     let db = req.app.db; |     let db = req.app.db; | ||||||
|     let config = common.getConfig(); |     let config = common.getConfig(); | ||||||
|  |  | ||||||
|  | @ -0,0 +1,144 @@ | ||||||
|  | const express = require('express'); | ||||||
|  | const common = require('./common'); | ||||||
|  | const router = express.Router(); | ||||||
|  | 
 | ||||||
|  | // Show orders
 | ||||||
|  | router.get('/orders', common.restrict, (req, res, next) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     // Top 10 products
 | ||||||
|  |     db.orders.find({}).sort({'orderDate': -1}).limit(10).toArray((err, orders) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         res.render('orders', { | ||||||
|  |             title: 'Cart', | ||||||
|  |             orders: orders, | ||||||
|  |             admin: true, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             session: req.session, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // Admin section
 | ||||||
|  | router.get('/orders/bystatus/:orderstatus', common.restrict, (req, res, next) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     if(typeof req.params.orderstatus === 'undefined'){ | ||||||
|  |         res.redirect('/admin/orders'); | ||||||
|  |         return; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // case insensitive search
 | ||||||
|  |     let regex = new RegExp(['^', req.params.orderstatus, '$'].join(''), 'i'); | ||||||
|  |     db.orders.find({orderStatus: regex}).sort({'orderDate': -1}).limit(10).toArray((err, orders) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         res.render('orders', { | ||||||
|  |             title: 'Cart', | ||||||
|  |             orders: orders, | ||||||
|  |             admin: true, | ||||||
|  |             filteredOrders: true, | ||||||
|  |             filteredStatus: req.params.orderstatus, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             session: req.session, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // render the editor
 | ||||||
|  | router.get('/order/view/:id', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     db.orders.findOne({_id: common.getId(req.params.id)}, (err, result) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         let productOptions = ''; | ||||||
|  |         if(result.options !== {}){ | ||||||
|  |             productOptions = result.options; | ||||||
|  |         } | ||||||
|  |         res.render('order', { | ||||||
|  |             title: 'View order', | ||||||
|  |             result: result, | ||||||
|  |             productOptions: productOptions, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             session: req.session, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             editor: true, | ||||||
|  |             admin: true, | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // Admin section
 | ||||||
|  | router.get('/orders/filter/:search', common.restrict, (req, res, next) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     let searchTerm = req.params.search; | ||||||
|  |     let ordersIndex = req.app.ordersIndex; | ||||||
|  | 
 | ||||||
|  |     let lunrIdArray = []; | ||||||
|  |     ordersIndex.search(searchTerm).forEach((id) => { | ||||||
|  |         lunrIdArray.push(common.getId(id.ref)); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     // we search on the lunr indexes
 | ||||||
|  |     db.orders.find({_id: {$in: lunrIdArray}}).toArray((err, orders) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         res.render('orders', { | ||||||
|  |             title: 'Order results', | ||||||
|  |             orders: orders, | ||||||
|  |             admin: true, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             session: req.session, | ||||||
|  |             searchTerm: searchTerm, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // order product
 | ||||||
|  | router.get('/order/delete/:id', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     // remove the article
 | ||||||
|  |     db.orders.remove({_id: common.getId(req.params.id)}, {}, (err, numRemoved) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         // remove the index
 | ||||||
|  |         common.indexOrders(req.app) | ||||||
|  |         .then(() => { | ||||||
|  |             // redirect home
 | ||||||
|  |             req.session.message = 'Order successfully deleted'; | ||||||
|  |             req.session.messageType = 'success'; | ||||||
|  |             res.redirect('/admin/orders'); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // update order status
 | ||||||
|  | router.post('/order/statusupdate', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     db.orders.update({_id: common.getId(req.body.order_id)}, {$set: {orderStatus: req.body.status}}, {multi: false}, (err, numReplaced) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         res.status(200).json({message: 'Status successfully updated'}); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | module.exports = router; | ||||||
|  | @ -0,0 +1,352 @@ | ||||||
|  | const express = require('express'); | ||||||
|  | const common = require('./common'); | ||||||
|  | const colors = require('colors'); | ||||||
|  | const rimraf = require('rimraf'); | ||||||
|  | const fs = require('fs'); | ||||||
|  | const path = require('path'); | ||||||
|  | const router = express.Router(); | ||||||
|  | 
 | ||||||
|  | router.get('/products', common.restrict, (req, res, next) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     // get the top results
 | ||||||
|  |     db.products.find({}).sort({'productAddedDate': -1}).limit(10).toArray((err, topResults) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         res.render('products', { | ||||||
|  |             title: 'Cart', | ||||||
|  |             top_results: topResults, | ||||||
|  |             session: req.session, | ||||||
|  |             admin: true, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | router.get('/products/filter/:search', common.restrict, (req, res, next) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     let searchTerm = req.params.search; | ||||||
|  |     let productsIndex = req.app.productsIndex; | ||||||
|  | 
 | ||||||
|  |     let lunrIdArray = []; | ||||||
|  |     productsIndex.search(searchTerm).forEach((id) => { | ||||||
|  |         lunrIdArray.push(common.getId(id.ref)); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     // we search on the lunr indexes
 | ||||||
|  |     db.products.find({_id: {$in: lunrIdArray}}).toArray((err, results) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.error(colors.red('Error searching', err)); | ||||||
|  |         } | ||||||
|  |         res.render('products', { | ||||||
|  |             title: 'Results', | ||||||
|  |             results: results, | ||||||
|  |             admin: true, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             session: req.session, | ||||||
|  |             searchTerm: searchTerm, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             helpers: req.handlebars.helpers | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // insert form
 | ||||||
|  | router.get('/product/new', common.restrict, (req, res) => { | ||||||
|  |     res.render('product_new', { | ||||||
|  |         title: 'New product', | ||||||
|  |         session: req.session, | ||||||
|  |         productTitle: common.clearSessionValue(req.session, 'productTitle'), | ||||||
|  |         productDescription: common.clearSessionValue(req.session, 'productDescription'), | ||||||
|  |         productPrice: common.clearSessionValue(req.session, 'productPrice'), | ||||||
|  |         productPermalink: common.clearSessionValue(req.session, 'productPermalink'), | ||||||
|  |         message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |         messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |         editor: true, | ||||||
|  |         admin: true, | ||||||
|  |         helpers: req.handlebars.helpers, | ||||||
|  |         config: common.getConfig() | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // insert new product form action
 | ||||||
|  | router.post('/product/insert', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     let doc = { | ||||||
|  |         productPermalink: req.body.frmProductPermalink, | ||||||
|  |         productTitle: req.body.frmProductTitle, | ||||||
|  |         productPrice: req.body.frmProductPrice, | ||||||
|  |         productDescription: req.body.frmProductDescription, | ||||||
|  |         productPublished: req.body.frmProductPublished, | ||||||
|  |         productTags: req.body.frmProductTags, | ||||||
|  |         productOptions: req.body.productOptJson, | ||||||
|  |         productAddedDate: new Date() | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     db.products.count({'productPermalink': req.body.frmProductPermalink}, (err, product) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         if(product > 0 && req.body.frmProductPermalink !== ''){ | ||||||
|  |             // permalink exits
 | ||||||
|  |             req.session.message = 'Permalink already exists. Pick a new one.'; | ||||||
|  |             req.session.messageType = 'danger'; | ||||||
|  | 
 | ||||||
|  |             // keep the current stuff
 | ||||||
|  |             req.session.productTitle = req.body.frmProductTitle; | ||||||
|  |             req.session.productDescription = req.body.frmProductDescription; | ||||||
|  |             req.session.productPrice = req.body.frmProductPrice; | ||||||
|  |             req.session.productPermalink = req.body.frmProductPermalink; | ||||||
|  |             req.session.productPermalink = req.body.productOptJson; | ||||||
|  |             req.session.productTags = req.body.frmProductTags; | ||||||
|  | 
 | ||||||
|  |             // redirect to insert
 | ||||||
|  |             res.redirect('/admin/insert'); | ||||||
|  |         }else{ | ||||||
|  |             db.products.insert(doc, (err, newDoc) => { | ||||||
|  |                 if(err){ | ||||||
|  |                     console.log(colors.red('Error inserting document: ' + err)); | ||||||
|  | 
 | ||||||
|  |                     // keep the current stuff
 | ||||||
|  |                     req.session.productTitle = req.body.frmProductTitle; | ||||||
|  |                     req.session.productDescription = req.body.frmProductDescription; | ||||||
|  |                     req.session.productPrice = req.body.frmProductPrice; | ||||||
|  |                     req.session.productPermalink = req.body.frmProductPermalink; | ||||||
|  |                     req.session.productPermalink = req.body.productOptJson; | ||||||
|  |                     req.session.productTags = req.body.frmProductTags; | ||||||
|  | 
 | ||||||
|  |                     req.session.message = 'Error: Inserting product'; | ||||||
|  |                     req.session.messageType = 'danger'; | ||||||
|  | 
 | ||||||
|  |                     // redirect to insert
 | ||||||
|  |                     res.redirect('/admin/product/new'); | ||||||
|  |                 }else{ | ||||||
|  |                     // get the new ID
 | ||||||
|  |                     let newId = newDoc.insertedIds[0]; | ||||||
|  | 
 | ||||||
|  |                     // add to lunr index
 | ||||||
|  |                     common.indexProducts(req.app) | ||||||
|  |                     .then(() => { | ||||||
|  |                         req.session.message = 'New product successfully created'; | ||||||
|  |                         req.session.messageType = 'success'; | ||||||
|  | 
 | ||||||
|  |                         // redirect to new doc
 | ||||||
|  |                         res.redirect('/admin/product/edit/' + newId); | ||||||
|  |                     }); | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // render the editor
 | ||||||
|  | router.get('/product/edit/:id', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     common.getImages(req.params.id, req, res, (images) => { | ||||||
|  |         db.products.findOne({_id: common.getId(req.params.id)}, (err, result) => { | ||||||
|  |             if(err){ | ||||||
|  |                 console.info(err.stack); | ||||||
|  |             } | ||||||
|  |             let options = {}; | ||||||
|  |             if(result.productOptions){ | ||||||
|  |                 options = JSON.parse(result.productOptions); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             res.render('product_edit', { | ||||||
|  |                 title: 'Edit product', | ||||||
|  |                 result: result, | ||||||
|  |                 images: images, | ||||||
|  |                 options: options, | ||||||
|  |                 admin: true, | ||||||
|  |                 session: req.session, | ||||||
|  |                 message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |                 messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |                 config: common.getConfig(), | ||||||
|  |                 editor: true, | ||||||
|  |                 helpers: req.handlebars.helpers | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // Update an existing product form action
 | ||||||
|  | router.post('/product/update', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     db.products.findOne({_id: common.getId(req.body.frmProductId)}, (err, product) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |             req.session.message = 'Failed updating product.'; | ||||||
|  |             req.session.messageType = 'danger'; | ||||||
|  |             res.redirect('/admin/product/edit/' + req.body.frmProductId); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         db.products.count({'productPermalink': req.body.frmProductPermalink, _id: {$ne: common.getId(product._id)}}, (err, count) => { | ||||||
|  |             if(err){ | ||||||
|  |                 console.info(err.stack); | ||||||
|  |                 req.session.message = 'Failed updating product.'; | ||||||
|  |                 req.session.messageType = 'danger'; | ||||||
|  |                 res.redirect('/admin/product/edit/' + req.body.frmProductId); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             if(count > 0 && req.body.frmProductPermalink !== ''){ | ||||||
|  |                 // permalink exits
 | ||||||
|  |                 req.session.message = 'Permalink already exists. Pick a new one.'; | ||||||
|  |                 req.session.messageType = 'danger'; | ||||||
|  | 
 | ||||||
|  |                 // keep the current stuff
 | ||||||
|  |                 req.session.productTitle = req.body.frmProductTitle; | ||||||
|  |                 req.session.productDescription = req.body.frmProductDescription; | ||||||
|  |                 req.session.productPrice = req.body.frmProductPrice; | ||||||
|  |                 req.session.productPermalink = req.body.frmProductPermalink; | ||||||
|  |                 req.session.productTags = req.body.frmProductTags; | ||||||
|  |                 req.session.productOptions = req.body.productOptJson; | ||||||
|  | 
 | ||||||
|  |                 // redirect to insert
 | ||||||
|  |                 res.redirect('/admin/product/edit/' + req.body.frmProductId); | ||||||
|  |             }else{ | ||||||
|  |                 common.getImages(req.body.frmProductId, req, res, (images) => { | ||||||
|  |                     let productDoc = { | ||||||
|  |                         productTitle: req.body.frmProductTitle, | ||||||
|  |                         productDescription: req.body.frmProductDescription, | ||||||
|  |                         productPublished: req.body.frmProductPublished, | ||||||
|  |                         productPrice: req.body.frmProductPrice, | ||||||
|  |                         productPermalink: req.body.frmProductPermalink, | ||||||
|  |                         productTags: req.body.frmProductTags, | ||||||
|  |                         productOptions: req.body.productOptJson | ||||||
|  |                     }; | ||||||
|  | 
 | ||||||
|  |                     // if no featured image
 | ||||||
|  |                     if(!product.productImage){ | ||||||
|  |                         if(images.length > 0){ | ||||||
|  |                             productDoc['productImage'] = images[0].path; | ||||||
|  |                         }else{ | ||||||
|  |                             productDoc['productImage'] = '/uploads/placeholder.png'; | ||||||
|  |                         } | ||||||
|  |                     }else{ | ||||||
|  |                         productDoc['productImage'] = product.productImage; | ||||||
|  |                     } | ||||||
|  | 
 | ||||||
|  |                     db.products.update({_id: common.getId(req.body.frmProductId)}, {$set: productDoc}, {}, (err, numReplaced) => { | ||||||
|  |                         if(err){ | ||||||
|  |                             console.error(colors.red('Failed to save product: ' + err)); | ||||||
|  |                             req.session.message = 'Failed to save. Please try again'; | ||||||
|  |                             req.session.messageType = 'danger'; | ||||||
|  |                             res.redirect('/admin/product/edit/' + req.body.frmProductId); | ||||||
|  |                         }else{ | ||||||
|  |                             // Update the index
 | ||||||
|  |                             common.indexProducts(req.app) | ||||||
|  |                             .then(() => { | ||||||
|  |                                 req.session.message = 'Successfully saved'; | ||||||
|  |                                 req.session.messageType = 'success'; | ||||||
|  |                                 res.redirect('/admin/product/edit/' + req.body.frmProductId); | ||||||
|  |                             }); | ||||||
|  |                         } | ||||||
|  |                     }); | ||||||
|  |                 }); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // delete product
 | ||||||
|  | router.get('/product/delete/:id', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     // remove the article
 | ||||||
|  |     db.products.remove({_id: common.getId(req.params.id)}, {}, (err, numRemoved) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         // delete any images and folder
 | ||||||
|  |         rimraf('public/uploads/' + req.params.id, (err) => { | ||||||
|  |             if(err){ | ||||||
|  |                 console.info(err.stack); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             // remove the index
 | ||||||
|  |             common.indexProducts(req.app) | ||||||
|  |             .then(() => { | ||||||
|  |                 // redirect home
 | ||||||
|  |                 req.session.message = 'Product successfully deleted'; | ||||||
|  |                 req.session.messageType = 'success'; | ||||||
|  |                 res.redirect('/admin/products'); | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // update the published state based on an ajax call from the frontend
 | ||||||
|  | router.post('/product/published_state', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     db.products.update({_id: common.getId(req.body.id)}, {$set: {productPublished: req.body.state}}, {multi: false}, (err, numReplaced) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.error(colors.red('Failed to update the published state: ' + err)); | ||||||
|  |             res.writeHead(400, {'Content-Type': 'application/text'}); | ||||||
|  |             res.end('Published state not updated'); | ||||||
|  |         }else{ | ||||||
|  |             res.writeHead(200, {'Content-Type': 'application/text'}); | ||||||
|  |             res.end('Published state updated'); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // set as main product image
 | ||||||
|  | router.post('/product/setasmainimage', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     // update the productImage to the db
 | ||||||
|  |     db.products.update({_id: common.getId(req.body.product_id)}, {$set: {productImage: req.body.productImage}}, {multi: false}, (err, numReplaced) => { | ||||||
|  |         if(err){ | ||||||
|  |             res.status(400).json({message: 'Unable to set as main image. Please try again.'}); | ||||||
|  |         }else{ | ||||||
|  |             res.status(200).json({message: 'Main image successfully set'}); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // deletes a product image
 | ||||||
|  | router.post('/product/deleteimage', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     // get the productImage from the db
 | ||||||
|  |     db.products.findOne({_id: common.getId(req.body.product_id)}, (err, product) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         if(req.body.productImage === product.productImage){ | ||||||
|  |             // set the produt_image to null
 | ||||||
|  |             db.products.update({_id: common.getId(req.body.product_id)}, {$set: {productImage: null}}, {multi: false}, (err, numReplaced) => { | ||||||
|  |                 if(err){ | ||||||
|  |                     console.info(err.stack); | ||||||
|  |                 } | ||||||
|  |                 // remove the image from disk
 | ||||||
|  |                 fs.unlink(path.join('public', req.body.productImage), (err) => { | ||||||
|  |                     if(err){ | ||||||
|  |                         res.status(400).json({message: 'Image not removed, please try again.'}); | ||||||
|  |                     }else{ | ||||||
|  |                         res.status(200).json({message: 'Image successfully deleted'}); | ||||||
|  |                     } | ||||||
|  |                 }); | ||||||
|  |             }); | ||||||
|  |         }else{ | ||||||
|  |             // remove the image from disk
 | ||||||
|  |             fs.unlink(path.join('public', req.body.productImage), (err) => { | ||||||
|  |                 if(err){ | ||||||
|  |                     res.status(400).json({message: 'Image not removed, please try again.'}); | ||||||
|  |                 }else{ | ||||||
|  |                     res.status(200).json({message: 'Image successfully deleted'}); | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | module.exports = router; | ||||||
|  | @ -0,0 +1,196 @@ | ||||||
|  | const express = require('express'); | ||||||
|  | const common = require('./common'); | ||||||
|  | const colors = require('colors'); | ||||||
|  | const bcrypt = require('bcryptjs'); | ||||||
|  | const router = express.Router(); | ||||||
|  | 
 | ||||||
|  | router.get('/users', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     db.users.find({}).toArray((err, users) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         res.render('users', { | ||||||
|  |             title: 'Users', | ||||||
|  |             users: users, | ||||||
|  |             admin: true, | ||||||
|  |             config: common.getConfig(), | ||||||
|  |             isAdmin: req.session.isAdmin, | ||||||
|  |             helpers: req.handlebars.helpers, | ||||||
|  |             session: req.session, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType') | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // edit user
 | ||||||
|  | router.get('/user/edit/:id', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     db.users.findOne({_id: common.getId(req.params.id)}, (err, user) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         // if the user we want to edit is not the current logged in user and the current user is not
 | ||||||
|  |         // an admin we render an access denied message
 | ||||||
|  |         if(user.userEmail !== req.session.user && req.session.isAdmin === 'false'){ | ||||||
|  |             req.session.message = 'Access denied'; | ||||||
|  |             req.session.messageType = 'danger'; | ||||||
|  |             res.redirect('/Users/'); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         res.render('user_edit', { | ||||||
|  |             title: 'User edit', | ||||||
|  |             user: user, | ||||||
|  |             admin: true, | ||||||
|  |             session: req.session, | ||||||
|  |             message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |             messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |             helpers: req.handlebars.helpers, | ||||||
|  |             config: common.getConfig() | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // users new
 | ||||||
|  | router.get('/user/new', common.restrict, (req, res) => { | ||||||
|  |     res.render('user_new', { | ||||||
|  |         title: 'User - New', | ||||||
|  |         admin: true, | ||||||
|  |         session: req.session, | ||||||
|  |         helpers: req.handlebars.helpers, | ||||||
|  |         message: common.clearSessionValue(req.session, 'message'), | ||||||
|  |         messageType: common.clearSessionValue(req.session, 'messageType'), | ||||||
|  |         config: common.getConfig() | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // delete user
 | ||||||
|  | router.get('/user/delete/:id', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  |     if(req.session.isAdmin === 'true'){ | ||||||
|  |         db.users.remove({_id: common.getId(req.params.id)}, {}, (err, numRemoved) => { | ||||||
|  |             if(err){ | ||||||
|  |                 console.info(err.stack); | ||||||
|  |             } | ||||||
|  |             req.session.message = 'User deleted.'; | ||||||
|  |             req.session.messageType = 'success'; | ||||||
|  |             res.redirect('/admin/users'); | ||||||
|  |         }); | ||||||
|  |     }else{ | ||||||
|  |         req.session.message = 'Access denied.'; | ||||||
|  |         req.session.messageType = 'danger'; | ||||||
|  |         res.redirect('/admin/users'); | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // update a user
 | ||||||
|  | router.post('/user/update', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     let isAdmin = req.body.user_admin === 'on' ? 'true' : 'false'; | ||||||
|  | 
 | ||||||
|  |     // get the user we want to update
 | ||||||
|  |     db.users.findOne({_id: common.getId(req.body.userId)}, (err, user) => { | ||||||
|  |         if(err){ | ||||||
|  |             console.info(err.stack); | ||||||
|  |         } | ||||||
|  |         // if the user we want to edit is not the current logged in user and the current user is not
 | ||||||
|  |         // an admin we render an access denied message
 | ||||||
|  |         if(user.userEmail !== req.session.user && req.session.isAdmin === 'false'){ | ||||||
|  |             req.session.message = 'Access denied'; | ||||||
|  |             req.session.messageType = 'danger'; | ||||||
|  |             res.redirect('/admin/users/'); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // create the update doc
 | ||||||
|  |         let updateDoc = {}; | ||||||
|  |         updateDoc.isAdmin = isAdmin; | ||||||
|  |         updateDoc.usersName = req.body.usersName; | ||||||
|  |         if(req.body.userPassword){ | ||||||
|  |             updateDoc.userPassword = bcrypt.hashSync(req.body.userPassword); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         db.users.update({_id: common.getId(req.body.userId)}, | ||||||
|  |             { | ||||||
|  |                 $set: updateDoc | ||||||
|  |             }, {multi: false}, (err, numReplaced) => { | ||||||
|  |                 if(err){ | ||||||
|  |                     console.error(colors.red('Failed updating user: ' + err)); | ||||||
|  |                     req.session.message = 'Failed to update user'; | ||||||
|  |                     req.session.messageType = 'danger'; | ||||||
|  |                     res.redirect('/admin/user/edit/' + req.body.userId); | ||||||
|  |                 }else{ | ||||||
|  |                     // show the view
 | ||||||
|  |                     req.session.message = 'User account updated.'; | ||||||
|  |                     req.session.messageType = 'success'; | ||||||
|  |                     res.redirect('/admin/user/edit/' + req.body.userId); | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | // insert a user
 | ||||||
|  | router.post('/user/insert', common.restrict, (req, res) => { | ||||||
|  |     const db = req.app.db; | ||||||
|  | 
 | ||||||
|  |     // set the account to admin if using the setup form. Eg: First user account
 | ||||||
|  |     let urlParts = url.parse(req.header('Referer')); | ||||||
|  | 
 | ||||||
|  |     let isAdmin = 'false'; | ||||||
|  |     if(urlParts.path === '/admin/setup'){ | ||||||
|  |         isAdmin = 'true'; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     let doc = { | ||||||
|  |         usersName: req.body.usersName, | ||||||
|  |         userEmail: req.body.userEmail, | ||||||
|  |         userPassword: bcrypt.hashSync(req.body.userPassword, 10), | ||||||
|  |         isAdmin: isAdmin | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     // check for existing user
 | ||||||
|  |     db.users.findOne({'userEmail': req.body.userEmail}, (err, user) => { | ||||||
|  |         if(user){ | ||||||
|  |             // user already exists with that email address
 | ||||||
|  |             console.error(colors.red('Failed to insert user, possibly already exists: ' + err)); | ||||||
|  |             req.session.message = 'A user with that email address already exists'; | ||||||
|  |             req.session.messageType = 'danger'; | ||||||
|  |             res.redirect('/admin/user/new'); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         // email is ok to be used.
 | ||||||
|  |         db.users.insert(doc, (err, doc) => { | ||||||
|  |             // show the view
 | ||||||
|  |             if(err){ | ||||||
|  |                 if(doc){ | ||||||
|  |                     console.error(colors.red('Failed to insert user: ' + err)); | ||||||
|  |                     req.session.message = 'User exists'; | ||||||
|  |                     req.session.messageType = 'danger'; | ||||||
|  |                     res.redirect('/admin/user/edit/' + doc._id); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 console.error(colors.red('Failed to insert user: ' + err)); | ||||||
|  |                 req.session.message = 'New user creation failed'; | ||||||
|  |                 req.session.messageType = 'danger'; | ||||||
|  |                 res.redirect('/admin/user/new'); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             req.session.message = 'User account inserted'; | ||||||
|  |             req.session.messageType = 'success'; | ||||||
|  | 
 | ||||||
|  |             // if from setup we add user to session and redirect to login.
 | ||||||
|  |             // Otherwise we show users screen
 | ||||||
|  |             if(urlParts.path === '/admin/setup'){ | ||||||
|  |                 req.session.user = req.body.userEmail; | ||||||
|  |                 res.redirect('/admin/login'); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             res.redirect('/admin/users'); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | module.exports = router; | ||||||
		Loading…
	
		Reference in New Issue