mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-12 07:23:21 -05:00
Added web app minifiy support
This commit is contained in:
parent
7a2205278e
commit
1e7a39c631
@ -79,7 +79,7 @@ function CreateMeshCentralServer(config, args) {
|
|||||||
try { require('./pass').hash('test', function () { }); } catch (e) { console.log('Old version of node, must upgrade.'); return; } // TODO: Not sure if this test works or not.
|
try { require('./pass').hash('test', function () { }); } catch (e) { console.log('Old version of node, must upgrade.'); return; } // TODO: Not sure if this test works or not.
|
||||||
|
|
||||||
// Check for invalid arguments
|
// Check for invalid arguments
|
||||||
var validArguments = ['_', 'notls', 'user', 'port', 'aliasport', 'mpsport', 'mpsaliasport', 'redirport', 'cert', 'mpscert', 'deletedomain', 'deletedefaultdomain', 'showall', 'showusers', 'shownodes', 'showmeshes', 'showevents', 'showpower', 'clearpower', 'showiplocations', 'help', 'exactports', 'install', 'uninstall', 'start', 'stop', 'restart', 'debug', 'filespath', 'datapath', 'noagentupdate', 'launch', 'noserverbackup', 'mongodb', 'mongodbcol', 'wanonly', 'lanonly', 'nousers', 'mpsdebug', 'mpspass', 'ciralocalfqdn', 'dbexport', 'dbimport', 'selfupdate', 'tlsoffload', 'userallowedip', 'fastcert', 'swarmport', 'swarmdebug', 'logintoken', 'logintokenkey', 'logintokengen', 'logintokengen', 'mailtokengen', 'admin', 'unadmin', 'sessionkey', 'sessiontime'];
|
var validArguments = ['_', 'notls', 'user', 'port', 'aliasport', 'mpsport', 'mpsaliasport', 'redirport', 'cert', 'mpscert', 'deletedomain', 'deletedefaultdomain', 'showall', 'showusers', 'shownodes', 'showmeshes', 'showevents', 'showpower', 'clearpower', 'showiplocations', 'help', 'exactports', 'install', 'uninstall', 'start', 'stop', 'restart', 'debug', 'filespath', 'datapath', 'noagentupdate', 'launch', 'noserverbackup', 'mongodb', 'mongodbcol', 'wanonly', 'lanonly', 'nousers', 'mpsdebug', 'mpspass', 'ciralocalfqdn', 'dbexport', 'dbimport', 'selfupdate', 'tlsoffload', 'userallowedip', 'fastcert', 'swarmport', 'swarmdebug', 'logintoken', 'logintokenkey', 'logintokengen', 'logintokengen', 'mailtokengen', 'admin', 'unadmin', 'sessionkey', 'sessiontime', 'minify'];
|
||||||
for (var arg in obj.args) { obj.args[arg.toLocaleLowerCase()] = obj.args[arg]; if (validArguments.indexOf(arg.toLocaleLowerCase()) == -1) { console.log('Invalid argument "' + arg + '", use --help.'); return; } }
|
for (var arg in obj.args) { obj.args[arg.toLocaleLowerCase()] = obj.args[arg]; if (validArguments.indexOf(arg.toLocaleLowerCase()) == -1) { console.log('Invalid argument "' + arg + '", use --help.'); return; } }
|
||||||
if (obj.args.mongodb == true) { console.log('Must specify: --mongodb [connectionstring] \r\nSee https://docs.mongodb.com/manual/reference/connection-string/ for MongoDB connection string.'); return; }
|
if (obj.args.mongodb == true) { console.log('Must specify: --mongodb [connectionstring] \r\nSee https://docs.mongodb.com/manual/reference/connection-string/ for MongoDB connection string.'); return; }
|
||||||
for (var i in obj.config.settings) { obj.args[i] = obj.config.settings[i]; } // Place all settings into arguments, arguments have already been placed into settings so arguments take precedence.
|
for (var i in obj.config.settings) { obj.args[i] = obj.config.settings[i]; } // Place all settings into arguments, arguments have already been placed into settings so arguments take precedence.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "meshcentral",
|
"name": "meshcentral",
|
||||||
"version": "0.1.9-n",
|
"version": "0.1.9-p",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"Remote Management",
|
"Remote Management",
|
||||||
"Intel AMT",
|
"Intel AMT",
|
||||||
|
38861
public/commander.htm
38861
public/commander.htm
File diff suppressed because one or more lines are too long
32
public/compress.bat
Normal file
32
public/compress.bat
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
@ECHO OFF
|
||||||
|
REM *** default.handlebars
|
||||||
|
DEL ..\views\default-min.handlebars
|
||||||
|
COPY ..\views\default.handlebars index.html
|
||||||
|
..\..\WebSiteCompiler\bin\Debug\WebSiteCompiler.exe compress.wcc -c
|
||||||
|
COPY compress.htm ..\views\default-min.handlebars
|
||||||
|
DEL compress.htm
|
||||||
|
DEL index.html
|
||||||
|
|
||||||
|
REM *** default-mobile.handlebars
|
||||||
|
DEL ..\views\default-mobile-min.handlebars
|
||||||
|
COPY ..\views\default-mobile.handlebars index.html
|
||||||
|
..\..\WebSiteCompiler\bin\Debug\WebSiteCompiler.exe compress.wcc -c
|
||||||
|
COPY compress.htm ..\views\default-mobile-min.handlebars
|
||||||
|
DEL compress.htm
|
||||||
|
DEL index.html
|
||||||
|
|
||||||
|
REM *** login.handlebars
|
||||||
|
DEL ..\views\login-min.handlebars
|
||||||
|
COPY ..\views\login.handlebars index.html
|
||||||
|
..\..\WebSiteCompiler\bin\Debug\WebSiteCompiler.exe compress.wcc -c
|
||||||
|
COPY compress.htm ..\views\login-min.handlebars
|
||||||
|
DEL compress.htm
|
||||||
|
DEL index.html
|
||||||
|
|
||||||
|
REM *** login-mobile.handlebars
|
||||||
|
DEL ..\views\login-mobile-min.handlebars
|
||||||
|
COPY ..\views\login-mobile.handlebars index.html
|
||||||
|
..\..\WebSiteCompiler\bin\Debug\WebSiteCompiler.exe compress.wcc -c
|
||||||
|
COPY compress.htm ..\views\login-mobile-min.handlebars
|
||||||
|
DEL compress.htm
|
||||||
|
DEL index.html
|
BIN
public/compress.wcc
Normal file
BIN
public/compress.wcc
Normal file
Binary file not shown.
1
views/default-min.handlebars
Normal file
1
views/default-min.handlebars
Normal file
File diff suppressed because one or more lines are too long
1
views/default-mobile-min.handlebars
Normal file
1
views/default-mobile-min.handlebars
Normal file
File diff suppressed because one or more lines are too long
@ -17,22 +17,97 @@
|
|||||||
<script type="text/javascript" src="scripts/zlib-inflate.js"></script>
|
<script type="text/javascript" src="scripts/zlib-inflate.js"></script>
|
||||||
<script type="text/javascript" src="scripts/zlib-adler32.js"></script>
|
<script type="text/javascript" src="scripts/zlib-adler32.js"></script>
|
||||||
<script type="text/javascript" src="scripts/zlib-crc32.js"></script>
|
<script type="text/javascript" src="scripts/zlib-crc32.js"></script>
|
||||||
<script type="text/javascript" src="scripts/filesaver.1.1.20151003.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/filesaver.1.1.20151003.js"></script>
|
||||||
<title>MeshCentral - Login</title>
|
<title>MeshCentral - Login</title>
|
||||||
<style>
|
<style>
|
||||||
a { color: #036; text-decoration: underline }
|
a {
|
||||||
#footer a { color: #fff; text-decoration: underline }
|
color: #036;
|
||||||
#footer a:hover { color: #fff; text-decoration: none }
|
text-decoration: underline;
|
||||||
.i1 {background:url(../images/icons50.png) 0px 0px;height:50px;width:50px;border:none;}
|
}
|
||||||
.i2 {background:url(../images/icons50.png) -50px 0px;height:50px;width:50px;border:none;}
|
|
||||||
.i3 {background:url(../images/icons50.png) -100px 0px;height:50px;width:50px;border:none;}
|
#footer a {
|
||||||
.i4 {background:url(../images/icons50.png) -150px 0px;height:50px;width:50px;border:none;}
|
color: #fff;
|
||||||
.i5 {background:url(../images/icons50.png) -200px 0px;height:50px;width:50px;border:none;}
|
text-decoration: underline;
|
||||||
.i6 {background:url(../images/icons50.png) -250px 0px; height:50px;width:50px; border:none; }
|
}
|
||||||
.m0 {background:url(../images/images16.png) -32px 0px; height:16px;width:16px; border:none;float:left }
|
|
||||||
.m1 {background:url(../images/images16.png) -16px 0px; height:16px;width:16px; border:none;float:left }
|
#footer a:hover {
|
||||||
.m2 {background:url(../images/images16.png) -96px 0px; height:16px;width:16px; border:none;float:left }
|
color: #fff;
|
||||||
.m3 {background:url(../images/images16.png) -112px 0px; height:16px;width:16px; border:none;float:left }
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.i1 {
|
||||||
|
background: url(../images/icons50.png) 0px 0px;
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.i2 {
|
||||||
|
background: url(../images/icons50.png) -50px 0px;
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.i3 {
|
||||||
|
background: url(../images/icons50.png) -100px 0px;
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.i4 {
|
||||||
|
background: url(../images/icons50.png) -150px 0px;
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.i5 {
|
||||||
|
background: url(../images/icons50.png) -200px 0px;
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.i6 {
|
||||||
|
background: url(../images/icons50.png) -250px 0px;
|
||||||
|
height: 50px;
|
||||||
|
width: 50px;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.m0 {
|
||||||
|
background: url(../images/images16.png) -32px 0px;
|
||||||
|
height: 16px;
|
||||||
|
width: 16px;
|
||||||
|
border: none;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.m1 {
|
||||||
|
background: url(../images/images16.png) -16px 0px;
|
||||||
|
height: 16px;
|
||||||
|
width: 16px;
|
||||||
|
border: none;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.m2 {
|
||||||
|
background: url(../images/images16.png) -96px 0px;
|
||||||
|
height: 16px;
|
||||||
|
width: 16px;
|
||||||
|
border: none;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.m3 {
|
||||||
|
background: url(../images/images16.png) -112px 0px;
|
||||||
|
height: 16px;
|
||||||
|
width: 16px;
|
||||||
|
border: none;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
.gray {
|
.gray {
|
||||||
/*filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#grayscale");*/ /* Firefox 10+, Firefox on Android */
|
/*filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#grayscale");*/ /* Firefox 10+, Firefox on Android */
|
||||||
@ -41,7 +116,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
.DevSt {
|
.DevSt {
|
||||||
padding-left:5px;
|
padding-left: 5px;
|
||||||
border-bottom-style: solid;
|
border-bottom-style: solid;
|
||||||
border-bottom-width: 1px;
|
border-bottom-width: 1px;
|
||||||
border-bottom-color: #DDDDDD;
|
border-bottom-color: #DDDDDD;
|
||||||
@ -438,8 +513,8 @@
|
|||||||
</div>
|
</div>
|
||||||
<iframe name="fileUploadFrame" style=display:none></iframe>
|
<iframe name="fileUploadFrame" style=display:none></iframe>
|
||||||
<script>
|
<script>
|
||||||
var debugLevel = {{{debuglevel}}};
|
var debugLevel = parseInt('{{{debuglevel}}}');
|
||||||
var features = {{{features}}};
|
var features = parseInt('{{{features}}}');
|
||||||
var meshserver = null;
|
var meshserver = null;
|
||||||
var xdr = null;
|
var xdr = null;
|
||||||
var serverinfo = null;
|
var serverinfo = null;
|
||||||
@ -451,7 +526,6 @@
|
|||||||
var nodeShortIdent = 0;
|
var nodeShortIdent = 0;
|
||||||
var serverPublicNamePort = "{{{serverDnsName}}}:{{{serverPublicPort}}}";
|
var serverPublicNamePort = "{{{serverDnsName}}}:{{{serverPublicPort}}}";
|
||||||
var debugmode = false;
|
var debugmode = false;
|
||||||
var features = {{{features}}};
|
|
||||||
var attemptWebRTC = ((features & 128) != 0);
|
var attemptWebRTC = ((features & 128) != 0);
|
||||||
var StatusStrs = ['Disconnected', 'Connecting...', 'Setup...', 'Connected', 'Intel® AMT Connected'];
|
var StatusStrs = ['Disconnected', 'Connecting...', 'Setup...', 'Connected', 'Intel® AMT Connected'];
|
||||||
var files;
|
var files;
|
||||||
@ -569,8 +643,8 @@
|
|||||||
//onSearchInputChanged();
|
//onSearchInputChanged();
|
||||||
updateDevices();
|
updateDevices();
|
||||||
//refreshMap(false, true);
|
//refreshMap(false, true);
|
||||||
if (xxcurrentView == 0) { if ('{{viewmode}}' != '') { go({{viewmode}}); } else { setDialogMode(0); go(1); } }
|
if (xxcurrentView == 0) { if ('{{viewmode}}' != '') { go(parseInt('{{viewmode}}')); } else { setDialogMode(0); go(1); } }
|
||||||
if ('{{currentNode}}' != '') { gotoDevice('{{currentNode}}',{{viewmode}});}
|
if ('{{currentNode}}' != '') { gotoDevice('{{currentNode}}', parseInt('{{viewmode}}')); }
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'powertimeline': {
|
case 'powertimeline': {
|
||||||
|
@ -23,9 +23,9 @@
|
|||||||
<script type="text/javascript" src="scripts/amt-wsman-ws-0.2.0.js"></script>
|
<script type="text/javascript" src="scripts/amt-wsman-ws-0.2.0.js"></script>
|
||||||
<script type="text/javascript" src="scripts/agent-redir-ws-0.1.0.js"></script>
|
<script type="text/javascript" src="scripts/agent-redir-ws-0.1.0.js"></script>
|
||||||
<script type="text/javascript" src="scripts/agent-desktop-0.0.2.js"></script>
|
<script type="text/javascript" src="scripts/agent-desktop-0.0.2.js"></script>
|
||||||
<script type="text/javascript" src="scripts/filesaver.1.1.20151003.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/filesaver.1.1.20151003.js"></script>
|
||||||
<script type="text/javascript" src="scripts/ol.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/ol.js"></script>
|
||||||
<script type="text/javascript" src="scripts/ol3-contextmenu.js"></script>
|
<script keeplink=1 type="text/javascript" src="scripts/ol3-contextmenu.js"></script>
|
||||||
<title>MeshCentral</title>
|
<title>MeshCentral</title>
|
||||||
</head>
|
</head>
|
||||||
<body onload="if (typeof(startup) !== 'undefined') startup();" oncontextmenu="handleContextMenu(event)">
|
<body onload="if (typeof(startup) !== 'undefined') startup();" oncontextmenu="handleContextMenu(event)">
|
||||||
@ -246,7 +246,8 @@
|
|||||||
<div style=width:100%;height:24px;background-color:#d3d9d6;margin-bottom:4px>
|
<div style=width:100%;height:24px;background-color:#d3d9d6;margin-bottom:4px>
|
||||||
<div class=style7 style=width:16px;height:100%;float:left> </div>
|
<div class=style7 style=width:16px;height:100%;float:left> </div>
|
||||||
<div class=h1 style=height:100%;float:left> </div>
|
<div class=h1 style=height:100%;float:left> </div>
|
||||||
<div class=style14 style=height:100%;float:left>
|
<div class=style14 style=height:100%;float:left>
|
||||||
|
|
||||||
<input type=button onclick=showCreateNewAccountDialog() value="New Account..." />
|
<input type=button onclick=showCreateNewAccountDialog() value="New Account..." />
|
||||||
<input id=UserSearchInput type=text style=width:120px placeholder=Search onchange=onUserSearchInputChanged() onkeyup=onUserSearchInputChanged() autocomplete=off onfocus=onUserSearchFocus(1) onblur=onUserSearchFocus(0) />
|
<input id=UserSearchInput type=text style=width:120px placeholder=Search onchange=onUserSearchInputChanged() onkeyup=onUserSearchInputChanged() autocomplete=off onfocus=onUserSearchFocus(1) onblur=onUserSearchFocus(0) />
|
||||||
</div>
|
</div>
|
||||||
@ -770,8 +771,8 @@
|
|||||||
var multidesktopsettings = { quality: 20, scaling: 128, framerate: 1000 };
|
var multidesktopsettings = { quality: 20, scaling: 128, framerate: 1000 };
|
||||||
var terminal;
|
var terminal;
|
||||||
var files;
|
var files;
|
||||||
var debugLevel = {{{debuglevel}}};
|
var debugLevel = parseInt("{{{debuglevel}}}");
|
||||||
var features = {{{features}}};
|
var features = parseInt("{{{features}}}");
|
||||||
var multiDesktop = {};
|
var multiDesktop = {};
|
||||||
var multiDesktopFilter = null;
|
var multiDesktopFilter = null;
|
||||||
var serverPublicNamePort = "{{{serverDnsName}}}:{{{serverPublicPort}}}";
|
var serverPublicNamePort = "{{{serverDnsName}}}:{{{serverPublicPort}}}";
|
||||||
@ -940,7 +941,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
function updateSiteAdmin() {
|
function updateSiteAdmin() {
|
||||||
var noServerBackup = {{{noServerBackup}}};
|
var noServerBackup = "{{{noServerBackup}}}";
|
||||||
var siteRights = userinfo.siteadmin;
|
var siteRights = userinfo.siteadmin;
|
||||||
if (noServerBackup == 1) { siteRights &= 0xFFFFFFFA; } // If not server backups allowed, remove server backup and restore permissions
|
if (noServerBackup == 1) { siteRights &= 0xFFFFFFFA; } // If not server backups allowed, remove server backup and restore permissions
|
||||||
|
|
||||||
@ -1028,8 +1029,8 @@
|
|||||||
onSearchInputChanged();
|
onSearchInputChanged();
|
||||||
updateDevices();
|
updateDevices();
|
||||||
refreshMap(false, true);
|
refreshMap(false, true);
|
||||||
if (xxcurrentView == 0) { if ('{{viewmode}}' != '') { go({{viewmode}}); } else { setDialogMode(0); go(1); } }
|
if (xxcurrentView == 0) { if ('{{viewmode}}' != '') { go(parseInt('{{viewmode}}')); } else { setDialogMode(0); go(1); } }
|
||||||
if ('{{currentNode}}' != '') { gotoDevice('{{currentNode}}',{{viewmode}});}
|
if ('{{currentNode}}' != '') { gotoDevice('{{currentNode}}',parseInt('{{viewmode}}'));}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'powertimeline': {
|
case 'powertimeline': {
|
||||||
@ -2037,9 +2038,9 @@
|
|||||||
function deviceHeaderSet() {
|
function deviceHeaderSet() {
|
||||||
if (deviceHeaderId == 0) { deviceHeaderId = 1; return; }
|
if (deviceHeaderId == 0) { deviceHeaderId = 1; return; }
|
||||||
deviceHeaders["DevxHeader" + deviceHeaderId] = ', ' + deviceHeaderTotal + ((deviceHeaderTotal == 1) ? ' node' : ' nodes');
|
deviceHeaders["DevxHeader" + deviceHeaderId] = ', ' + deviceHeaderTotal + ((deviceHeaderTotal == 1) ? ' node' : ' nodes');
|
||||||
var title = '';
|
//var title = '';
|
||||||
for (x in deviceHeaderCount) { if (title.length > 0) title += ', '; title += deviceHeaderCount[x] + ' ' + PowerStateStr2(x); }
|
//for (x in deviceHeaderCount) { if (title.length > 0) title += ', '; title += deviceHeaderCount[x] + ' ' + PowerStateStr2(x); }
|
||||||
deviceHeadersTitles["DevxHeader" + deviceHeaderId] = title;
|
//deviceHeadersTitles["DevxHeader" + deviceHeaderId] = title;
|
||||||
deviceHeaderId++;
|
deviceHeaderId++;
|
||||||
deviceHeaderCount = {};
|
deviceHeaderCount = {};
|
||||||
deviceHeaderTotal = 0;
|
deviceHeaderTotal = 0;
|
||||||
@ -2207,8 +2208,8 @@
|
|||||||
function cmmeshaction(action) {
|
function cmmeshaction(action) {
|
||||||
var meshid = contextelement.attributes.onclick.value.substring(32, (32 + 69));
|
var meshid = contextelement.attributes.onclick.value.substring(32, (32 + 69));
|
||||||
var elements = document.getElementsByClassName("DeviceCheckbox");
|
var elements = document.getElementsByClassName("DeviceCheckbox");
|
||||||
if (action == 1) { for (var i=0;i<elements.length;i++) { if (elements[i].attributes && elements[i].attributes.class.value.substring(0, 69) == meshid) { elements[i].checked = true; } } }
|
if (action == 1) { for (var i = 0; i < elements.length; i++) { if ( (elements[i].attributes) && (elements[i].attributes['class']['value'].substring(0, 69) == meshid)) { elements[i].checked = true; } } }
|
||||||
if (action == 2) { for (var i=0;i<elements.length;i++) { if (elements[i].attributes && elements[i].attributes.class.value.substring(0, 69) == meshid) { elements[i].checked = false; } } }
|
if (action == 2) { for (var i = 0; i < elements.length; i++) { if ( (elements[i].attributes) && (elements[i].attributes['class']['value'].substring(0, 69) == meshid)) { elements[i].checked = false; } } }
|
||||||
//if (action == 3) { window.location = "multidesktop.aspx?mesh=" + meshid + "&auto=1"; }
|
//if (action == 3) { window.location = "multidesktop.aspx?mesh=" + meshid + "&auto=1"; }
|
||||||
p1updateInfo();
|
p1updateInfo();
|
||||||
}
|
}
|
||||||
@ -2237,21 +2238,23 @@
|
|||||||
|
|
||||||
// Add a feature for every Node and change style if connection status changes
|
// Add a feature for every Node and change style if connection status changes
|
||||||
function updateMapMarkers(selectedMesh) {
|
function updateMapMarkers(selectedMesh) {
|
||||||
if ((xxmap != null) && (xxmap.map == null)) loadmap();
|
if ((xxmap != null) && (xxmap.map == null)) { try { loadmap(); } catch (ex) { console.error('loadmap() exception', ex); } }
|
||||||
if (xxmap == null) return;
|
if (xxmap == null) return;
|
||||||
var boundingBox = null;
|
var boundingBox = null;
|
||||||
for (var i in nodes) {
|
for (var i in nodes) {
|
||||||
var loc = map_parseNodeLoc(nodes[i]);
|
try {
|
||||||
var feature = xxmap.markersSource.getFeatureById(nodes[i]._id);
|
var loc = map_parseNodeLoc(nodes[i]);
|
||||||
if ((loc != null) && ((nodes[i].meshid == selectedMesh) || (selectedMesh == null))) { // Draw markers for devices with locations
|
var feature = xxmap.markersSource.getFeatureById(nodes[i]._id);
|
||||||
lat = loc[0];
|
if ((loc != null) && ((nodes[i].meshid == selectedMesh) || (selectedMesh == null))) { // Draw markers for devices with locations
|
||||||
lon = loc[1];
|
lat = loc[0];
|
||||||
var type = loc[2];
|
lon = loc[1];
|
||||||
if (boundingBox == null) { boundingBox = [ lat, lon, lat, lon, 0 ]; } else { if (lat < boundingBox[0]) { boundingBox[0] = lat; } if (lon < boundingBox[1]) { boundingBox[1] = lon; } if (lat > boundingBox[2]) { boundingBox[2] = lat; } if (lon > boundingBox[3]) { boundingBox[3] = lon; } }
|
var type = loc[2];
|
||||||
if (feature == null) { addFeature(nodes[i]); boundingBox[4] = 1; } else { updateFeature(nodes[i], feature); feature.setStyle(markerStyle(nodes[i], loc[2])); } // Update Feature
|
if (boundingBox == null) { boundingBox = [ lat, lon, lat, lon, 0 ]; } else { if (lat < boundingBox[0]) { boundingBox[0] = lat; } if (lon < boundingBox[1]) { boundingBox[1] = lon; } if (lat > boundingBox[2]) { boundingBox[2] = lat; } if (lon > boundingBox[3]) { boundingBox[3] = lon; } }
|
||||||
} else {
|
if (feature == null) { addFeature(nodes[i]); boundingBox[4] = 1; } else { updateFeature(nodes[i], feature); feature.setStyle(markerStyle(nodes[i], loc[2])); } // Update Feature
|
||||||
if (feature) { xxmap.markersSource.removeFeature(feature); }
|
} else {
|
||||||
}
|
if (feature) { xxmap.markersSource.removeFeature(feature); }
|
||||||
|
}
|
||||||
|
} catch (ex) { console.error('updateMapMarkers() exception', ex, JSON.stringify(nodes[i])); }
|
||||||
}
|
}
|
||||||
return boundingBox;
|
return boundingBox;
|
||||||
}
|
}
|
||||||
@ -5846,5 +5849,5 @@
|
|||||||
function validateEmail(v) { var emailReg = /^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/; return emailReg.test(v); }
|
function validateEmail(v) { var emailReg = /^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/; return emailReg.test(v); }
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
1
views/login-min.handlebars
Normal file
1
views/login-min.handlebars
Normal file
File diff suppressed because one or more lines are too long
1
views/login-mobile-min.handlebars
Normal file
1
views/login-mobile-min.handlebars
Normal file
File diff suppressed because one or more lines are too long
@ -175,9 +175,9 @@
|
|||||||
</div>
|
</div>
|
||||||
<script>
|
<script>
|
||||||
var passhint = "{{{passhint}}}";
|
var passhint = "{{{passhint}}}";
|
||||||
var newAccountPass = {{{newAccountPass}}};
|
var newAccountPass = parseInt('{{{newAccountPass}}}');
|
||||||
var emailCheck = {{{emailcheck}}};
|
var emailCheck = parseInt('{{{emailcheck}}}');
|
||||||
var features = {{{features}}};
|
var features = parseInt('{{{features}}}');
|
||||||
|
|
||||||
function startup() {
|
function startup() {
|
||||||
if ((features & 32) == 0) {
|
if ((features & 32) == 0) {
|
||||||
@ -191,7 +191,7 @@
|
|||||||
center();
|
center();
|
||||||
validateLogin();
|
validateLogin();
|
||||||
validateCreate();
|
validateCreate();
|
||||||
if ('{{loginmode}}' != '') { go({{loginmode}}); } else { go(1); }
|
if ('{{loginmode}}' != '') { go(parseInt('{{loginmode}}')); } else { go(1); }
|
||||||
QV('newAccountDiv', '{{{newAccount}}}' != '0' );
|
QV('newAccountDiv', '{{{newAccount}}}' != '0' );
|
||||||
if ((passhint != null) && (passhint.length > 0)) { QV("showPassHintLink", true); }
|
if ((passhint != null) && (passhint.length > 0)) { QV("showPassHintLink", true); }
|
||||||
QV("newAccountPass", (newAccountPass == 1));
|
QV("newAccountPass", (newAccountPass == 1));
|
||||||
|
@ -169,9 +169,9 @@
|
|||||||
</div>
|
</div>
|
||||||
<script>
|
<script>
|
||||||
var passhint = "{{{passhint}}}";
|
var passhint = "{{{passhint}}}";
|
||||||
var newAccountPass = {{{newAccountPass}}};
|
var newAccountPass = parseInt('{{{newAccountPass}}}');
|
||||||
var emailCheck = {{{emailcheck}}};
|
var emailCheck = parseInt('{{{emailcheck}}}');
|
||||||
var features = {{{features}}};
|
var features = parseInt('{{{features}}}');
|
||||||
|
|
||||||
function startup() {
|
function startup() {
|
||||||
if ((features & 32) == 0) {
|
if ((features & 32) == 0) {
|
||||||
@ -185,7 +185,7 @@
|
|||||||
center();
|
center();
|
||||||
validateLogin();
|
validateLogin();
|
||||||
validateCreate();
|
validateCreate();
|
||||||
if ('{{loginmode}}' != '') { go({{loginmode}}); } else { go(1); }
|
if ('{{loginmode}}' != '') { go(parseInt('{{loginmode}}')); } else { go(1); }
|
||||||
QV('newAccountDiv', '{{{newAccount}}}' != '0' );
|
QV('newAccountDiv', '{{{newAccount}}}' != '0' );
|
||||||
if ((passhint != null) && (passhint.length > 0)) { QV("showPassHintLink", true); }
|
if ((passhint != null) && (passhint.length > 0)) { QV("showPassHintLink", true); }
|
||||||
QV("newAccountPass", (newAccountPass == 1));
|
QV("newAccountPass", (newAccountPass == 1));
|
||||||
|
28
webserver.js
28
webserver.js
@ -721,14 +721,38 @@ module.exports.CreateWebServer = function (parent, db, args, certificates) {
|
|||||||
// Send the master web application
|
// Send the master web application
|
||||||
if ((!obj.args.user) && (obj.args.nousers != true) && (nologout == false)) { logoutcontrol += ' <a href=' + domain.url + 'logout?' + Math.random() + ' style=color:white>Logout</a>'; } // If a default user is in use or no user mode, don't display the logout button
|
if ((!obj.args.user) && (obj.args.nousers != true) && (nologout == false)) { logoutcontrol += ' <a href=' + domain.url + 'logout?' + Math.random() + ' style=color:white>Logout</a>'; } // If a default user is in use or no user mode, don't display the logout button
|
||||||
var httpsPort = ((obj.args.aliasport == null) ? obj.args.port : obj.args.aliasport); // Use HTTPS alias port is specified
|
var httpsPort = ((obj.args.aliasport == null) ? obj.args.port : obj.args.aliasport); // Use HTTPS alias port is specified
|
||||||
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/default-mobile' : 'views/default'), { viewmode: viewmode, currentNode: currentNode, logoutControl: logoutcontrol, title: domain.title, title2: domain.title2, domainurl: domain.url, domain: domain.id, debuglevel: parent.debugLevel, serverDnsName: getWebServerName(domain), serverRedirPort: args.redirport, serverPublicPort: httpsPort, noServerBackup: (args.noserverbackup == 1 ? 1 : 0), features: features, mpspass: args.mpspass, webcerthash: obj.webCertificateHashBase64, footer: (domain.footer == null) ? '' : domain.footer });
|
|
||||||
|
if (obj.args.minify) {
|
||||||
|
// Try to server the minified version if we can.
|
||||||
|
try {
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/default-mobile-min' : 'views/default-min'), { viewmode: viewmode, currentNode: currentNode, logoutControl: logoutcontrol, title: domain.title, title2: domain.title2, domainurl: domain.url, domain: domain.id, debuglevel: parent.debugLevel, serverDnsName: getWebServerName(domain), serverRedirPort: args.redirport, serverPublicPort: httpsPort, noServerBackup: (args.noserverbackup == 1 ? 1 : 0), features: features, mpspass: args.mpspass, webcerthash: obj.webCertificateHashBase64, footer: (domain.footer == null) ? '' : domain.footer });
|
||||||
|
} catch (ex) {
|
||||||
|
// In case of an exception, serve the non-minified version.
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/default-mobile' : 'views/default'), { viewmode: viewmode, currentNode: currentNode, logoutControl: logoutcontrol, title: domain.title, title2: domain.title2, domainurl: domain.url, domain: domain.id, debuglevel: parent.debugLevel, serverDnsName: getWebServerName(domain), serverRedirPort: args.redirport, serverPublicPort: httpsPort, noServerBackup: (args.noserverbackup == 1 ? 1 : 0), features: features, mpspass: args.mpspass, webcerthash: obj.webCertificateHashBase64, footer: (domain.footer == null) ? '' : domain.footer });
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// Serve non-minified version of web pages.
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/default-mobile' : 'views/default'), { viewmode: viewmode, currentNode: currentNode, logoutControl: logoutcontrol, title: domain.title, title2: domain.title2, domainurl: domain.url, domain: domain.id, debuglevel: parent.debugLevel, serverDnsName: getWebServerName(domain), serverRedirPort: args.redirport, serverPublicPort: httpsPort, noServerBackup: (args.noserverbackup == 1 ? 1 : 0), features: features, mpspass: args.mpspass, webcerthash: obj.webCertificateHashBase64, footer: (domain.footer == null) ? '' : domain.footer });
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// Send back the login application
|
// Send back the login application
|
||||||
var loginmode = req.session.loginmode, features = 0;
|
var loginmode = req.session.loginmode, features = 0;
|
||||||
delete req.session.loginmode; // Clear this state, if the user hits refresh, we want to go back to the login page.
|
delete req.session.loginmode; // Clear this state, if the user hits refresh, we want to go back to the login page.
|
||||||
if ((parent.config != null) && (parent.config.settings != null) && (parent.config.settings.allowframing == true)) { features += 32; } // Allow site within iframe
|
if ((parent.config != null) && (parent.config.settings != null) && (parent.config.settings.allowframing == true)) { features += 32; } // Allow site within iframe
|
||||||
var httpsPort = ((obj.args.aliasport == null) ? obj.args.port : obj.args.aliasport); // Use HTTPS alias port is specified
|
var httpsPort = ((obj.args.aliasport == null) ? obj.args.port : obj.args.aliasport); // Use HTTPS alias port is specified
|
||||||
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/login-mobile' : 'views/login'), { loginmode: loginmode, rootCertLink: getRootCertLink(), title: domain.title, title2: domain.title2, newAccount: domain.newaccounts, newAccountPass: (((domain.newaccountspass == null) || (domain.newaccountspass == '')) ? 0 : 1), serverDnsName: getWebServerName(domain), serverPublicPort: httpsPort, emailcheck: obj.parent.mailserver != null, features: features, footer: (domain.footer == null) ? '' : domain.footer });
|
|
||||||
|
if (obj.args.minify) {
|
||||||
|
// Try to server the minified version if we can.
|
||||||
|
try {
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/login-mobile-min' : 'views/login-min'), { loginmode: loginmode, rootCertLink: getRootCertLink(), title: domain.title, title2: domain.title2, newAccount: domain.newaccounts, newAccountPass: (((domain.newaccountspass == null) || (domain.newaccountspass == '')) ? 0 : 1), serverDnsName: getWebServerName(domain), serverPublicPort: httpsPort, emailcheck: obj.parent.mailserver != null, features: features, footer: (domain.footer == null) ? '' : domain.footer });
|
||||||
|
} catch (ex) {
|
||||||
|
// In case of an exception, serve the non-minified version.
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/login-mobile' : 'views/login'), { loginmode: loginmode, rootCertLink: getRootCertLink(), title: domain.title, title2: domain.title2, newAccount: domain.newaccounts, newAccountPass: (((domain.newaccountspass == null) || (domain.newaccountspass == '')) ? 0 : 1), serverDnsName: getWebServerName(domain), serverPublicPort: httpsPort, emailcheck: obj.parent.mailserver != null, features: features, footer: (domain.footer == null) ? '' : domain.footer });
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// Serve non-minified version of web pages.
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/login-mobile' : 'views/login'), { loginmode: loginmode, rootCertLink: getRootCertLink(), title: domain.title, title2: domain.title2, newAccount: domain.newaccounts, newAccountPass: (((domain.newaccountspass == null) || (domain.newaccountspass == '')) ? 0 : 1), serverDnsName: getWebServerName(domain), serverPublicPort: httpsPort, emailcheck: obj.parent.mailserver != null, features: features, footer: (domain.footer == null) ? '' : domain.footer });
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
var xoptions = { loginmode: loginmode, rootCertLink: getRootCertLink(), title: domain.title, title2: domain.title2, newAccount: domain.newaccounts, newAccountPass: (((domain.newaccountspass == null) || (domain.newaccountspass == '')) ? 0 : 1), serverDnsName: getWebServerName(domain), serverPublicPort: httpsPort, emailcheck: obj.parent.mailserver != null, features: features, footer: (domain.footer == null) ? '' : domain.footer };
|
var xoptions = { loginmode: loginmode, rootCertLink: getRootCertLink(), title: domain.title, title2: domain.title2, newAccount: domain.newaccounts, newAccountPass: (((domain.newaccountspass == null) || (domain.newaccountspass == '')) ? 0 : 1), serverDnsName: getWebServerName(domain), serverPublicPort: httpsPort, emailcheck: obj.parent.mailserver != null, features: features, footer: (domain.footer == null) ? '' : domain.footer };
|
||||||
|
Loading…
Reference in New Issue
Block a user