mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-11 23:13:21 -05:00
Added a way to specify terms of service in terms.txt.
This commit is contained in:
parent
8b87d82278
commit
79dd5ec5d2
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -8,6 +8,33 @@ var _NET_WM_STATE_TOGGLE = 2; // toggle property
|
|||||||
var SubstructureRedirectMask = (1 << 20);
|
var SubstructureRedirectMask = (1 << 20);
|
||||||
var SubstructureNotifyMask = (1 << 19);
|
var SubstructureNotifyMask = (1 << 19);
|
||||||
|
|
||||||
|
function getLibInfo(libname)
|
||||||
|
{
|
||||||
|
if (process.platform != 'linux') { throw ('Only supported on linux'); }
|
||||||
|
|
||||||
|
var child = require('child_process').execFile('/bin/sh', ['sh']);
|
||||||
|
child.stdout.str = '';
|
||||||
|
child.stdout.on('data', function (chunk) { this.str += chunk.toString(); });
|
||||||
|
child.stdin.write("ldconfig -p | grep '" + libname + ".so.'\nexit\n");
|
||||||
|
child.waitExit();
|
||||||
|
|
||||||
|
var v = [];
|
||||||
|
var lines = child.stdout.str.split('\n');
|
||||||
|
for (var i in lines) {
|
||||||
|
if (lines[i]) {
|
||||||
|
var info = lines[i].split('=>');
|
||||||
|
var pth = info[1].trim();
|
||||||
|
var libinfo = info[0].trim().split(' ');
|
||||||
|
var lib = libinfo[0];
|
||||||
|
var plat = libinfo[1].substring(1, libinfo[1].length - 1).split(',');
|
||||||
|
|
||||||
|
if (lib.startsWith(libname + '.so.')) {
|
||||||
|
v.push({ lib: lib, path: pth, info: plat });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return (v);
|
||||||
|
}
|
||||||
|
|
||||||
function monitorinfo()
|
function monitorinfo()
|
||||||
{
|
{
|
||||||
@ -44,46 +71,67 @@ function monitorinfo()
|
|||||||
if (info._user32.EnumDisplayMonitors(0, 0, this._monitorinfo.callback, this._monitorinfo.dwData).Val == 0) {
|
if (info._user32.EnumDisplayMonitors(0, 0, this._monitorinfo.callback, this._monitorinfo.dwData).Val == 0) {
|
||||||
rejector('LastError=' + info._kernel32.GetLastError().Val);
|
rejector('LastError=' + info._kernel32.GetLastError().Val);
|
||||||
return;
|
return;
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
resolver(this._monitorinfo.callback.results);
|
resolver(this._monitorinfo.callback.results);
|
||||||
}
|
}
|
||||||
|
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (process.platform == 'linux')
|
else if(process.platform == 'linux')
|
||||||
{
|
{
|
||||||
// First thing we need to do, is determine where the X11 libraries are
|
// First thing we need to do, is determine where the X11 libraries are
|
||||||
var askOS = false;
|
var askOS = false;
|
||||||
try { if (require('user-sessions').isRoot()) { askOS = true; } } catch (e) { }
|
try
|
||||||
|
{
|
||||||
|
if (require('user-sessions').isRoot()) { askOS = true; }
|
||||||
|
}
|
||||||
|
catch (e)
|
||||||
|
{ }
|
||||||
|
|
||||||
if (askOS)
|
if (askOS)
|
||||||
{
|
{
|
||||||
// Sufficient access rights to use ldconfig
|
// Sufficient access rights to use ldconfig
|
||||||
var p = require('child_process').execFile('/bin/sh', ['sh']);
|
var x11info = getLibInfo('libX11');
|
||||||
p.stdout._lines = '';
|
var xtstinfo = getLibInfo('libXtst');
|
||||||
p.stdout.on('data', function (chunk) { this._lines += chunk.toString(); });
|
var xextinfo = getLibInfo('libXext');
|
||||||
p.stdin.write('ldconfig -v\nexit\n');
|
var ix;
|
||||||
p.waitExit();
|
|
||||||
|
|
||||||
var paths = p.stdout._lines.split('\n');
|
for(ix in x11info)
|
||||||
var searchPath = '';
|
{
|
||||||
for (var i in paths) {
|
try
|
||||||
if (paths[i].endsWith(':')) {
|
{
|
||||||
searchPath = paths[i].substring(0, paths[i].length - 1);
|
this._gm.CreateNativeProxy(x11info[ix].path);
|
||||||
} else {
|
Object.defineProperty(this, 'Location_X11LIB', { value: x11info[ix].path });
|
||||||
try { // Added by Ylian: Try/catch to fix X11 detection, not sure if this is correct.
|
break;
|
||||||
if (paths[i].split('libX11.').length > 1)
|
}
|
||||||
{
|
catch(ex)
|
||||||
//require('MeshAgent').SendCommand({ "action": "msg", "type": "console", "value": "path = " + searchPath + '/' + paths[i].split('->')[1].trim() });
|
{
|
||||||
Object.defineProperty(this, 'Location_X11LIB', { value: searchPath + '/' + paths[i].split('->')[1].trim() });
|
}
|
||||||
}
|
}
|
||||||
if (paths[i].split('libXtst.').length > 1) { Object.defineProperty(this, 'Location_X11TST', { value: searchPath + '/' + paths[i].split('->')[1].trim() }); }
|
for (ix in xtstinfo)
|
||||||
if (paths[i].split('libXext.').length > 1) { Object.defineProperty(this, 'Location_X11EXT', { value: searchPath + '/' + paths[i].split('->')[1].trim() }); }
|
{
|
||||||
} catch (ex)
|
try
|
||||||
{
|
{
|
||||||
//require('MeshAgent').SendCommand({ "action": "msg", "type": "console", "value": "[" + searchPath + '/' + paths[i].split('->')[1].trim() + "] uncaughtException7: " + ex });
|
this._gm.CreateNativeProxy(xtstinfo[ix].path);
|
||||||
}
|
Object.defineProperty(this, 'Location_X11TST', { value: xtstinfo[ix].path });
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
catch (ex)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (ix in xextinfo)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
this._gm.CreateNativeProxy(xextinfo[ix].path);
|
||||||
|
Object.defineProperty(this, 'Location_X11EXT', { value: xextinfo[ix].path });
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
catch (ex)
|
||||||
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "meshcentral",
|
"name": "meshcentral",
|
||||||
"version": "0.2.3-l",
|
"version": "0.2.3-o",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"Remote Management",
|
"Remote Management",
|
||||||
"Intel AMT",
|
"Intel AMT",
|
||||||
|
File diff suppressed because one or more lines are too long
@ -242,6 +242,10 @@
|
|||||||
if (webPageFullScreen == 'true') { webPageFullScreen = true; }
|
if (webPageFullScreen == 'true') { webPageFullScreen = true; }
|
||||||
toggleFullScreen();
|
toggleFullScreen();
|
||||||
|
|
||||||
|
var terms = "{{{terms}}}";
|
||||||
|
if (terms != "") { QH('column_l', decodeURIComponent(terms)); }
|
||||||
|
QV('column_l', true);
|
||||||
|
|
||||||
// Toggle the web page to full screen
|
// Toggle the web page to full screen
|
||||||
function toggleFullScreen(toggle) {
|
function toggleFullScreen(toggle) {
|
||||||
if (toggle === 1) { webPageFullScreen = !webPageFullScreen; putstore('webPageFullScreen', webPageFullScreen); }
|
if (toggle === 1) { webPageFullScreen = !webPageFullScreen; putstore('webPageFullScreen', webPageFullScreen); }
|
||||||
|
32
webserver.js
32
webserver.js
@ -804,13 +804,33 @@ module.exports.CreateWebServer = function (parent, db, args, certificates) {
|
|||||||
function handleTermsRequest(req, res) {
|
function handleTermsRequest(req, res) {
|
||||||
var domain = checkUserIpAddress(req, res);
|
var domain = checkUserIpAddress(req, res);
|
||||||
if (domain == null) return;
|
if (domain == null) return;
|
||||||
res.set({ 'Cache-Control': 'no-cache, no-store, must-revalidate', 'Pragma': 'no-cache', 'Expires': '0' });
|
|
||||||
if (req.session && req.session.userid) {
|
// See if there is a terms.txt file in meshcentral-data
|
||||||
if (req.session.domainid != domain.id) { req.session = null; res.redirect(domain.url); return; } // Check is the session is for the correct domain
|
var p = obj.path.join(obj.parent.datapath, 'terms.txt');
|
||||||
var user = obj.users[req.session.userid];
|
if (obj.fs.existsSync(p)) {
|
||||||
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/terms-mobile' : 'views/terms'), { title: domain.title, title2: domain.title2, logoutControl: 'Welcome ' + user.name + '. <a href=' + domain.url + 'logout?' + Math.random() + ' style=color:white>Logout</a>' });
|
readEntireTextFile(p, function (data) {
|
||||||
|
if (data == null) { res.sendStatus(404); return; }
|
||||||
|
|
||||||
|
// Send the terms
|
||||||
|
res.set({ 'Cache-Control': 'no-cache, no-store, must-revalidate', 'Pragma': 'no-cache', 'Expires': '0' });
|
||||||
|
if (req.session && req.session.userid) {
|
||||||
|
if (req.session.domainid != domain.id) { req.session = null; res.redirect(domain.url); return; } // Check is the session is for the correct domain
|
||||||
|
var user = obj.users[req.session.userid];
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/terms-mobile' : 'views/terms'), { title: domain.title, title2: domain.title2, terms: encodeURIComponent(data), logoutControl: 'Welcome ' + user.name + '. <a href=' + domain.url + 'logout?' + Math.random() + ' style=color:white>Logout</a>' });
|
||||||
|
} else {
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/terms-mobile' : 'views/terms'), { title: domain.title, title2: domain.title2, terms: encodeURIComponent(data) });
|
||||||
|
}
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/terms-mobile' : 'views/terms'), { title: domain.title, title2: domain.title2 });
|
// Send the terms
|
||||||
|
res.set({ 'Cache-Control': 'no-cache, no-store, must-revalidate', 'Pragma': 'no-cache', 'Expires': '0' });
|
||||||
|
if (req.session && req.session.userid) {
|
||||||
|
if (req.session.domainid != domain.id) { req.session = null; res.redirect(domain.url); return; } // Check is the session is for the correct domain
|
||||||
|
var user = obj.users[req.session.userid];
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/terms-mobile' : 'views/terms'), { title: domain.title, title2: domain.title2, logoutControl: 'Welcome ' + user.name + '. <a href=' + domain.url + 'logout?' + Math.random() + ' style=color:white>Logout</a>' });
|
||||||
|
} else {
|
||||||
|
res.render(obj.path.join(__dirname, isMobileBrowser(req) ? 'views/terms-mobile' : 'views/terms'), { title: domain.title, title2: domain.title2 });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user