โ† Back to list
groeimetai

mid-server

by groeimetai

๐Ÿค– AI-powered ServiceNow development with 400+ MCP tools. Works with Claude, GPT, Gemini, Ollama & 75+ providers. Deploy widgets, manage incidents, automate workflows - all through natural language. Open-source Build Agent alternative.

โญ 42๐Ÿด 9๐Ÿ“… Jan 23, 2026

SKILL.md


name: mid-server description: This skill should be used when the user asks to "MID Server", "MID script", "ECC queue", "probe", "sensor", "mid server script", "orchestration", "remote execution", or any ServiceNow MID Server development. license: Apache-2.0 compatibility: Designed for Snow-Code and ServiceNow development metadata: author: groeimetai version: "1.0.0" category: servicenow tools:

  • snow_query_table
  • snow_find_artifact
  • snow_execute_script_with_output

MID Server for ServiceNow

MID Server enables ServiceNow to communicate with resources inside your network.

MID Server Architecture

ServiceNow Instance
    โ†“ ECC Queue
MID Server
    โ”œโ”€โ”€ Probes (Outbound)
    โ”‚   โ””โ”€โ”€ Commands sent TO MID
    โ”œโ”€โ”€ Sensors (Inbound)
    โ”‚   โ””โ”€โ”€ Results sent FROM MID
    โ””โ”€โ”€ Script Execution

Key Tables

TablePurpose
ecc_agentMID Server records
ecc_queueInput/Output queue
discovery_probesProbe definitions
discovery_sensorsSensor definitions
sys_script_executionScript execution requests

ECC Queue Communication (ES5)

Send Command to MID Server

// Send command via ECC queue (ES5 ONLY!)
function sendMIDCommand(midServerName, command, parameters) {
    var mid = getMIDServer(midServerName);
    if (!mid) {
        gs.error('MID Server not found: ' + midServerName);
        return null;
    }

    var ecc = new GlideRecord('ecc_queue');
    ecc.initialize();

    // ECC Queue settings
    ecc.setValue('agent', mid.getUniqueValue());
    ecc.setValue('topic', 'Command');
    ecc.setValue('name', command);
    ecc.setValue('source', 'CustomScript');

    // Parameters as payload
    ecc.setValue('payload', buildPayload(parameters));

    // Direction: output = to MID, input = from MID
    ecc.setValue('queue', 'output');

    // State
    ecc.setValue('state', 'ready');

    return ecc.insert();
}

function getMIDServer(name) {
    var mid = new GlideRecord('ecc_agent');
    mid.addQuery('name', name);
    mid.addQuery('status', 'Up');
    mid.query();
    if (mid.next()) {
        return mid;
    }
    return null;
}

function buildPayload(params) {
    var xml = '<?xml version="1.0" encoding="UTF-8"?>';
    xml += '<parameters>';
    for (var key in params) {
        if (params.hasOwnProperty(key)) {
            xml += '<parameter name="' + key + '">';
            xml += '<value>' + escapeXML(params[key]) + '</value>';
            xml += '</parameter>';
        }
    }
    xml += '</parameters>';
    return xml;
}

