forked from MagicMirrorOrg/MagicMirror
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'develop' into feature/indoorHumidity
* develop: (71 commits) Update sample address set version of express-ipfilter: Describe default in comment of sample config More secure defaults. Fix grunt errors Weather forecast settings match current weather Fix JavaScript error in weatherforecast Update fr.json TestSuite: Show the missing strings for translations files. Update fr.json with added translations Added e2e test for font files Fix issue MagicMirrorOrg#986 Fix extra tab file translations/zh_cn.json Add Changelog entry for new e2e test for helloworld module Small change for re-running Travis CI Change Two Conditionals to UpperCase-If Fix linting? Show Scale of Temperature if config flag is set Change to install Roboto fonts by npm Update stylelint package ... # Conflicts: # CHANGELOG.md
- Loading branch information
Showing
105 changed files
with
1,316 additions
and
708 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,104 @@ | ||
/* jshint esversion: 6 */ | ||
|
||
"use strict"; | ||
|
||
// Use seperate scope to prevent global scope pollution | ||
(function () { | ||
var config = {}; | ||
|
||
// Helper function to get server address/hostname from either the commandline or env | ||
function getServerAddress() { | ||
// Helper function to get command line parameters | ||
// Assumes that a cmdline parameter is defined with `--key [value]` | ||
function getCommandLineParameter(key, defaultValue = undefined) { | ||
var index = process.argv.indexOf(`--${key}`); | ||
var value = index > -1 ? process.argv[index + 1] : undefined; | ||
return value !== undefined ? String(value) : defaultValue; | ||
} | ||
|
||
// Prefer command line arguments over environment variables | ||
["address", "port"].forEach((key) => { | ||
config[key] = getCommandLineParameter(key, process.env[key.toUpperCase()]); | ||
}) | ||
} | ||
|
||
function getServerConfig(url) { | ||
// Return new pending promise | ||
return new Promise((resolve, reject) => { | ||
// Select http or https module, depending on reqested url | ||
const lib = url.startsWith("https") ? require("https") : require("http"); | ||
const request = lib.get(url, (response) => { | ||
var configData = ""; | ||
|
||
// Gather incomming data | ||
response.on("data", function(chunk) { | ||
configData += chunk; | ||
}); | ||
// Resolve promise at the end of the HTTP/HTTPS stream | ||
response.on("end", function() { | ||
resolve(JSON.parse(configData)); | ||
}); | ||
}); | ||
|
||
request.on("error", function(error) { | ||
reject(new Error(`Unable to read config from server (${url} (${error.message}`)); | ||
}); | ||
}) | ||
}; | ||
|
||
function fail(message, code = 1) { | ||
if (message !== undefined && typeof message === "string") { | ||
console.log(message); | ||
} else { | ||
console.log("Usage: 'node clientonly --address 192.168.1.10 --port 8080'"); | ||
} | ||
process.exit(code); | ||
} | ||
|
||
getServerAddress(); | ||
|
||
(config.address && config.port) || fail(); | ||
|
||
// Only start the client if a non-local server was provided | ||
if (["localhost", "127.0.0.1", "::1", "::ffff:127.0.0.1", undefined].indexOf(config.address) === -1) { | ||
getServerConfig(`http://${config.address}:${config.port}/config/`) | ||
.then(function (config) { | ||
// Pass along the server config via an environment variable | ||
var env = Object.create(process.env); | ||
var options = { env: env }; | ||
config.address = config.address; | ||
config.port = config.port; | ||
env.config = JSON.stringify(config); | ||
|
||
// Spawn electron application | ||
const electron = require("electron"); | ||
const child = require("child_process").spawn(electron, ["js/electron.js"], options); | ||
|
||
// Pipe all child process output to current stdout | ||
child.stdout.on("data", function (buf) { | ||
process.stdout.write(`Client: ${buf}`); | ||
}); | ||
|
||
// Pipe all child process errors to current stderr | ||
child.stderr.on("data", function (buf) { | ||
process.stderr.write(`Client: ${buf}`); | ||
}); | ||
|
||
child.on("error", function (err) { | ||
process.stdout.write(`Client: ${err}`); | ||
}); | ||
|
||
child.on('close', (code) => { | ||
if (code != 0) { | ||
console.log(`There something wrong. The clientonly is not running code ${code}`); | ||
} | ||
}); | ||
|
||
}) | ||
.catch(function (reason) { | ||
fail(`Unable to connect to server: (${reason})`); | ||
}); | ||
} else { | ||
fail(); | ||
} | ||
}()); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.