| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  | /* Magic Mirror | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-06-14 11:04:11 +02:00
										 |  |  |  * Check the configuration file for errors | 
					
						
							| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-06-14 11:04:11 +02:00
										 |  |  |  * By Rodrigo Ramírez Norambuena https://rodrigoramirez.com
 | 
					
						
							| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  |  * MIT Licensed. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-03-15 20:38:52 +01:00
										 |  |  | const Linter = require("eslint").Linter; | 
					
						
							|  |  |  | const linter = new Linter(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-01 21:07:50 +02:00
										 |  |  | const path = require("path"); | 
					
						
							|  |  |  | const fs = require("fs"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const rootPath = path.resolve(__dirname + "/../"); | 
					
						
							|  |  |  | const config = require(rootPath + "/.eslintrc.json"); | 
					
						
							| 
									
										
										
										
											2020-05-31 22:12:26 +02:00
										 |  |  | const Log = require(rootPath + "/js/logger.js"); | 
					
						
							| 
									
										
										
										
											2020-04-01 21:07:50 +02:00
										 |  |  | const Utils = require(rootPath + "/js/utils.js"); | 
					
						
							| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* getConfigFile() | 
					
						
							|  |  |  |  * Return string with path of configuration file | 
					
						
							| 
									
										
										
										
											2019-06-04 10:15:50 +02:00
										 |  |  |  * Check if set by environment variable MM_CONFIG_FILE | 
					
						
							| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  |  */ | 
					
						
							|  |  |  | function getConfigFile() { | 
					
						
							|  |  |  | 	// FIXME: This function should be in core. Do you want refactor me ;) ?, be good!
 | 
					
						
							| 
									
										
										
										
											2020-04-01 21:07:50 +02:00
										 |  |  | 	let configFileName = path.resolve(rootPath + "/config/config.js"); | 
					
						
							| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  | 	if (process.env.MM_CONFIG_FILE) { | 
					
						
							|  |  |  | 		configFileName = path.resolve(process.env.MM_CONFIG_FILE); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return configFileName; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | function checkConfigFile() { | 
					
						
							| 
									
										
										
										
											2020-04-01 21:07:50 +02:00
										 |  |  | 	const configFileName = getConfigFile(); | 
					
						
							| 
									
										
										
										
											2020-06-14 11:04:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 	// Check if file is present
 | 
					
						
							|  |  |  | 	if (fs.existsSync(configFileName) === false) { | 
					
						
							| 
									
										
										
										
											2020-05-31 22:12:26 +02:00
										 |  |  | 		Log.error(Utils.colors.error("File not found: "), configFileName); | 
					
						
							| 
									
										
										
										
											2020-06-14 11:04:11 +02:00
										 |  |  | 		throw new Error("No config file present!"); | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-06-14 11:04:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-04 10:15:50 +02:00
										 |  |  | 	// check permission
 | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 	try { | 
					
						
							|  |  |  | 		fs.accessSync(configFileName, fs.F_OK); | 
					
						
							|  |  |  | 	} catch (e) { | 
					
						
							| 
									
										
										
										
											2020-05-31 22:12:26 +02:00
										 |  |  | 		Log.log(Utils.colors.error(e)); | 
					
						
							| 
									
										
										
										
											2020-06-14 11:04:11 +02:00
										 |  |  | 		throw new Error("No permission to access config file!"); | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 	// Validate syntax of the configuration file.
 | 
					
						
							| 
									
										
										
										
											2020-05-31 22:12:26 +02:00
										 |  |  | 	Log.info(Utils.colors.info("Checking file... "), configFileName); | 
					
						
							| 
									
										
										
										
											2020-05-18 09:53:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 	// I'm not sure if all ever is utf-8
 | 
					
						
							|  |  |  | 	fs.readFile(configFileName, "utf-8", function (err, data) { | 
					
						
							| 
									
										
										
										
											2020-05-11 22:22:32 +02:00
										 |  |  | 		if (err) { | 
					
						
							|  |  |  | 			throw err; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-03-15 20:38:52 +01:00
										 |  |  | 		const messages = linter.verify(data, config); | 
					
						
							|  |  |  | 		if (messages.length === 0) { | 
					
						
							| 
									
										
										
										
											2020-05-31 22:12:26 +02:00
										 |  |  | 			Log.log("Your configuration file doesn't contain syntax errors :)"); | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 			return true; | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2020-05-18 09:53:34 +02:00
										 |  |  | 			// In case the there errors show messages and return
 | 
					
						
							| 
									
										
										
										
											2020-05-25 18:57:15 +02:00
										 |  |  | 			messages.forEach((error) => { | 
					
						
							| 
									
										
										
										
											2020-05-31 22:12:26 +02:00
										 |  |  | 				Log.log("Line", error.line, "col", error.column, error.message); | 
					
						
							| 
									
										
										
										
											2020-04-01 21:07:50 +02:00
										 |  |  | 			}); | 
					
						
							| 
									
										
										
										
											2020-06-14 11:04:11 +02:00
										 |  |  | 			throw new Error("Wrong syntax in config file!"); | 
					
						
							| 
									
										
										
										
											2017-03-18 09:33:03 -03:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-01-25 20:07:51 +01:00
										 |  |  | 	}); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-01 21:07:50 +02:00
										 |  |  | checkConfigFile(); |