diff --git a/MeshCentralServer.njsproj b/MeshCentralServer.njsproj
index 0bb90dc8..81ea687c 100644
--- a/MeshCentralServer.njsproj
+++ b/MeshCentralServer.njsproj
@@ -90,6 +90,7 @@
+
diff --git a/amt/amt-wsman-comm.js b/amt/amt-wsman-comm.js
index 7d1bb155..4e3bd206 100644
--- a/amt/amt-wsman-comm.js
+++ b/amt/amt-wsman-comm.js
@@ -5,7 +5,7 @@
*/
// Construct a MeshServer object
-var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent, mode) {
+var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, mode) {
//console.log('CreateWsmanComm', host, port, user, pass, tls, tlsoptions);
var obj = {};
@@ -38,8 +38,7 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
obj.pass = pass;
obj.xtls = tls;
obj.xtlsoptions = tlsoptions;
- obj.parent = parent;
- obj.mode = mode;//1: direct, 2: CIRA, 3: APF relay
+ obj.mode = mode; // 1 = Direct, 2 = CIRA, 3 = APF relay
obj.xtlsFingerprint;
obj.xtlsCertificate = null;
obj.xtlsCheck = 0; // 0 = No TLS, 1 = CA Checked, 2 = Pinned, 3 = Untrusted
@@ -90,7 +89,7 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
// NODE.js specific private method
obj.PerformAjaxExNodeJS2 = function (postdata, callback, tag, url, action, retry) {
- if (retry <= 0 || obj.FailAllError != 0) {
+ if ((retry <= 0) || (obj.FailAllError != 0)) {
// Too many retry, fail here.
obj.ActiveAjaxCount--;
if (obj.FailAllError != 999) obj.gotNextMessages(null, 'error', { status: ((obj.FailAllError == 0) ? 408 : obj.FailAllError) }, [postdata, callback, tag, url, action]); // 408 is timeout error
@@ -167,7 +166,7 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
obj.socketState = 1;
obj.kerberosDone = 0;
- if ((obj.parent != null) && (obj.mode === 2) || (obj.mode === 3)) { // CIRA and APF
+ if ((obj.parent != null) && ((obj.mode === 2) || (obj.mode === 3))) { // CIRA and APF
if (obj.mode == 2) { // CIRA
var ciraconn = obj.parent.mpsserver.ciraConnections[obj.host];
obj.socket = obj.parent.mpsserver.SetupCiraChannel(ciraconn, obj.port);
@@ -200,7 +199,7 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
obj.socket.setTimeout(6000); // Set socket idle timeout
obj.socket.on('data', obj.xxOnSocketData);
obj.socket.on('close', obj.xxOnSocketClosed);
- obj.socket.on('timeout', obj.xxOnSocketClosed);
+ obj.socket.on('timeout', obj.xxOnSocketTimeout);
obj.socket.connect(obj.port, obj.host, obj.xxOnSocketConnected);
} else {
// Connect with TLS
@@ -210,14 +209,13 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
if (obj.xtlsoptions.ca) options.ca = obj.xtlsoptions.ca;
if (obj.xtlsoptions.cert) options.cert = obj.xtlsoptions.cert;
if (obj.xtlsoptions.key) options.key = obj.xtlsoptions.key;
- obj.xtlsoptions = options;
}
- obj.socket = obj.tls.connect(obj.port, obj.host, obj.xtlsoptions, obj.xxOnSocketConnected);
+ obj.socket = obj.tls.connect(obj.port, obj.host, options, obj.xxOnSocketConnected);
obj.socket.setEncoding('binary');
obj.socket.setTimeout(6000); // Set socket idle timeout
obj.socket.on('data', obj.xxOnSocketData);
obj.socket.on('close', obj.xxOnSocketClosed);
- obj.socket.on('timeout', obj.xxOnSocketClosed);
+ obj.socket.on('timeout', obj.xxOnSocketTimeout);
obj.socket.on('error', function (e) { if (e.message && e.message.indexOf('sslv3 alert bad record mac') >= 0) { obj.xtlsMethod = 1 - obj.xtlsMethod; } });
}
obj.socket.setNoDelay(true); // Disable nagle. We will encode each WSMAN request as a single send block and want to send it at once. This may help Intel AMT handle pipelining?
@@ -232,13 +230,13 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
obj.xxOnSocketConnected = function () {
if (obj.socket == null) return;
// check TLS certificate for webrelay and direct only
- if (obj.mode < 2 && obj.xtls == 1) {
+ if (((obj.mode == null) || (obj.mode < 2)) && (obj.xtls == 1)) {
obj.xtlsCertificate = obj.socket.getPeerCertificate();
// ###BEGIN###{Certificates}
// Setup the forge certificate check
var camatch = 0;
- if (obj.xtlsoptions.ca) {
+ if ((obj.xtlsoptions != null) && (obj.xtlsoptions.ca != null)) {
var forgeCert = forge.pki.certificateFromAsn1(forge.asn1.fromDer(atob(obj.xtlsCertificate.raw.toString('base64'))));
var caStore = forge.pki.createCaStore(obj.xtlsoptions.ca);
// Got thru all certificates in the store and look for a match.
@@ -351,9 +349,7 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
if (isNaN(s)) s = 500;
if (s == 401 && ++(obj.authcounter) < 3) {
obj.challengeParams = obj.parseDigest(header['www-authenticate']); // Set the digest parameters, after this, the socket will close and we will auto-retry
- if (obj.mode==1) {
- obj.socket.end();
- }
+ if (obj.mode == 1) { obj.socket.end(); }
} else {
var r = obj.pendingAjaxCall.shift();
if (r == null || r.length < 1) { console.log("pendingAjaxCall error, " + r); return; }
@@ -366,22 +362,23 @@ var CreateWsmanComm = function (host, port, user, pass, tls, tlsoptions, parent,
}
// NODE.js specific private method
- obj.xxOnSocketClosed = function (data) {
+ obj.xxOnSocketClosed = function () {
//obj.Debug("xxOnSocketClosed");
obj.socketState = 0;
- if (obj.mode ==1 && obj.socket != null) { obj.socket.destroy(); obj.socket = null; }
+ if (((obj.mode == null) || (obj.mode == 1)) && (obj.socket != null)) { obj.socket.destroy(); obj.socket = null; }
if (obj.pendingAjaxCall.length > 0) {
- var r = obj.pendingAjaxCall.shift();
- var retry = r[5];
+ var r = obj.pendingAjaxCall.shift(), retry = r[5];
setTimeout(function () { obj.PerformAjaxExNodeJS2(r[0], r[1], r[2], r[3], r[4], --retry) }, 500); // Wait half a second and try again
}
}
+ obj.xxOnSocketTimeout = function () {
+ if (((obj.mode == null) || (obj.mode == 1)) && (obj.socket != null)) { obj.socket.destroy(); obj.socket = null; }
+ }
+
// NODE.js specific private method
obj.xxSend = function (x) {
- if (obj.socketState == 2) {
- obj.socket.write(Buffer.from(x, "binary"));
- }
+ if (obj.socketState == 2) { obj.socket.write(Buffer.from(x, "binary")); }
}
// Cancel all pending queries with given status
diff --git a/amt/amt-wsman.js b/amt/amt-wsman.js
index 4dc38aa5..b1faa412 100644
--- a/amt/amt-wsman.js
+++ b/amt/amt-wsman.js
@@ -21,26 +21,16 @@ limitations under the License.
*/
// Construct a MeshServer object
-function WsmanStackCreateService(CreateWsmanComm, host, port, user, pass, tls, extra, parent, mode)
+//function WsmanStackCreateService(comm, host, port, user, pass, tls, extra, parent, mode)
+function WsmanStackCreateService(comm)
{
var obj = {_ObjectID: 'WSMAN'};
//obj.onDebugMessage = null; // Set to a function if you want to get debug messages.
obj.NextMessageId = 1; // Next message number, used to label WSMAN calls.
obj.Address = '/wsman';
obj.xmlParser = require('./amt-xml.js');
-
- if (arguments.length == 1 && typeof (arguments[0] == 'object'))
- {
- var CreateWsmanComm = arguments[0].transport;
- if (CreateWsmanComm) { obj.comm = new CreateWsmanComm(arguments[0]); }
- }
- else
- {
- var CreateWsmanComm = arguments[0];
- if (CreateWsmanComm) {
- obj.comm = new CreateWsmanComm(host, port, user, pass, tls, extra, parent, mode);
- }
- }
+ obj.comm = comm;
+ obj.comm.parent = obj;
obj.PerformAjax = function PerformAjax(postdata, callback, tag, pri, namespaces) {
if (namespaces == null) namespaces = '';
diff --git a/amtmanager.js b/amtmanager.js
new file mode 100644
index 00000000..e0d912cc
--- /dev/null
+++ b/amtmanager.js
@@ -0,0 +1,260 @@
+/**
+* @description MeshCentral remote desktop multiplexor
+* @author Ylian Saint-Hilaire
+* @copyright Intel Corporation 2018-2020
+* @license Apache-2.0
+* @version v0.0.1
+*/
+
+/*jslint node: true */
+/*jshint node: true */
+/*jshint strict:false */
+/*jshint -W097 */
+/*jshint esversion: 6 */
+"use strict";
+
+
+module.exports.CreateAmtManager = function(parent) {
+ var obj = {};
+ obj.parent = parent;
+ obj.amtDevices = {}; // Nodeid --> dev
+ obj.activeLocalConnections = {}; // Host --> dev
+ obj.amtAdminAccounts = [];
+
+ // WSMAN stack
+ const CreateWsmanComm = require('./amt/amt-wsman-comm');
+ const WsmanStackCreateService = require('./amt/amt-wsman');
+ const AmtStackCreateService = require('./amt/amt');
+
+ // Load the Intel AMT admin accounts
+ if ((typeof parent.args.amtmanager == 'object') && (Array.isArray(parent.args.amtmanager.amtadminaccount) == true)) {
+ for (var i in parent.args.amtmanager.amtadminaccount) {
+ var c = parent.args.amtmanager.amtadminaccount[i], c2 = { user: "admin" };
+ if (typeof c.user == 'string') { c2.user = c.user; }
+ if (typeof c.pass == 'string') { c2.pass = c.pass; obj.amtAdminAccounts.push(c2); }
+ }
+ }
+
+ // Subscribe to server events
+ parent.AddEventDispatch(['*'], obj);
+
+ // Handle server events
+ obj.HandleEvent = function (source, event, ids, id) {
+ if (event.action != 'nodeconnect') return;
+ if ((event.conn & 14) != 0) { // connectType: Bitmask, 1 = MeshAgent, 2 = Intel AMT CIRA, 4 = Intel AMT local, 8 = Intel AMT Relay, 16 = MQTT
+ // We have an OOB connection to Intel AMT, update our information
+ var dev = obj.amtDevices[event.nodeid];
+ if (dev == null) { obj.amtDevices[event.nodeid] = dev = { conn: event.conn }; fetchIntelAmtInformation(event.nodeid); } else { dev.conn = event.conn; }
+ } else if (((event.conn & 1) != 0) && (parent.webserver != null)) {
+ // We have an agent connection without OOB, check if this agent supports Intel AMT
+ var agent = parent.webserver.wsagents[event.nodeid];
+ if ((agent == null) || (agent.agentInfo == null) || (parent.meshAgentsArchitectureNumbers[agent.agentInfo.agentId].amt == false)) { removeDevice(event.nodeid); return; }
+ var dev = obj.amtDevices[event.nodeid];
+ if (dev == null) { obj.amtDevices[event.nodeid] = dev = { conn: event.conn }; fetchIntelAmtInformation(event.nodeid); } else { dev.conn = event.conn; }
+ } else {
+ removeDevice(event.nodeid);
+ }
+ }
+
+ // Remove a device
+ function removeDevice(nodeid) {
+ const dev = obj.amtDevices[nodeid];
+ if (dev == null) return;
+ if (dev.amtstack != null) { dev.amtstack.wsman.comm.FailAllError = 999; delete dev.amtstack; } // Disconnect any active connections.
+ delete obj.amtDevices[nodeid];
+ }
+
+ // Update information about a device
+ function fetchIntelAmtInformation(nodeid) {
+ parent.db.Get(nodeid, function (err, nodes) {
+ if ((nodes == null) || (nodes.length != 1)) { removeDevice(nodeid); return; }
+ const node = nodes[0];
+ if ((node.intelamt == null) || (node.meshid == null)) { removeDevice(nodeid); return; }
+ const mesh = parent.webserver.meshes[node.meshid];
+ if (mesh == null) { removeDevice(nodeid); return; }
+ const dev = obj.amtDevices[nodeid];
+ if (dev == null) { return; }
+ dev.name = node.name;
+ dev.nodeid = node._id;
+ if (node.host) { dev.host = node.host.toLowerCase(); }
+ dev.meshid = node.meshid;
+ dev.intelamt = node.intelamt;
+ attemptInitialContact(nodeid, dev);
+ });
+ }
+
+ // Attempt to perform initial contact with Intel AMT
+ function attemptInitialContact(nodeid, dev) {
+ if (dev == null) { dev = obj.amtDevices[nodeid]; }
+ if (dev == null) return;
+
+ //if (dev.host != '192.168.2.136') return;
+
+ if ((dev.acctry == null) && ((typeof dev.intelamt.user != 'string') || (typeof dev.intelamt.pass != 'string'))) {
+ if (obj.amtAdminAccounts.length > 0) { dev.acctry = 0; } else { return; }
+ }
+
+ if (((dev.conn & 4) != 0) && (typeof dev.host == 'string')) {
+ // Since we don't allow two or more connections to the same host, check if a pending connection is active.
+ if (obj.activeLocalConnections[dev.host] != null) {
+ // Active connection, hold and try later.
+ setTimeout(function () { attemptInitialContact(nodeid); }, 5000);
+ } else {
+ // No active connections, see what user/pass to try.
+ var user = null, pass = null;
+ if (dev.acctry == null) { user = dev.intelamt.user; pass = dev.intelamt.pass; } else { user = obj.amtAdminAccounts[dev.acctry].user; pass = obj.amtAdminAccounts[dev.acctry].pass; }
+
+ // Connect now
+ //console.log('Connect', dev.name, dev.host, user, pass);
+ var comm;
+ if (dev.tlsfail !== true) {
+ comm = CreateWsmanComm(dev.host, 16993, user, pass, 1); // Always try with TLS first
+ comm.xtlsFingerprint = 0; // Perform no certificate checking
+ } else {
+ comm = CreateWsmanComm(dev.host, 16992, user, pass, 0); // Try without TLS
+ }
+ var wsstack = WsmanStackCreateService(comm);
+ dev.amtstack = AmtStackCreateService(wsstack);
+ dev.amtstack.dev = dev;
+ obj.activeLocalConnections[dev.host] = dev;
+ dev.amtstack.BatchEnum(null, ['*AMT_GeneralSettings', '*IPS_HostBasedSetupService'], attemptLocalConectResponse);
+ }
+ }
+ }
+
+ function attemptLocalConectResponse(stack, name, responses, status) {
+ // Release active connection to this host.
+ delete obj.activeLocalConnections[stack.wsman.comm.host];
+
+ // Check if the device still exists
+ const dev = stack.dev;
+ if (obj.amtDevices[dev.nodeid] == null) return; // Device no longer exists, ignore this response.
+
+ // Check the response
+ if ((status == 200) && (responses['AMT_GeneralSettings'] != null) && (responses['IPS_HostBasedSetupService'] != null) && (responses['IPS_HostBasedSetupService'].response != null) && (responses['IPS_HostBasedSetupService'].response != null) && (stack.wsman.comm.digestRealm == responses['AMT_GeneralSettings'].response.DigestRealm)) {
+ // Everything looks good
+ if (dev.aquired == null) { dev.aquired = {}; }
+ dev.aquired.controlMode = responses['IPS_HostBasedSetupService'].response.CurrentControlMode; // 1 = CCM, 2 = ACM
+ var verSplit = stack.wsman.comm.amtVersion.split('.');
+ if (verSplit.length >= 3) { dev.aquired.version = verSplit[0] + '.' + verSplit[1] + '.' + verSplit[2]; }
+ dev.aquired.realm = stack.wsman.comm.digestRealm;
+ dev.aquired.user = stack.wsman.comm.user;
+ dev.aquired.pass = stack.wsman.comm.pass;
+ dev.aquired.lastContact = Date.now();
+ dev.aquired.tls = stack.wsman.comm.xtls;
+ if (stack.wsman.comm.xtls == 1) { dev.aquired.tlshash = stack.wsman.comm.xtlsCertificate.fingerprint.split(':').join('').toLowerCase(); } else { delete dev.aquired.tlshash; }
+ //console.log(dev.nodeid, dev.name, dev.host, dev.aquired);
+ UpdateDevice(dev);
+ //attemptFetchHardwareInventory(dev); // See if we need to get hardware inventory
+ } else {
+ // We got a bad response
+ if ((dev.tlsfail !== true) && (status == 408)) {
+ // TLS error, try again without TLS
+ dev.tlsfail = true; attemptInitialContact(dev.nodeid, dev); return;
+ } else if (status == 401) {
+ // Authentication error, see if we can use alternative credentials
+ if ((dev.acctry == null) && (obj.amtAdminAccounts.length > 0)) { dev.acctry = 0; attemptInitialContact(dev.nodeid, dev); return; }
+ if ((dev.acctry != null) && (obj.amtAdminAccounts.length > (dev.acctry + 1))) { dev.acctry++; attemptInitialContact(dev.nodeid, dev); return; }
+ }
+ //console.log(dev.nodeid, dev.name, dev.host, status, 'Bad response');
+ removeDevice(dev.nodeid);
+ }
+ }
+
+ // Change the current core information string and event it
+ function UpdateDevice(dev) {
+ if (obj.amtDevices[dev.nodeid] == null) return false; // Device no longer exists, ignore this request.
+
+ // Check that the mesh exists
+ const mesh = parent.webserver.meshes[dev.meshid];
+ if (mesh == null) { removeDevice(dev.nodeid); return false; }
+
+ // Get the node and change it if needed
+ parent.db.Get(dev.nodeid, function (err, nodes) {
+ if ((nodes == null) || (nodes.length != 1)) { return false; }
+ const device = nodes[0];
+ var changes = [], change = 0, log = 0;
+ var domain = parent.config.domains[device.domain];
+ if (domain == null) { return false; }
+
+ // Check if anything changes
+ if (device.intelamt == null) { device.intelamt = {}; }
+ if (dev.aquired.version && (typeof dev.aquired.version == 'string') && (dev.aquired.version != device.intelamt.ver)) { change = 1; log = 1; device.intelamt.ver = dev.aquired.version; changes.push('AMT version'); }
+ if (dev.aquired.user && (typeof dev.aquired.user == 'string') && (dev.aquired.user != device.intelamt.user)) { change = 1; log = 1; device.intelamt.user = dev.aquired.user; changes.push('AMT user'); }
+ if (dev.aquired.pass && (typeof dev.aquired.pass == 'string') && (dev.aquired.pass != device.intelamt.pass)) { change = 1; log = 1; device.intelamt.pass = dev.aquired.pass; changes.push('AMT pass'); }
+ if (dev.aquired.realm && (typeof dev.aquired.realm == 'string') && (dev.aquired.realm != device.intelamt.realm)) { change = 1; log = 1; device.intelamt.realm = dev.aquired.realm; changes.push('AMT realm'); }
+ if (device.intelamt.state != 2) { change = 1; log = 1; device.intelamt.state = 2; changes.push('AMT state'); }
+
+ // Update Intel AMT flags if needed
+ // dev.aquired.controlMode // 1 = CCM, 2 = ACM
+ // (node.intelamt.flags & 2) == CCM, (node.intelamt.flags & 4) == ACM
+ var flags = 0;
+ if (typeof device.intelamt.flags == 'number') { flags = device.intelamt.flags; }
+ if (dev.aquired.controlMode == 1) { if ((flags & 4) != 0) { flags -= 4; } if ((flags & 2) == 0) { flags += 2; } } // CCM
+ if (dev.aquired.controlMode == 2) { if ((flags & 4) == 0) { flags += 4; } if ((flags & 2) != 0) { flags -= 2; } } // ACM
+ if (device.intelamt.flags != flags) { change = 1; log = 1; device.intelamt.flags = flags; changes.push('AMT flags'); }
+
+ // If there are changes, event the new device
+ if (change == 1) {
+ // Save to the database
+ parent.db.Set(device);
+
+ // Event the node change
+ var event = { etype: 'node', action: 'changenode', nodeid: device._id, domain: domain.id, node: parent.webserver.CloneSafeNode(device) };
+ if (changes.length > 0) { event.msg = 'Changed device ' + device.name + ' from group ' + mesh.name + ': ' + changes.join(', '); }
+ if ((log == 0) || ((obj.agentInfo) && (obj.agentInfo.capabilities) && (obj.agentInfo.capabilities & 0x20)) || (changes.length == 0)) { event.nolog = 1; } // If this is a temporary device, don't log changes
+ if (parent.db.changeStream) { event.noact = 1; } // If DB change stream is active, don't use this event to change the node. Another event will come.
+ parent.DispatchEvent(parent.webserver.CreateMeshDispatchTargets(device.meshid, [device._id]), obj, event);
+ }
+
+ });
+ }
+
+ function attemptFetchHardwareInventory(dev) {
+ if (obj.amtDevices[dev.nodeid] == null) return false; // Device no longer exists, ignore this request.
+ const mesh = parent.webserver.meshes[dev.meshid];
+ if (mesh == null) { removeDevice(dev.nodeid); return false; }
+ if (mesh.mtype == 1) { // If this is a Intel AMT only device group, pull the hardware inventory for this device
+ dev.amtstack.BatchEnum('', ['*CIM_ComputerSystemPackage', 'CIM_SystemPackaging', '*CIM_Chassis', 'CIM_Chip', '*CIM_Card', '*CIM_BIOSElement', 'CIM_Processor', 'CIM_PhysicalMemory', 'CIM_MediaAccessDevice', 'CIM_PhysicalPackage'], attemptFetchHardwareInventoryResponse);
+ return true;
+ }
+ return false;
+ }
+
+ // http://www.dmtf.org/sites/default/files/standards/documents/DSP0134_2.7.1.pdf
+ const DMTFCPUStatus = ["Unknown", "Enabled", "Disabled by User", "Disabled By BIOS (POST Error)", "Idle", "Other"];
+ const DMTFMemType = ["Unknown", "Other", "DRAM", "Synchronous DRAM", "Cache DRAM", "EDO", "EDRAM", "VRAM", "SRAM", "RAM", "ROM", "Flash", "EEPROM", "FEPROM", "EPROM", "CDRAM", "3DRAM", "SDRAM", "SGRAM", "RDRAM", "DDR", "DDR-2", "BRAM", "FB-DIMM", "DDR3", "FBD2", "DDR4", "LPDDR", "LPDDR2", "LPDDR3", "LPDDR4"];
+ const DMTFMemFormFactor = ['', "Other", "Unknown", "SIMM", "SIP", "Chip", "DIP", "ZIP", "Proprietary Card", "DIMM", "TSOP", "Row of chips", "RIMM", "SODIMM", "SRIMM", "FB-DIM"];
+ const DMTFProcFamilly = { // Page 46 of DMTF document
+ 191: "Intel® Core™ 2 Duo Processor",
+ 192: "Intel® Core™ 2 Solo processor",
+ 193: "Intel® Core™ 2 Extreme processor",
+ 194: "Intel® Core™ 2 Quad processor",
+ 195: "Intel® Core™ 2 Extreme mobile processor",
+ 196: "Intel® Core™ 2 Duo mobile processor",
+ 197: "Intel® Core™ 2 Solo mobile processor",
+ 198: "Intel® Core™ i7 processor",
+ 199: "Dual-Core Intel® Celeron® processor"
+ };
+
+ function attemptFetchHardwareInventoryResponse(stack, name, responses, status) {
+ const dev = stack.dev;
+ if (obj.amtDevices[dev.nodeid] == null) return; // Device no longer exists, ignore this response.
+
+ //console.log(JSON.stringify(responses, null, 2));
+
+ var hw = {}
+ hw.PlatformGUID = responses['CIM_ComputerSystemPackage'].response.PlatformGUID;
+ hw.Chassis = responses['CIM_Chassis'].response;
+ hw.Chips = responses['CIM_Chip'].responses;
+ hw.Card = responses['CIM_Card'].response;
+ hw.Bios = responses['CIM_BIOSElement'].response;
+ hw.Processors = responses['CIM_Processor'].responses;
+ hw.PhysicalMemory = responses['CIM_PhysicalMemory'].responses;
+ hw.MediaAccessDevice = responses['CIM_MediaAccessDevice'].responses;
+ hw.PhysicalPackage = responses['CIM_PhysicalPackage'].responses;
+ console.log(JSON.stringify(hw, null, 2));
+ }
+
+ return obj;
+};
diff --git a/db.js b/db.js
index f823f39f..4a1464fe 100644
--- a/db.js
+++ b/db.js
@@ -1156,11 +1156,11 @@ module.exports.CreateDB = function (parent, func) {
if (extrasids == null) {
var x = { type: type, domain: domain, meshid: { $in: meshes } };
if (id) { x._id = id; }
- obj.file.find(x, { type: 0 }, function (err, docs) { func(err, performTypedRecordDecrypt(docs)); });
+ obj.file.find(x, function (err, docs) { func(err, performTypedRecordDecrypt(docs)); });
} else {
var x = { type: type, domain: domain, $or: [{ meshid: { $in: meshes } }, { _id: { $in: extrasids } }] };
if (id) { x._id = id; }
- obj.file.find(x, { type: 0 }, function (err, docs) { func(err, performTypedRecordDecrypt(docs)); });
+ obj.file.find(x, function (err, docs) { func(err, performTypedRecordDecrypt(docs)); });
}
};
obj.GetAllType = function (type, func) { obj.file.find({ type: type }, function (err, docs) { func(err, performTypedRecordDecrypt(docs)); }); };
diff --git a/emails/translations/account-check_cs.txt b/emails/translations/account-check_cs.txt
index c1dcfba6..6bf7299f 100644
--- a/emails/translations/account-check_cs.txt
+++ b/emails/translations/account-check_cs.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Ověření e-mailem
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Ahoj [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) provádí ověření e-mailem. Chcete-li proces dokončit, přejděte na následující odkaz:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_de.txt b/emails/translations/account-check_de.txt
index ece2fdf6..df7bc55f 100644
--- a/emails/translations/account-check_de.txt
+++ b/emails/translations/account-check_de.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - E-Mail-Überprüfung
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Hallo [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) führt eine E-Mail-Überprüfung durch. Klicken Sie auf den folgenden Link, um den Vorgang abzuschließen:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_es.txt b/emails/translations/account-check_es.txt
index dc61d732..33f2e949 100644
--- a/emails/translations/account-check_es.txt
+++ b/emails/translations/account-check_es.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Verificación de Correo Electrónico
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Hola [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) esta realizando una comprobación del correo electrónico. Navegue al siguiente enlace para completar el proceso:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_fi.txt b/emails/translations/account-check_fi.txt
index 9ebdfc0a..bde9a7a5 100644
--- a/emails/translations/account-check_fi.txt
+++ b/emails/translations/account-check_fi.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Sähköpostivarmistus
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Hei [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) tarkistaa sähköpostiosoitetta. Seuraa linkkiä prosessin loppuun saattamiseksi:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_fr.txt b/emails/translations/account-check_fr.txt
index da39ae6d..1deeaafa 100644
--- a/emails/translations/account-check_fr.txt
+++ b/emails/translations/account-check_fr.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Vérification E-mail
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Bonjour [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) effectue une vérification par e-mail. Accédez au lien suivant pour terminer le processus:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_hi.txt b/emails/translations/account-check_hi.txt
index 2ea6380c..b7a11ab3 100644
--- a/emails/translations/account-check_hi.txt
+++ b/emails/translations/account-check_hi.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - ईमेल सत्यापन
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+हाय [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) ई-मेल सत्यापन कर रहा है। प्रक्रिया को पूरा करने के लिए निम्नलिखित लिंक को बताएं:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_ja.txt b/emails/translations/account-check_ja.txt
index 9630200c..04db0e8c 100644
--- a/emails/translations/account-check_ja.txt
+++ b/emails/translations/account-check_ja.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - メールの確認
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+こんにちは[[[USERNAME]]]、[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) は電子メールの検証を実行しています。プロセスを完了するには、次のリンクに移動します。
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_ko.txt b/emails/translations/account-check_ko.txt
index 3f0a085c..f1260753 100644
--- a/emails/translations/account-check_ko.txt
+++ b/emails/translations/account-check_ko.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Email 인증
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+안녕하세요, [[[USERNAME]]]님. [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]])은 이메일 검증을 위해 실행됩니다. 다음 링크로 이동하여 과정을 완료하십시오 :
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_pt.txt b/emails/translations/account-check_pt.txt
index 602e3033..8371a6bf 100644
--- a/emails/translations/account-check_pt.txt
+++ b/emails/translations/account-check_pt.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Verificação de Email
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Olá, [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) está realizando uma verificação de e-mail. Acesse o seguinte link para concluir o processo:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_ru.txt b/emails/translations/account-check_ru.txt
index 9f37e20e..ab6dd187 100644
--- a/emails/translations/account-check_ru.txt
+++ b/emails/translations/account-check_ru.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - подтверждение по электронной почте
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Здравствуйте, [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) выполняет проверку электронной почты. Для завершения процесса перейдите по следующей ссылке:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_tr.txt b/emails/translations/account-check_tr.txt
index b4ba2547..b8e675d9 100644
--- a/emails/translations/account-check_tr.txt
+++ b/emails/translations/account-check_tr.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - E-posta Doğrulaması
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+Merhaba [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) bir e-posta doğrulaması yapıyor. İşlemi tamamlamak için aşağıdaki bağlantıya gidin:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_zh-chs.txt b/emails/translations/account-check_zh-chs.txt
index a231cb58..f8c390d7 100644
--- a/emails/translations/account-check_zh-chs.txt
+++ b/emails/translations/account-check_zh-chs.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]]-电邮验证
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+嗨[[[USERNAME]]],[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在执行电邮验证。导航至以下连结以完成该过程:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-check_zh-cht.txt b/emails/translations/account-check_zh-cht.txt
index a448c960..4b843330 100644
--- a/emails/translations/account-check_zh-cht.txt
+++ b/emails/translations/account-check_zh-cht.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]]-電郵驗證
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is performing an e-mail verification. Nagivate to the following link to complete the process:
+嗨[[[USERNAME]]],[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在執行電郵驗證。導航至以下鏈結以完成該過程:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-invite_cs.txt b/emails/translations/account-invite_cs.txt
index 5d066577..b3f5b64b 100644
--- a/emails/translations/account-invite_cs.txt
+++ b/emails/translations/account-invite_cs.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Pozvánka na účet
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+Účet pro vás byl vytvořen na serveru [[[SERVERNAME]]] ([[[[SERVERURL]]]/[[[URLARGS1]]]), nyní k němu můžete přistupovat pomocí uživatelského jména „[[[[ACCOUNTNAME]]]“ “a hesla„ [[[HESLO]] ]] ".
~
S pozdravem,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_de.txt b/emails/translations/account-invite_de.txt
index 4e7d5294..eaed8c06 100644
--- a/emails/translations/account-invite_de.txt
+++ b/emails/translations/account-invite_de.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Kontoeinladung
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+Auf dem Server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) wurde ein Konto für Sie erstellt, Sie können ab sofort mit dem Benutzernamen "[[[ACCOUNTNAME]]]" und dem Passwort "[[[PASSWORD]]]" darauf zugreifen.
~
Freundliche Grüße,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_es.txt b/emails/translations/account-invite_es.txt
index 9e753efd..d828102a 100644
--- a/emails/translations/account-invite_es.txt
+++ b/emails/translations/account-invite_es.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Invitación de Cuenta
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+Una cuenta ha sido creada en su servidor [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), ahora puede acceder con el usuario "[[[ACCOUNTNAME]]]" y la contraseña "[[[PASSWORD]]]".
~
Atentamente,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_fi.txt b/emails/translations/account-invite_fi.txt
index c5fb7e22..bb953120 100644
--- a/emails/translations/account-invite_fi.txt
+++ b/emails/translations/account-invite_fi.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Tili kutsu
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+Sinulle on luotu tili palvelimelle [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), voit käyttää sitä nyt käyttäjätunnuksella "[[[ACCOUNTNAME]]]" and salasanalla "[[[PASSWORD]]]".
~
Ystävällisin terveisin,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_fr.txt b/emails/translations/account-invite_fr.txt
index 57531cf2..2b2b6a09 100644
--- a/emails/translations/account-invite_fr.txt
+++ b/emails/translations/account-invite_fr.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Invitation au compte
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+Un compte a été créé pour vous sur le serveur [[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), vous pouvez y accéder maintenant avec le nom d'utilisateur "[[[ACCOUNTNAME]]]" et le mot de passe "[[[PASSWORD]]]".
~
Meilleures salutations,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_hi.txt b/emails/translations/account-invite_hi.txt
index db26edbb..f1e09f0f 100644
--- a/emails/translations/account-invite_hi.txt
+++ b/emails/translations/account-invite_hi.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - खाता निमंत्रण
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+सर्वर [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) पर आपके लिए एक खाता बनाया गया था, आप इसे अब उपयोगकर्ता नाम "[[[ACCOUNTNAME]]]]" और पासवर्ड "[[[PASSWORD]]]" के साथ एक्सेस कर सकते हैं।।
~
सादर,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_ja.txt b/emails/translations/account-invite_ja.txt
index c25538de..b689fdb2 100644
--- a/emails/translations/account-invite_ja.txt
+++ b/emails/translations/account-invite_ja.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - アカウントの招待
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+サーバー[[[SERVERNAME]]]([[[SERVERURL]]]/[[[URLARGS1]]])にアカウントが作成されました。ユーザー名 "[[[ACCOUNTNAME]]]"とパスワード "[[[PASSWORD] ]] "。
~
宜しくお願いします、
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_ko.txt b/emails/translations/account-invite_ko.txt
index b6fa8246..348270a5 100644
--- a/emails/translations/account-invite_ko.txt
+++ b/emails/translations/account-invite_ko.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - 계정 초대
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+당신을 위해 서버에서 한 계정이 생성되었습니다 : [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), 이제 당신은 다음 이름으로 접근 가능합니다 : "[[[ACCOUNTNAME]]]" 그리고 비밀번호는 다음과 같습니다 : "[[[PASSWORD]]]".
~
최고의 안부를 전합니다,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_pt.txt b/emails/translations/account-invite_pt.txt
index d9119918..b9d0e618 100644
--- a/emails/translations/account-invite_pt.txt
+++ b/emails/translations/account-invite_pt.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Convite para conta
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+Uma conta foi criada para você no servidor [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), você pode acessá-la agora com o nome de usuário "[[[ACCOUNTNAME]]]" e a senha "[[[PASSWORD] ]] ".
~
Cumprimentos,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_ru.txt b/emails/translations/account-invite_ru.txt
index 14b47dab..924237ba 100644
--- a/emails/translations/account-invite_ru.txt
+++ b/emails/translations/account-invite_ru.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - приглашение в аккаунт
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+Учетная запись была создана для вас на сервере [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), теперь вы можете получить к ней доступ с именем пользователя «[[[ACCOUNTNAME]]]» и паролем «[[[PASSWORD] ]] ".
~
С уважением,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_tr.txt b/emails/translations/account-invite_tr.txt
index aaff8dea..49e30567 100644
--- a/emails/translations/account-invite_tr.txt
+++ b/emails/translations/account-invite_tr.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Hesap Davetiyesi
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) sunucusunda sizin için bir hesap oluşturuldu, şimdi "[[[ACCOUNTNAME]]]" kullanıcı adı ve "[[[PASSWORD]]]" ile bu hesaba erişebilirsiniz.
~
Saygılarımla,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_zh-chs.txt b/emails/translations/account-invite_zh-chs.txt
index f761c3f1..61bac8b0 100644
--- a/emails/translations/account-invite_zh-chs.txt
+++ b/emails/translations/account-invite_zh-chs.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]]-帐户邀请
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+已在服务器[[[SERVERNAME]]]([[[SERVERURL]]]/[[[URLARGS1]]])上为您创建了一个帐户,您现在可以使用用户名“ [[[ACCOUNTNAME]]]”和密码“ [[[PASSWORD] ]]”。
~
最好的祝福,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-invite_zh-cht.txt b/emails/translations/account-invite_zh-cht.txt
index a98310c4..1ea2736a 100644
--- a/emails/translations/account-invite_zh-cht.txt
+++ b/emails/translations/account-invite_zh-cht.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]]-帳戶邀請
-An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username "[[[ACCOUNTNAME]]]" and password "[[[PASSWORD]]]".
+在伺服器[[[SERVERNAME]]]([[[SERVERURL]]]/[[[URLARGS1]]])上為你創建了一個帳戶,你現在可以使用用戶名“ [[[ACCOUNTNAME]]]”和密碼“ [[[PASSWORD] ]]”。
~
最好的祝福,
~[[[USERNAME]]]
\ No newline at end of file
diff --git a/emails/translations/account-reset_cs.txt b/emails/translations/account-reset_cs.txt
index 3d8baad7..bdd89774 100644
--- a/emails/translations/account-reset_cs.txt
+++ b/emails/translations/account-reset_cs.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Reset účtu
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Ahoj [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) požaduje obnovení hesla k účtu. Chcete-li proces dokončit, přejděte na následující odkaz:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_de.txt b/emails/translations/account-reset_de.txt
index 77d08850..fe4feb86 100644
--- a/emails/translations/account-reset_de.txt
+++ b/emails/translations/account-reset_de.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Zurücksetzen des Kontos
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Hallo [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) fordert ein Zurücksetzen des Kontokennworts an. Klicken Sie auf den folgenden Link, um den Vorgang abzuschließen:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_es.txt b/emails/translations/account-reset_es.txt
index e340566e..e6cbcae3 100644
--- a/emails/translations/account-reset_es.txt
+++ b/emails/translations/account-reset_es.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Restablecimiento de Cuenta
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Hola [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) está solicitando un restablecimiento de contraseña de cuenta. Navegue al siguiente enlace para completar el proceso:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_fi.txt b/emails/translations/account-reset_fi.txt
index 29e9c184..99b6fe22 100644
--- a/emails/translations/account-reset_fi.txt
+++ b/emails/translations/account-reset_fi.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Tili nollattu
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Hei [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) pyytää tilin salasanan palauttamista. Seuraa linkkiä prosessin loppuun saattamiseksi:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_fr.txt b/emails/translations/account-reset_fr.txt
index 2577d2d3..23467a20 100644
--- a/emails/translations/account-reset_fr.txt
+++ b/emails/translations/account-reset_fr.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Réinitialisation du compte
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Bonjour [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) demande une réinitialisation du mot de passe du compte. Accédez au lien suivant pour terminer le processus:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_hi.txt b/emails/translations/account-reset_hi.txt
index a1b76a61..9578c0d2 100644
--- a/emails/translations/account-reset_hi.txt
+++ b/emails/translations/account-reset_hi.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - खाता रीसेट
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+हाय [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) से खाता पासवर्ड रीसेट करने का अनुरोध किया जा रहा है। प्रक्रिया को पूरा करने के लिए निम्नलिखित लिंक को बताएं:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_ja.txt b/emails/translations/account-reset_ja.txt
index 910bea9f..18e5701c 100644
--- a/emails/translations/account-reset_ja.txt
+++ b/emails/translations/account-reset_ja.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - アカウントのリセット
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+こんにちは[[[USERNAME]]]、([[[SERVERURL]]][[[URLARGS1]]]) はアカウントパスワードのリセットをリクエストしています。プロセスを完了するには、次のリンクに移動します。
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_ko.txt b/emails/translations/account-reset_ko.txt
index cb9d7b54..b5b03b0c 100644
--- a/emails/translations/account-reset_ko.txt
+++ b/emails/translations/account-reset_ko.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - 계정 재설정
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+안녕하세요, [[[USERNAME]]]님. [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]])은 계정 비밀번호 초기화를 위해 요구됩니다. 다음 링크로 이동하여 과정을 완료하십시오 :
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_pt.txt b/emails/translations/account-reset_pt.txt
index a3deed16..c4dc402e 100644
--- a/emails/translations/account-reset_pt.txt
+++ b/emails/translations/account-reset_pt.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Redefinição de conta
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Olá, [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) está solicitando uma redefinição de senha de conta. Acesse o seguinte link para concluir o processo:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_ru.txt b/emails/translations/account-reset_ru.txt
index 8a090937..c61f4178 100644
--- a/emails/translations/account-reset_ru.txt
+++ b/emails/translations/account-reset_ru.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Сброс учетной записи
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Здравствуйте, [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) запрашивает сброс пароля учетной записи. Для завершения процесса перейдите по следующей ссылке:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_tr.txt b/emails/translations/account-reset_tr.txt
index 57bc24d3..1c30b082 100644
--- a/emails/translations/account-reset_tr.txt
+++ b/emails/translations/account-reset_tr.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]] - Hesabı Sıfırlama
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+Merhaba [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) bir hesap şifresi sıfırlama istiyor. İşlemi tamamlamak için aşağıdaki bağlantıya gidin:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_zh-chs.txt b/emails/translations/account-reset_zh-chs.txt
index a428475f..97e9a2b7 100644
--- a/emails/translations/account-reset_zh-chs.txt
+++ b/emails/translations/account-reset_zh-chs.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]]-帐户重置
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+[[[USERNAME]],您好:[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在请求重置帐户密码。导航至以下连结以完成该过程:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/account-reset_zh-cht.txt b/emails/translations/account-reset_zh-cht.txt
index 01dbafb1..7356909e 100644
--- a/emails/translations/account-reset_zh-cht.txt
+++ b/emails/translations/account-reset_zh-cht.txt
@@ -1,5 +1,5 @@
[[[SERVERNAME]]]-帳戶重置
-Hi [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) is requesting an account password reset. Nagivate to the following link to complete the process:
+[[[USERNAME]],你好,[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在請求重設帳戶密碼。導航至以下鏈結以完成該過程:
~
~[[[SERVERURL]]]/checkmail?c=[[[COOKIE]]][[[URLARGS2]]]
~
diff --git a/emails/translations/mesh-invite_cs.txt b/emails/translations/mesh-invite_cs.txt
index cd87c864..0fa358af 100644
--- a/emails/translations/mesh-invite_cs.txt
+++ b/emails/translations/mesh-invite_cs.txt
@@ -2,7 +2,7 @@
~
Dobrý den, [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+Uživatel [[[USERNAME]]] na serveru [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) požaduje instalaci softwaru k zahájení relace vzdáleného řízení.
~
~
Zpráva: [[[MSG]]]
@@ -27,7 +27,7 @@ V případě systému Linux vyjměte a vložte do terminálu a nainstalujte agen
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Chcete-li nainstalovat software, přejděte na [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] a postupujte podle pokynů.
~
Pokud jste tento požadavek nezačali, ignorujte tento e-mail.
~
diff --git a/emails/translations/mesh-invite_de.txt b/emails/translations/mesh-invite_de.txt
index af4a27ed..755f7825 100644
--- a/emails/translations/mesh-invite_de.txt
+++ b/emails/translations/mesh-invite_de.txt
@@ -2,7 +2,7 @@
~
Hallo [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+Benutzer [[[USERNAME]]] auf dem Server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) fordert Sie auf, Software zu installieren, um die Fernsteuerungssitzung zu starten.
~
~
Nachricht: [[[MSG]]]
@@ -27,7 +27,7 @@ Schneiden Sie unter Linux Folgendes aus und fügen Sie es in ein Terminal ein, u
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Navigieren Sie zum Installieren der Software zu [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] und befolgen Sie die Anweisungen.
~
Wenn Sie diese Anfrage nicht initiiert haben, ignorieren Sie diese Mail bitte.
~
diff --git a/emails/translations/mesh-invite_es.txt b/emails/translations/mesh-invite_es.txt
index e368e121..5a6fddca 100644
--- a/emails/translations/mesh-invite_es.txt
+++ b/emails/translations/mesh-invite_es.txt
@@ -2,7 +2,7 @@
~
Hola [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+Usuario [[[USERNAME]]] en servitor [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) solicita que instale el software para iniciar la sesión de control remoto.
~
~
Mensaje: [[[MSG]]]
@@ -27,7 +27,7 @@ Para Linux, copie y pegue lo siguiente en la terminal para instalar el agente:
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Para instalar el software, navega a [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] y siga las instrucciones.
~
Si Ud. no inicio este requerimiento, por favor ignore este correo.
~
diff --git a/emails/translations/mesh-invite_fi.txt b/emails/translations/mesh-invite_fi.txt
index 756c9cf7..c74a61d2 100644
--- a/emails/translations/mesh-invite_fi.txt
+++ b/emails/translations/mesh-invite_fi.txt
@@ -2,7 +2,7 @@
~
Hei [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+Käyttäjä[[[USERNAME]]] palvelimella [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) pyytää sinua asentamaan ohjelmiston etähallintaistunnon käynnistämiseksi.
~
~
Viesti: [[[MSG]]]
@@ -27,7 +27,7 @@ Linux: leikkaa ja liitä seuraava päätelaitteeseen agentin asentamiseksi:
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Asenna ohjelmisto siirtymällä kohtaan [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] ja noudattamalla ohjeita.
~
Jos et suorittanut tätä pyyntöä, voit ohitaa tämän sähköpostin.
~
diff --git a/emails/translations/mesh-invite_fr.txt b/emails/translations/mesh-invite_fr.txt
index 3a6243ab..217f589a 100644
--- a/emails/translations/mesh-invite_fr.txt
+++ b/emails/translations/mesh-invite_fr.txt
@@ -2,7 +2,7 @@
~
Bonjour [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+L'utilisateur [[[USERNAME]]] sur le serveur [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) vous demande d'installer un logiciel pour démarrer la session de contrôle à distance.
~
~
Message: [[[MSG]]]
@@ -27,7 +27,7 @@ Pour Linux, copiez et collez les éléments suivants dans un terminal pour insta
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Pour installer le logiciel, accédez à [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] et suivez les instructions.
~
Si vous n'avez pas initié cette demande, veuillez ignorer ce courrier.
~
diff --git a/emails/translations/mesh-invite_hi.txt b/emails/translations/mesh-invite_hi.txt
index 7a4756a8..160780c6 100644
--- a/emails/translations/mesh-invite_hi.txt
+++ b/emails/translations/mesh-invite_hi.txt
@@ -2,7 +2,7 @@
~
नमस्कार [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+उपयोगकर्ता [[[USERNAME]]] सर्वर पर [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) आपसे रिमोट कंट्रोल सेशन शुरू करने के लिए सॉफ़्टवेयर स्थापित करने का अनुरोध कर रहा है।
~
~
संदेश: [[[MSG]]]
@@ -27,7 +27,7 @@ Apple OSX के लिए, इस प्रक्रिया को पूर
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+सॉफ़्टवेयर को स्थापित करने के लिए, [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] पर जाएँ और निर्देशों का पालन करें।
~
यदि आपने यह अनुरोध आरंभ नहीं किया है, तो कृपया इस मेल को अनदेखा करें।
~
diff --git a/emails/translations/mesh-invite_ja.txt b/emails/translations/mesh-invite_ja.txt
index 03b1819d..c4a7af7c 100644
--- a/emails/translations/mesh-invite_ja.txt
+++ b/emails/translations/mesh-invite_ja.txt
@@ -2,7 +2,7 @@
~
[[[NAME]]]様
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+サーバー[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) のユーザー[[[USERNAME]]]が、リモートコントロールセッションを開始するためのソフトウェアのインストールを要求しています。
~
~
メッセージ:[[[MSG]]]
@@ -27,7 +27,7 @@ Linuxの場合は、ターミナルで以下をカットアンドペーストし
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+ソフトウェアをインストールするには、[[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]]に移動し、指示に従います。
~
このリクエストを開始していない場合は、このメールを無視してください。
~
diff --git a/emails/translations/mesh-invite_ko.txt b/emails/translations/mesh-invite_ko.txt
index df7b8d0f..76b43417 100644
--- a/emails/translations/mesh-invite_ko.txt
+++ b/emails/translations/mesh-invite_ko.txt
@@ -2,7 +2,7 @@
~
안녕하세요, [[[NAME]]]님.
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) 서버의 [[[USERNAME]]] 사용자가 원격 제어 세션을 시작하기 위해서는 소프트웨어 설치가 요구됩니다.
~
~
메시지: [[[MSG]]]
@@ -28,7 +28,7 @@ Linux의 경우, 다음을 잘라내어 터미널에 붙여 넣어 에이전트
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+소프트웨어를 설치하려면, 다음에 접속하여 지시에 따르십시오 : [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]]
~
이 요청을 시작하지 않은 경우, 이 메일을 무시하십시오.
~
diff --git a/emails/translations/mesh-invite_pt.txt b/emails/translations/mesh-invite_pt.txt
index c2a30572..5e3bf249 100644
--- a/emails/translations/mesh-invite_pt.txt
+++ b/emails/translations/mesh-invite_pt.txt
@@ -2,7 +2,7 @@
~
Olá [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+O usuário [[[USERNAME]]] no servidor [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) está solicitando a instalação do software para iniciar a sessão de controle remoto.
~
~
Mensagem: [[[MSG]]]
@@ -27,7 +27,7 @@ Para Linux, recorte e cole o seguinte em um terminal para instalar o agente:
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Para instalar o software, navegue até [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] e siga as instruções.
~
Se você não iniciou esta solicitação, ignore este e-mail.
~
diff --git a/emails/translations/mesh-invite_ru.txt b/emails/translations/mesh-invite_ru.txt
index 6477b8ac..97b92336 100644
--- a/emails/translations/mesh-invite_ru.txt
+++ b/emails/translations/mesh-invite_ru.txt
@@ -2,7 +2,7 @@
~
Здравствуйте, [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+Пользователь [[[USERNAME]]] на сервере [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) запрашивает установку программного обеспечения для запуска сеанса удаленного управления.
~
~
Сообщение: [[[MSG]]]
@@ -27,7 +27,7 @@ User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]])
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Для установки программного обеспечения перейдите к [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] и следуйте инструкциям.
~
Если вы не инициировали этот запрос, игнорируйте это письмо.
~
diff --git a/emails/translations/mesh-invite_tr.txt b/emails/translations/mesh-invite_tr.txt
index c6809c29..460262f3 100644
--- a/emails/translations/mesh-invite_tr.txt
+++ b/emails/translations/mesh-invite_tr.txt
@@ -2,7 +2,7 @@
~
Merhaba [[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+[[[SERVERNAME]]] [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) sunucusundaki [[[USERNAME]]] uzaktan kontrol oturumunu başlatmak için yazılım yüklemenizi istiyor.
~
~
Mesaj: [[[MSG]]]
@@ -27,7 +27,7 @@ Linux için, aracıyı yüklemek için aşağıdakileri kesip bir terminale yap
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+Yazılımı kurmak için [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] adresine gidin ve talimatları takip edin.
~
Bu isteği siz başlatmadıysanız, lütfen bu postayı dikkate almayın.
~
diff --git a/emails/translations/mesh-invite_zh-chs.txt b/emails/translations/mesh-invite_zh-chs.txt
index 9913fc6d..57b3b127 100644
--- a/emails/translations/mesh-invite_zh-chs.txt
+++ b/emails/translations/mesh-invite_zh-chs.txt
@@ -2,7 +2,7 @@
~
您好[[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+服务器[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) 上的用户[[[USERNAME]]]请求您安装软件以启动远程控制。
~
~
消息:[[[MSG]]]
@@ -27,7 +27,7 @@ User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]])
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+要安装软件,请导航至[[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]],然后按照说明进行操作。
~
如果您没有发起此请求,请不理此邮件。
~
diff --git a/emails/translations/mesh-invite_zh-cht.txt b/emails/translations/mesh-invite_zh-cht.txt
index 8b657367..4cba108d 100644
--- a/emails/translations/mesh-invite_zh-cht.txt
+++ b/emails/translations/mesh-invite_zh-cht.txt
@@ -2,7 +2,7 @@
~
你好[[[NAME]]],
~
-User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) is requesting you install software to start the remote control session.
+伺服器[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) 上的用戶[[[USERNAME]]]請求你安裝軟體以啟動遠程控制。
~
~
訊息:[[[MSG]]]
@@ -27,7 +27,7 @@ User [[[USERNAME]]] on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]])
~
~
~
-To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.
+要安裝軟體,請導航至[[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]],然後按照說明進行操作。
~
如果你沒有發起此請求,請不理此電郵。
~
diff --git a/meshcentral-config-schema.json b/meshcentral-config-schema.json
index bc65bd85..f33ce4c9 100644
--- a/meshcentral-config-schema.json
+++ b/meshcentral-config-schema.json
@@ -55,6 +55,7 @@
"agentsInRam": { "type": "boolean", "default": false, "description": "Loads all agent binaries in RAM for faster agent updates." },
"agentPing": { "type": "integer", "minimum": 1, "description": "When specified, sends data to the agent at x seconds interval and expects a response from the agent." },
"agentPong": { "type": "integer", "minimum": 1, "description": "When specified, sends data to the agent at x seconds interval." },
+ "amtmanager": { "type": "boolean", "default": false, "description": "When enabled, MeshCentral will automatically monitor and manage Intel AMT devices." },
"orphanAgentUser": { "type": "string", "default": null, "description": "If an agent attempts to connect to a unknown device group, automatically create a new device group and grant access to the specified user. Example: admin" },
"agentIdleTimeout": { "type": "integer", "minimum": 1 },
"compression": { "type": "boolean", "default": true, "description": "Enables GZIP compression for web requests." },
diff --git a/meshcentral.js b/meshcentral.js
index 3b2d6aab..d23b2ad2 100644
--- a/meshcentral.js
+++ b/meshcentral.js
@@ -34,6 +34,7 @@ function CreateMeshCentralServer(config, args) {
obj.amtEventHandler = null;
obj.pluginHandler = null;
obj.amtScanner = null;
+ obj.amtManager = null;
obj.meshScanner = null;
obj.letsencrypt = null;
obj.eventsDispatch = {};
@@ -1336,6 +1337,11 @@ function CreateMeshCentralServer(config, args) {
obj.meshScanner = require('./meshscanner.js').CreateMeshScanner(obj).start();
}
+ // Setup the Intel AMT manager
+ if ((obj.args.amtmanager == true) || (typeof obj.args.amtmanager == 'object')) {
+ obj.amtManager = require('./amtmanager.js').CreateAmtManager(obj);
+ }
+
// Setup and start the MPS server
if ((obj.args.lanonly != true) && (obj.args.mpsport !== 0)) {
obj.mpsserver = require('./mpsserver.js').CreateMpsServer(obj, obj.db, obj.args, obj.certificates);
diff --git a/meshuser.js b/meshuser.js
index bf1abdd2..b48b0655 100644
--- a/meshuser.js
+++ b/meshuser.js
@@ -856,7 +856,7 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain, use
switch (cmd) {
case 'help': {
- var fin = '', f = '', availcommands = 'help,info,versions,resetserver,usersessions,closeusersessions,tasklimiter,setmaxtasks,cores,migrationagents,agentstats,webstats,mpsstats,swarmstats,acceleratorsstats,updatecheck,serverupdate,nodeconfig,heapdump,relays,autobackup,backupconfig,dupagents,dispatchtable,badlogins,showpaths,le,lecheck,leevents,dbstats,sms,amtacm,certhashes,watchdog';
+ var fin = '', f = '', availcommands = 'help,info,versions,resetserver,usersessions,closeusersessions,tasklimiter,setmaxtasks,cores,migrationagents,agentstats,webstats,mpsstats,swarmstats,acceleratorsstats,updatecheck,serverupdate,nodeconfig,heapdump,relays,autobackup,backupconfig,dupagents,dispatchtable,badlogins,showpaths,le,lecheck,leevents,dbstats,sms,amtacm,certhashes,watchdog,amtmanager';
if (parent.parent.config.settings.heapdump === true) { availcommands += ',heapdump'; }
availcommands = availcommands.split(',').sort();
while (availcommands.length > 0) { if (f.length > 80) { fin += (f + ',\r\n'); f = ''; } f += (((f != '') ? ', ' : ' ') + availcommands.shift()); }
@@ -877,6 +877,15 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain, use
}
break;
}
+ case 'amtmanager': {
+ if (parent.parent.amtManager == null) { r = 'Intel AMT Manager not active.'; break; }
+ for (var nodeid in parent.parent.amtManager.amtDevices) {
+ var dev = parent.parent.amtManager.amtDevices[nodeid];
+ r += (dev.conn + ', \"' + dev.name + '\"\r\n');
+ }
+ if (r == '') { r = 'Not current managing any devices.'; }
+ break;
+ }
case 'certhashes': {
r += 'AgentCertHash: ' + parent.agentCertificateHashHex;
for (var i in parent.webCertificateHashs) { r += '\r\nwebCertificateHash (' + i + '): ' + common.rstr2hex(parent.webCertificateHashs[i]); }
diff --git a/translate/translate.json b/translate/translate.json
index f81baff6..d4c479c5 100644
--- a/translate/translate.json
+++ b/translate/translate.json
@@ -4676,36 +4676,19 @@
]
},
{
- "cs": "Účet pro vás byl vytvořen na serveru [[[SERVERNAME]]] ([[[[SERVERURL]]] /), nyní k němu můžete přistupovat pomocí uživatelského jména „[[[[ACCOUNTNAME]]]“ “a hesla„ [[[HESLO]] ]] \".",
- "de": "Auf dem Server [[[SERVERNAME]]] ([[[SERVERURL]]]/) wurde ein Konto für Sie erstellt, Sie können ab sofort mit dem Benutzernamen \"[[[ACCOUNTNAME]]]\" und dem Passwort \"[[[PASSWORD]]]\" darauf zugreifen.",
- "es": "Una cuenta ha sido creada en su servidor [[[SERVERNAME]]] ([[[SERVERURL]]]/), ahora puede acceder con el usuario \"[[[ACCOUNTNAME]]]\" y la contraseña \"[[[PASSWORD]]]\".",
- "fi": "Sinulle on luotu tili palvelimelle [[[SERVERNAME]]] ([[[SERVERURL]]]/), voit käyttää sitä nyt käyttäjätunnuksella \"[[[ACCOUNTNAME]]]\" and salasanalla \"[[[PASSWORD]]]\".",
- "fr": "Un compte a été créé pour vous sur le serveur [[[[SERVERNAME]]] ([[[SERVERURL]]] /), vous pouvez y accéder maintenant avec le nom d'utilisateur \"[[[ACCOUNTNAME]]]\" et le mot de passe \"[[[PASSWORD]]]\".",
- "hi": "सर्वर [[[SERVERNAME]]] ([[[SERVERURL]]] /) पर आपके लिए एक खाता बनाया गया था, आप इसे अब उपयोगकर्ता नाम \"[[[ACCOUNTNAME]]]]\" और पासवर्ड \"[[[PASSWORD]]]\" के साथ एक्सेस कर सकते हैं।।",
- "ja": "サーバー[[[SERVERNAME]]]([[[SERVERURL]]] /)にアカウントが作成されました。ユーザー名 \"[[[ACCOUNTNAME]]]\"とパスワード \"[[[PASSWORD] ]] \"。",
- "ko": "당신을 위해 서버에서 한 계정이 생성되었습니다 : [[[SERVERNAME]]] ([[[SERVERURL]]]/), 이제 당신은 다음 이름으로 접근 가능합니다 : \"[[[ACCOUNTNAME]]]\" 그리고 비밀번호는 다음과 같습니다 : \"[[[PASSWORD]]]\".",
- "pt": "Uma conta foi criada para você no servidor [[[SERVERNAME]]] ([[[SERVERURL]]] /), você pode acessá-la agora com o nome de usuário \"[[[ACCOUNTNAME]]]\" e a senha \"[[[PASSWORD] ]] \".",
- "ru": "Учетная запись была создана для вас на сервере [[[SERVERNAME]]] ([[[SERVERURL]]] /), теперь вы можете получить к ней доступ с именем пользователя «[[[ACCOUNTNAME]]]» и паролем «[[[PASSWORD] ]] \".",
- "tr": "[[[SERVERNAME]]] ([[[SERVERURL]]] /) sunucusunda sizin için bir hesap oluşturuldu, şimdi \"[[[ACCOUNTNAME]]]\" kullanıcı adı ve \"[[[PASSWORD]]]\" ile bu hesaba erişebilirsiniz.",
- "zh-chs": "已在服务器[[[SERVERNAME]]]([[[SERVERURL]]] /)上为您创建了一个帐户,您现在可以使用用户名“ [[[ACCOUNTNAME]]]”和密码“ [[[PASSWORD] ]]”。",
- "zh-cht": "在伺服器[[[SERVERNAME]]]([[[SERVERURL]]] /)上為你創建了一個帳戶,你現在可以使用用戶名“ [[[ACCOUNTNAME]]]”和密碼“ [[[PASSWORD] ]]”。"
- },
- {
- "cs": "Účet byl pro vás vytvořen na serveru [[[SERVERNAME]]] ([[[SERVERURL]]]/), nyní k němu máte přístup pomocí uživatelského jména \\\"[[[ACCOUNTNAME]]]\\\" a hesla \\\"[[[PASSWORD]]]\\\".",
- "de": "Auf dem Server [[[SERVERNAME]]] ([[[SERVERURL]]]/) wurde ein Konto für Sie erstellt. Sie können jetzt mit dem Benutzernamen \\\"[[[ACCOUNTNAME]]]\\\" und dem Passwort \\\"[[[PASSWORD]]]\\\".",
- "es": "Una cuenta ha sido creada en su servidor [[[SERVERNAME]]] ([[[SERVERURL]]]/), ahora puede acceder con el usuario \\\"[[[ACCOUNTNAME]]]\\\" y la consigna \\\"[[[PASSWORD]]]\\\".",
- "fi": "Sinulle on luotu tili palvelimelle [[[SERVERNAME]]] ([[[SERVERURL]]]/), voit käyttää sitä nyt käyttäjätunnuksella \\\"[[[ACCOUNTNAME]]]\\\" and salasanalla \\\"[[[PASSWORD]]]\\\".",
- "fr": "Un compte a été créé pour vous sur le serveur [[[SERVERNAME]]] ([[[SERVERURL]]]/), vous pouvez y accéder maintenant avec le nom d'utilisateur \\\"[[[ACCOUNTNAME]]]\\\" et le mot de passe \\\"[[[PASSWORD]]]\\\".",
- "hi": "सर्वर [[[SERVERNAME]]] ([[[SERVERURL]]]/) पर आपके लिए एक खाता बनाया गया था, अब आप इसे उपयोगकर्ता नाम \\\"[[ACCOUNTNAME]]] \\\" en wachchwoord \\\"[[PASSWORD]]]\\\"।",
- "ja": "サーバー[[[SERVERNAME]]]([[[SERVERURL]]]/)にアカウントが作成されました。ユーザー名 \\\"[[[ACCOUNTNAME]]]\\\" とパスワード \\\"[[[PASSWORD]]]\\\"。",
- "ko": "당신을 위해 서버에서 한 계정이 생성되었습니다 : [[[SERVERNAME]]] ([[[SERVERURL]]]/), 이제 당신은 다음 이름으로 접근이 가능합니다 : \\\"[[[ACCOUNTNAME]]]\\\" 그리고 비밀번호는 다음과 같습니다 : \\\"[[[PASSWORD]]]\\\".",
- "pt": "Uma conta foi criada para você no servidor [[[SERVERNAME]]] ([[[SERVERURL]]] /), você pode acessá-la agora com o nome de usuário \\\"[[[ACCOUNTNAME]]] \\\" en wachtwoord \\\"[[ [SENHA]]]\\\".",
- "ru": "Для вас была создана учетная запись на сервере [[[SERVERNAME]]] ([[[SERVERURL]]]/), теперь вы можете получить к ней доступ с помощью имени пользователя \\\"[[[ACCOUNTNAME]]]\\\" и пароля \\\"[[[PASSWORD]]]\\\".",
- "tr": "[[[SERVERNAME]] ([[[SERVERURL]]]/) sunucusunda sizin için bir hesap oluşturuldu, şimdi \\\"[[[ACCOUNTNAME]]]\\\" en wachtwoord \\\"[[[PASSWORD]]]\\\".",
- "zh-chs": "已在服务器[[[SERVERNAME]]]([[[SERVERURL]]]/ 上为您创建了一个帐户,您现在可以使用用户名“ [[[ACCOUNTNAME]]] 和密码 “[[[PASSWORD]]]”。",
- "zh-cht": "在伺服器[[[SERVERNAME]]]([[[SERVERURL]]] /上為你創建了一個帳戶,你現在可以使用用戶名“ [[[ACCOUNTNAME]]] ” en wachtwoord “[[[PASSWORD]]]”。"
- },
- {
+ "cs": "Účet pro vás byl vytvořen na serveru [[[SERVERNAME]]] ([[[[SERVERURL]]]/[[[URLARGS1]]]), nyní k němu můžete přistupovat pomocí uživatelského jména „[[[[ACCOUNTNAME]]]“ “a hesla„ [[[HESLO]] ]] \".",
+ "de": "Auf dem Server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) wurde ein Konto für Sie erstellt, Sie können ab sofort mit dem Benutzernamen \"[[[ACCOUNTNAME]]]\" und dem Passwort \"[[[PASSWORD]]]\" darauf zugreifen.",
+ "es": "Una cuenta ha sido creada en su servidor [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), ahora puede acceder con el usuario \"[[[ACCOUNTNAME]]]\" y la contraseña \"[[[PASSWORD]]]\".",
+ "fi": "Sinulle on luotu tili palvelimelle [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), voit käyttää sitä nyt käyttäjätunnuksella \"[[[ACCOUNTNAME]]]\" and salasanalla \"[[[PASSWORD]]]\".",
+ "fr": "Un compte a été créé pour vous sur le serveur [[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), vous pouvez y accéder maintenant avec le nom d'utilisateur \"[[[ACCOUNTNAME]]]\" et le mot de passe \"[[[PASSWORD]]]\".",
+ "hi": "सर्वर [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) पर आपके लिए एक खाता बनाया गया था, आप इसे अब उपयोगकर्ता नाम \"[[[ACCOUNTNAME]]]]\" और पासवर्ड \"[[[PASSWORD]]]\" के साथ एक्सेस कर सकते हैं।।",
+ "ja": "サーバー[[[SERVERNAME]]]([[[SERVERURL]]]/[[[URLARGS1]]])にアカウントが作成されました。ユーザー名 \"[[[ACCOUNTNAME]]]\"とパスワード \"[[[PASSWORD] ]] \"。",
+ "ko": "당신을 위해 서버에서 한 계정이 생성되었습니다 : [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), 이제 당신은 다음 이름으로 접근 가능합니다 : \"[[[ACCOUNTNAME]]]\" 그리고 비밀번호는 다음과 같습니다 : \"[[[PASSWORD]]]\".",
+ "pt": "Uma conta foi criada para você no servidor [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), você pode acessá-la agora com o nome de usuário \"[[[ACCOUNTNAME]]]\" e a senha \"[[[PASSWORD] ]] \".",
+ "ru": "Учетная запись была создана для вас на сервере [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), теперь вы можете получить к ней доступ с именем пользователя «[[[ACCOUNTNAME]]]» и паролем «[[[PASSWORD] ]] \".",
+ "tr": "[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) sunucusunda sizin için bir hesap oluşturuldu, şimdi \"[[[ACCOUNTNAME]]]\" kullanıcı adı ve \"[[[PASSWORD]]]\" ile bu hesaba erişebilirsiniz.",
+ "zh-chs": "已在服务器[[[SERVERNAME]]]([[[SERVERURL]]]/[[[URLARGS1]]])上为您创建了一个帐户,您现在可以使用用户名“ [[[ACCOUNTNAME]]]”和密码“ [[[PASSWORD] ]]”。",
+ "zh-cht": "在伺服器[[[SERVERNAME]]]([[[SERVERURL]]]/[[[URLARGS1]]])上為你創建了一個帳戶,你現在可以使用用戶名“ [[[ACCOUNTNAME]]]”和密碼“ [[[PASSWORD] ]]”。",
"en": "An account was created for you on server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), you can access it now with username \"[[[ACCOUNTNAME]]]\" and password \"[[[PASSWORD]]]\".",
"nl": "Er is een account jouw aangemaakt op de server [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]), Je kan inloggen met de gebruikersnaam \"[[[ACCOUNTNAME]]]\" en wachtwoord \"[[[PASSWORD]]]\".",
"xloc": [
@@ -17010,7 +16993,7 @@
"ru": "Здравствуйте, [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) выполняет проверку электронной почты. Для завершения процесса перейдите по следующей ссылке:",
"tr": "Merhaba [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) bir e-posta doğrulaması yapıyor. İşlemi tamamlamak için aşağıdaki bağlantıya gidin:",
"zh-chs": "嗨[[[USERNAME]]],[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在执行电邮验证。导航至以下连结以完成该过程:",
- "zh-cht": "嗨[[[USERNAME]]],[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在執行電郵驗證。導航至以下鏈結以完成該過程:"
+ "zh-cht": "嗨[[[USERNAME]]],[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在執行電郵驗證。導航至以下鏈結以完成該過程:",
"xloc": [
"account-check.txt"
]
@@ -17030,7 +17013,7 @@
"ru": "Здравствуйте, [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) запрашивает сброс пароля учетной записи. Для завершения процесса перейдите по следующей ссылке:",
"tr": "Merhaba [[[USERNAME]]], [[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) bir hesap şifresi sıfırlama istiyor. İşlemi tamamlamak için aşağıdaki bağlantıya gidin:",
"zh-chs": "[[[USERNAME]],您好:[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在请求重置帐户密码。导航至以下连结以完成该过程:",
- "zh-cht": "[[[USERNAME]],你好,[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在請求重設帳戶密碼。導航至以下鏈結以完成該過程:"
+ "zh-cht": "[[[USERNAME]],你好,[[[SERVERNAME]]] ([[[SERVERURL]]][[[URLARGS1]]]) 正在請求重設帳戶密碼。導航至以下鏈結以完成該過程:",
"xloc": [
"account-reset.txt"
]
@@ -35968,14 +35951,12 @@
"mesh-invite.html->2->15->1"
]
},
- {
- },
{
"en": "To install the software, navigate to [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] and follow the instructions.",
"nl": "Om de software te installeren, navigeert u naar [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] en volgt u de instructies.",
"cs": "Chcete-li nainstalovat software, přejděte na [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] a postupujte podle pokynů.",
"de": "Navigieren Sie zum Installieren der Software zu [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] und befolgen Sie die Anweisungen.",
- "es": "Para instalar el software, navega a [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] y siga las instrucciones.",
+ "es": "Para instalar el software, navega a [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] y siga las instrucciones.",
"fi": "Asenna ohjelmisto siirtymällä kohtaan [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] ja noudattamalla ohjeita.",
"fr": "Pour installer le logiciel, accédez à [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] et suivez les instructions.",
"hi": "सॉफ़्टवेयर को स्थापित करने के लिए, [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] पर जाएँ और निर्देशों का पालन करें।",
@@ -35985,7 +35966,7 @@
"ru": "Для установки программного обеспечения перейдите к [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] и следуйте инструкциям.",
"tr": "Yazılımı kurmak için [[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]] adresine gidin ve talimatları takip edin.",
"zh-chs": "要安装软件,请导航至[[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]],然后按照说明进行操作。",
- "zh-cht": "要安裝軟體,請導航至[[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]],然後按照說明進行操作。"
+ "zh-cht": "要安裝軟體,請導航至[[[SERVERURL]]][[[LINKURL]]][[[URLARGS2]]],然後按照說明進行操作。",
"xloc": [
"mesh-invite.txt"
]
@@ -38058,7 +38039,7 @@
"ru": "Пользователь [[[USERNAME]]] на сервере [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) запрашивает установку программного обеспечения для запуска сеанса удаленного управления.",
"tr": "[[[SERVERNAME]]] [[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) sunucusundaki [[[USERNAME]]] uzaktan kontrol oturumunu başlatmak için yazılım yüklemenizi istiyor.",
"zh-chs": "服务器[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) 上的用户[[[USERNAME]]]请求您安装软件以启动远程控制。",
- "zh-cht": "伺服器[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) 上的用戶[[[USERNAME]]]請求你安裝軟體以啟動遠程控制。"
+ "zh-cht": "伺服器[[[SERVERNAME]]] ([[[SERVERURL]]]/[[[URLARGS1]]]) 上的用戶[[[USERNAME]]]請求你安裝軟體以啟動遠程控制。",
"xloc": [
"mesh-invite.txt"
]
@@ -42642,4 +42623,4 @@
]
}
]
-}
+}
\ No newline at end of file
diff --git a/views/default-mobile.handlebars b/views/default-mobile.handlebars
index 82f4f44e..220f8b2d 100644
--- a/views/default-mobile.handlebars
+++ b/views/default-mobile.handlebars
@@ -1381,6 +1381,7 @@
if (message.event.node.intelamt.tag != null) { node.intelamt.tag = message.event.node.intelamt.tag; }
if (message.event.node.intelamt.uuid != null) { node.intelamt.uuid = message.event.node.intelamt.uuid; }
if (message.event.node.intelamt.realm != null) { node.intelamt.realm = message.event.node.intelamt.realm; }
+ if (message.event.node.intelamt.flags != null) { node.intelamt.flags = message.event.node.intelamt.flags; }
}
node.namel = node.name.toLowerCase();
if (node.rname) { node.rnamel = node.rname.toLowerCase(); } else { node.rnamel = node.namel; }
diff --git a/views/default.handlebars b/views/default.handlebars
index 1bd83f03..08750d37 100644
--- a/views/default.handlebars
+++ b/views/default.handlebars
@@ -2783,6 +2783,7 @@
if (message.event.node.intelamt.tag != null) { node.intelamt.tag = message.event.node.intelamt.tag; }
if (message.event.node.intelamt.uuid != null) { node.intelamt.uuid = message.event.node.intelamt.uuid; }
if (message.event.node.intelamt.realm != null) { node.intelamt.realm = message.event.node.intelamt.realm; }
+ if (message.event.node.intelamt.flags != null) { node.intelamt.flags = message.event.node.intelamt.flags; }
}
if (message.event.node.av != null) { node.av = message.event.node.av; }
node.namel = node.name.toLowerCase();