We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/atree1023/snc-cribl-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server
{
"id": "splunk",
"schema": {
"type": "object",
"title": "",
"required": [
"search",
"searchHead",
"endpoint",
"authentication",
"outputMode"
],
"properties": {
"type": {
"type": "string",
"enum": ["splunk"],
"flag": {
"prefix": "collector",
"modes": ["single", "worker"]
}
},
"searchHead": {
"type": "string",
"title": "Search head",
"default": "https://localhost:8089",
"description": "Search head base URL. Can be an expression. Default is https://localhost:8089."
},
"search": {
"type": "string",
"title": "Search",
"description": "Examples: 'index=myAppLogs level=error channel=myApp' OR '| mstats avg(myStat) as myStat WHERE index=myStatsIndex.'"
},
"earliest": {
"title": "Earliest",
"type": "string",
"description": "The earliest time boundary for the search. Can be an exact or relative time. Examples: '2022-01-14T12:00:00Z' or '-16m@m'"
},
"latest": {
"title": "Latest",
"type": "string",
"description": "The latest time boundary for the search. Can be an exact or relative time. Examples: '2022-01-14T12:00:00Z' or '-1m@m'"
},
"endpoint": {
"type": "string",
"title": "Search endpoint",
"default": "/services/search/v2/jobs/export",
"description": "REST API used to create a search"
},
"outputMode": {
"type": "string",
"title": "Output mode",
"description": "Format of the returned output",
"enum": ["csv", "json"],
"default": "json"
},
"collectRequestParams": {
"title": "Extra parameters",
"description": "Optional collect request parameters",
"type": "array",
"items": {
"type": "object",
"required": ["name", "value"],
"properties": {
"name": {
"title": "Parameter Name",
"type": "string"
},
"value": {
"title": "Value",
"type": "string",
"description": "JavaScript expression to compute the parameter's value, normally enclosed in backticks (`${earliest}`). If a constant, use single quotes ('earliest'). Values without delimiters (earliest) are evaluated as strings.",
"jsExpression": true
}
}
}
},
"collectRequestHeaders": {
"title": "Extra headers",
"description": "Optional collect request headers",
"type": "array",
"items": {
"type": "object",
"required": ["name", "value"],
"properties": {
"name": {
"type": "string",
"title": "Header Name"
},
"value": {
"type": "string",
"title": "Value",
"description": "JavaScript expression to compute the header's value, normally enclosed in backticks (`${earliest}`). If a constant, use single quotes ('earliest'). Values without delimiters (earliest) are evaluated as strings.",
"jsExpression": true,
"encrypt": true
}
}
}
},
"authentication": {
"type": "string",
"title": "Authentication",
"description": "Authentication method for Discover and Collect REST calls",
"enum": ["none", "basic", "basicSecret", "token", "tokenSecret"],
"enumNames": [
"None",
"Basic",
"Basic (credentials secret)",
"Bearer Token",
"Bearer Token (text secret)"
],
"default": "basic"
},
"timeout": {
"type": "number",
"title": "Request timeout (secs)",
"description": "HTTP request inactivity timeout. Use 0 for no timeout.",
"minimum": 0,
"maximum": 1800,
"default": 0
},
"useRoundRobinDns": {
"type": "boolean",
"title": "Round-robin DNS",
"description": "Use round-robin DNS lookup. Suitable when DNS server returns multiple addresses in sort order.",
"default": false
},
"disableTimeFilter": {
"type": "boolean",
"title": "Disable time filter",
"description": "Disable collector event time filtering when a date range is specified",
"default": true
},
"rejectUnauthorized": {
"type": "boolean",
"title": "Reject unauthorized certificates",
"description": "Reject certificates that cannot be verified against a valid CA (such as self-signed certificates)",
"default": false,
"defaultNew": true
},
"handleEscapedChars": {
"type": "boolean",
"title": "Preserve escaped characters",
"description": "Escape characters (\\\") in search queries will be passed directly to Splunk",
"default": false,
"defaultNew": true
},
"retryRules": {
"type": "object",
"required": ["type"],
"properties": {
"type": {
"type": "string",
"title": "Retry type",
"description": "Algorithm to use when performing HTTP retries",
"enum": ["none", "backoff", "static"],
"enumNames": ["Disabled", "Backoff", "Static"],
"default": "backoff"
},
"interval": {},
"limit": {},
"multiplier": {},
"codes": {},
"enableHeader": {},
"retryConnectTimeout": {},
"retryConnectReset": {}
},
"dependencies": {
"type": {
"oneOf": [
{
"properties": {
"type": {
"enum": ["none"]
}
}
},
{
"properties": {
"type": {
"enum": ["static"]
},
"interval": {
"type": "number",
"title": "Wait (ms)",
"description": "Time interval between retries. Maximum allowed value is 20,000 ms (1/3 minute).",
"minimum": 0,
"maximum": 20000,
"default": 1000
},
"limit": {
"type": "number",
"title": "Retry limit",
"description": "The maximum number of times to retry a failed HTTP request",
"minimum": 0,
"maximum": 20,
"default": 5
},
"codes": {
"type": "array",
"title": "Retry HTTP codes",
"description": "List of HTTP codes that trigger a retry. Leave empty to use the default list of 429 and 503.",
"minItems": 1,
"default": [429, 503],
"items": {
"type": "number",
"minLength": 1
}
},
"enableHeader": {
"type": "boolean",
"title": "Honor Retry-After header",
"description": "Honor any Retry-After header that specifies a delay (in seconds) or a timestamp after which to retry the request. The delay is limited to 20 seconds, even if the Retry-After header specifies a longer delay. When disabled, all Retry-After headers are ignored.",
"default": true
},
"retryConnectTimeout": {
"type": "boolean",
"title": "Retry connection timeout",
"description": "Make a single retry attempt when a connection timeout (ETIMEDOUT) error occurs",
"default": false
},
"retryConnectReset": {
"type": "boolean",
"title": "Retry connection reset",
"description": "Retry request when a connection reset error (ECONNRESET) error occurs",
"default": false
}
}
},
{
"properties": {
"type": {
"enum": ["backoff"]
},
"interval": {
"type": "number",
"title": "Initial retry interval (ms)",
"description": "Time interval between failed request and first retry (kickoff). Maximum allowed value is 20,000 ms (1/3 minute).",
"minimum": 0,
"maximum": 20000,
"default": 1000
},
"limit": {
"type": "number",
"title": "Retry limit",
"description": "The maximum number of times to retry a failed HTTP request",
"minimum": 0,
"maximum": 20,
"default": 5
},
"multiplier": {
"type": "number",
"title": "Backoff multiplier",
"description": "Base for exponential backoff. For example, base 2 means that retries will occur after 2, then 4, then 8 seconds, and so on.",
"minimum": 1,
"maximum": 20,
"default": 2
},
"codes": {
"type": "array",
"title": "Retry HTTP codes",
"description": "List of HTTP codes that trigger a retry. Leave empty to use the default list of 429 and 503.",
"minItems": 1,
"default": [429, 503],
"items": {
"type": "number",
"minLength": 1
}
},
"enableHeader": {
"type": "boolean",
"title": "Honor Retry-After header",
"description": "Honor any Retry-After header that specifies a delay (in seconds) or a timestamp after which to retry the request. The delay is limited to 20 seconds, even if the Retry-After header specifies a longer delay. When disabled, all Retry-After headers are ignored.",
"default": true
},
"retryConnectTimeout": {
"type": "boolean",
"title": "Retry connection timeout",
"description": "Make a single retry attempt when a connection timeout (ETIMEDOUT) error occurs",
"default": false
},
"retryConnectReset": {
"type": "boolean",
"title": "Retry connection reset",
"description": "Retry request when a connection reset error (ECONNRESET) error occurs",
"default": false
}
}
}
]
}
}
}
},
"dependencies": {
"authentication": {
"oneOf": [
{
"properties": {
"authentication": {
"enum": ["none"]
}
}
},
{
"required": ["username", "password"],
"properties": {
"authentication": {
"enum": ["basic"]
},
"username": {
"type": "string",
"title": "Username",
"description": "Basic authentication username",
"encrypt": true
},
"password": {
"type": "string",
"title": "Password",
"description": "Basic authentication password",
"encrypt": true
}
}
},
{
"required": ["credentialsSecret"],
"properties": {
"authentication": {
"enum": ["basicSecret"]
},
"credentialsSecret": {
"type": "string",
"title": "Credentials secret",
"secret": {
"type": "credentials",
"target": ["username", "password"]
},
"description": "Select or create a stored secret that references your credentials"
}
}
},
{
"required": ["token"],
"properties": {
"authentication": {
"enum": ["token"]
},
"token": {
"type": "string",
"title": "Bearer token",
"encrypt": true
}
}
},
{
"required": ["tokenSecret"],
"properties": {
"authentication": {
"enum": ["tokenSecret"]
},
"tokenSecret": {
"type": "string",
"title": "Bearer token secret",
"secret": {
"type": "text",
"target": ["token"]
},
"secretRef": true,
"description": "Select or create a stored secret that references your Bearer token"
}
}
},
{
"required": [
"loginUrl",
"username",
"password",
"loginBody",
"tokenRespAttribute",
"authHeaderExpr"
],
"properties": {
"authentication": {
"enum": ["login"]
},
"loginUrl": {
"type": "string",
"title": "Login URL",
"description": "URL to use for login API call. This call is expected to be a POST.",
"default": "`https://localhost:9000/api/v1/auth/login`",
"jsExpression": true
},
"username": {
"type": "string",
"title": "Username",
"minLength": 1,
"encrypt": true
},
"password": {
"type": "string",
"title": "Password",
"minLength": 1,
"encrypt": true
},
"loginBody": {
"type": "string",
"title": "POST body",
"description": "Template for POST body to send with login request. ${username} and ${password} are used to specify location of these attributes in the message.",
"default": "`{ \"username\": \"${username}\", \"password\": \"${password}\" }`",
"jsExpression": true
},
"tokenRespAttribute": {
"type": "string",
"title": "Token attribute",
"description": "Path to token attribute in login response body. Nested attributes are allowed.",
"default": "token"
},
"authHeaderExpr": {
"type": "string",
"title": "Authorize Expression",
"description": "JavaScript expression to compute the Authorization header to pass in discover and collect calls. The value ${token} is used to reference the token obtained from login.",
"default": "`Bearer ${token}`",
"jsExpression": true
}
}
},
{
"required": [
"loginUrl",
"credentialsSecret",
"loginBody",
"tokenRespAttribute",
"authHeaderExpr"
],
"properties": {
"authentication": {
"enum": ["loginSecret"]
},
"loginUrl": {
"type": "string",
"title": "Login URL",
"description": "URL to use for login API call, this call is expected to be a POST.",
"default": "`https://localhost:9000/api/v1/auth/login`",
"jsExpression": true
},
"credentialsSecret": {
"type": "string",
"title": "Credentials secret",
"secret": {
"type": "credentials",
"target": ["username", "password"]
},
"description": "Select or create a stored secret that references your login credentials"
},
"loginBody": {
"type": "string",
"title": "POST Body",
"description": "Template for POST body to send with login request, ${username} and ${password} are used to specify location of these attributes in the message",
"default": "`{ \"username\": \"${username}\", \"password\": \"${password}\" }`",
"jsExpression": true
},
"tokenRespAttribute": {
"type": "string",
"title": "Token Attribute",
"description": "Path to token attribute in login response body. Nested attributes are allowed.",
"default": "token"
},
"authHeaderExpr": {
"type": "string",
"title": "Authorize expression",
"description": "JavaScript expression to compute the Authorization header to pass in discover and collect calls. The value ${token} is used to reference the token obtained from login.",
"default": "`Bearer ${token}`",
"jsExpression": true
}
}
}
]
}
}
}
}