function escapeXML(str) {
    return str.replace(/&/g, '&amp;')
              .replace(/</g, '&lt;')
              .replace(/>/g, '&gt;')
              .replace(/"/g, '&quot;')
              .replace(/'/g, '&apos;');
}

Monitor ECC Response

// Wait for ECC queue response (ES5 ONLY!)
function waitForECCResponse(eccSysId, timeoutSeconds) {
    var startTime = new Date().getTime();
    var timeout = timeoutSeconds * 1000;

    while (true) {
        // Check for response
        var response = new GlideRecord('ecc_queue');
        response.addQuery('response_to', eccSysId);
        response.addQuery('queue', 'input');
        response.query();

        if (response.next()) {
            return {
                success: response.getValue('state') === 'processed',
                payload: response.getValue('payload'),
                error: response.getValue('error_string')
            };
        }

        // Check timeout
        if (new Date().getTime() - startTime > timeout) {
            return {
                success: false,
                error: 'Timeout waiting for MID response'
            };
        }

        // Wait before retry
        gs.sleep(1000);
    }
}

MID Server Scripts (ES5)

Execute Script on MID

// Execute JavaScript on MID Server (ES5 ONLY!)
function executeMIDScript(midServerName, script) {
    var mid = getMIDServer(midServerName);
    if (!mid) {
        return { success: false, error: 'MID Server not found' };
    }

    var ecc = new GlideRecord('ecc_queue');
    ecc.initialize();
    ecc.setValue('agent', mid.getUniqueValue());
    ecc.setValue('topic', 'JSProbe');
    ecc.setValue('name', 'Custom Script Execution');

    // Script payload
    var payload = '<?xml version="1.0" encoding="UTF-8"?>';
    payload += '<parameters>';
    payload += '<parameter name="script"><value><![CDATA[' + script + ']]></value></parameter>';
    payload += '</parameters>';

    ecc.setValue('payload', payload);
    ecc.setValue('queue', 'output');
    ecc.setValue('state', 'ready');

    var eccSysId = ecc.insert();

    return {
        success: true,
        ecc_sys_id: eccSysId
    };
}

// Example: Check disk space on remote server
var diskCheckScript = [
    'var output = {};',
    'try {',
    '    var cmd = "df -h /";',
    '    var result = Packages.com.service_now.mid.probe.tpcon.OperatingSystemCommand.execute(cmd);',
    '    output.disk_info = result.getOutput();',
    '    output.success = true;',
    '} catch (e) {',
    '    output.success = false;',
    '    output.error = e.message;',
    '}',
    'output;'
].join('\n');

Custom Probes (ES5)

Create Probe

// Create custom probe (ES5 ONLY!)
var probe = new GlideRecord('discovery_probes');
probe.initialize();

probe.setValue('name', 'Custom Application Status');
probe.setValue('short_description', 'Check custom application status');
probe.setValue('active', true);

// Probe type
probe.setValue('mid_type', 'probe');

// Trigger type
probe.setValue('triggered_by', 'on_demand');

// Probe script (runs on MID Server - ES5/Rhino!)
probe.setValue('script',
    'var output = {};\n' +
    '\n' +
    '// Get parameters\n' +
    'var host = probe.getParameter("host");\n' +
    'var port = probe.getParameter("port");\n' +
    '\n' +
    'try {\n' +
    '    // Execute health check\n' +
    '    var url = "http://" + host + ":" + port + "/health";\n' +
    '    var conn = new java.net.URL(url).openConnection();\n' +
    '    conn.setRequestMethod("GET");\n' +
    '    conn.setConnectTimeout(5000);\n' +
    '    conn.setReadTimeout(5000);\n' +
    '    \n' +
    '    var responseCode = conn.getResponseCode();\n' +
    '    output.status = (responseCode === 200) ? "healthy" : "unhealthy";\n' +
    '    output.response_code = responseCode;\n' +
    '    output.success = true;\n' +
    '} catch (e) {\n' +
    '    output.status = "unreachable";\n' +
    '    output.error = e.message;\n' +
    '    output.success = false;\n' +
    '}\n' +
    '\n' +
    'output;'
);

probe.insert();

Create Sensor

// Create sensor to process probe results (ES5 ONLY!)
var sensor = new GlideRecord('discovery_sensors');
sensor.initialize();

sensor.setValue('name', 'Process Application Status');
sensor.setValue('short_description', 'Process custom application status results');
sensor.setValue('active', true);

// Link to probe
sensor.setValue('triggered_by', probeSysId);

// Sensor script (runs on ServiceNow instance - ES5!)
sensor.setValue('script',
    '(function process(result, source) {\n' +
    '    var output = JSON.parse(result.output);\n' +
    '    \n' +
    '    // Find or create application CI\n' +
    '    var appCI = new GlideRecord("cmdb_ci_appl");\n' +
    '    appCI.addQuery("name", source.getParameter("app_name"));\n' +
    '    appCI.query();\n' +
    '    \n' +
    '    if (!appCI.next()) {\n' +
    '        appCI.initialize();\n' +
    '        appCI.name = source.getParameter("app_name");\n' +
    '        appCI.insert();\n' +
    '    }\n' +
    '    \n' +
    '    // Update status\n' +
    '    appCI.u_health_status = output.status;\n' +
    '    appCI.u_last_health_check = new GlideDateTime();\n' +
    '    appCI.update();\n' +
    '    \n' +
    '    // Create event if unhealthy\n' +
    '    if (output.status !== "healthy") {\n' +
    '        createHealthAlert(appCI, output);\n' +
    '    }\n' +
    '})(result, source);'
);

sensor.insert();

Orchestration (ES5)

Remote PowerShell

// Execute PowerShell on Windows server (ES5 ONLY!)
function executeRemotePowerShell(midServerName, targetHost, script, credential) {
    var payload = [
        '<?xml version="1.0" encoding="UTF-8"?>',
        '<parameters>',
        '  <parameter name="host"><value>' + targetHost + '</value></parameter>',
        '  <parameter name="credential_id"><value>' + credential + '</value></parameter>',
        '  <parameter name="script"><value><![CDATA[' + script + ']]></value></parameter>',
        '</parameters>'
    ].join('\n');

    var mid = getMIDServer(midServerName);
    if (!mid) {
        return { success: false, error: 'MID Server not found' };
    }

    var ecc = new GlideRecord('ecc_queue');
    ecc.initialize();
    ecc.setValue('agent', mid.getUniqueValue());
    ecc.setValue('topic', 'PowerShell');
    ecc.setValue('name', 'Remote PowerShell Execution');
    ecc.setValue('payload', payload);
    ecc.setValue('queue', 'output');
    ecc.setValue('state', 'ready');

    return {
        success: true,
        ecc_sys_id: ecc.insert()
    };
}

Remote SSH

// Execute SSH command (ES5 ONLY!)
function executeRemoteSSH(midServerName, targetHost, command, credential) {
    var payload = [
        '<?xml version="1.0" encoding="UTF-8"?>',
        '<parameters>',
        '  <parameter name="host"><value>' + targetHost + '</value></parameter>',
        '  <parameter name="credential_id"><value>' + credential + '</value></parameter>',
        '  <parameter name="command"><value>' + escapeXML(command) + '</value></parameter>',
        '</parameters>'
    ].join('\n');

    var mid = getMIDServer(midServerName);
    if (!mid) {
        return { success: false, error: 'MID Server not found' };
    }

    var ecc = new GlideRecord('ecc_queue');
    ecc.initialize();
    ecc.setValue('agent', mid.getUniqueValue());
    ecc.setValue('topic', 'SSHCommand');
    ecc.setValue('name', 'Remote SSH Execution');
    ecc.setValue('payload', payload);
    ecc.setValue('queue', 'output');
    ecc.setValue('state', 'ready');

    return {
        success: true,
        ecc_sys_id: ecc.insert()
    };
}

MID Server Monitoring (ES5)

Check MID Status

// Get MID Server status (ES5 ONLY!)
function getMIDServerStatus() {
    var servers = [];

    var mid = new GlideRecord('ecc_agent');
    mid.addQuery('status', '!=', 'Decommissioned');
    mid.query();

    while (mid.next()) {
        servers.push({
            name: mid.getValue('name'),
            status: mid.getValue('status'),
            ip: mid.getValue('ip_address'),
            version: mid.getValue('version'),
            validated: mid.getValue('validated'),
            last_refreshed: mid.getValue('last_refreshed'),
            host_name: mid.getValue('host_name')
        });
    }

    return servers;
}

MCP Tool Integration

Available Tools

ToolPurpose
snow_query_tableQuery MID and ECC tables
snow_find_artifactFind probes/sensors
snow_execute_script_with_outputTest MID scripts

Example Workflow

// 1. Check MID Server status
await snow_query_table({
    table: 'ecc_agent',
    query: 'status=Up',
    fields: 'name,ip_address,version,last_refreshed'
});

// 2. Query ECC queue
await snow_query_table({
    table: 'ecc_queue',
    query: 'queue=output^state=ready',
    fields: 'agent,topic,name,state,sys_created_on'
});

// 3. Find probes
await snow_query_table({
    table: 'discovery_probes',
    query: 'active=true',
    fields: 'name,short_description,mid_type'
});

Best Practices

  1. Credentials - Never hardcode in scripts
  2. Error Handling - Handle network failures
  3. Timeouts - Set appropriate timeouts
  4. Logging - Log for troubleshooting
  5. Security - Limit MID access
  6. Monitoring - Track MID health
  7. Load Balancing - Multiple MIDs for HA
  8. ES5 Only - No modern JavaScript syntax

Score

Total Score

75/100

Based on repository quality metrics

โœ“SKILL.md

SKILL.mdใƒ•ใ‚กใ‚คใƒซใŒๅซใพใ‚Œใฆใ„ใ‚‹

+20
โœ“LICENSE

ใƒฉใ‚คใ‚ปใƒณใ‚นใŒ่จญๅฎšใ•ใ‚Œใฆใ„ใ‚‹

+10
โœ“่ชฌๆ˜Žๆ–‡

100ๆ–‡ๅญ—ไปฅไธŠใฎ่ชฌๆ˜ŽใŒใ‚ใ‚‹

+10
โ—‹ไบบๆฐ—

GitHub Stars 100ไปฅไธŠ

0/15
โœ“ๆœ€่ฟ‘ใฎๆดปๅ‹•

1ใƒถๆœˆไปฅๅ†…ใซๆ›ดๆ–ฐ

+10
โ—‹ใƒ•ใ‚ฉใƒผใ‚ฏ

10ๅ›žไปฅไธŠใƒ•ใ‚ฉใƒผใ‚ฏใ•ใ‚Œใฆใ„ใ‚‹

0/5
โœ“Issue็ฎก็†

ใ‚ชใƒผใƒ—ใƒณIssueใŒ50ๆœชๆบ€

+5
โœ“่จ€่ชž

ใƒ—ใƒญใ‚ฐใƒฉใƒŸใƒณใ‚ฐ่จ€่ชžใŒ่จญๅฎšใ•ใ‚Œใฆใ„ใ‚‹

+5
โœ“ใ‚ฟใ‚ฐ

1ใคไปฅไธŠใฎใ‚ฟใ‚ฐใŒ่จญๅฎšใ•ใ‚Œใฆใ„ใ‚‹

+5

Reviews

๐Ÿ’ฌ

Reviews coming soon