| 
									
										
										
										
											2018-08-31 16:04:04 +01:00
										 |  |  | // import { inspect } from 'util';
 | 
					
						
							|  |  |  | // import _ from 'lodash/fp';
 | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  | import accepts from 'accepts'; | 
					
						
							| 
									
										
										
										
											2018-08-29 20:52:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-31 16:04:04 +01:00
										 |  |  | import { homeLocation } from '../../../config/env'; | 
					
						
							| 
									
										
										
										
											2018-08-29 20:52:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-13 11:39:07 -07:00
										 |  |  | import { unwrapHandledError } from '../utils/create-handled-error.js'; | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-24 09:15:00 +01:00
										 |  |  | const errTemplate = (error, req) => { | 
					
						
							|  |  |  |   const { message, stack } = error; | 
					
						
							|  |  |  |   return `
 | 
					
						
							|  |  |  | Error: ${message} | 
					
						
							|  |  |  | Is authenticated user: ${!!req.user} | 
					
						
							|  |  |  | Headers: ${JSON.stringify(req.headers, null, 2)} | 
					
						
							|  |  |  | Original request: ${req.originalMethod} ${req.originalUrl} | 
					
						
							|  |  |  | Stack: ${stack} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // raw
 | 
					
						
							|  |  |  | ${JSON.stringify(error, null, 2)} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | `;
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-19 01:19:40 +05:30
										 |  |  | const isDev = process.env.FREECODECAMP_NODE_ENV !== 'production'; | 
					
						
							| 
									
										
										
										
											2017-12-27 16:41:42 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default function prodErrorHandler() { | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  |   // error handling in production.
 | 
					
						
							| 
									
										
										
										
											2018-11-29 12:12:15 +00:00
										 |  |  |   // eslint-disable-next-line no-unused-vars
 | 
					
						
							| 
									
										
										
										
											2018-08-31 16:04:04 +01:00
										 |  |  |   return function(err, req, res, next) { | 
					
						
							| 
									
										
										
										
											2017-12-28 11:19:31 -08:00
										 |  |  |     const handled = unwrapHandledError(err); | 
					
						
							|  |  |  |     // respect handled error status
 | 
					
						
							|  |  |  |     let status = handled.status || err.status || res.statusCode; | 
					
						
							|  |  |  |     if (!handled.status && status < 400) { | 
					
						
							|  |  |  |       status = 500; | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-12-28 11:19:31 -08:00
										 |  |  |     res.status(status); | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     // parse res type
 | 
					
						
							| 
									
										
										
										
											2016-07-16 10:40:14 -07:00
										 |  |  |     const accept = accepts(req); | 
					
						
							|  |  |  |     const type = accept.type('html', 'json', 'text'); | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-29 20:52:41 +01:00
										 |  |  |     const redirectTo = handled.redirectTo || `${homeLocation}/`; | 
					
						
							| 
									
										
										
										
											2018-08-31 16:04:04 +01:00
										 |  |  |     const message = | 
					
						
							| 
									
										
										
										
											2019-06-19 15:31:03 +01:00
										 |  |  |       handled.message || | 
					
						
							|  |  |  |       'Oops! Something went wrong. Please try again in a moment.'; | 
					
						
							| 
									
										
										
										
											2017-12-27 16:41:42 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-27 17:34:56 -08:00
										 |  |  |     if (isDev) { | 
					
						
							| 
									
										
										
										
											2020-03-24 09:15:00 +01:00
										 |  |  |       console.error(errTemplate(err, req)); | 
					
						
							| 
									
										
										
										
											2017-12-27 17:34:56 -08:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  |     if (type === 'html') { | 
					
						
							| 
									
										
										
										
											2015-08-16 15:26:43 -07:00
										 |  |  |       if (typeof req.flash === 'function') { | 
					
						
							| 
									
										
										
										
											2018-01-12 14:16:33 -08:00
										 |  |  |         req.flash(handled.type || 'danger', message); | 
					
						
							| 
									
										
										
										
											2015-08-16 15:26:43 -07:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-08-30 15:27:53 +01:00
										 |  |  |       return res.redirectWithFlash(redirectTo); | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  |       // json
 | 
					
						
							|  |  |  |     } else if (type === 'json') { | 
					
						
							|  |  |  |       res.setHeader('Content-Type', 'application/json'); | 
					
						
							|  |  |  |       return res.send({ | 
					
						
							| 
									
										
										
										
											2018-01-01 15:39:14 -08:00
										 |  |  |         type: handled.type || 'errors', | 
					
						
							| 
									
										
										
										
											2017-07-13 11:39:07 -07:00
										 |  |  |         message | 
					
						
							| 
									
										
										
										
											2015-08-04 01:25:34 -07:00
										 |  |  |       }); | 
					
						
							|  |  |  |       // plain text
 | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       res.setHeader('Content-Type', 'text/plain'); | 
					
						
							|  |  |  |       return res.send(message); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } |