Skyhigh Security Policy Code Function Reference
- Last updated
- Save as PDF
NOTE: This documentation is a work in progress. If you find an error, please leave feedback at the bottom of the page.
×
[{"name": "Append (STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the concatenated string.", "parameter_desc": "1. `STRING`: The first string that you want to combine.\n2. `STRING`: The second string that you want to append to the first.", "description": "Appends the second string argument to the first and returns the concatenated string.", "example_code": "STRING str1 = \"Hello\"\nSTRING str2 = \"World\"\nSTRING result = Append(str1, str2)\n// result now contains \"HelloWorld\"", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "STRING str1 = \"Hello\"\nSTRING str2 = \"World\"\nSTRING result = Append(str1, str2)\n// result now contains \"HelloWorld\""}, {"name": "ArrayAppend (JSON, JSON)", "return_type": "JSON", "return_desc": "Returns the combined JSON array.", "parameter_desc": "1. `JSON`: The first JSON array that you want to combine.\n2. `JSON`: The second JSON array that you want to append to the first one.", "description": "Appends the second JSON array argument to the first JSON array argument and returns the combined array.", "example_code": "// Initialize a JSON array\nJSON jsonArray = JSON.CreateEmptyArray\n\n// Create a JSON object to append\nJSON jsonObject1 = JSON.FromString (\"[\\\"apple\\\", \\\"pear\\\"]\")\nJSON jsonObject2 = JSON.FromString (\"[\\\"cherry\\\", \\\"pineapple\\\"]\")\n\n// Append the JSON objects to the JSON array\njsonArray = ArrayAppend (jsonArray, jsonObject1)\njsonArray = ArrayAppend (jsonArray, jsonObject2)\n\n// jsonArray now contains [\"apple\", \"pear\", \"cherry\", \"pineapple\"]", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Initialize a JSON array\nJSON jsonArray = JSON.CreateEmptyArray\n\n// Create a JSON object to append\nJSON jsonObject1 = JSON.FromString (\"[\"apple\", \"pear\"]\")\nJSON jsonObject2 = JSON.FromString (\"[\"cherry\", \"pineapple\"]\")\n\n// Append the JSON objects to the JSON array\njsonArray = ArrayAppend (jsonArray, jsonObject1)\njsonArray = ArrayAppend (jsonArray, jsonObject2)\n\n// jsonArray now contains [\"apple\", \"pear\", \"cherry\", \"pineapple\"]"}, {"name": "At (STRING, NUMBER)", "return_type": "STRING", "return_desc": "Returns a single character (as a string) from the specified position in the provided string.", "parameter_desc": "1. `STRING`: The string from which you want to find a character.\n2. `NUMBER`: The index value of the character you want to return from the string.", "description": "Finds the character at a given index of a string.", "example_code": "STRING exampleString = \"Hello, World!\"\nNUMBER position = 7\nSTRING characterAtPosition = At (exampleString, position)\n\n// characterAtPosition now equals \"W\"", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "STRING exampleString = \"Hello, World!\"\nNUMBER position = 7\nSTRING characterAtPosition = At (exampleString, position)\n\n// characterAtPosition now equals \"W\""}, {"name": "Contains (RegExJSi.List, RegExJSi)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE`if the regular expression list contains the given regular expression.", "parameter_desc": "1. `RegExJSi.List`: List of regular expressions to check.\n2. `RegExJSi`: The regular expression to look for.", "description": "Checks whether the regular expression list contains the given regular expression.", "example_code": "// Retrieve the list of regular expressions by name\nRegExJSi.List regexList = MWG.RegexListByName (\"example_regex_list\")\n\n// Create a wildcard regex that matches any string\nRegExJSi wildcardRegex = ToRegExJSi (\".*\")\n\n// Stop this ruleset if the regex list contains the wildcard expression\nIF Contains (regexList, wildcardRegex) THEN\n    END", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Retrieve the list of regular expressions by name\nRegExJSi.List regexList = MWG.RegexListByName (\"example_regex_list\")\n\n// Create a wildcard regex that matches any string\nRegExJSi wildcardRegex = ToRegExJSi (\".*\")\n\n// Stop this ruleset if the regex list contains the wildcard expression\nIF Contains (regexList, wildcardRegex) THEN\n    END"}, {"name": "Contains (UCE.FileTransferControlList, STRING, MediaType)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the specified `UCE.FileTransferControlList` contains an entry matching the specified hostname (or domain) and media type.", "parameter_desc": "1. `UCE.FileTransferControlList`: The list to check.\n2. `STRING`: The hostname or domain to search for\n3. `MediaType`: The media type to search for.", "description": "Checks whether a `UCE.FileTransferControlList` contains a specified combination of hostname (or domain) and media type.", "example_code": "// Load file transfer control list\nUCE.FileTransferControlList allowedDownloadTypes = [\"AllowedDownloadTypesList\"]\n\n// Only look at response trigger\nIF Trigger == \"Web.Response\" THEN {\n    IF Contains (allowedDownloadTypes, MWG.Url.Host, MediaType.FromHeader) THEN {\n        // File transfer is allowed.\n        MWG.Allow (\"File transfer allowed by policy\")\n    } ELSE {\n        // File transfer is not allowed.\n        MWG.Block (\"File transfer blocked by policy\")\n    }\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Load file transfer control list\nUCE.FileTransferControlList allowedDownloadTypes = [\"AllowedDownloadTypesList\"]\n\n// Only look at response trigger\nIF Trigger == \"Web.Response\" THEN {\n    IF Contains (allowedDownloadTypes, MWG.Url.Host, MediaType.FromHeader) THEN {\n        // File transfer is allowed.\n        MWG.Allow (\"File transfer allowed by policy\")\n    } ELSE {\n        // File transfer is not allowed.\n        MWG.Block (\"File transfer blocked by policy\")\n    }\n}"}, {"name": "Contains (UCE.FileTransferControlList, STRING, VECTOR<MediaType>)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the specified `UCE.FileTransferControlList` contains an entry matching the specified hostname (or domain) and list of media types.", "parameter_desc": "1. `UCE.FileTransferControlList`: The list to search in.\n2. `STRING`: The hostname or domain to check for.\n3. `VECTOR<MediaType>`: The list of media types to check for.", "description": "Checks whether a `UCE.FileTransferControlList` contains a specified combination of hostname (or domain) and list of media types.", "example_code": "// Load file transfer control list\nUCE.FileTransferControlList allowedDownloadTypes = [\"AllowedDownloadTypesList\"]\n\n// Only look at response trigger\nIF Trigger == \"Web.Response\" THEN {\n    IF Contains (allowedDownloadTypes, MWG.Url.Host, MediaType.Ensured) THEN {\n        // File transfer is allowed.\n        MWG.Allow (\"File transfer allowed by policy\")\n    } ELSE {\n        // File transfer is not allowed.\n        MWG.Block (\"File transfer blocked by policy\")\n    }\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Load file transfer control list\nUCE.FileTransferControlList allowedDownloadTypes = [\"AllowedDownloadTypesList\"]\n\n// Only look at response trigger\nIF Trigger == \"Web.Response\" THEN {\n    IF Contains (allowedDownloadTypes, MWG.Url.Host, MediaType.Ensured) THEN {\n        // File transfer is allowed.\n        MWG.Allow (\"File transfer allowed by policy\")\n    } ELSE {\n        // File transfer is not allowed.\n        MWG.Block (\"File transfer blocked by policy\")\n    }\n}"}, {"name": "Contains (VECTOR<MediaType>, MediaType)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the provided list of media types contains the provided `MediaType`.", "parameter_desc": "1. `VECTOR<MediaType>`: A vector of media types to search.\n2. `MediaType`: The media type to search for.", "description": "Checks whether a list of media types contains a specified media type.", "example_code": "// Define a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = ToMediaType (\"image/jpeg\"), ToMediaType (\"image/png\"), ToMediaType (\"application/pdf\")\n\n// Define the MediaType to check for\nMediaType targetType = ToMediaType (\"image/png\")\n\n// Check if the targetType is in the mediaTypes vector\nIF Contains (mediaTypes, targetType) THEN {\n    // The media type image/png is present in the list.\n} ELSE {\n    // The media type image/png is not present in the list.\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = ToMediaType (\"image/jpeg\"), ToMediaType (\"image/png\"), ToMediaType (\"application/pdf\")\n\n// Define the MediaType to check for\nMediaType targetType = ToMediaType (\"image/png\")\n\n// Check if the targetType is in the mediaTypes vector\nIF Contains (mediaTypes, targetType) THEN {\n    // The media type image/png is present in the list.\n} ELSE {\n    // The media type image/png is not present in the list.\n}"}, {"name": "Contains (VECTOR<MWG.HostAndCertificate>, MWG.HostAndCertificate)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the provided list contains the provided`MWG.HostAndCertificate`.", "parameter_desc": "1. `VECTOR<MWG.HostAndCertificate>`: A vector of `MWG.HostAndCertificates` to search.\n2. `MWG.HostAndCertificate`: A `MWG.HostAndCertificate` to search for.", "description": "Checks whether a list of `MWG.HostAndCertificate` objects contains a specified `MWG.HostAndCertificate`.", "example_code": "// Select a VECTOR of MWG.HostAndCertificate from the List Catalog\nVECTOR<MWG.HostAndCertificate> trustedHosts = list_mytrustedhosts\n\n// Get host and certificate of current request\nMWG.HostAndCertificate currentHost = MWG.HostAndCertificate\n\n// Check if the current host is in the list of trusted hosts\nIF Contains (trustedHosts, currentHost) THEN {\n    // The current host is trusted.  Allow request without further scanning\n    MWG.Allow (\"Trusted Host\")\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Select a VECTOR of MWG.HostAndCertificate from the List Catalog\nVECTOR<MWG.HostAndCertificate> trustedHosts = list_mytrustedhosts\n\n// Get host and certificate of current request\nMWG.HostAndCertificate currentHost = MWG.HostAndCertificate\n\n// Check if the current host is in the list of trusted hosts\nIF Contains (trustedHosts, currentHost) THEN {\n    // The current host is trusted.  Allow request without further scanning\n    MWG.Allow (\"Trusted Host\")\n}"}, {"name": "Contains (VECTOR<MWG.UrlCategory>, MWG.UrlCategory)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the provided list contains the provided `MWG.UrlCategory`.", "parameter_desc": "1. `VECTOR<MWG.UrlCategory>`: A vector of `MWG.UrlCategory`s to search.\n2. `MWG.UrlCategory`: A `MWG.UrlCategory` to search for.", "description": "Checks whether a list of URL categories contains a specified URL category.", "example_code": "// Get URL categories for current request\nVECTOR<MWG.UrlCategory> categories = MWG.UrlCategories (McAfee_GTI_Setting)\n\n// Create an MWG.UrlCategory object for Gambling\nMWG.UrlCategory gambling = ToWebUrlCategory (115)\n\n// Check if current request is categorized as Gambling and block if true\nIF Contains (categories, gambling) THEN {\n    MWG.Block (\"Gambling content not allowed\")\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get URL categories for current request\nVECTOR<MWG.UrlCategory> categories = MWG.UrlCategories (McAfee_GTI_Setting)\n\n// Create an MWG.UrlCategory object for Gambling\nMWG.UrlCategory gambling = ToWebUrlCategory (115)\n\n// Check if current request is categorized as Gambling and block if true\nIF Contains (categories, gambling) THEN {\n    MWG.Block (\"Gambling content not allowed\")\n}"}, {"name": "Contains (VECTOR<Net.IP>, Net.IP)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the provided list of IP addresses contains the specified IP address.", "parameter_desc": "1. `VECTOR<Net.IP>`: The list of IP addresses to search.\n2. `Net.IP`: The IP address to search for.", "description": "Checks whether a list of IP addresses contains a specified IP address.", "example_code": "// Load list of IP addresses from List Catalog\nVECTOR<Net.IP> allowedIPs = list_AllowedClientIPs\n\n// Check the IP address of the client\nNet.IP currentIP = MWG.ClientIP\n\n// Block clients not in the list of allowed client IPs\nIF Contains (allowedIPs, currentIP) THEN {\n    MWG.Allow (\"Allowed client IP address\")\n} ELSE {\n    MWG.Block (\"Client IP address not allowed.\")\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Load list of IP addresses from List Catalog\nVECTOR<Net.IP> allowedIPs = list_AllowedClientIPs\n\n// Check the IP address of the client\nNet.IP currentIP = MWG.ClientIP\n\n// Block clients not in the list of allowed client IPs\nIF Contains (allowedIPs, currentIP) THEN {\n    MWG.Allow (\"Allowed client IP address\")\n} ELSE {\n    MWG.Block (\"Client IP address not allowed.\")\n}"}, {"name": "Contains (VECTOR<Net.IPRange>, Net.IPRange)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the list of IP ranges contains the given IP range.", "parameter_desc": "1. `VECTOR<Net.IPRange>`: List of IP ranges to search through.\n2. `Net.IPRange`: The IP range to search for.", "description": "Checks whether a list of IP ranges contains a specified IP range.", "example_code": "// Load a list of imported IP ranges from List Catalog\nVECTOR<Net.IPRange> importedIPRanges = list_ImportedIPRanges\n\n// Define an RFC1918 IP range\nNet.IPRange rfc1918 = Net.ToIPRange (\"10.0.0.0/8\")\n\n// Check if the imported range list contains RFC1918 range\nBOOLEAN rangesIncludePrivateIPs = Contains (importedIPRanges, rfc1918)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Load a list of imported IP ranges from List Catalog\nVECTOR<Net.IPRange> importedIPRanges = list_ImportedIPRanges\n\n// Define an RFC1918 IP range\nNet.IPRange rfc1918 = Net.ToIPRange (\"10.0.0.0/8\")\n\n// Check if the imported range list contains RFC1918 range\nBOOLEAN rangesIncludePrivateIPs = Contains (importedIPRanges, rfc1918)"}, {"name": "Contains (VECTOR<Net.IPRange>, VECTOR<Net.IP>)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if any IP from the list of IPs is found within any IP range specified in the list of IP ranges.", "parameter_desc": "1. `VECTOR<Net.IPRange>`: The list of IP ranges.\n2. `VECTOR<Net.IP>`: The list of IP addresses.", "description": "Checks whether a list of IP ranges contains at least one IP address from a list of IP addresses.", "example_code": "// Define a vector of IP ranges\nVECTOR<Net.IPRange> ipRanges = Net.ToIPRange (\"192.168.1.0/24\"), Net.ToIPRange (\"10.0.0.0/8\")\n\n// Define a vector of client IPs\nVECTOR<Net.IP> clientIPs = Net.ToIP (\"192.168.1.10\"), Net.ToIP (\"172.16.0.1\")\n\n// Check if any IP is contained in any range\nBOOLEAN ipMatched = Contains (ipRanges, clientIPs)\n// ipMatched now equals TRUE because 192.168.1.10 is contained in 192.168.1.0/24", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define a vector of IP ranges\nVECTOR<Net.IPRange> ipRanges = Net.ToIPRange (\"192.168.1.0/24\"), Net.ToIPRange (\"10.0.0.0/8\")\n\n// Define a vector of client IPs\nVECTOR<Net.IP> clientIPs = Net.ToIP (\"192.168.1.10\"), Net.ToIP (\"172.16.0.1\")\n\n// Check if any IP is contained in any range\nBOOLEAN ipMatched = Contains (ipRanges, clientIPs)\n// ipMatched now equals TRUE because 192.168.1.10 is contained in 192.168.1.0/24"}, {"name": "Contains (VECTOR<NUMBER>, NUMBER)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the provided list of numbers contains the specified number.", "parameter_desc": "1. `VECTOR<NUMBER>`: The list of numbers to search.\n2. `NUMBER`: The number to search for.", "description": "Determines whether the given vector contains the given number.", "example_code": "VECTOR<NUMBER> primes = 2, 3, 5, 7, 11, 13, 17, 19, 23, 29\nNUMBER numberToCheck = 3\n\nBOOLEAN numberIsPrime = Contains (primes, numberToCheck)\n// numberIsPrime now equals TRUE", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> primes = 2, 3, 5, 7, 11, 13, 17, 19, 23, 29\nNUMBER numberToCheck = 3\n\nBOOLEAN numberIsPrime = Contains (primes, numberToCheck)\n// numberIsPrime now equals TRUE"}, {"name": "Contains (VECTOR<STRING>, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the provided list of strings contains the specified string.", "parameter_desc": "1. `VECTOR<STRING>`: The list of strings to search.\n2. `STRING`: The string to search for.", "description": "Checks whether a list of strings contains a specified string.", "example_code": "VECTOR<STRING> fordVehicles = \"Mustang\", \"F-150\", \"Explorer\", \"Expedition\"\nSTRING myVehicle = \"F-150\"\n\nBOOLEAN isFord = Contains (fordVehicles, myVehicle)\n// isFord now equals TRUE", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "VECTOR<STRING> fordVehicles = \"Mustang\", \"F-150\", \"Explorer\", \"Expedition\"\nSTRING myVehicle = \"F-150\"\n\nBOOLEAN isFord = Contains (fordVehicles, myVehicle)\n// isFord now equals TRUE"}, {"name": "Contains (VECTOR<YouTubeVideoCategory>, YouTubeVideoCategory)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the provided list of YouTube video categories contains the specified YouTube video category .", "parameter_desc": "1. `VECTOR<YouTubeVideoCategory>`: The list of YouTube video categories to search.\n2. `YouTubeVideoCategory`: The YouTube video category to search for.", "description": "Checks whether a list of YouTube video categories contains a specified YouTube video category.", "example_code": "// Call Skyhigh-provided YouTube_API ROUTINE to get video category\nCALL \"YouTube_API\"\nYouTubeVideoCategory videoCategory = ToYouTubeVideoCategory (JSON.GetAsString (callParameter, \"youTube_CategoryId\"))\n\n// Create list of YouTubeVideoCategorys to block\nVECTOR<YouTubeVideoCategory> blockedCategories = ToYouTubeVideoCategory (\"Gaming\"), ToYouTubeVideoCategory (\"Movies\")\n\n// Block if current video is in a blocked category\nIF Contains (blockedCategories, videoCategory) THEN\n    MWG.Block (\"Blocked YouTube category\")", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Call Skyhigh-provided YouTube_API ROUTINE to get video category\nCALL \"YouTube_API\"\nYouTubeVideoCategory videoCategory = ToYouTubeVideoCategory (JSON.GetAsString (callParameter, \"youTube_CategoryId\"))\n\n// Create list of YouTubeVideoCategorys to block\nVECTOR<YouTubeVideoCategory> blockedCategories = ToYouTubeVideoCategory (\"Gaming\"), ToYouTubeVideoCategory (\"Movies\")\n\n// Block if current video is in a blocked category\nIF Contains (blockedCategories, videoCategory) THEN\n    MWG.Block (\"Blocked YouTube category\")"}, {"name": "ContainsAll (VECTOR<Net.IPRange>, VECTOR<Net.IP>)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the IP rangelist contains all of the IPs from the IP list.", "parameter_desc": "1. `VECTOR<Net.IPRange>`: The list of IP ranges to search through.\n2. `VECTOR<Net.IP>`: The list of IP addresses to search for.", "description": "Checks whether a list of IP ranges contains all of the IPs in a list of IP addresses.", "example_code": "VECTOR<Net.IPRange> privateIPRanges = Net.ToIPRange(\"10.0.0.0/8\"),\n    Net.ToIPRange(\"172.16.0.0/12\"),\n    Net.ToIPRange (\"192.168.0.0/16\")\nVECTOR<Net.IP> connectionIPs = MWG.ClientIP, MWG.DestinationIP\n\n// Check whether connection's source and destination IP are both private\nBOOLEAN isInternal = ContainsAll (privateIPRanges, connectionIPs)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> privateIPRanges = Net.ToIPRange(\"10.0.0.0/8\"),\n    Net.ToIPRange(\"172.16.0.0/12\"),\n    Net.ToIPRange (\"192.168.0.0/16\")\nVECTOR<Net.IP> connectionIPs = MWG.ClientIP, MWG.DestinationIP\n\n// Check whether connection's source and destination IP are both private\nBOOLEAN isInternal = ContainsAll (privateIPRanges, connectionIPs)"}, {"name": "ContainsCaseInsensitive (VECTOR<STRING>, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE if the provided list of strings contains the provided string without considering case.", "parameter_desc": "1. `VECTOR<STRING>`: The list of strings to search.\n2. `STRING`: The string to search for case-insensitively.", "description": "Checks whether a list of strings contains a specified string in a case-insensitive manner.", "example_code": "VECTOR<STRING> fruit = \"Plum\", \"Pear\", \"Pineapple\", \"Peach\"\nSTRING myFood = \"pear\"\n\nBOOLEAN myFoodIsFruit = ContainsCaseInsensitive (fruit, myFood)\n// myFoodIsFruit now equals TRUE", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "VECTOR<STRING> fruit = \"Plum\", \"Pear\", \"Pineapple\", \"Peach\"\nSTRING myFood = \"pear\"\n\nBOOLEAN myFoodIsFruit = ContainsCaseInsensitive (fruit, myFood)\n// myFoodIsFruit now equals TRUE"}, {"name": "ContainsMatch (VECTOR<MediaType>, RegExJSi)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the input `VECTOR`contains at least one element that matches the regular expression `RegExJSi`.", "parameter_desc": "1. `VECTOR<MediaType>`: The input list to be searched.\n2. `RegExJSi`: The regular expression pattern to match.", "description": "Returns TRUE if the input list contains at least one regular expression match.", "example_code": "// Define a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = [\"text/html\", \"application/json\", \"image/png\"]\n\n// Define a regular expression pattern to match media types that are text-based\nRegExJSi textPattern = \"/text\\/.*/\"\n\n// Check if any of the media types match the text pattern\nBOOLEAN hasTextMediaType = ContainsMatch(mediaTypes, textPattern)\n\n// Print the result to the console\nIF hasTextMediaType THEN {\n    // The media types contain a text-based media type.\n} ELSE {\n    // The media types do not contain a text-based media type.\n}", "reviewed": "FALSE", "need_info": "TRUE", "code_example": "// Define a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = [\"text/html\", \"application/json\", \"image/png\"]\n\n// Define a regular expression pattern to match media types that are text-based\nRegExJSi textPattern = \"/text\\/.*/\"\n\n// Check if any of the media types match the text pattern\nBOOLEAN hasTextMediaType = ContainsMatch(mediaTypes, textPattern)\n\n// Print the result to the console\nIF hasTextMediaType THEN {\n    // The media types contain a text-based media type.\n} ELSE {\n    // The media types do not contain a text-based media type.\n}"}, {"name": "ContainsMatch (VECTOR<STRING>, RegExJSi)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if any string in the list matches the regular expression pattern specified by `RegExJSi`.", "parameter_desc": "1. `VECTOR<STRING>`: The list of strings to be checked for matches.\n2. `RegExJSi`: The regular expression pattern to search for within the list.", "description": "Checks whether a list of strings contains at least one match with a given regular expression.", "example_code": "// Define a vector of strings\nVECTOR<STRING> stringList = \"apple\", \"banana\", \"cherry\", \"date\"\n\n// Define a regular expression pattern to match any string beginning with the letter 'a'\nRegExJSi pattern = RegExJSi(\"^a.*\")\n\n// Check if any string in the vector matches the pattern\nBOOLEAN hasMatch = ContainsMatch(stringList, pattern)\n// hasMatch now equals `TRUE` because the string \"apple\" matched the regex", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define a vector of strings\nVECTOR<STRING> stringList = \"apple\", \"banana\", \"cherry\", \"date\"\n\n// Define a regular expression pattern to match any string beginning with the letter 'a'\nRegExJSi pattern = RegExJSi(\"^a.*\")\n\n// Check if any string in the vector matches the pattern\nBOOLEAN hasMatch = ContainsMatch(stringList, pattern)\n// hasMatch now equals `TRUE` because the string \"apple\" matched the regex"}, {"name": "ContainsNone (VECTOR<Net.IPRange>, VECTOR<Net.IP>)", "return_type": "BOOLEAN", "return_desc": "Return `TRUE` if the list of IP ranges contains **none** of the IPs from the list of IP addresses.", "parameter_desc": "1. `VECTOR<Net.IPRange>`: The list of IP ranges to search through.\n2. `VECTOR<Net.IP>`: The list of IP addresses to search for.", "description": "Checks whether a list of IP ranges contains none of the IPs from a list of IP addresses.", "example_code": "// Define a vector of IP ranges\nVECTOR<Net.IPRange> ipRanges = Net.ToIPRange (\"192.168.1.0/24\"), Net.ToIPRange (\"10.0.0.0/8\")\n\n// Define a vector of client IPs\nVECTOR<Net.IP> clientIPs = Net.ToIP (\"192.168.1.10\"), Net.ToIP (\"172.16.0.1\")\n\n// Check if any IP is contained in any range\nBOOLEAN ipMatched = ContainsNone (ipRanges, clientIPs)\n// ipMatched now equals FALSE because 192.168.1.10 is contained in 192.168.1.0/24", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define a vector of IP ranges\nVECTOR<Net.IPRange> ipRanges = Net.ToIPRange (\"192.168.1.0/24\"), Net.ToIPRange (\"10.0.0.0/8\")\n\n// Define a vector of client IPs\nVECTOR<Net.IP> clientIPs = Net.ToIP (\"192.168.1.10\"), Net.ToIP (\"172.16.0.1\")\n\n// Check if any IP is contained in any range\nBOOLEAN ipMatched = ContainsNone (ipRanges, clientIPs)\n// ipMatched now equals FALSE because 192.168.1.10 is contained in 192.168.1.0/24"}, {"name": "CreateMapSTRINGToSTRING ()", "return_type": "MAP<STRING,STRING>", "return_desc": "Returns an empty `MAP<STRING,STRING>`.", "parameter_desc": "*N/A*", "description": "Creates an empty `MAP<STRING,STRING>` object.", "example_code": "// Create an empty map of STRING to STRING\nMAP<STRING, STRING> myMap = CreateMapStringToString()\n\n// Add some key-value pairs to the map\nmyMap = myMap.Set (\"key1\", \"value1\")\nmyMap = myMap.Set (\"key2\", \"value2\")\nmyMap = myMap.Set (\"key3\", \"value3\")", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Create an empty map of STRING to STRING\nMAP<STRING, STRING> myMap = CreateMapStringToString()\n\n// Add some key-value pairs to the map\nmyMap = myMap.Set (\"key1\", \"value1\")\nmyMap = myMap.Set (\"key2\", \"value2\")\nmyMap = myMap.Set (\"key3\", \"value3\")"}, {"name": "Cryptography.CreateRandomBytes (NUMBER)", "return_type": "DATAREF", "return_desc": "Returns a `DATAREF` with the specified amount of randomly generated data.", "parameter_desc": "1. `NUMBER`: The length of random data to be generated, in bytes.", "description": "Creates randomly generated data.", "example_code": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nDATAREF randomBytes = Cryptography.CreateRandomBytes (numBytes)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nDATAREF randomBytes = Cryptography.CreateRandomBytes (numBytes)"}, {"name": "Cryptography.CreateRandomBytesAsBase64STRING (NUMBER)", "return_type": "STRING", "return_desc": "Returns a base64-encoded string representing the specified number of randomly generated bytes.", "parameter_desc": "1. `NUMBER`: The length of the random data to be generated, in bytes.", "description": "Creates randomly generated data as a base64-encoded string.", "example_code": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nSTRING randomB64Bytes = Cryptography.CreateRandomBytesAsBase64String (numBytes)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nSTRING randomB64Bytes = Cryptography.CreateRandomBytesAsBase64String (numBytes)"}, {"name": "Cryptography.CreateRandomBytesAsBase64URLSTRING (NUMBER)", "return_type": "STRING", "return_desc": "Returns a base64-URL encoded string representing the specified number of randomly generated bytes.", "parameter_desc": "1. `NUMBER`: The length of the random data to generate.", "description": "Creates randomly generated data as a base64-URL formatted string.", "example_code": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nSTRING randomB64URLBytes = Cryptography.CreateRandomBytesAsBase64URLString (numBytes)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nSTRING randomB64URLBytes = Cryptography.CreateRandomBytesAsBase64URLString (numBytes)"}, {"name": "Cryptography.CreateRandomBytesAsSTRING (NUMBER)", "return_type": "STRING", "return_desc": "Returns a string containing the specified number of randomly generated bytes.", "parameter_desc": "1. `NUMBER`: The length of the random byte STRING to be generated.", "description": "Returns randomly generated data as a string.", "example_code": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nSTRING randomB64URLBytes = Cryptography.CreateRandomBytesAsString (numBytes)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the number of random bytes you want to generate\nNUMBER numBytes = 16\n\n// Generate the random bytes\nSTRING randomB64URLBytes = Cryptography.CreateRandomBytesAsString (numBytes)"}, {"name": "Cryptography.CreateRandomUUID ()", "return_type": "STRING", "return_desc": "Returns a randomly generated UUID as a string.", "parameter_desc": "*N/A*", "description": "Creates a random UUID.", "example_code": "// Generate random UUID\nSTRING uuid = Cryptography.CreateRandomUUID\n\n// Store UUID as a User-Defined Variable\nMWG.SetUserDefinedVar (\"GeneratedUUID\", uuid)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Generate random UUID\nSTRING uuid = Cryptography.CreateRandomUUID\n\n// Store UUID as a User-Defined Variable\nMWG.SetUserDefinedVar (\"GeneratedUUID\", uuid)"}, {"name": "Cryptography.DataRefDecrypt (STRING, DATAREF, STRING)", "return_type": "DATAREF", "return_desc": "Returns the decrypted data reference using the specified algorithm and key.", "parameter_desc": "1. `STRING`: The encryption algorithm. This can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".\n2. `DATAREF`: The encrypted data.\n3. `STRING`: The key used for decryption.", "description": "Decrypts data using the specified algorithm and encryption key. The algorithm can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".", "example_code": "// Define the encryption algorithm, encrypted data, and key\nSTRING algorithm = \"aes-256-cbc\"\nDATAREF encryptedData = ... // Assume this is your encrypted data reference\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Decrypt the data\nDATAREF decryptedData = Cryptography.DataRefDecrypt (algorithm, encryptedData, key)\n\n// The decryptedData object now contains the original, decrypted data", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the encryption algorithm, encrypted data, and key\nSTRING algorithm = \"aes-256-cbc\"\nDATAREF encryptedData = ... // Assume this is your encrypted data reference\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Decrypt the data\nDATAREF decryptedData = Cryptography.DataRefDecrypt (algorithm, encryptedData, key)\n\n// The decryptedData object now contains the original, decrypted data"}, {"name": "Cryptography.Decrypt (STRING, DATAREF, STRING)", "return_type": "STRING", "return_desc": "Returns the decrypted data using the specified algorithm and key.", "parameter_desc": "1. `STRING`: The encryption algorithm. This can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".\n2. `DATAREF`: The encrypted data.\n3. `STRING`: The key used for decryption.", "description": "Decrypts data using the specified algorithm and encryption key. The algorithm can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".", "example_code": "// Define the encryption algorithm, encrypted data, and key\nSTRING algorithm = \"aes-256-cbc\"\nDATAREF encryptedData = ... // Assume this is your encrypted data\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Decrypt the data\nSTRING decryptedString = Cryptography.DataRefDecrypt (algorithm, encryptedData, key)\n\n// The decryptedString object now contains the original, decrypted data", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the encryption algorithm, encrypted data, and key\nSTRING algorithm = \"aes-256-cbc\"\nDATAREF encryptedData = ... // Assume this is your encrypted data\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Decrypt the data\nSTRING decryptedString = Cryptography.DataRefDecrypt (algorithm, encryptedData, key)\n\n// The decryptedString object now contains the original, decrypted data"}, {"name": "Cryptography.Encrypt (STRING, DATAREF, STRING)", "return_type": "DATAREF", "return_desc": "Returns the encrypted data using the specified algorithm and key.", "parameter_desc": "1. `STRING`: The encryption algorithm. This can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".\n2. `DATAREF`: The data to encrypt.\n3. `STRING`: The key used for encryption.", "description": "Encrypts data using the specified algorithm and encryption key. The algorithm can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".", "example_code": "// Define the algorithm to use for encryption\nSTRING algorithm = \"aes-256-cbc\"\n\n// Define the data to encrypt\nDATAREF dataToEncrypt = ToDataRef(\"This is some sensitive data.\")\n\n// Define the password to use for encryption\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Encrypt the data\nDATAREF encryptedData = Cryptography.Encrypt(algorithm, dataToEncrypt, key)\n\n// encryptedData now contains the encrypted, sensitive data", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the algorithm to use for encryption\nSTRING algorithm = \"aes-256-cbc\"\n\n// Define the data to encrypt\nDATAREF dataToEncrypt = ToDataRef(\"This is some sensitive data.\")\n\n// Define the password to use for encryption\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Encrypt the data\nDATAREF encryptedData = Cryptography.Encrypt(algorithm, dataToEncrypt, key)\n\n// encryptedData now contains the encrypted, sensitive data"}, {"name": "Cryptography.Encrypt (STRING, STRING, STRING)", "return_type": "DATAREF", "return_desc": "Returns the encrypted data using the specified algorithm and key.", "parameter_desc": "1. `STRING`: The encryption algorithm. This can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".\n2. `STRING`: The string to encrypt.\n3. `STRING`: The key used for encryption.", "description": "Encrypts a string using the specified algorithm and encryption key. The algorithm can be any that OpenSSL supports, such as \"aes-128-cbc\" or \"aes-256-ecb\".", "example_code": "// Define the algorithm to use for encryption\nSTRING algorithm = \"aes-256-cbc\"\n\n// Define the string to encrypt\nSTRING stringToEncrypt = \"This is some sensitive data.\"\n\n// Define the password to use for encryption\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Encrypt the data\nDATAREF encryptedData = Cryptography.Encrypt(algorithm, stringToEncrypt, key)\n\n// encryptedData now contains the encrypted, sensitive data", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Define the algorithm to use for encryption\nSTRING algorithm = \"aes-256-cbc\"\n\n// Define the string to encrypt\nSTRING stringToEncrypt = \"This is some sensitive data.\"\n\n// Define the password to use for encryption\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Encrypt the data\nDATAREF encryptedData = Cryptography.Encrypt(algorithm, stringToEncrypt, key)\n\n// encryptedData now contains the encrypted, sensitive data"}, {"name": "Cryptography.Hash (STRING, DATAREF)", "return_type": "DATAREF", "return_desc": "Returns a reference to the hashed data generated using the specified algorithm.", "parameter_desc": "1. `STRING`: Specifies the hash algorithm. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".\n2. `DATAREF`: The data to be hashed.", "description": "Calculates the hash of data using a specified algorithm. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".", "example_code": "// Get downloaded content (HTTP response body)\nbodyData = MWG.Response.BodyData\n\n// Select hashing algorithm\nSTRING hashAlgorithm = \"SHA-256\"\n\n// Generate the hash\nDATAREF bodyHash = Cryptography.Hash(hashAlgorithm, bodyData)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get downloaded content (HTTP response body)\nbodyData = MWG.Response.BodyData\n\n// Select hashing algorithm\nSTRING hashAlgorithm = \"SHA-256\"\n\n// Generate the hash\nDATAREF bodyHash = Cryptography.Hash(hashAlgorithm, bodyData)"}, {"name": "Cryptography.Hash (STRING, STRING)", "return_type": "DATAREF", "return_desc": "Returns a reference to the hashed data generated using the specified algorithm.", "parameter_desc": "1. `STRING`: Specifies the hash algorithm. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".\n2. `STRING`: The string to be hashed.", "description": "Calculates the hash of a string using a specified algorithm. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".", "example_code": "// String to be hashed\nSTRING stringToHash = \"Hello, World!\"\n\n// Select hashing algorithm\nSTRING hashingAlgorithm = \"sha-256\"\n\n// Calculate the hash\nDATAREF hashedData = Cryptography.Hash(stringToHash, hashingAlgorithm)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// String to be hashed\nSTRING stringToHash = \"Hello, World!\"\n\n// Select hashing algorithm\nSTRING hashingAlgorithm = \"sha-256\"\n\n// Calculate the hash\nDATAREF hashedData = Cryptography.Hash(stringToHash, hashingAlgorithm)"}, {"name": "Cryptography.HMAC (STRING, STRING, DATAREF)", "return_type": "DATAREF", "return_desc": "Returns a reference to the HMAC value generated from the given data, algorithm, and key.", "parameter_desc": "1. `STRING`: The hashing algorithm to be used. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".\n2. `STRING`: The encryption key to be used.\n3. `DATAREF`: The data to be hashed.", "description": "Generates a hash-based message authentication code (HMAC) of data using a given algorithm and key. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".", "example_code": "// Capture the data to hash (e.g., HTTP response body)\nDATAREF data = MWG.Response.BodyData\n\n// Select encryption algorith and set encryption key\nSTRING algorithm = \"sha256\"\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Calculate HMAC data\nDATAREF hmacValue = Cryptography.HMAC(algorithm, key, data)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Capture the data to hash (e.g., HTTP response body)\nDATAREF data = MWG.Response.BodyData\n\n// Select encryption algorith and set encryption key\nSTRING algorithm = \"sha256\"\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Calculate HMAC data\nDATAREF hmacValue = Cryptography.HMAC(algorithm, key, data)"}, {"name": "Cryptography.HMAC (STRING, STRING, STRING)", "return_type": "DATAREF", "return_desc": "Returns a reference to data containing the HMAC of the input string using the specified algorithm and key.", "parameter_desc": "1. `STRING`: The hashing algorithm to be used. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".\n2. `STRING`: The encryption key to be used.\n3. `STRING`: The string to be hashed.", "description": "Generates a hash-based message authentication code (HMAC) of a string using a given algorithm and key. The algorithm can be any that OpenSSL supports such as \"md5\" or \"sha512\".", "example_code": "// Set message string to be hashed\nSTRING message = \"The quick brown fox jumps over the lazy dog\"\n\n// Select encryption algorith and set encryption key\nSTRING algorithm = \"sha-256\"\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Calculate HMAC data\nDATAREF hmacValue = Cryptography.HMAC(algorithm, key, data)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Set message string to be hashed\nSTRING message = \"The quick brown fox jumps over the lazy dog\"\n\n// Select encryption algorith and set encryption key\nSTRING algorithm = \"sha-256\"\nSTRING key = \"my_very_secret_encryption_key\"\n\n// Calculate HMAC data\nDATAREF hmacValue = Cryptography.HMAC(algorithm, key, data)"}, {"name": "DataLoaderCrypto.Decrypt (STRING)", "return_type": "STRING", "return_desc": "Returns decrypted sensitive data from a feature configuration.", "parameter_desc": "1. `STRING`: The encrypted sensitive data to be decrypted.", "description": "Decrypts sensitive data stored in a feature config.", "example_code": "STRING encryptedData = \"U2FsdGVkX1+5K1v8J8+5K1v8J8+5K1v8J8+5K1v8J8=\"\nSTRING decryptedData = DataLoaderCrypto.Decrypt(encryptedData)\n// Decrypted Data: \" + decryptedData", "reviewed": "FALSE", "need_info": "TRUE", "code_example": "STRING encryptedData = \"U2FsdGVkX1+5K1v8J8+5K1v8J8+5K1v8J8+5K1v8J8=\"\nSTRING decryptedData = DataLoaderCrypto.Decrypt(encryptedData)\n// Decrypted Data: \" + decryptedData"}, {"name": "DateTime.DateToSTRING (STRING)", "return_type": "STRING", "return_desc": "Returns current date in a string formatted according to the provided string argument.", "parameter_desc": "1. `STRING`: Specifies the desired date format of the output string.  Specify year as \"%YY\" or \"%YYYY\", month as \"%MM\" or \"%M\", and day as \"%DD\" or \"%D\".", "description": "Creates a string containing the current date formatted according to the provided string argument.", "example_code": "// Select desired date format\nSTRING format = \"%YYYY-%MM-%DD\"\n\n// Get current date in formatted string\nSTRING formattedDate = DateTime.DateToString (format)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Select desired date format\nSTRING format = \"%YYYY-%MM-%DD\"\n\n// Get current date in formatted string\nSTRING formattedDate = DateTime.DateToString (format)"}, {"name": "DateTime.DayOfMonth ()", "return_type": "NUMBER", "return_desc": "Returns the numerical day of the current month.", "parameter_desc": "*N/A*", "description": "Gets the day of current month.", "example_code": "// Get current day of the month\nNUMBER currentDay = DateTime.DayOfMonth\n\n// Check if this is the first week of the month\nBOOLEAN firstWeek\nIF currentDay < 8 THEN {\n    firstWeek = TRUE\n} ELSE {\n    firstWeek = FALSE\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get current day of the month\nNUMBER currentDay = DateTime.DayOfMonth\n\n// Check if this is the first week of the month\nBOOLEAN firstWeek\nIF currentDay < 8 THEN {\n    firstWeek = TRUE\n} ELSE {\n    firstWeek = FALSE\n}"}, {"name": "DateTime.DayOfWeek ()", "return_type": "NUMBER", "return_desc": "Returns a numeric value (1-7) representing the current day of the week where 1 represents Monday and 7 is Sunday", "parameter_desc": "*N/A*", "description": "Gets the current day of the week as a number.", "example_code": "// Get the day of the week as a number\nNUMBER dayOfWeek = DateTime.DayOfWeek\n\n// Check whether it's a weekday\nBOOLEAN isWeekDay\nIF dayOfWeek < 6 THEN {\n    isWeekDay = TRUE\n} ELSE {\n    isWeekDay = FALSE\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get the day of the week as a number\nNUMBER dayOfWeek = DateTime.DayOfWeek\n\n// Check whether it's a weekday\nBOOLEAN isWeekDay\nIF dayOfWeek < 6 THEN {\n    isWeekDay = TRUE\n} ELSE {\n    isWeekDay = FALSE\n}"}, {"name": "DateTime.DayOfYear ()", "return_type": "NUMBER", "return_desc": "Returns the current day of the year as a number (1-365, or 1-366 in leap year).", "parameter_desc": "*N/A*", "description": "Gets the current day of the year.", "example_code": "// Get the current day of the year\nNUMBER currentDay = DateTime.DayOfYear\n\n// Determine the current week of the year\nNUMBER currentWeek = Math.Div (currentDay, 7)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get the current day of the year\nNUMBER currentDay = DateTime.DayOfYear\n\n// Determine the current week of the year\nNUMBER currentWeek = Math.Div (currentDay, 7)"}, {"name": "DateTime.GetLocalTimezoneOffset ()", "return_type": "NUMBER", "return_desc": "Returns the offset (in seconds) of the local time zone of the machine running this code.", "parameter_desc": "*N/A*", "description": "Gets the offset (in seconds) of the local time zone of the machine running this code.", "example_code": "// Get the local timezone offset in seconds\nNUMBER localOffset = DateTime.GetLocalTimezoneOffset()\n\n// Check if GMT time\nBOOLEAN isGMT\nIF localOffset == 0 THEN {\n    isGMT = TRUE\n} ELSE {\n    isGMT = FALSE\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get the local timezone offset in seconds\nNUMBER localOffset = DateTime.GetLocalTimezoneOffset()\n\n// Check if GMT time\nBOOLEAN isGMT\nIF localOffset == 0 THEN {\n    isGMT = TRUE\n} ELSE {\n    isGMT = FALSE\n}"}, {"name": "DateTime.Hour ()", "return_type": "NUMBER", "return_desc": "Returns the current hour from the clock as a numerical value (0-23) in 24-hour UTC time.", "parameter_desc": "*N/A*", "description": "Gets the current hour from the clock in 24-hour UTC time.", "example_code": "// Get current hour\nNUMBER currentHour = DateTime.Hour\n\n// Check if lunch time (12:00-1:00pm) in GMT time zone\nBOOLEAN isLunchGMT\nIF currentHour == 12 THEN {\n    isLunchGMT = TRUE\n} ELSE {\n    isLunchGMT = FALSE\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get current hour\nNUMBER currentHour = DateTime.Hour\n\n// Check if lunch time (12:00-1:00pm) in GMT time zone\nBOOLEAN isLunchGMT\nIF currentHour == 12 THEN {\n    isLunchGMT = TRUE\n} ELSE {\n    isLunchGMT = FALSE\n}"}, {"name": "DateTime.IsInRangeISO (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current date and time is within the specified range.", "parameter_desc": "1. `STRING`: Start time in ISO format.\n2. `STRING`: End time in ISO format.", "description": "Checks whether the current date and time (in local time zone defined by timezoneOffset stored in the context) is in the given range, specified in ISO format.", "example_code": "STRING startTime = \"2023-10-01T00:00:00Z\"\nSTRING endTime = \"2023-10-31T23:59:59Z\"\n\nIF DateTime.IsInRangeISO(startTime, endTime) THEN {\n    // Current date and time is within the specified range.\n    MWG.Allow(\"TimeRangeCheck\")\n} ELSE {\n    // Current date and time is outside the specified range.\n    MWG.Block(\"Access outside allowed time range.\")\n}", "reviewed": "FALSE", "need_info": "TRUE", "code_example": "STRING startTime = \"2023-10-01T00:00:00Z\"\nSTRING endTime = \"2023-10-31T23:59:59Z\"\n\nIF DateTime.IsInRangeISO(startTime, endTime) THEN {\n    // Current date and time is within the specified range.\n    MWG.Allow(\"TimeRangeCheck\")\n} ELSE {\n    // Current date and time is outside the specified range.\n    MWG.Block(\"Access outside allowed time range.\")\n}"}, {"name": "DateTime.Minute ()", "return_type": "NUMBER", "return_desc": "Returns the current minute from the clock as a number.", "parameter_desc": "*N/A*", "description": "Gets the current minute from the clock.", "example_code": "// Get current minute from the clock\nNUMBER currentMinute = DateTime.Minute\n\n// Check if it's the top half of the hour\nBOOLEAN isTopHalfHour\nIF currentMinute < 30 THEN {\n    isTopHalfHour = TRUE\n} ELSE {\n    isTopHalfHour = FALSE\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get current minute from the clock\nNUMBER currentMinute = DateTime.Minute\n\n// Check if it's the top half of the hour\nBOOLEAN isTopHalfHour\nIF currentMinute < 30 THEN {\n    isTopHalfHour = TRUE\n} ELSE {\n    isTopHalfHour = FALSE\n}"}, {"name": "DateTime.MonthNumber ()", "return_type": "NUMBER", "return_desc": "Returns the numeric value representing the current month where January=1 and December=12.", "parameter_desc": "*N/A*", "description": "Gets the number of the current month.", "example_code": "// Get current month number\nNUMBER currentMonth = DateTime.MonthNumber\n\n// Check whether it's December\nBOOLEAN isDecember\nIF currentMonth == 12 THEN {\n    isDecember = TRUE\n} ELSE {\n    isDecember = FALSE\n}", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get current month number\nNUMBER currentMonth = DateTime.MonthNumber\n\n// Check whether it's December\nBOOLEAN isDecember\nIF currentMonth == 12 THEN {\n    isDecember = TRUE\n} ELSE {\n    isDecember = FALSE\n}"}, {"name": "DateTime.Second ()", "return_type": "NUMBER", "return_desc": "Returns the current second from the clock as a number (0-59).", "parameter_desc": "*N/A*", "description": "Gets the current second from the clock.", "example_code": "NUMBER currentSecond = DateTime.Second", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "NUMBER currentSecond = DateTime.Second"}, {"name": "DateTime.TimeIsInRange (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns if the current time is in the given range (UTC).", "parameter_desc": "1. `STRING`: Range to check.", "description": "Returns if the current time is in the given range (UTC).", "example_code": "STRING timeRange = \"09:00-17:00\"  // Time range in HH:MM-HH:MM format (UTC)\n\nIF DateTime.TimeIsInRange(timeRange) THEN {\n    // Current time is within the specified range.\n} ELSE {\n    // Current time is outside the specified range.\n}", "reviewed": "FALSE", "need_info": "TRUE", "code_example": "STRING timeRange = \"09:00-17:00\"  // Time range in HH:MM-HH:MM format (UTC)\n\nIF DateTime.TimeIsInRange(timeRange) THEN {\n    // Current time is within the specified range.\n} ELSE {\n    // Current time is outside the specified range.\n}"}, {"name": "DateTime.TimestampToGMTSTRING (NUMBER)", "return_type": "STRING", "return_desc": "Returns string representation of the specified timestamp in the following format: Thu, 1 September 2012 22:06:03 GMT.", "parameter_desc": "1. `NUMBER`: The timestamp to convert which is evaluated as Unix epoch time.", "description": "Generates a string representation of a given timestamp in the following format: Thu, 1 September 2012 22:06:03 GMT.", "example_code": "// Example timestamp (Unix epoch time)\nNUMBER timestamp = 1\n\n// Convert the timestamp to a GMT string\nSTRING gmtString = DateTime.TimestampToGMTString (timestamp)\n// gmtString now equals \"Thu, 1 January 1970 00:00:01 GMT\"\n\n// Now get current time\ntimestamp = DateTime.ToNumber\n\n// Convert current time to a GMT string\ngmtString = DateTiem.TimestampToGMTString (timestamp)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Example timestamp (Unix epoch time)\nNUMBER timestamp = 1\n\n// Convert the timestamp to a GMT string\nSTRING gmtString = DateTime.TimestampToGMTString (timestamp)\n// gmtString now equals \"Thu, 1 January 1970 00:00:01 GMT\"\n\n// Now get current time\ntimestamp = DateTime.ToNumber\n\n// Convert current time to a GMT string\ngmtString = DateTiem.TimestampToGMTString (timestamp)"}, {"name": "DateTime.TimestampToISOSTRING (NUMBER)", "return_type": "STRING", "return_desc": "Returns string representation of the specified timestamp in the following format: 2010-03-22 22:45:12", "parameter_desc": "1. `NUMBER`: The timestamp to convert which is evaluated as Unix epoch time.", "description": "Generates a string representation of a given timestamp in the following format: 2010-03-22 22:45:12", "example_code": "// Example timestamp (Unix epoch time)\nNUMBER timestamp = 1\n\n// Convert the timestamp to a ISO string\nSTRING gmtString = DateTime.TimestampToISOString (timestamp)\n// gmtString now equals \"1970-01-01 00:00:01\"\n\n// Now get current time\ntimestamp = DateTime.ToNumber\n\n// Convert current time to a ISO string\ngmtString = DateTiem.TimestampToISOString (timestamp)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Example timestamp (Unix epoch time)\nNUMBER timestamp = 1\n\n// Convert the timestamp to a ISO string\nSTRING gmtString = DateTime.TimestampToISOString (timestamp)\n// gmtString now equals \"1970-01-01 00:00:01\"\n\n// Now get current time\ntimestamp = DateTime.ToNumber\n\n// Convert current time to a ISO string\ngmtString = DateTiem.TimestampToISOString (timestamp)"}, {"name": "DateTime.TimeToSTRING (STRING)", "return_type": "STRING", "return_desc": "Returns current time in a string formatted according to the provided string argument.", "parameter_desc": "1. `STRING`: Specifies the desired date format of the output string.  Specify hour as \"%hh\" or \"%h\", minute as \"%mm\" or \"%m\", and second as \"%ss\" or \"%s\".", "description": "Creates a string containing the current time formatted according to the provided string argument.", "example_code": "// Select desired time format\nSTRING format = \"%h:%mm:%ss\"\n\n// Get current time in formatted string\nSTRING formattedTime = DateTime.TimeToString (format)", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Select desired time format\nSTRING format = \"%h:%mm:%ss\"\n\n// Get current time in formatted string\nSTRING formattedTime = DateTime.TimeToString (format)"}, {"name": "DateTime.ToGMTSTRING ()", "return_type": "STRING", "return_desc": "Returns the current date and time as a string formatted in GMT. (e.g., \"Fri, 28 March 2025 17:46:25 GMT\")", "parameter_desc": "*N/A*", "description": "Gets the current time and date as GMT formatted string. (e.g., \"Fri, 28 March 2025 17:46:25 GMT\")", "example_code": "// Get the current date and time as a GMT-formatted string\nSTRING gmtString = DateTime.ToGMTString\n// gmtString now contains the current time formatted like this: \"Fri, 28 March 2025 17:46:25 GMT\"", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get the current date and time as a GMT-formatted string\nSTRING gmtString = DateTime.ToGMTString\n// gmtString now contains the current time formatted like this: \"Fri, 28 March 2025 17:46:25 GMT\""}, {"name": "DateTime.ToISOSTRING ()", "return_type": "STRING", "return_desc": "Returns the current date and time as a string formatted in GMT. (e.g., \"2025-03-28 17:48:09\")", "parameter_desc": "*N/A*", "description": "Gets the current time and date as GMT formatted string. (e.g., \"2025-03-28 17:48:09\")", "example_code": "// Get the current date and time as an ISO-formatted string\nSTRING isoString = DateTime.ToISOString\n// isoString now contains the current time formatted like this: \"2025-03-28 17:48:09\"", "reviewed": "TRUE", "need_info": "FALSE", "code_example": "// Get the current date and time as an ISO-formatted string\nSTRING isoString = DateTime.ToISOString\n// isoString now contains the current time formatted like this: \"2025-03-28 17:48:09\""}, {"name": "DateTime.ToISOSTRINGWithMs ()", "return_type": "STRING", "return_desc": "Returns a string representation of current date and time in ISO format including milliseconds in GMT time zone, e.g. 2010-03-22 22:45:12.123.", "parameter_desc": "*N/A*", "description": "Returns a string representation of current date and time in ISO format including milliseconds in GMT time zone, e.g. 2010-03-22 22:45:12.123.", "example_code": "STRING currentDateTime = DateTime.ToISOStringWithMs()\n// currentDateTime", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING currentDateTime = DateTime.ToISOStringWithMs()\n// currentDateTime"}, {"name": "DateTime.ToNumber ()", "return_type": "NUMBER", "return_desc": "Returns the Unix epoch time in seconds.", "parameter_desc": "*N/A*", "description": "Returns Unix-epoch time in seconds.", "example_code": "NUMBER currentMonth = DateTime.MonthNumber()\n// The current month number is: currentMonth\n\nIF currentMonth == 12 THEN {\n    // It's December!\n} ELSE {\n    // It's not December.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER currentMonth = DateTime.MonthNumber()\n// The current month number is: currentMonth\n\nIF currentMonth == 12 THEN {\n    // It's December!\n} ELSE {\n    // It's not December.\n}"}, {"name": "DateTime.ToSTRING (STRING)", "return_type": "STRING", "return_desc": "Returns the current date and time as a formatted string.", "parameter_desc": "1. `STRING`: The format in which to return the current date and time.", "description": "Returns current date and time as formatted string.", "example_code": "STRING currentDateTime = DateTime.ToString(\"yyyy-MM-dd HH:mm:ss\")\n// Output currentDateTime to the console", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING currentDateTime = DateTime.ToString(\"yyyy-MM-dd HH:mm:ss\")\n// Output currentDateTime to the console"}, {"name": "DateTime.ToWebReporterSTRING ()", "return_type": "STRING", "return_desc": "Returns the current date and time as a GMT-formatted string.", "parameter_desc": "*N/A*", "description": "Returns current time and date as GMT formatted string.", "example_code": "// Get the current date and time\nDateTime currentDateTime = DateTime.Now()\n\n// Convert the DateTime object to a web reporter string\nSTRING webReporterString = currentDateTime.ToWebReporterString()\n\n// Log the web reporter string\n// Current DateTime in Web Reporter format: \" + webReporterString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the current date and time\nDateTime currentDateTime = DateTime.Now()\n\n// Convert the DateTime object to a web reporter string\nSTRING webReporterString = currentDateTime.ToWebReporterString()\n\n// Log the web reporter string\n// Current DateTime in Web Reporter format: \" + webReporterString"}, {"name": "DateTime.Year ()", "return_type": "NUMBER", "return_desc": "Returns the current year as a number.", "parameter_desc": "*N/A*", "description": "Returns current year.", "example_code": "NUMBER currentYear = DateTime.Year()\n// The current year is: currentYear", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER currentYear = DateTime.Year()\n// The current year is: currentYear"}, {"name": "DateTime.YearTwoDigits ()", "return_type": "STRING", "return_desc": "Returns the last two digits of the current year as a string.", "parameter_desc": "*N/A*", "description": "Returns the last two digits of the current year.", "example_code": "STRING yearTwoDigits = DateTime.YearTwoDigits()\n// The last two digits of the current year are: yearTwoDigits", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING yearTwoDigits = DateTime.YearTwoDigits()\n// The last two digits of the current year are: yearTwoDigits"}, {"name": "DLP.DLPServiceCallCount (DLP.Classifier)", "return_type": "NUMBER", "return_desc": "Returns the number of times the DLP service was invoked.", "parameter_desc": "1. `DLP.Classifier`: Specifies the classifier for which you want to count DLP service calls.", "description": "Returns how often the DLP service was called.", "example_code": "DLP.Classifier classifier = // Initialize your classifier here\nNUMBER callCount = DLP.DLPServiceCallCount(classifier)\n\n// DLP Service Call Count: \" + callCount\n\nIF callCount > 10 THEN {\n    // DLP Service has been called more than 10 times.\n    // Additional logic can be added here\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "DLP.Classifier classifier = // Initialize your classifier here\nNUMBER callCount = DLP.DLPServiceCallCount(classifier)\n\n// DLP Service Call Count: \" + callCount\n\nIF callCount > 10 THEN {\n    // DLP Service has been called more than 10 times.\n    // Additional logic can be added here\n}"}, {"name": "DLP.HasAtLeast (DLP.IncidentCollector, NUMBER)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the severity level of the incident is equal to or higher than the specified `NUMBER`.", "parameter_desc": "1. `DLP.IncidentCollector`: Collector of incidents.\n2. `NUMBER`: Severity level to test against.", "description": "Tests if severity is at least of given level.", "example_code": "DLP.IncidentCollector collector\nNUMBER threshold = 5\n\n// Start a DLP rule\nDLP.StartRule(collector, \"Check for incidents\")\n\n// Check if the collector has at least the specified number of incidents\nIF DLP.HasAtLeast(collector, threshold) THEN {\n    // The DLP incident collector has at least threshold incidents.\n    // Take some action, for example, block the connection\n    MWG.Block(\"Too many DLP incidents detected\")\n} ELSE {\n    // The DLP incident collector has fewer than threshold incidents.\n    // Allow the connection\n    MWG.Allow(\"DLP incident count is within acceptable limits\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "DLP.IncidentCollector collector\nNUMBER threshold = 5\n\n// Start a DLP rule\nDLP.StartRule(collector, \"Check for incidents\")\n\n// Check if the collector has at least the specified number of incidents\nIF DLP.HasAtLeast(collector, threshold) THEN {\n    // The DLP incident collector has at least threshold incidents.\n    // Take some action, for example, block the connection\n    MWG.Block(\"Too many DLP incidents detected\")\n} ELSE {\n    // The DLP incident collector has fewer than threshold incidents.\n    // Allow the connection\n    MWG.Allow(\"DLP incident count is within acceptable limits\")\n}"}, {"name": "DLP.Match (DLP.Classifier, DLP.Classification)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the object matches the specified classification, otherwise it returns`FALSE`", "parameter_desc": "1. `DLP.Classifier`: The predefined criteria or model object for classification.\n2. `DLP.Classification`: The object or entity to be tested against the classifier.", "description": "Tests if object matches a given classification.", "example_code": "DLP.Classifier classifier = [PredefinedClassifier]\nDLP.Classification classification = [ObjectToClassify]\n\nIF DLP.Match(classifier, classification) THEN {\n    // The object matches the specified classification.\n    // Take some action, e.g., block the request\n    MWG.Block(\"Content matches restricted classification.\")\n} ELSE {\n    // The object does not match the specified classification.\n    // Allow the request to proceed\n    MWG.Allow(\"Content does not match restricted classification.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "DLP.Classifier classifier = [PredefinedClassifier]\nDLP.Classification classification = [ObjectToClassify]\n\nIF DLP.Match(classifier, classification) THEN {\n    // The object matches the specified classification.\n    // Take some action, e.g., block the request\n    MWG.Block(\"Content matches restricted classification.\")\n} ELSE {\n    // The object does not match the specified classification.\n    // Allow the request to proceed\n    MWG.Allow(\"Content does not match restricted classification.\")\n}"}, {"name": "DLP.SeverityCritical ()", "return_type": "NUMBER", "return_desc": "Returns a number representing the severity level of a critical incident.", "parameter_desc": "*N/A*", "description": "Constant: Critical incident severity.", "example_code": "NUMBER severityLevel = DLP.SeverityCritical()\n\nIF severityLevel > 5 THEN {\n    // Incident severity is critical.\n    MWG.Block(\"Access blocked due to critical incident severity.\")\n} ELSE {\n    // Incident severity is not critical.\n    MWG.Allow(\"Incident severity is acceptable.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER severityLevel = DLP.SeverityCritical()\n\nIF severityLevel > 5 THEN {\n    // Incident severity is critical.\n    MWG.Block(\"Access blocked due to critical incident severity.\")\n} ELSE {\n    // Incident severity is not critical.\n    MWG.Allow(\"Incident severity is acceptable.\")\n}"}, {"name": "DLP.SeverityInfo ()", "return_type": "NUMBER", "return_desc": "Returns a numeric value representing the severity level of an informational incident.", "parameter_desc": "*N/A*", "description": "Constant: Info incident severity.", "example_code": "NUMBER severityLevel = DLP.SeverityInfo()\n// The severity level of an informational incident is: \" + severityLevel\n\nIF severityLevel > 0 THEN {\n    // This is an informational incident with a non-zero severity level.\n} ELSE {\n    // This is an informational incident with a zero severity level.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER severityLevel = DLP.SeverityInfo()\n// The severity level of an informational incident is: \" + severityLevel\n\nIF severityLevel > 0 THEN {\n    // This is an informational incident with a non-zero severity level.\n} ELSE {\n    // This is an informational incident with a zero severity level.\n}"}, {"name": "DLP.SeverityMajor ()", "return_type": "NUMBER", "return_desc": "Returns a constant numeric value representing the severity level of a major incident.", "parameter_desc": "*N/A*", "description": "Defines major incident severity.", "example_code": "NUMBER majorSeverity = DLP.SeverityMajor()\n\n// Simulate getting the current incident severity (this part is hypothetical)\nNUMBER currentSeverity = GetCurrentIncidentSeverity() // Assume this function exists and returns the current incident severity\n\nIF currentSeverity == majorSeverity THEN {\n    // \"Incident severity is major.\"\n    // Take appropriate action for major incidents\n    MWG.Block(\"Access blocked due to major incident severity.\")\n} ELSE {\n    // \"Incident severity is not major.\"\n    // Take appropriate action for non-major incidents\n    MWG.Allow(\"Incident severity is not major.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER majorSeverity = DLP.SeverityMajor()\n\n// Simulate getting the current incident severity (this part is hypothetical)\nNUMBER currentSeverity = GetCurrentIncidentSeverity() // Assume this function exists and returns the current incident severity\n\nIF currentSeverity == majorSeverity THEN {\n    // \"Incident severity is major.\"\n    // Take appropriate action for major incidents\n    MWG.Block(\"Access blocked due to major incident severity.\")\n} ELSE {\n    // \"Incident severity is not major.\"\n    // Take appropriate action for non-major incidents\n    MWG.Allow(\"Incident severity is not major.\")\n}"}, {"name": "DLP.SeverityMinor ()", "return_type": "NUMBER", "return_desc": "Returns a constant numerical value representing the severity level of a minor incident.", "parameter_desc": "*N/A*", "description": "Defines minor incident severity.", "example_code": "NUMBER severityLevel = DLP.SeverityMajor()\n\nIF severityLevel > 5 THEN {\n    // Major severity level detected: \n    MWG.Block(\"Access blocked due to major severity level\")\n} ELSE {\n    // Severity level is acceptable: \n    MWG.Allow(\"Severity level check passed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER severityLevel = DLP.SeverityMajor()\n\nIF severityLevel > 5 THEN {\n    // Major severity level detected: \n    MWG.Block(\"Access blocked due to major severity level\")\n} ELSE {\n    // Severity level is acceptable: \n    MWG.Allow(\"Severity level check passed\")\n}"}, {"name": "DLP.SeverityWarning ()", "return_type": "NUMBER", "return_desc": "Returns the numeric value representing the severity level of a warning incident.", "parameter_desc": "*N/A*", "description": "Constant: Warning incident severity.", "example_code": "NUMBER severity = DLP.SeverityWarning()\n\nIF severity > 5 THEN {\n    // High severity warning detected: \n    MWG.Block(\"Access blocked due to high severity warning.\")\n} ELSE {\n    // Low severity warning detected: \n    MWG.Allow(\"Low severity warning, access allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER severity = DLP.SeverityWarning()\n\nIF severity > 5 THEN {\n    // High severity warning detected: \n    MWG.Block(\"Access blocked due to high severity warning.\")\n} ELSE {\n    // Low severity warning detected: \n    MWG.Allow(\"Low severity warning, access allowed.\")\n}"}, {"name": "DLP.StartRoutine (DLP.Classifier, STRING)", "return_type": "DLP.IncidentCollector", "return_desc": "The function DLP.StartRoutine returns a new DLP.IncidentCollector object.", "parameter_desc": "1. `DLP.Classifier`: Specifies the data classification method to use.\n2. `STRING`: The identifier or name for the routine.", "description": "Creates a new DLP incident collector object.", "example_code": "// Define a DLP.Classifier object\nDLP.Classifier classifier = DLP.Classifier(\"SensitiveData\");\n\n// Start a DLP routine with the classifier and a name for the routine\nDLP.IncidentCollector incidentCollector = DLP.StartRoutine(classifier, \"ExampleRoutine\");\n\n// Perform additional actions with the incidentCollector if needed\n// For example, you might want to log the incident or take some action based on the classification\n// DLP routine started with classifier: \" + classifier + \" and routine name: ExampleRoutine", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a DLP.Classifier object\nDLP.Classifier classifier = DLP.Classifier(\"SensitiveData\");\n\n// Start a DLP routine with the classifier and a name for the routine\nDLP.IncidentCollector incidentCollector = DLP.StartRoutine(classifier, \"ExampleRoutine\");\n\n// Perform additional actions with the incidentCollector if needed\n// For example, you might want to log the incident or take some action based on the classification\n// DLP routine started with classifier: \" + classifier + \" and routine name: ExampleRoutine"}, {"name": "Encoding.Base64Decode (STRING)", "return_type": "STRING", "return_desc": "Returns the original string that was base64 encoded.", "parameter_desc": "1. `STRING`: The base64 encoded input STRING to be decoded.", "description": "Decodes a base64 encoded string.", "example_code": "STRING encodedString = \"SGVsbG8gV29ybGQh\"  // This is \"Hello World!\" in base64\nSTRING decodedString = Encoding.Base64Decode(encodedString)\n// Decoded String: \" + decodedString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING encodedString = \"SGVsbG8gV29ybGQh\"  // This is \"Hello World!\" in base64\nSTRING decodedString = Encoding.Base64Decode(encodedString)\n// Decoded String: \" + decodedString"}, {"name": "Encoding.Base64Encode (DATAREF)", "return_type": "STRING", "return_desc": "Returns the base64-encoded representation of the input data.", "parameter_desc": "1. `DATAREF`: The data to be encoded in base64 format.", "description": "Encodes data base64.", "example_code": "STRING data = \"Hello, World!\"\nSTRING encodedData = Encoding.Base64URLEncode(data)\n// Encoded Data: \" + encodedData", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING data = \"Hello, World!\"\nSTRING encodedData = Encoding.Base64URLEncode(data)\n// Encoded Data: \" + encodedData"}, {"name": "Encoding.Base64Encode (STRING)", "return_type": "STRING", "return_desc": "Returns the Base64-encoded version of the input string.", "parameter_desc": "1. `STRING`: The input text to be encoded in base64 format.", "description": "Encodes a string base64.", "example_code": "STRING originalText = \"Hello, World!\"\nSTRING encodedText = Encoding.Base64Encode(originalText)\n// Original Text: Hello, World!\n// Encoded Text: SGVsbG8sIFdvcmxkIQ==", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalText = \"Hello, World!\"\nSTRING encodedText = Encoding.Base64Encode(originalText)\n// Original Text: Hello, World!\n// Encoded Text: SGVsbG8sIFdvcmxkIQ=="}, {"name": "Encoding.Base64URLDecode (STRING)", "return_type": "STRING", "return_desc": "Returns the decoded string from a base64-URL-encoded input.", "parameter_desc": "1. `STRING`: The base64-URL-encoded STRING to be decoded.", "description": "Decodes a base64-URL-encoded string.", "example_code": "STRING encodedString = \"SGVsbG8gV29ybGQh\"  // This is \"Hello World!\" in base64-URL-encoded form\nSTRING decodedString = Encoding.Base64URLDecode(encodedString)\n// Decoded String: \" + decodedString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING encodedString = \"SGVsbG8gV29ybGQh\"  // This is \"Hello World!\" in base64-URL-encoded form\nSTRING decodedString = Encoding.Base64URLDecode(encodedString)\n// Decoded String: \" + decodedString"}, {"name": "Encoding.Base64URLEncode (DATAREF)", "return_type": "STRING", "return_desc": "Returns a base64-encoded string suitable for use in URLs.", "parameter_desc": "1. `DATAREF`: The data to be encoded into base64 URL-safe format.", "description": "Encodes data into base64 format that can be used as a URL parameter.", "example_code": "STRING data = \"Hello, World!\"\nSTRING encodedData = Encoding.Base64URLEncode(data)\n// Encoded Data: \" + encodedData", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING data = \"Hello, World!\"\nSTRING encodedData = Encoding.Base64URLEncode(data)\n// Encoded Data: \" + encodedData"}, {"name": "Encoding.Base64URLEncode (STRING)", "return_type": "STRING", "return_desc": "Returns the input string encoded in a Base64 format suitable for use in URLs.", "parameter_desc": "1. `STRING`: The input STRING to be encoded in base64 URL format.", "description": "Encodes a string into base64 format that can be used as a URL parameter.", "example_code": "STRING originalString = \"Hello, World!\"\nSTRING encodedString = Encoding.Base64URLEncode(originalString)\n// Original String: Hello, World!\n// Encoded String: SGVsbG8sIFdvcmxkIQ==", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!\"\nSTRING encodedString = Encoding.Base64URLEncode(originalString)\n// Original String: Hello, World!\n// Encoded String: SGVsbG8sIFdvcmxkIQ=="}, {"name": "Encoding.DataRefBase64Decode (STRING)", "return_type": "DATAREF", "return_desc": "Returns a `DATAREF` containing the binary data decoded from the provided base64 encoded `STRING`.", "parameter_desc": "1. `STRING`: The base64 encoded data to be decoded.", "description": "Decodes base64 encoded data.", "example_code": "STRING encodedString = \"SGVsbG8gV29ybGQh\"  // This is \"Hello World!\" in Base64\nSTRING decodedString = Encoding.DataRefBase64Decode(encodedString)\n\n// Encoded String: \" + encodedString\n// Decoded String: \" + decodedString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING encodedString = \"SGVsbG8gV29ybGQh\"  // This is \"Hello World!\" in Base64\nSTRING decodedString = Encoding.DataRefBase64Decode(encodedString)\n\n// Encoded String: \" + encodedString\n// Decoded String: \" + decodedString"}, {"name": "Encoding.DataRefBase64URLDecode (STRING)", "return_type": "DATAREF", "return_desc": "Returns a dataref that contains the data decoded from a base64-URL-encoded string.", "parameter_desc": "1. `STRING`: The base64-URL-encoded data to be decoded.", "description": "Decodes base64-URL-encoded data.", "example_code": "STRING encodedString = \"U29tZUJhc2U2NFVSTEVuY29kZWRTdHJpbmc\"  // Example Base64URL encoded string\nSTRING decodedString = Encoding.DataRefBase64URLDecode(encodedString)\n\n// Encoded String: \" + encodedString\n// Decoded String: \" + decodedString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING encodedString = \"U29tZUJhc2U2NFVSTEVuY29kZWRTdHJpbmc\"  // Example Base64URL encoded string\nSTRING decodedString = Encoding.DataRefBase64URLDecode(encodedString)\n\n// Encoded String: \" + encodedString\n// Decoded String: \" + decodedString"}, {"name": "Encoding.DataRefHexDecode (STRING)", "return_type": "DATAREF", "return_desc": "Returns a dataref value by decoding the provided hex string.", "parameter_desc": "1. `STRING`: The hex-encoded input to be decoded.", "description": "Decodes hex digits.", "example_code": "STRING hexEncodedString = \"48656c6c6f20576f726c64\"  // This is \"Hello World\" in hex\nSTRING decodedString = Encoding.DataRefHexDecode(hexEncodedString)\n// Decoded String: \" + decodedString\n\nIn this example:\n- We initialize a `STRING` variable `hexEncodedString` with a hexadecimal-encoded string.\n- We use the `Encoding.DataRefHexDecode` function to decode the hexadecimal string and store the result in the `decodedString` variable.\n- Finally, we print the decoded string to the console using the `DEBUG()` function.\n\nWhen this routine runs, it will output:\n\nDecoded String: Hello World", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING hexEncodedString = \"48656c6c6f20576f726c64\"  // This is \"Hello World\" in hex\nSTRING decodedString = Encoding.DataRefHexDecode(hexEncodedString)\n// Decoded String: \" + decodedString\n\nIn this example:\n- We initialize a `STRING` variable `hexEncodedString` with a hexadecimal-encoded string.\n- We use the `Encoding.DataRefHexDecode` function to decode the hexadecimal string and store the result in the `decodedString` variable.\n- Finally, we print the decoded string to the console using the `DEBUG()` function.\n\nWhen this routine runs, it will output:\n\nDecoded String: Hello World"}, {"name": "Encoding.HexDecode (STRING)", "return_type": "STRING", "return_desc": "Returns a string decoded from the input hex string.", "parameter_desc": "1. `STRING`: The hex-encoded STRING to be decoded.", "description": "Decodes hex digits.", "example_code": "STRING hexString = \"48656c6c6f20576f726c64\"  // Hex-encoded string for \"Hello World\"\nSTRING decodedString = Encoding.HexDecode(hexString)\n// Decoded String: \" + decodedString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING hexString = \"48656c6c6f20576f726c64\"  // Hex-encoded string for \"Hello World\"\nSTRING decodedString = Encoding.HexDecode(hexString)\n// Decoded String: \" + decodedString"}, {"name": "Encoding.HexEncode (DATAREF)", "return_type": "STRING", "return_desc": "Returns a string of hexadecimal digits representing the encoded input data.", "parameter_desc": "1. `DATAREF`: The data reference to be encoded into hex digits.", "description": "Encodes data into hex digits.", "example_code": "// Assume we have a data reference, for example, a string\nSTRING data = \"Hello, MOWGLI!\"\n\n// Encode the data into hexadecimal format\nSTRING hexEncodedData = Encoding.HexEncode(data)\n\n// Hex Encoded Data: \n// + hexEncodedData", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a data reference, for example, a string\nSTRING data = \"Hello, MOWGLI!\"\n\n// Encode the data into hexadecimal format\nSTRING hexEncodedData = Encoding.HexEncode(data)\n\n// Hex Encoded Data: \n// + hexEncodedData"}, {"name": "Encoding.HexEncode (STRING)", "return_type": "STRING", "return_desc": "Returns the hexadecimal representation of the input string.", "parameter_desc": "1. `STRING`: The text input to be encoded into hexadecimal digits.", "description": "Encodes a string into hex digits.", "example_code": "STRING originalString = \"Hello, MOWGLI!\"\nSTRING hexEncodedString = Encoding.HexEncode(originalString)\n// Original String: Hello, MOWGLI!\n// Hex Encoded String: Hex encoded version of the original string", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, MOWGLI!\"\nSTRING hexEncodedString = Encoding.HexEncode(originalString)\n// Original String: Hello, MOWGLI!\n// Hex Encoded String: Hex encoded version of the original string"}, {"name": "Encoding.URLDecode (STRING)", "return_type": "STRING", "return_desc": "Returns a string that is the decoded version of the given URL-encoded string.", "parameter_desc": "1. `STRING`: The URL-encoded STRING that needs to be decoded.", "description": "Decodes a URL encoding and returns the resulting string.", "example_code": "STRING encodedURL = \"https%3A%2F%2Fwww.example.com%2Fsearch%3Fq%3Dtest%26lang%3Den\"\nSTRING decodedURL = Encoding.URLDecode(encodedURL)\n// Decoded URL: \" + decodedURL", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING encodedURL = \"https%3A%2F%2Fwww.example.com%2Fsearch%3Fq%3Dtest%26lang%3Den\"\nSTRING decodedURL = Encoding.URLDecode(encodedURL)\n// Decoded URL: \" + decodedURL"}, {"name": "Encoding.URLEncode (STRING)", "return_type": "STRING", "return_desc": "Returns the input string encoded in a format suitable for inclusion in a URL.", "parameter_desc": "1. `STRING`: The text input to be encoded as a URL.", "description": "Encodes a string as a URL and returns it.", "example_code": "STRING originalString = \"Hello World! This is a test.\"\nSTRING encodedString = Encoding.URLEncode(originalString)\n// Original String: Hello World! This is a test.\n// Encoded String: Hello%20World%21%20This%20is%20a%20test.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello World! This is a test.\"\nSTRING encodedString = Encoding.URLEncode(originalString)\n// Original String: Hello World! This is a test.\n// Encoded String: Hello%20World%21%20This%20is%20a%20test."}, {"name": "EndsWith (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first `STRING` ends with the second `STRING`, otherwise`FALSE`", "parameter_desc": "1. `STRING`: The main STRING to check.\n2. `STRING`: The STRING to match at the end.", "description": "Returns TRUE if the string ends with the other string.", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF EndsWith(urlString, \".exe\") THEN {\n    // Executable files are not allowed\n    MWG.Block()\n} ELSE {\n    // URL does not end with .exe\n    MWG.Allow()\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF EndsWith(urlString, \".exe\") THEN {\n    // Executable files are not allowed\n    MWG.Block()\n} ELSE {\n    // URL does not end with .exe\n    MWG.Allow()\n}"}, {"name": "EndsWithCaseInsensitive (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns true if the first string ends with the second string, ignoring case differences.", "parameter_desc": "1. `STRING`: The string to be checked if it ends with the second string, case-insensitively.\n2. `STRING`: The string to check if it is the ending of the first string, case-insensitively.", "description": "Returns true if the string ends (case insensitive) with the other string.", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF EndsWithCaseInsensitive(urlString, \".jpg\") THEN {\n    // The URL ends with .jpg (case insensitive)\n} ELSE {\n    // The URL does not end with .jpg (case insensitive)\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF EndsWithCaseInsensitive(urlString, \".jpg\") THEN {\n    // The URL ends with .jpg (case insensitive)\n} ELSE {\n    // The URL does not end with .jpg (case insensitive)\n}"}, {"name": "EqualsCaseInsensitive (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns true if the two input strings are equal, ignoring case differences.", "parameter_desc": "1. `STRING`: The first string to compare for case-insensitive equality.\n2. `STRING`: The second string to compare for case-insensitive equality.", "description": "Returns true if the strings are equal (case insensitive).", "example_code": "STRING string1 = \"HelloWorld\"\nSTRING string2 = \"helloworld\"\n\nIF EqualsCaseInsensitive(string1, string2) THEN {\n    // The strings are equal (case insensitive).\n} ELSE {\n    // The strings are not equal.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING string1 = \"HelloWorld\"\nSTRING string2 = \"helloworld\"\n\nIF EqualsCaseInsensitive(string1, string2) THEN {\n    // The strings are equal (case insensitive).\n} ELSE {\n    // The strings are not equal.\n}"}, {"name": "Erase (STRING, NUMBER)", "return_type": "STRING", "return_desc": "Returns the substring from the start of the original string up to, but not including, the specified position.", "parameter_desc": "1. `STRING`: A STRING from which characters will be erased.\n2. `NUMBER`: A NUMBER indicating the starting position for erasure.", "description": "Erases from the given position up to the end of the string.", "example_code": "STRING originalString = \"Hello, World!\"\nNUMBER position = 5\n\nSTRING resultString = Erase(originalString, position)\n\n// Original String: \" + originalString\n// Position: \" + position\n// Resulting String: \" + resultString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!\"\nNUMBER position = 5\n\nSTRING resultString = Erase(originalString, position)\n\n// Original String: \" + originalString\n// Position: \" + position\n// Resulting String: \" + resultString"}, {"name": "Erase (STRING, NUMBER, NUMBER)", "return_type": "STRING", "return_desc": "Returns the modified string after erasing a specified number of characters from the given position.", "parameter_desc": "1. `STRING`: The input string.\n2. `NUMBER`: The starting position.\n3. `NUMBER`: The number of characters to erase (negative to erase up to the end).", "description": "Erases from given position the given number of characters (or up to the end if length is negative) and returns the result.", "example_code": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\nNUMBER lengthToRemove = 5\n\n// Using the Erase function to remove \"World\" from the original string\nSTRING modifiedString = Erase(originalString, startPosition, lengthToRemove)\n\n// Print the modified string to the console\n// Output will be \"Hello, !\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\nNUMBER lengthToRemove = 5\n\n// Using the Erase function to remove \"World\" from the original string\nSTRING modifiedString = Erase(originalString, startPosition, lengthToRemove)\n\n// Print the modified string to the console\n// Output will be \"Hello, !\""}, {"name": "EraseAll (STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the original string with all occurrences of the specified substring removed.", "parameter_desc": "1. `STRING`: The main string to search in.\n2. `STRING`: The substring to be erased.", "description": "Erases all occurrences of a substring.", "example_code": "STRING originalString = \"Hello, this is a test string. This string is for testing.\"\nSTRING subStringToRemove = \"is\"\n\nSTRING resultString = EraseAll(originalString, subStringToRemove)\n\n// Original String: \" + originalString\n// SubString to Remove: \" + subStringToRemove\n// Resulting String: \" + resultString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, this is a test string. This string is for testing.\"\nSTRING subStringToRemove = \"is\"\n\nSTRING resultString = EraseAll(originalString, subStringToRemove)\n\n// Original String: \" + originalString\n// SubString to Remove: \" + subStringToRemove\n// Resulting String: \" + resultString"}, {"name": "EscapeHTML (STRING)", "return_type": "STRING", "return_desc": "Returns a string with HTML special characters encoded to prevent HTML injection.", "parameter_desc": "1. `STRING`: The input text to be encoded into safe HTML.", "description": "Encodes a given string into safe HTML.", "example_code": "STRING inputString = \"<script>alert('Hello, world!');</script>\";\nSTRING escapedString = EscapeHTML(inputString);\n// Original String: <script>alert('Hello, world!');</script>\n// Escaped String: &lt;script&gt;alert('Hello, world!');&lt;/script&gt;", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"<script>alert('Hello, world!');</script>\";\nSTRING escapedString = EscapeHTML(inputString);\n// Original String: <script>alert('Hello, world!');</script>\n// Escaped String: &lt;script&gt;alert('Hello, world!');&lt;/script&gt;"}, {"name": "EscapeJSON (STRING)", "return_type": "STRING", "return_desc": "Returns a string where special characters in the input JSON string are encoded for safe inclusion in output.", "parameter_desc": "1. `STRING`: A JSON-encoded STRING to be escaped.", "description": "Encodes a given JSON string.", "example_code": "STRING jsonString = \"{\\\"key\\\": \\\"value with special characters: \\\\\\\" \\\\n \\\\t\\\"}\"\nSTRING escapedJsonString = EscapeJSON(jsonString)\n// Original JSON String: \" + jsonString\n// Escaped JSON String: \" + escapedJsonString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING jsonString = \"{\"key\": \"value with special characters: \\\" \\n \\t\"}\"\nSTRING escapedJsonString = EscapeJSON(jsonString)\n// Original JSON String: \" + jsonString\n// Escaped JSON String: \" + escapedJsonString"}, {"name": "Find (RegExJSi.List, RegExJSi)", "return_type": "NUMBER", "return_desc": "Returns the position of the regular expression in the list, or -1 if not found.", "parameter_desc": "1. `RegExJSi.List`: A list of regular expressions to be searched.\n2. `RegExJSi`: The regular expression pattern to search for.", "description": "Searches a regular expression and returns the position or -1.", "example_code": "// Initialize the list of regular expressions\nRegExJSi.List regExList = [\"example_list\"]\n\n// The regular expression to find\nRegExJSi targetRegEx = RegExJSi(\"target_pattern\")\n\n// Variable to store if the target regex is found\nBOOLEAN found = FALSE\n\n// Iterate through the list to find the target regex\nFOR EACH regEx IN regExList {\n    IF regEx == targetRegEx THEN {\n        found = TRUE\n        BREAK\n    }\n}\n\n// Output the result\nIF found THEN {\n    // Target regular expression found in the list.\n} ELSE {\n    // Target regular expression not found in the list.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize the list of regular expressions\nRegExJSi.List regExList = [\"example_list\"]\n\n// The regular expression to find\nRegExJSi targetRegEx = RegExJSi(\"target_pattern\")\n\n// Variable to store if the target regex is found\nBOOLEAN found = FALSE\n\n// Iterate through the list to find the target regex\nFOR EACH regEx IN regExList {\n    IF regEx == targetRegEx THEN {\n        found = TRUE\n        BREAK\n    }\n}\n\n// Output the result\nIF found THEN {\n    // Target regular expression found in the list.\n} ELSE {\n    // Target regular expression not found in the list.\n}"}, {"name": "Find (STRING, NUMBER, STRING)", "return_type": "NUMBER", "return_desc": "Returns the starting position of the second string within the first string, beginning at the given offset, or -1 if not found.", "parameter_desc": "", "description": "Searches 2nd string in 1st, starting at given offset and returns the start position or -1.", "example_code": "STRING text = \"The quick brown fox jumps over the lazy dog\"\nSTRING searchString = \"fox\"\nNUMBER startPosition = 0\n\nNUMBER foundPosition = Find(text, startPosition, searchString)\n\nIF foundPosition != -1 THEN {\n    // Found 'searchString' at position: foundPosition\n} ELSE {\n    // Did not find 'searchString' in the string.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING text = \"The quick brown fox jumps over the lazy dog\"\nSTRING searchString = \"fox\"\nNUMBER startPosition = 0\n\nNUMBER foundPosition = Find(text, startPosition, searchString)\n\nIF foundPosition != -1 THEN {\n    // Found 'searchString' at position: foundPosition\n} ELSE {\n    // Did not find 'searchString' in the string.\n}"}, {"name": "Find (STRING, STRING)", "return_type": "NUMBER", "return_desc": "Returns the starting index of the second string within the first string, or -1 if not found.", "parameter_desc": "", "description": "Searches the 2nd string in the 1st and returns the start position or -1.", "example_code": "STRING mainString = \"Hello, world!\"\nSTRING searchString = \"world\"\n\nNUMBER position = ReverseFind(mainString, searchString)\n\nIF position != -1 THEN {\n    // The position of 'searchString' in 'mainString' is: position\n} ELSE {\n    // 'searchString' not found in 'mainString'\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mainString = \"Hello, world!\"\nSTRING searchString = \"world\"\n\nNUMBER position = ReverseFind(mainString, searchString)\n\nIF position != -1 THEN {\n    // The position of 'searchString' in 'mainString' is: position\n} ELSE {\n    // 'searchString' not found in 'mainString'\n}"}, {"name": "Find (VECTOR<STRING>, RegExJSi)", "return_type": "NUMBER", "return_desc": "Returns the index of the first string in the vector that matches the regular expression, or -1 if no match is found.", "parameter_desc": "VECTOR: A list of STRINGs to search within.  RegExJSi: The regular expression pattern to match against the STRINGs in VECTOR.", "description": "Returns the index of the first matching string from the string list (-1 in case of not being found).", "example_code": "// Define a VECTOR of STRINGs\nVECTOR<STRING> stringList = \"apple\", \"banana\", \"cherry\", \"date\", \"elderberry\"\n\n// Define a regular expression to search for a STRING that contains the letter 'a'\nRegExJSi regex = RegExJSi(\"a\")\n\n// Use the Find function to get the index of the first STRING that matches the regex\nNUMBER index = Find(stringList, regex)\n\n// The index of the first match is: \" + index", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of STRINGs\nVECTOR<STRING> stringList = \"apple\", \"banana\", \"cherry\", \"date\", \"elderberry\"\n\n// Define a regular expression to search for a STRING that contains the letter 'a'\nRegExJSi regex = RegExJSi(\"a\")\n\n// Use the Find function to get the index of the first STRING that matches the regex\nNUMBER index = Find(stringList, regex)\n\n// The index of the first match is: \" + index"}, {"name": "FindCaseInsensitive (STRING, NUMBER, STRING)", "return_type": "NUMBER", "return_desc": "Returns the starting index of the second string found within the first string, ignoring case, or -1 if not found.", "parameter_desc": "STRING: The main STRING to search within; NUMBER: The position within the main STRING to start the search; STRING: The subSTRING to search for.", "description": "Searches the 2nd string case insensitively in the 1st and returns the start position or -1.", "example_code": "STRING mainString = \"Hello World, hello universe\"\nSTRING searchString = \"hello\"\nNUMBER startPosition = 0\n\n// Use the FindCaseInsensitive function to find the position of searchString in mainString\nNUMBER position = FindCaseInsensitive(mainString, startPosition, searchString)\n\n// The position of the search string is: \" + position", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mainString = \"Hello World, hello universe\"\nSTRING searchString = \"hello\"\nNUMBER startPosition = 0\n\n// Use the FindCaseInsensitive function to find the position of searchString in mainString\nNUMBER position = FindCaseInsensitive(mainString, startPosition, searchString)\n\n// The position of the search string is: \" + position"}, {"name": "FindCaseInsensitive (STRING, STRING)", "return_type": "NUMBER", "return_desc": "Returns the zero-based start index of the second string in the first string, or -1 if not found, in a case-insensitive manner.", "parameter_desc": "STRING: main text to search within; STRING: target to search for.", "description": "Searches the 2nd string, case insensitive, in the 1st and returns the start position or -1.", "example_code": "STRING url = MWG.Url().ToString()\nSTRING keyword = \"example\"\n\nIF FindCaseInsensitive(url, keyword) THEN {\n    // Keyword found in URL\n} ELSE {\n    // Keyword not found in URL\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING url = MWG.Url().ToString()\nSTRING keyword = \"example\"\n\nIF FindCaseInsensitive(url, keyword) THEN {\n    // Keyword found in URL\n} ELSE {\n    // Keyword not found in URL\n}"}, {"name": "FindFirstOf (STRING, STRING)", "return_type": "NUMBER", "return_desc": "Returns the position of the first character in the first string that matches any character in the second string, or -1 if no match is found.", "parameter_desc": "STRING: input to search within; STRING: characters to match.", "description": "Searches within given string for the first character that is equal to any character within given second string. If found, position is returned. Otherwise, -1 is returned.", "example_code": "STRING inputString = \"hello world\"\nSTRING charactersToMatch = \"aeiou\"\n\nNUMBER position = FindFirstOf(inputString, charactersToMatch)\n\nIF position != -1 THEN {\n    // First vowel found at position: \" + position\n} ELSE {\n    // No vowels found in the input string.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"hello world\"\nSTRING charactersToMatch = \"aeiou\"\n\nNUMBER position = FindFirstOf(inputString, charactersToMatch)\n\nIF position != -1 THEN {\n    // First vowel found at position: \" + position\n} ELSE {\n    // No vowels found in the input string.\n}"}, {"name": "FindFirstOf (STRING, STRING, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the position of the first occurrence of any character from the second string within the specified range of the first string, or -1 if no such character is found.", "parameter_desc": "STRING: the STRING to search within; STRING: the STRING containing characters to search for; NUMBER: the position from which to begin the search.", "description": "Searches within given string, beginning at given position (or from start of string), for the first character that is equal to any character within given second string. If found, position is returned. Otherwise, -1 is returned.", "example_code": "STRING text = \"Hello, World!\"\nSTRING searchChars = \"oW\"\nNUMBER startPosition = 0\n\nNUMBER position = FindFirstOf(text, searchChars, startPosition)\n\nIF position != -1 THEN {\n    // First occurrence of any character from '\" + searchChars + \"' in '\" + text + \"' is at position: \" + position\n} ELSE {\n    // No characters from '\" + searchChars + \"' found in '\" + text + \"'\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING text = \"Hello, World!\"\nSTRING searchChars = \"oW\"\nNUMBER startPosition = 0\n\nNUMBER position = FindFirstOf(text, searchChars, startPosition)\n\nIF position != -1 THEN {\n    // First occurrence of any character from '\" + searchChars + \"' in '\" + text + \"' is at position: \" + position\n} ELSE {\n    // No characters from '\" + searchChars + \"' found in '\" + text + \"'\"\n}"}, {"name": "FindLast (STRING, STRING)", "return_type": "NUMBER", "return_desc": "Returns the starting position of the last occurrence of the second string within the first string, or -1 if it is not found.", "parameter_desc": "STRING: input to search within; STRING: subSTRING to find.", "description": "Searches within given string, beginning at the end, for the second string. If found, the start position is returned. Otherwise, -1 is returned.", "example_code": "STRING text = \"The quick brown fox jumps over the lazy dog. The quick brown fox is fast.\"\nSTRING searchString = \"fox\"\n\nNUMBER position = FindLast(text, searchString)\n\nIF position != -1 THEN {\n    // The last occurrence of 'searchString' is at position: position\n} ELSE {\n    // The string 'searchString' was not found.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING text = \"The quick brown fox jumps over the lazy dog. The quick brown fox is fast.\"\nSTRING searchString = \"fox\"\n\nNUMBER position = FindLast(text, searchString)\n\nIF position != -1 THEN {\n    // The last occurrence of 'searchString' is at position: position\n} ELSE {\n    // The string 'searchString' was not found.\n}"}, {"name": "FindLast (STRING, STRING, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the starting position of the last occurrence of the second string in the first string, starting from the specified position, or -1 if not found.", "parameter_desc": "STRING: input to search within; STRING: subSTRING to search for; NUMBER: starting position for search.", "description": "Searches within given string, beginning at the given position (or from end of string), for the second string. If found, the start position is returned. Otherwise, -1 is returned.", "example_code": "STRING text = \"This is a sample string to demonstrate the FindLast function.\"\nSTRING searchString = \"s\"\nNUMBER startPosition = 30\n\nNUMBER lastIndex = FindLast(text, searchString, startPosition)\n\nIF lastIndex != -1 THEN {\n    // The last occurrence of 'searchString' before position startPosition is at index: lastIndex\n} ELSE {\n    // The string 'searchString' was not found before position startPosition\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING text = \"This is a sample string to demonstrate the FindLast function.\"\nSTRING searchString = \"s\"\nNUMBER startPosition = 30\n\nNUMBER lastIndex = FindLast(text, searchString, startPosition)\n\nIF lastIndex != -1 THEN {\n    // The last occurrence of 'searchString' before position startPosition is at index: lastIndex\n} ELSE {\n    // The string 'searchString' was not found before position startPosition\n}"}, {"name": "FindLastOf (STRING, STRING)", "return_type": "NUMBER", "return_desc": "Returns the position of the last character in the first string that matches any character in the second string, or -1 if no such character is found.", "parameter_desc": "STRING: input to search within; STRING: characters to search for.", "description": "Searches backward within given string, beginning at the end of the string, for the first character that is equal to any character within the given second string. If found, position is returned. Otherwise, -1 is returned.", "example_code": "STRING inputString = \"Hello, World!\"\nSTRING searchString = \"o\"\n\nNUMBER position = FindLastOf(inputString, searchString)\n\nIF position != -1 THEN {\n    // The last occurrence of any character in 'o' in the string 'Hello, World!' is at position: position\n} ELSE {\n    // No characters from 'o' were found in the string 'Hello, World!'\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"Hello, World!\"\nSTRING searchString = \"o\"\n\nNUMBER position = FindLastOf(inputString, searchString)\n\nIF position != -1 THEN {\n    // The last occurrence of any character in 'o' in the string 'Hello, World!' is at position: position\n} ELSE {\n    // No characters from 'o' were found in the string 'Hello, World!'\n}"}, {"name": "FindLastOf (STRING, STRING, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the position of the last occurrence of any character from the second string in the first string, starting from a given position or from the end, or -1 if no such character is found.", "parameter_desc": "STRING: input to search within; STRING: characters to search for; NUMBER: starting position for the search.", "description": "Searches backward within given string, beginning at given position (or from end of string), for the first character that is equal to any character within given second string. If found, position is returned. Otherwise, -1 is returned.", "example_code": "STRING text = \"Hello, world! Welcome to MOWGLI.\"\nSTRING searchChar = \"o\"\nNUMBER startPosition = 20\n\nNUMBER lastIndex = FindLastOf(text, searchChar, startPosition)\n\n// The last occurrence of 'o' in the text starting from position 20 is at index: lastIndex", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING text = \"Hello, world! Welcome to MOWGLI.\"\nSTRING searchChar = \"o\"\nNUMBER startPosition = 20\n\nNUMBER lastIndex = FindLastOf(text, searchChar, startPosition)\n\n// The last occurrence of 'o' in the text starting from position 20 is at index: lastIndex"}, {"name": "FindWildCardMatch (VECTOR<STRING>, STRING)", "return_type": "NUMBER", "return_desc": "Returns the index of the first matching of the wildcard as a string from the string list (-1 in case of not found).", "parameter_desc": "VECTOR<STRING>: list to search; STRING: wildcard to search for.", "description": "Returns the index of the first matching of the wildcard as a string from the string list. Returns -1 in case of not found.", "example_code": "VECTOR<STRING> urlPatterns = \"*.example.com\", \"*.test.com\", \"*.sample.org\"\nSTRING currentUrl = MWG.Url().Host\n\nIF FindWildCardMatch(urlPatterns, currentUrl) THEN {\n    // Match found for URL: currentUrl\n    MWG.Allow(\"URL matched with wildcard pattern\")\n} ELSE {\n    // No match found for URL: currentUrl\n    MWG.Block(\"URL did not match any wildcard pattern\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> urlPatterns = \"*.example.com\", \"*.test.com\", \"*.sample.org\"\nSTRING currentUrl = MWG.Url().Host\n\nIF FindWildCardMatch(urlPatterns, currentUrl) THEN {\n    // Match found for URL: currentUrl\n    MWG.Allow(\"URL matched with wildcard pattern\")\n} ELSE {\n    // No match found for URL: currentUrl\n    MWG.Block(\"URL did not match any wildcard pattern\")\n}"}, {"name": "Get (MAP<STRING, STRING>, STRING)", "return_type": "STRING", "return_desc": "Returns the value for the given key.", "parameter_desc": "MAP<STRING, STRING>: map to use; STRING: key to look up.", "description": "Gets a value from a map with a given key.", "example_code": "// Define a map with some key-value pairs\nMAP<STRING, STRING> exampleMap = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Retrieve a value from the map using the Get function\nSTRING value = Get(exampleMap, \"key2\")\n\n// The value for 'key2' is: \" + value", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a map with some key-value pairs\nMAP<STRING, STRING> exampleMap = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Retrieve a value from the map using the Get function\nSTRING value = Get(exampleMap, \"key2\")\n\n// The value for 'key2' is: \" + value"}, {"name": "Get (RegExJSi.List, NUMBER)", "return_type": "RegExJSi", "return_desc": "Returns the element at the specified index from the `RegExJSi`.List.", "parameter_desc": "RegExJSi.List: the list to retrieve from; NUMBER: the index of the element to retrieve.", "description": "Retrieves a list element.", "example_code": "// Assume regexList is a predefined RegExJSi.List\nRegExJSi.List regexList = [\"example_regex_list\"]\n\n// Retrieve the element at index 2\nRegExJSi regexElement = Get(regexList, 2)\n\n// Print the retrieved element to the console\n// Retrieved RegExJSi element: \" + regexElement", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume regexList is a predefined RegExJSi.List\nRegExJSi.List regexList = [\"example_regex_list\"]\n\n// Retrieve the element at index 2\nRegExJSi regexElement = Get(regexList, 2)\n\n// Print the retrieved element to the console\n// Retrieved RegExJSi element: \" + regexElement"}, {"name": "GetKeys (MAP<STRING, STRING>)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a list of the keys for the given map.", "parameter_desc": "MAP<STRING, STRING>: map to get keys for.", "description": "Gets a list of all the keys in a map.", "example_code": "// Define a map with some key-value pairs\nMAP<STRING, STRING> exampleMap = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Get the keys from the map\nVECTOR<STRING> keys = GetKeys(exampleMap)\n\n// Print the keys to the console\nFOR EACH key IN keys {\n    // Key: \" + key\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a map with some key-value pairs\nMAP<STRING, STRING> exampleMap = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Get the keys from the map\nVECTOR<STRING> keys = GetKeys(exampleMap)\n\n// Print the keys to the console\nFOR EACH key IN keys {\n    // Key: \" + key\n}"}, {"name": "GetRange (RegExJSi.List, NUMBER, NUMBER)", "return_type": "RegExJSi.List", "return_desc": "Returns a sublist containing elements from the input list between the specified start and end indices.", "parameter_desc": "RegExJSi.List: A list of regular expressions to be searched; NUMBER: a starting index (inclusive); NUMBER: an ending index (exclusive).", "description": "Gets list elements between the given indices.", "example_code": "// Assume we have a RegExJSi.List named \"exampleList\" with some regex patterns\nRegExJSi.List exampleList = [\"exampleList\"]\n\n// Define the start and end indices\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the sublist of regex patterns within the specified range\nRegExJSi.List subList = GetRange(exampleList, startIndex, endIndex)\n\n// Print the sublist to the console for debugging\n// subList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a RegExJSi.List named \"exampleList\" with some regex patterns\nRegExJSi.List exampleList = [\"exampleList\"]\n\n// Define the start and end indices\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the sublist of regex patterns within the specified range\nRegExJSi.List subList = GetRange(exampleList, startIndex, endIndex)\n\n// Print the sublist to the console for debugging\n// subList"}, {"name": "GetRange (VECTOR<MediaType>, NUMBER, NUMBER)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Initialize a VECTOR of MediaType\nVECTOR<MediaType> mediaList = MediaType(\"image/jpeg\"), MediaType(\"image/png\"), MediaType(\"video/mp4\"), MediaType(\"application/pdf\")\n\n// Define the start and end indices\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the sublist of MediaType elements within the specified range\nVECTOR<MediaType> subList = GetRange(mediaList, startIndex, endIndex)\n\n// Sublist of MediaType elements: \n// + subList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MediaType\nVECTOR<MediaType> mediaList = MediaType(\"image/jpeg\"), MediaType(\"image/png\"), MediaType(\"video/mp4\"), MediaType(\"application/pdf\")\n\n// Define the start and end indices\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the sublist of MediaType elements within the specified range\nVECTOR<MediaType> subList = GetRange(mediaList, startIndex, endIndex)\n\n// Sublist of MediaType elements: \n// + subList"}, {"name": "GetRange (VECTOR<MWG.ApplicationCategoryType>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.ApplicationCategoryType>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Assume we have a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"SocialMedia\", \"StreamingMedia\", \"FileSharing\", \"Gaming\", \"News\"]\n\n// Define the start and end indices for the range\nNUMBER startIndex = 1\nNUMBER endIndex = 4\n\n// Get the range of application categories\nVECTOR<MWG.ApplicationCategoryType> selectedCategories = GetRange(appCategories, startIndex, endIndex)\n\n// Selected Categories: selectedCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"SocialMedia\", \"StreamingMedia\", \"FileSharing\", \"Gaming\", \"News\"]\n\n// Define the start and end indices for the range\nNUMBER startIndex = 1\nNUMBER endIndex = 4\n\n// Get the range of application categories\nVECTOR<MWG.ApplicationCategoryType> selectedCategories = GetRange(appCategories, startIndex, endIndex)\n\n// Selected Categories: selectedCategories"}, {"name": "GetRange (VECTOR<MWG.ApplicationType>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.ApplicationType>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appList = [\"AppTypeList\"]\n\n// Define the start and end indices\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the sublist using GetRange\nVECTOR<MWG.ApplicationType> subList = GetRange(appList, startIndex, endIndex)\n\n// Sublist: \" + subList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appList = [\"AppTypeList\"]\n\n// Define the start and end indices\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the sublist using GetRange\nVECTOR<MWG.ApplicationType> subList = GetRange(appList, startIndex, endIndex)\n\n// Sublist: \" + subList"}, {"name": "GetRange (VECTOR<MWG.HostAndCertificate>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.HostAndCertificate>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Assume we have a VECTOR of MWG.HostAndCertificate objects\nVECTOR<MWG.HostAndCertificate> hostAndCerts = MWG.ServerHostAndCert(), MWG.ServerHostAndCert(), MWG.ServerHostAndCert(), MWG.ServerHostAndCert()\n\n// Define the start index and the number of elements to get\nNUMBER startIndex = 1\nNUMBER count = 2\n\n// Use the GetRange function to get a subrange of the VECTOR\nVECTOR<MWG.HostAndCertificate> subRange = GetRange(hostAndCerts, startIndex, count)\n\n// Subrange of host and certificates: \" + subRange", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a VECTOR of MWG.HostAndCertificate objects\nVECTOR<MWG.HostAndCertificate> hostAndCerts = MWG.ServerHostAndCert(), MWG.ServerHostAndCert(), MWG.ServerHostAndCert(), MWG.ServerHostAndCert()\n\n// Define the start index and the number of elements to get\nNUMBER startIndex = 1\nNUMBER count = 2\n\n// Use the GetRange function to get a subrange of the VECTOR\nVECTOR<MWG.HostAndCertificate> subRange = GetRange(hostAndCerts, startIndex, count)\n\n// Subrange of host and certificates: \" + subRange"}, {"name": "GetRange (VECTOR<MWG.UrlCategory>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Assume we have a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"example_list\"]\n\n// Define the start and end indices for the range\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the range of URL categories\nVECTOR<MWG.UrlCategory> rangeCategories = GetRange(urlCategories, startIndex, endIndex)\n\n// Range of URL Categories: \n// rangeCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"example_list\"]\n\n// Define the start and end indices for the range\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Get the range of URL categories\nVECTOR<MWG.UrlCategory> rangeCategories = GetRange(urlCategories, startIndex, endIndex)\n\n// Range of URL Categories: \n// rangeCategories"}, {"name": "GetRange (VECTOR<Net.IP>, NUMBER, NUMBER)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Define a vector of IP addresses\nVECTOR<Net.IP> ipAddresses = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\"), Net.IP(\"192.168.1.4\"), Net.IP(\"192.168.1.5\")\n\n// Extract a subrange of IP addresses from the vector\nVECTOR<Net.IP> subRange = GetRange(ipAddresses, 1, 3)\n\n// Print the extracted subrange to the console\n// Extracted IP Range: \" + subRange", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a vector of IP addresses\nVECTOR<Net.IP> ipAddresses = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\"), Net.IP(\"192.168.1.4\"), Net.IP(\"192.168.1.5\")\n\n// Extract a subrange of IP addresses from the vector\nVECTOR<Net.IP> subRange = GetRange(ipAddresses, 1, 3)\n\n// Print the extracted subrange to the console\n// Extracted IP Range: \" + subRange"}, {"name": "GetRange (VECTOR<Net.IPRange>, NUMBER, NUMBER)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Define a vector of IP ranges\nVECTOR<Net.IPRange> ipRanges = \"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"\n\n// Define the start and end indices for the range you want to get\nNUMBER startIndex = 1\nNUMBER endIndex = 2\n\n// Get the subrange of IP ranges\nVECTOR<Net.IPRange> subRange = GetRange(ipRanges, startIndex, endIndex)\n\n// Subrange of IP ranges: \n// Commented out the DEBUG line, replace it with your own console log or print statement if needed\n// \"Subrange of IP ranges: \" + subRange", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a vector of IP ranges\nVECTOR<Net.IPRange> ipRanges = \"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"\n\n// Define the start and end indices for the range you want to get\nNUMBER startIndex = 1\nNUMBER endIndex = 2\n\n// Get the subrange of IP ranges\nVECTOR<Net.IPRange> subRange = GetRange(ipRanges, startIndex, endIndex)\n\n// Subrange of IP ranges: \n// Commented out the DEBUG line, replace it with your own console log or print statement if needed\n// \"Subrange of IP ranges: \" + subRange"}, {"name": "GetRange (VECTOR<NUMBER>, NUMBER, NUMBER)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Initialize a VECTOR of NUMBERs\nVECTOR<NUMBER> numbers = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10\n\n// Define the start and end indices\nNUMBER startIndex = 2\nNUMBER endIndex = 5\n\n// Get the sublist of numbers within the specified range\nVECTOR<NUMBER> sublist = GetRange(numbers, startIndex, endIndex)\n\n// Sublist: \" + sublist", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of NUMBERs\nVECTOR<NUMBER> numbers = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10\n\n// Define the start and end indices\nNUMBER startIndex = 2\nNUMBER endIndex = 5\n\n// Get the sublist of numbers within the specified range\nVECTOR<NUMBER> sublist = GetRange(numbers, startIndex, endIndex)\n\n// Sublist: \" + sublist"}, {"name": "GetRange (VECTOR<STRING>, NUMBER, NUMBER)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a sublist of the elements within the specified range of indices from the original list.", "parameter_desc": "VECTOR: list to be searched; NUMBER: starting index (inclusive); NUMBER: ending index (exclusive).", "description": "Gets list elements between given indices.", "example_code": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> exampleList = \"apple\", \"banana\", \"cherry\", \"date\", \"elderberry\", \"fig\", \"grape\"\n\n// Define the start and end indices\nNUMBER startIndex = 2\nNUMBER endIndex = 5\n\n// Get the sublist using GetRange\nVECTOR<STRING> sublist = GetRange(exampleList, startIndex, endIndex)\n\n// Sublist: \" + sublist was printed to the console\n// Sublist: \" + sublist", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> exampleList = \"apple\", \"banana\", \"cherry\", \"date\", \"elderberry\", \"fig\", \"grape\"\n\n// Define the start and end indices\nNUMBER startIndex = 2\nNUMBER endIndex = 5\n\n// Get the sublist using GetRange\nVECTOR<STRING> sublist = GetRange(exampleList, startIndex, endIndex)\n\n// Sublist: \" + sublist was printed to the console\n// Sublist: \" + sublist"}, {"name": "GetType (JSON)", "return_type": "STRING", "return_desc": "Returns the data type of the given JSON node as a string.", "parameter_desc": "JSON: input to determine node type of.", "description": "Gets type of JSON node.", "example_code": "// Create a JSON object\nJSON myJson = {}\n\n// Create a MAP to hold the value\nMAP<STRING, MWG.InternalVariant> valueMap\nvalueMap[\"key1\"] = \"value1\"\nvalueMap[\"key2\"] = 123\n\n// Set the value in the JSON object\nmyJson = JSON.Set(myJson, \"exampleKey\", valueMap)\n\n// Set a user-defined variable with the modified JSON\nMWG.SetUserDefinedVar(\"exampleVar\", myJson)\n\n// Print the JSON object to the console for debugging\n// myJson", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object\nJSON myJson = {}\n\n// Create a MAP to hold the value\nMAP<STRING, MWG.InternalVariant> valueMap\nvalueMap[\"key1\"] = \"value1\"\nvalueMap[\"key2\"] = 123\n\n// Set the value in the JSON object\nmyJson = JSON.Set(myJson, \"exampleKey\", valueMap)\n\n// Set a user-defined variable with the modified JSON\nMWG.SetUserDefinedVar(\"exampleVar\", myJson)\n\n// Print the JSON object to the console for debugging\n// myJson"}, {"name": "HasKey (MAP<STRING, STRING>, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the map has the given key.", "parameter_desc": "MAP<STRING, STRING>: map to search; STRING: key to search for.", "description": "Checks if a map has a given key.", "example_code": "MAP<STRING, STRING> headers = MWG.GetRequestHeaders()\nSTRING keyToCheck = \"User-Agent\"\n\nIF HasKey(headers, keyToCheck) THEN {\n    // Key exists in the headers map.\n} ELSE {\n    // Key does not exist in the headers map.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MAP<STRING, STRING> headers = MWG.GetRequestHeaders()\nSTRING keyToCheck = \"User-Agent\"\n\nIF HasKey(headers, keyToCheck) THEN {\n    // Key exists in the headers map.\n} ELSE {\n    // Key does not exist in the headers map.\n}"}, {"name": "InitialTrigger ()", "return_type": "STRING", "return_desc": "Returns the initial trigger as a string.", "parameter_desc": "None", "description": "Returns the initial trigger.", "example_code": "// Routine triggered on Web.Request or Web.Response\n\n// Example condition\nIF MWG.Url().Host == \"example.com\" THEN {\n    MWG.Block(\"Access to example.com is blocked\")\n} ELSE {\n    MWG.Allow(\"Access allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Routine triggered on Web.Request or Web.Response\n\n// Example condition\nIF MWG.Url().Host == \"example.com\" THEN {\n    MWG.Block(\"Access to example.com is blocked\")\n} ELSE {\n    MWG.Allow(\"Access allowed\")\n}"}, {"name": "Insert (RegExJSi.List, RegExJSi, NUMBER)", "return_type": "RegExJSi.List", "return_desc": "Returns a list with the element inserted at the specified position.", "parameter_desc": "RegExJSi.List: the list to insert into; RegExJSi: the element to insert; NUMBER: the position to insert the element at.", "description": "Inserts element at given position.", "example_code": "// Create a new RegExJSi.List\nRegExJSi.List regexList = RegExJSi.List()\n\n// Create a new RegExJSi object\nRegExJSi regex1 = RegExJSi(\"pattern1\")\nRegExJSi regex2 = RegExJSi(\"pattern2\")\n\n// Insert the first regex at position 0\nregexList.Insert(regex1, 0)\n\n// Insert the second regex at position 1\nregexList.Insert(regex2, 1)\n\n// Debug output to verify the insertion was replaced with a comment\n// First regex pattern: regexList[0].Pattern()\n// Second regex pattern: regexList[1].Pattern()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a new RegExJSi.List\nRegExJSi.List regexList = RegExJSi.List()\n\n// Create a new RegExJSi object\nRegExJSi regex1 = RegExJSi(\"pattern1\")\nRegExJSi regex2 = RegExJSi(\"pattern2\")\n\n// Insert the first regex at position 0\nregexList.Insert(regex1, 0)\n\n// Insert the second regex at position 1\nregexList.Insert(regex2, 1)\n\n// Debug output to verify the insertion was replaced with a comment\n// First regex pattern: regexList[0].Pattern()\n// Second regex pattern: regexList[1].Pattern()"}, {"name": "Insert (STRING, NUMBER, STRING)", "return_type": "STRING", "return_desc": "Returns a new string with the second string inserted at the specified position in the first string.", "parameter_desc": "STRING: The original STRING, NUMBER: The position where the new STRING will be inserted, STRING: The STRING to be inserted.", "description": "Inserts the string at the given position and returns the result.", "example_code": "STRING originalString = \"Hello World\"\nNUMBER position = 6\nSTRING stringToInsert = \"Beautiful \"\n\nSTRING resultString = Insert(originalString, position, stringToInsert)\n// Output will be \"Hello Beautiful World\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello World\"\nNUMBER position = 6\nSTRING stringToInsert = \"Beautiful \"\n\nSTRING resultString = Insert(originalString, position, stringToInsert)\n// Output will be \"Hello Beautiful World\""}, {"name": "Insert (VECTOR<MediaType>, MediaType, NUMBER)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns a vector with the new element inserted at the specified position.", "parameter_desc": "VECTOR: list to insert into; MediaType: element to insert; NUMBER: position to insert the element at.", "description": "Inserts an element at a given position.", "example_code": "// Initialize a VECTOR of MediaType with some initial values\nVECTOR<MediaType> mediaTypes = MediaType(\"text/html\"), MediaType(\"image/png\"), MediaType(\"application/xml\")\n\n// Create a new MediaType object to insert\nMediaType newMediaType = MediaType(\"application/json\")\n\n// Specify the position to insert the new MediaType\nNUMBER position = 1\n\n// Insert the new MediaType into the VECTOR at the specified position\nmediaTypes = Insert(mediaTypes, newMediaType, position)\n\n// Debug output to verify the insertion\n// \"Updated mediaTypes: \" + mediaTypes", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MediaType with some initial values\nVECTOR<MediaType> mediaTypes = MediaType(\"text/html\"), MediaType(\"image/png\"), MediaType(\"application/xml\")\n\n// Create a new MediaType object to insert\nMediaType newMediaType = MediaType(\"application/json\")\n\n// Specify the position to insert the new MediaType\nNUMBER position = 1\n\n// Insert the new MediaType into the VECTOR at the specified position\nmediaTypes = Insert(mediaTypes, newMediaType, position)\n\n// Debug output to verify the insertion\n// \"Updated mediaTypes: \" + mediaTypes"}, {"name": "Insert (VECTOR<MWG.ApplicationCategoryType>, MWG.ApplicationCategoryType, NUMBER)", "return_type": "VECTOR<MWG.ApplicationCategoryType>", "return_desc": "Returns a vector with the given element inserted at the specified position.", "parameter_desc": "VECTOR: The VECTOR in which to insert the element; MWG.ApplicationCategoryType: the element to insert; NUMBER: the position at which to insert the element.", "description": "Inserts an element at a given position.", "example_code": "// Initialize a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"category1\", \"category2\", \"category3\"]\n\n// Create a new MWG.ApplicationCategoryType to insert\nMWG.ApplicationCategoryType newCategory = \"newCategory\"\n\n// Specify the position where the new category should be inserted\nNUMBER position = 1\n\n// Insert the new category into the specified position\nInsert(appCategories, newCategory, position)\n\n// Debug to check the updated VECTOR\n// DEBUG(appCategories) replaced with a comment to explain the code\n// Check the updated VECTOR", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"category1\", \"category2\", \"category3\"]\n\n// Create a new MWG.ApplicationCategoryType to insert\nMWG.ApplicationCategoryType newCategory = \"newCategory\"\n\n// Specify the position where the new category should be inserted\nNUMBER position = 1\n\n// Insert the new category into the specified position\nInsert(appCategories, newCategory, position)\n\n// Debug to check the updated VECTOR\n// DEBUG(appCategories) replaced with a comment to explain the code\n// Check the updated VECTOR"}, {"name": "Insert (VECTOR<MWG.ApplicationType>, MWG.ApplicationType, NUMBER)", "return_type": "VECTOR<MWG.ApplicationType>", "return_desc": "Returns the modified vector after inserting the `MWG.ApplicationType element at the `specified number position.", "parameter_desc": "VECTOR: The VECTOR where the element will be inserted; MWG.ApplicationType: The element to be inserted; NUMBER: The position at which to insert the element.", "description": "Inserts an element at a given position.", "example_code": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appTypes = [\"exampleAppList\"]\n\n// Create an MWG.ApplicationType object to insert\nMWG.ApplicationType newAppType\nnewAppType.name = \"New Application\"\nnewAppType.category = \"Example Category\"\n\n// Specify the position where the new application type should be inserted\nNUMBER position = 2\n\n// Insert the new application type into the vector at the specified position\nInsert(appTypes, newAppType, position)\n\n// Inserted new application type at position\n// Previously: DEBUG(\"Inserted new application type at position \" + position)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appTypes = [\"exampleAppList\"]\n\n// Create an MWG.ApplicationType object to insert\nMWG.ApplicationType newAppType\nnewAppType.name = \"New Application\"\nnewAppType.category = \"Example Category\"\n\n// Specify the position where the new application type should be inserted\nNUMBER position = 2\n\n// Insert the new application type into the vector at the specified position\nInsert(appTypes, newAppType, position)\n\n// Inserted new application type at position\n// Previously: DEBUG(\"Inserted new application type at position \" + position)"}, {"name": "Insert (VECTOR<MWG.HostAndCertificate>, MWG.HostAndCertificate, NUMBER)", "return_type": "VECTOR<MWG.HostAndCertificate>", "return_desc": "Returns a vector with the`MWG.HostAndCertificate`element inserted at the specified position.", "parameter_desc": "VECTOR: The list to insert into, MWG.HostAndCertificate: The element to insert, NUMBER: The position where the element should be inserted.", "description": "Inserts an element at a given position.", "example_code": "// Initialize a VECTOR of MWG.HostAndCertificate\nVECTOR<MWG.HostAndCertificate> hostCertList = [\"existingHostCertList\"]\n\n// Create a new MWG.HostAndCertificate object\nMWG.HostAndCertificate newHostCert\nnewHostCert.Host = \"example.com\"\nnewHostCert.Certificate = \"exampleCertificate\"\n\n// Specify the position where the new element should be inserted\nNUMBER position = 1\n\n// Insert the new MWG.HostAndCertificate into the VECTOR at the specified position\nhostCertList = Insert(hostCertList, newHostCert, position)\n\n// Updated hostCertList: \" + hostCertList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.HostAndCertificate\nVECTOR<MWG.HostAndCertificate> hostCertList = [\"existingHostCertList\"]\n\n// Create a new MWG.HostAndCertificate object\nMWG.HostAndCertificate newHostCert\nnewHostCert.Host = \"example.com\"\nnewHostCert.Certificate = \"exampleCertificate\"\n\n// Specify the position where the new element should be inserted\nNUMBER position = 1\n\n// Insert the new MWG.HostAndCertificate into the VECTOR at the specified position\nhostCertList = Insert(hostCertList, newHostCert, position)\n\n// Updated hostCertList: \" + hostCertList"}, {"name": "Insert (VECTOR<MWG.UrlCategory>, MWG.UrlCategory, NUMBER)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns the updated vector.", "parameter_desc": "VECTOR: the list to modify; MWG.UrlCategory: the element to insert; NUMBER: the position to insert the element at.", "description": "Inserts an element at a given position.", "example_code": "// Initialize a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"category_list\"]\n\n// Create a new MWG.UrlCategory object\nMWG.UrlCategory newCategory = MWG.UrlCategory()\nnewCategory.Name = \"New Category\"\nnewCategory.Description = \"This is a new URL category\"\n\n// Insert the new category at position 2 (index 1)\nurlCategories = Insert(urlCategories, newCategory, 1)\n\n// Updated URL Categories: \" + urlCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"category_list\"]\n\n// Create a new MWG.UrlCategory object\nMWG.UrlCategory newCategory = MWG.UrlCategory()\nnewCategory.Name = \"New Category\"\nnewCategory.Description = \"This is a new URL category\"\n\n// Insert the new category at position 2 (index 1)\nurlCategories = Insert(urlCategories, newCategory, 1)\n\n// Updated URL Categories: \" + urlCategories"}, {"name": "Insert (VECTOR<NUMBER>, NUMBER, NUMBER)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns a vector with the specified element inserted at the given position.", "parameter_desc": "VECTOR: The VECTOR to insert the element into, NUMBER1: The element to be inserted, NUMBER2: The position at which to insert the element.", "description": "Inserts an element at a given position.", "example_code": "VECTOR<NUMBER> numbers = 1, 2, 3, 5, 6\nNUMBER newNumber = 4\nNUMBER position = 3\n\n// Insert the new number at the specified position\nnumbers = Insert(numbers, newNumber, position)\n\n// Print the updated vector to the console\n// numbers", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> numbers = 1, 2, 3, 5, 6\nNUMBER newNumber = 4\nNUMBER position = 3\n\n// Insert the new number at the specified position\nnumbers = Insert(numbers, newNumber, position)\n\n// Print the updated vector to the console\n// numbers"}, {"name": "Insert (VECTOR<STRING>, STRING, NUMBER)", "return_type": "VECTOR<STRING>", "return_desc": "Returns the vector with the string inserted at the specified number position.", "parameter_desc": "VECTOR: The list where the element will be inserted; STRING: The element to be inserted; NUMBER: The position at which to insert the element.", "description": "Inserts an element at a given position.", "example_code": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> fruits = \"Apple\", \"Banana\", \"Cherry\"\n\n// Insert a new fruit at the second position (index 1)\nfruits = Insert(fruits, \"Orange\", 1)\n\n// The updated VECTOR was previously printed to the console\n// fruits", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> fruits = \"Apple\", \"Banana\", \"Cherry\"\n\n// Insert a new fruit at the second position (index 1)\nfruits = Insert(fruits, \"Orange\", 1)\n\n// The updated VECTOR was previously printed to the console\n// fruits"}, {"name": "IsDisjoined (RegExJSi.List, RegExJSi.List)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed (their intersection results in an empty list).", "example_code": "// Define two RegExJSi.List objects\nRegExJSi.List list1 = [\"example_list1\"]\nRegExJSi.List list2 = [\"example_list2\"]\n\n// Check if the lists are disjoined\nBOOLEAN areDisjoined = IsDisjoined(list1, list2)\n\n// Print the result to the console\nIF areDisjoined THEN {\n    // The lists are disjoined.\n} ELSE {\n    // The lists are not disjoined.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two RegExJSi.List objects\nRegExJSi.List list1 = [\"example_list1\"]\nRegExJSi.List list2 = [\"example_list2\"]\n\n// Check if the lists are disjoined\nBOOLEAN areDisjoined = IsDisjoined(list1, list2)\n\n// Print the result to the console\nIF areDisjoined THEN {\n    // The lists are disjoined.\n} ELSE {\n    // The lists are not disjoined.\n}"}, {"name": "IsDisjoined (VECTOR<MediaType>, VECTOR<MediaType>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed. Their intersection results in an empty list.", "example_code": "VECTOR<MediaType> mediaTypes1 = [\"mediaTypeList1\"]\nVECTOR<MediaType> mediaTypes2 = [\"mediaTypeList2\"]\n\nIF IsDisjoined(mediaTypes1, mediaTypes2) THEN {\n    // The media types are disjoint.\n} ELSE {\n    // The media types are not disjoint.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MediaType> mediaTypes1 = [\"mediaTypeList1\"]\nVECTOR<MediaType> mediaTypes2 = [\"mediaTypeList2\"]\n\nIF IsDisjoined(mediaTypes1, mediaTypes2) THEN {\n    // The media types are disjoint.\n} ELSE {\n    // The media types are not disjoint.\n}"}, {"name": "IsDisjoined (VECTOR<MWG.HostAndCertificate>, VECTOR<MWG.HostAndCertificate>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed. Their intersection results in an empty list.", "example_code": "// Initialize two vectors of MWG.HostAndCertificate objects\nVECTOR<MWG.HostAndCertificate> hostList1 = MWG.ServerHostAndCert(), MWG.ServerHostAndCert()\nVECTOR<MWG.HostAndCertificate> hostList2 = MWG.ServerHostAndCert(), MWG.ServerHostAndCert()\n\n// Check if the two vectors are disjoint\nIF IsDisjoined(hostList1, hostList2) THEN {\n    // The host lists are disjoint.\n    // Additional actions if the lists are disjoint\n} ELSE {\n    // The host lists are not disjoint.\n    // Additional actions if the lists are not disjoint\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize two vectors of MWG.HostAndCertificate objects\nVECTOR<MWG.HostAndCertificate> hostList1 = MWG.ServerHostAndCert(), MWG.ServerHostAndCert()\nVECTOR<MWG.HostAndCertificate> hostList2 = MWG.ServerHostAndCert(), MWG.ServerHostAndCert()\n\n// Check if the two vectors are disjoint\nIF IsDisjoined(hostList1, hostList2) THEN {\n    // The host lists are disjoint.\n    // Additional actions if the lists are disjoint\n} ELSE {\n    // The host lists are not disjoint.\n    // Additional actions if the lists are not disjoint\n}"}, {"name": "IsDisjoined (VECTOR<MWG.UrlCategory>, VECTOR<MWG.UrlCategory>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed. Their intersection results in an empty list.", "example_code": "VECTOR<MWG.UrlCategory> categoryList1 = [\"CategoryList1\"]\nVECTOR<MWG.UrlCategory> categoryList2 = [\"CategoryList2\"]\n\nIF IsDisjoined(categoryList1, categoryList2) THEN {\n    // The URL categories are disjoint.\n} ELSE {\n    // The URL categories are not disjoint.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.UrlCategory> categoryList1 = [\"CategoryList1\"]\nVECTOR<MWG.UrlCategory> categoryList2 = [\"CategoryList2\"]\n\nIF IsDisjoined(categoryList1, categoryList2) THEN {\n    // The URL categories are disjoint.\n} ELSE {\n    // The URL categories are not disjoint.\n}"}, {"name": "IsDisjoined (VECTOR<Net.IP>, VECTOR<Net.IP>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed (their intersection results in an empty list).", "example_code": "VECTOR<Net.IP> vector1 = [\"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"]\nVECTOR<Net.IP> vector2 = [\"192.168.2.1\", \"192.168.2.2\", \"192.168.2.3\"]\n\nBOOLEAN isDisjoint = TRUE\n\nFOR EACH ip1 IN vector1 {\n    FOR EACH ip2 IN vector2 {\n        IF ip1 == ip2 THEN {\n            isDisjoint = FALSE\n            BREAK\n        }\n    }\n    IF NOT isDisjoint THEN {\n        BREAK\n    }\n}\n\nIF isDisjoint THEN {\n    // The vectors are disjoint.\n} ELSE {\n    // The vectors are not disjoint.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> vector1 = [\"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"]\nVECTOR<Net.IP> vector2 = [\"192.168.2.1\", \"192.168.2.2\", \"192.168.2.3\"]\n\nBOOLEAN isDisjoint = TRUE\n\nFOR EACH ip1 IN vector1 {\n    FOR EACH ip2 IN vector2 {\n        IF ip1 == ip2 THEN {\n            isDisjoint = FALSE\n            BREAK\n        }\n    }\n    IF NOT isDisjoint THEN {\n        BREAK\n    }\n}\n\nIF isDisjoint THEN {\n    // The vectors are disjoint.\n} ELSE {\n    // The vectors are not disjoint.\n}"}, {"name": "IsDisjoined (VECTOR<Net.IPRange>, VECTOR<Net.IPRange>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed. Their intersection results in an empty list.", "example_code": "VECTOR<Net.IPRange> list1 = \"192.168.1.0/24\", \"10.0.0.0/8\"\nVECTOR<Net.IPRange> list2 = \"172.16.0.0/12\", \"192.168.2.0/24\"\n\nBOOLEAN result = IsDisjoined(list1, list2)\n\nIF result THEN {\n    // The IP ranges are disjoined.\n} ELSE {\n    // The IP ranges are not disjoined.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> list1 = \"192.168.1.0/24\", \"10.0.0.0/8\"\nVECTOR<Net.IPRange> list2 = \"172.16.0.0/12\", \"192.168.2.0/24\"\n\nBOOLEAN result = IsDisjoined(list1, list2)\n\nIF result THEN {\n    // The IP ranges are disjoined.\n} ELSE {\n    // The IP ranges are not disjoined.\n}"}, {"name": "IsDisjoined (VECTOR<NUMBER>, VECTOR<NUMBER>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed (their intersection results in an empty list).", "example_code": "VECTOR<NUMBER> vector1 = 1, 2, 3\nVECTOR<NUMBER> vector2 = 4, 5, 6\n\nBOOLEAN result = IsDisjoined(vector1, vector2)\n\nIF result THEN {\n    // The number vectors are disjoint.\n} ELSE {\n    // The number vectors are not disjoint.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> vector1 = 1, 2, 3\nVECTOR<NUMBER> vector2 = 4, 5, 6\n\nBOOLEAN result = IsDisjoined(vector1, vector2)\n\nIF result THEN {\n    // The number vectors are disjoint.\n} ELSE {\n    // The number vectors are not disjoint.\n}"}, {"name": "IsDisjoined (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two lists have zero items in common.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the two lists are disjointed. Their intersection results in an empty list.", "example_code": "VECTOR<STRING> list1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> list2 = \"date\", \"fig\", \"grape\"\n\nIF IsDisjoined(list1, list2) THEN {\n    // The lists are disjoined.\n} ELSE {\n    // The lists are not disjoined.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> list1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> list2 = \"date\", \"fig\", \"grape\"\n\nIF IsDisjoined(list1, list2) THEN {\n    // The lists are disjoined.\n} ELSE {\n    // The lists are not disjoined.\n}"}, {"name": "IsDisjoinedCaseInsensitive (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "BOOLEAN", "return_desc": "Returns true if the two vectors have no overlapping elements, ignoring case.", "parameter_desc": "The parameters are two VECTORs that will be compared in a case-insensitive manner to determine if they are disjoint.", "description": "Is disjoined case insensitive.", "example_code": "VECTOR<STRING> vector1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> vector2 = \"date\", \"elderberry\", \"fig\"\n\nIF IsDisjoinedCaseInsensitive(vector1, vector2) THEN {\n    // The vectors are disjoint.\n} ELSE {\n    // The vectors are not disjoint.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> vector1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> vector2 = \"date\", \"elderberry\", \"fig\"\n\nIF IsDisjoinedCaseInsensitive(vector1, vector2) THEN {\n    // The vectors are disjoint.\n} ELSE {\n    // The vectors are not disjoint.\n}"}, {"name": "IsEmpty (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the given `STRING` has no characters, otherwise`FALSE`", "parameter_desc": "STRING: input text to be checked for emptiness.", "description": "Returns if the given string is empty.", "example_code": "STRING myString = \"Hello, World!\"\n\nIF IsEmpty(myString) THEN {\n    // The string is empty.\n} ELSE {\n    // The string is not empty.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING myString = \"Hello, World!\"\n\nIF IsEmpty(myString) THEN {\n    // The string is empty.\n} ELSE {\n    // The string is not empty.\n}"}, {"name": "IsSubSet (RegExJSi.List, RegExJSi.List)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "// Define two RegExJSi.List objects\nRegExJSi.List list1 = [\"example_list1\"]\nRegExJSi.List list2 = [\"example_list2\"]\n\n// Check if list1 is a subset of list2\nIF IsSubSet(list1, list2) THEN {\n    // list1 is a subset of list2\n} ELSE {\n    // list1 is not a subset of list2\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two RegExJSi.List objects\nRegExJSi.List list1 = [\"example_list1\"]\nRegExJSi.List list2 = [\"example_list2\"]\n\n// Check if list1 is a subset of list2\nIF IsSubSet(list1, list2) THEN {\n    // list1 is a subset of list2\n} ELSE {\n    // list1 is not a subset of list2\n}"}, {"name": "IsSubSet (VECTOR<MediaType>, VECTOR<MediaType>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "VECTOR<MediaType> allowedMediaTypes = [\"image/jpeg\", \"image/png\", \"application/pdf\"];\nVECTOR<MediaType> requestMediaTypes = [\"image/jpeg\", \"image/png\"];\n\nIF IsSubSet(requestMediaTypes, allowedMediaTypes) THEN {\n    // \"Request media types are allowed.\"\n    MWG.Allow(\"Media types are allowed\");\n} ELSE {\n    // \"Request media types are not allowed.\"\n    MWG.Block(\"Media types are not allowed\");\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MediaType> allowedMediaTypes = [\"image/jpeg\", \"image/png\", \"application/pdf\"];\nVECTOR<MediaType> requestMediaTypes = [\"image/jpeg\", \"image/png\"];\n\nIF IsSubSet(requestMediaTypes, allowedMediaTypes) THEN {\n    // \"Request media types are allowed.\"\n    MWG.Allow(\"Media types are allowed\");\n} ELSE {\n    // \"Request media types are not allowed.\"\n    MWG.Block(\"Media types are not allowed\");\n}"}, {"name": "IsSubSet (VECTOR<MWG.HostAndCertificate>, VECTOR<MWG.HostAndCertificate>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "VECTOR<MWG.HostAndCertificate> allowedHosts = [\"allowed_hosts_list\"]\nVECTOR<MWG.HostAndCertificate> currentHosts = [\"current_hosts_list\"]\n\nIF IsSubSet(currentHosts, allowedHosts) THEN {\n    // Current hosts are a subset of allowed hosts\n    MWG.Allow(\"SubsetCheckPassed\")\n} ELSE {\n    // Current hosts are NOT a subset of allowed hosts\n    MWG.Block(\"SubsetCheckFailed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.HostAndCertificate> allowedHosts = [\"allowed_hosts_list\"]\nVECTOR<MWG.HostAndCertificate> currentHosts = [\"current_hosts_list\"]\n\nIF IsSubSet(currentHosts, allowedHosts) THEN {\n    // Current hosts are a subset of allowed hosts\n    MWG.Allow(\"SubsetCheckPassed\")\n} ELSE {\n    // Current hosts are NOT a subset of allowed hosts\n    MWG.Block(\"SubsetCheckFailed\")\n}"}, {"name": "IsSubSet (VECTOR<MWG.UrlCategory>, VECTOR<MWG.UrlCategory>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "VECTOR<MWG.UrlCategory> allowedCategories = [\"allowed_categories_list\"]\nVECTOR<MWG.UrlCategory> currentCategories = [\"current_categories_list\"]\n\nIF IsSubSet(currentCategories, allowedCategories) THEN {\n    // The current URL categories are a subset of the allowed categories.\n    MWG.Allow(\"URL categories are allowed\")\n} ELSE {\n    // The current URL categories are NOT a subset of the allowed categories.\n    MWG.Block(\"URL categories are not allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.UrlCategory> allowedCategories = [\"allowed_categories_list\"]\nVECTOR<MWG.UrlCategory> currentCategories = [\"current_categories_list\"]\n\nIF IsSubSet(currentCategories, allowedCategories) THEN {\n    // The current URL categories are a subset of the allowed categories.\n    MWG.Allow(\"URL categories are allowed\")\n} ELSE {\n    // The current URL categories are NOT a subset of the allowed categories.\n    MWG.Block(\"URL categories are not allowed\")\n}"}, {"name": "IsSubSet (VECTOR<Net.IP>, VECTOR<Net.IP>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "VECTOR<Net.IP> allowedIPs = [\"allowed_ip_list\"]\nVECTOR<Net.IP> requestIPs = [\"request_ip_list\"]\n\nIF IsSubSet(requestIPs, allowedIPs) THEN {\n    // Request IPs are a subset of allowed IPs\n    MWG.Allow(\"IP Check Passed\")\n} ELSE {\n    // Request IPs are not a subset of allowed IPs\n    MWG.Block(\"IP Check Failed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> allowedIPs = [\"allowed_ip_list\"]\nVECTOR<Net.IP> requestIPs = [\"request_ip_list\"]\n\nIF IsSubSet(requestIPs, allowedIPs) THEN {\n    // Request IPs are a subset of allowed IPs\n    MWG.Allow(\"IP Check Passed\")\n} ELSE {\n    // Request IPs are not a subset of allowed IPs\n    MWG.Block(\"IP Check Failed\")\n}"}, {"name": "IsSubSet (VECTOR<Net.IPRange>, VECTOR<Net.IPRange>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "VECTOR<Net.IPRange> allowedRanges = [\"allowed_ip_ranges\"]\nVECTOR<Net.IPRange> requestRanges = [\"request_ip_ranges\"]\n\nIF IsSubSet(requestRanges, allowedRanges) THEN {\n    // IP ranges are within the allowed set\n    MWG.Allow()\n} ELSE {\n    // IP ranges are not within the allowed set\n    MWG.Block()\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> allowedRanges = [\"allowed_ip_ranges\"]\nVECTOR<Net.IPRange> requestRanges = [\"request_ip_ranges\"]\n\nIF IsSubSet(requestRanges, allowedRanges) THEN {\n    // IP ranges are within the allowed set\n    MWG.Allow()\n} ELSE {\n    // IP ranges are not within the allowed set\n    MWG.Block()\n}"}, {"name": "IsSubSet (VECTOR<NUMBER>, VECTOR<NUMBER>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "VECTOR<NUMBER> subset = 1, 2, 3\nVECTOR<NUMBER> superset = 1, 2, 3, 4, 5\n\nIF IsSubSet(subset, superset) THEN {\n    // The first vector is a subset of the second vector.\n} ELSE {\n    // The first vector is not a subset of the second vector.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> subset = 1, 2, 3\nVECTOR<NUMBER> superset = 1, 2, 3, 4, 5\n\nIF IsSubSet(subset, superset) THEN {\n    // The first vector is a subset of the second vector.\n} ELSE {\n    // The first vector is not a subset of the second vector.\n}"}, {"name": "IsSubSet (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first list is a subset of the second list.", "parameter_desc": "Two lists for comparison.", "description": "Checks if the first list is a subset of the second list. All items from the first list can be found in the second list.", "example_code": "VECTOR<STRING> subset = \"apple\", \"banana\"\nVECTOR<STRING> superset = \"apple\", \"banana\", \"cherry\", \"date\"\n\nIF IsSubSet(subset, superset) THEN {\n    // The first vector is a subset of the second vector.\n} ELSE {\n    // The first vector is NOT a subset of the second vector.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> subset = \"apple\", \"banana\"\nVECTOR<STRING> superset = \"apple\", \"banana\", \"cherry\", \"date\"\n\nIF IsSubSet(subset, superset) THEN {\n    // The first vector is a subset of the second vector.\n} ELSE {\n    // The first vector is NOT a subset of the second vector.\n}"}, {"name": "IsSubSetCaseInsensitive (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "BOOLEAN", "return_desc": "Returns true if all elements of the first vector are present in the second vector, ignoring case differences. Otherwise, it returns false.", "parameter_desc": "The parameters are two VECTORs which will be compared to check if the first is a subset of the second, ignoring case differences.", "description": "Is a subset case insensitive.", "example_code": "VECTOR<STRING> subset = \"apple\", \"banana\"\nVECTOR<STRING> superset = \"Apple\", \"Banana\", \"Cherry\"\n\nIF IsSubSetCaseInsensitive(subset, superset) THEN {\n    // The subset is contained within the superset (case insensitive).\n} ELSE {\n    // The subset is NOT contained within the superset (case insensitive).\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> subset = \"apple\", \"banana\"\nVECTOR<STRING> superset = \"Apple\", \"Banana\", \"Cherry\"\n\nIF IsSubSetCaseInsensitive(subset, superset) THEN {\n    // The subset is contained within the superset (case insensitive).\n} ELSE {\n    // The subset is NOT contained within the superset (case insensitive).\n}"}, {"name": "Join (RegExJSi.List, RegExJSi.List)", "return_type": "RegExJSi.List", "return_desc": "Returns a single list that is the concatenation of the two input lists.", "parameter_desc": "The parameters are two lists of type RegExJSi.List to be joined together.", "description": "Returns a join of two lists.", "example_code": "// Define two RegExJSi.List variables\nRegExJSi.List list1 = [\"pattern1\", \"pattern2\", \"pattern3\"]\nRegExJSi.List list2 = [\"pattern4\", \"pattern5\"]\n\n// Use the Join function to concatenate the two lists\nRegExJSi.List combinedList = Join(list1, list2)\n\n// The DEBUG line was used to print the combined list to the console for debugging\n// combinedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two RegExJSi.List variables\nRegExJSi.List list1 = [\"pattern1\", \"pattern2\", \"pattern3\"]\nRegExJSi.List list2 = [\"pattern4\", \"pattern5\"]\n\n// Use the Join function to concatenate the two lists\nRegExJSi.List combinedList = Join(list1, list2)\n\n// The DEBUG line was used to print the combined list to the console for debugging\n// combinedList"}, {"name": "Join (VECTOR<MediaType>, VECTOR<MediaType>)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "// Define two VECTOR<MediaType> variables\nVECTOR<MediaType> mediaList1 = MediaType(\"image/jpeg\"), MediaType(\"image/png\");\nVECTOR<MediaType> mediaList2 = MediaType(\"application/pdf\"), MediaType(\"text/plain\");\n\n// Use the Join function to combine the two lists\nVECTOR<MediaType> combinedMediaList = Join(mediaList1, mediaList2);\n\n// Combined Media List: combinedMediaList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two VECTOR<MediaType> variables\nVECTOR<MediaType> mediaList1 = MediaType(\"image/jpeg\"), MediaType(\"image/png\");\nVECTOR<MediaType> mediaList2 = MediaType(\"application/pdf\"), MediaType(\"text/plain\");\n\n// Use the Join function to combine the two lists\nVECTOR<MediaType> combinedMediaList = Join(mediaList1, mediaList2);\n\n// Combined Media List: combinedMediaList"}, {"name": "Join (VECTOR<MWG.ApplicationCategoryType>, VECTOR<MWG.ApplicationCategoryType>)", "return_type": "VECTOR<MWG.ApplicationCategoryType>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "// Define two vectors of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> vector1 = [\"CategoryList1\"]\nVECTOR<MWG.ApplicationCategoryType> vector2 = [\"CategoryList2\"]\n\n// Join the two vectors\nVECTOR<MWG.ApplicationCategoryType> combinedVector = Join(vector1, vector2)\n\n// Combined Vector: \" + combinedVector", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two vectors of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> vector1 = [\"CategoryList1\"]\nVECTOR<MWG.ApplicationCategoryType> vector2 = [\"CategoryList2\"]\n\n// Join the two vectors\nVECTOR<MWG.ApplicationCategoryType> combinedVector = Join(vector1, vector2)\n\n// Combined Vector: \" + combinedVector"}, {"name": "Join (VECTOR<MWG.ApplicationType>, VECTOR<MWG.ApplicationType>)", "return_type": "VECTOR<MWG.ApplicationType>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "// Define two vectors of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> vector1 = [\"AppTypeList1\"]\nVECTOR<MWG.ApplicationType> vector2 = [\"AppTypeList2\"]\n\n// Use the Join function to combine the two vectors\nVECTOR<MWG.ApplicationType> combinedVector = Join(vector1, vector2)\n\n// Combined Vector: \" + combinedVector", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two vectors of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> vector1 = [\"AppTypeList1\"]\nVECTOR<MWG.ApplicationType> vector2 = [\"AppTypeList2\"]\n\n// Use the Join function to combine the two vectors\nVECTOR<MWG.ApplicationType> combinedVector = Join(vector1, vector2)\n\n// Combined Vector: \" + combinedVector"}, {"name": "Join (VECTOR<MWG.HostAndCertificate>, VECTOR<MWG.HostAndCertificate>)", "return_type": "VECTOR<MWG.HostAndCertificate>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "// Define two VECTORs of MWG.HostAndCertificate\nVECTOR<MWG.HostAndCertificate> list1 = [\"host_cert_list1\"]\nVECTOR<MWG.HostAndCertificate> list2 = [\"host_cert_list2\"]\n\n// Use the Join function to combine the two lists\nVECTOR<MWG.HostAndCertificate> combinedList = Join(list1, list2)\n\n// Combined Host and Certificate List: combinedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two VECTORs of MWG.HostAndCertificate\nVECTOR<MWG.HostAndCertificate> list1 = [\"host_cert_list1\"]\nVECTOR<MWG.HostAndCertificate> list2 = [\"host_cert_list2\"]\n\n// Use the Join function to combine the two lists\nVECTOR<MWG.HostAndCertificate> combinedList = Join(list1, list2)\n\n// Combined Host and Certificate List: combinedList"}, {"name": "Join (VECTOR<MWG.UrlCategory>, VECTOR<MWG.UrlCategory>)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "// Define two VECTORs of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> categoryList1 = [\"SocialMedia\", \"News\"]\nVECTOR<MWG.UrlCategory> categoryList2 = [\"Shopping\", \"Entertainment\"]\n\n// Use the Join function to combine the two lists\nVECTOR<MWG.UrlCategory> combinedCategories = Join(categoryList1, categoryList2)\n\n// Combined URL Categories: combinedCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two VECTORs of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> categoryList1 = [\"SocialMedia\", \"News\"]\nVECTOR<MWG.UrlCategory> categoryList2 = [\"Shopping\", \"Entertainment\"]\n\n// Use the Join function to combine the two lists\nVECTOR<MWG.UrlCategory> combinedCategories = Join(categoryList1, categoryList2)\n\n// Combined URL Categories: combinedCategories"}, {"name": "Join (VECTOR<Net.IP>, VECTOR<Net.IP>)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "VECTOR<Net.IP> list1 = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"\nVECTOR<Net.IP> list2 = \"10.0.0.1\", \"10.0.0.2\", \"10.0.0.3\"\n\nVECTOR<Net.IP> combinedList = Join(list1, list2)\n\n// Combined IP List: \" + combinedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> list1 = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"\nVECTOR<Net.IP> list2 = \"10.0.0.1\", \"10.0.0.2\", \"10.0.0.3\"\n\nVECTOR<Net.IP> combinedList = Join(list1, list2)\n\n// Combined IP List: \" + combinedList"}, {"name": "Join (VECTOR<Net.IPRange>, VECTOR<Net.IPRange>)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "// Define two vectors of Net.IPRange\nVECTOR<Net.IPRange> ipRangeVector1 = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\");\nVECTOR<Net.IPRange> ipRangeVector2 = Net.IPRange(\"172.16.0.0/12\"), Net.IPRange(\"192.168.2.0/24\");\n\n// Join the two vectors\nVECTOR<Net.IPRange> combinedIPRanges = Join(ipRangeVector1, ipRangeVector2);\n\n// Combined IP Ranges: combinedIPRanges", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two vectors of Net.IPRange\nVECTOR<Net.IPRange> ipRangeVector1 = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\");\nVECTOR<Net.IPRange> ipRangeVector2 = Net.IPRange(\"172.16.0.0/12\"), Net.IPRange(\"192.168.2.0/24\");\n\n// Join the two vectors\nVECTOR<Net.IPRange> combinedIPRanges = Join(ipRangeVector1, ipRangeVector2);\n\n// Combined IP Ranges: combinedIPRanges"}, {"name": "Join (VECTOR<NUMBER>, VECTOR<NUMBER>)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "VECTOR<NUMBER> list1 = 1, 2, 3\nVECTOR<NUMBER> list2 = 4, 5, 6\n\nVECTOR<NUMBER> combinedList = Join(list1, list2)\n\n// Output combinedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> list1 = 1, 2, 3\nVECTOR<NUMBER> list2 = 4, 5, 6\n\nVECTOR<NUMBER> combinedList = Join(list1, list2)\n\n// Output combinedList"}, {"name": "Join (VECTOR<STRING>, STRING)", "return_type": "STRING", "return_desc": "Returns the vector converted into a single string.", "parameter_desc": "VECTOR<STRING>: list of STRINGs to combine; STRING: delimiter to use.", "description": "Combines all of the strings found in the vector into one with the specified delimiter in between each string.", "example_code": "VECTOR<STRING> words = \"Hello\", \"world\", \"this\", \"is\", \"MOWGLI\"\nSTRING delimiter = \" \"\nSTRING result = Join(words, delimiter)\n// Output: \"Hello world this is MOWGLI\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> words = \"Hello\", \"world\", \"this\", \"is\", \"MOWGLI\"\nSTRING delimiter = \" \"\nSTRING result = Join(words, delimiter)\n// Output: \"Hello world this is MOWGLI\""}, {"name": "Join (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "VECTOR<STRING>", "return_desc": "Returns the two lists combined.", "parameter_desc": "Two lists to combine.", "description": "Joins two lists into one.", "example_code": "VECTOR<STRING> vector1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> vector2 = \"date\", \"elderberry\", \"fig\"\n\nVECTOR<STRING> result = Join(vector1, vector2)\n\n// Resulting vector: \" + result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> vector1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> vector2 = \"date\", \"elderberry\", \"fig\"\n\nVECTOR<STRING> result = Join(vector1, vector2)\n\n// Resulting vector: \" + result"}, {"name": "JSON.ArrayAppend (JSON, BOOLEAN)", "return_type": "JSON", "return_desc": "Returns a JSON array with the input`BOOLEAN`value appended to its end.", "parameter_desc": "JSON: array to append to; BOOLEAN: value to append.", "description": "Adds a Boolean at the end of an array.", "example_code": "// Initialize a JSON array\nJSON jsonArray = [true, false, true]\n\n// Boolean value to append\nBOOLEAN newValue = false\n\n// Append the boolean value to the JSON array\nJSON updatedArray = JSON.ArrayAppend(jsonArray, newValue)\n\n// Print the updated array to the console\n// updatedArray", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a JSON array\nJSON jsonArray = [true, false, true]\n\n// Boolean value to append\nBOOLEAN newValue = false\n\n// Append the boolean value to the JSON array\nJSON updatedArray = JSON.ArrayAppend(jsonArray, newValue)\n\n// Print the updated array to the console\n// updatedArray"}, {"name": "JSON.ArrayAppend (JSON, JSON)", "return_type": "JSON", "return_desc": "Returns a JSON array with the specified JSON object appended to the end.", "parameter_desc": "JSON: array to append to; JSON: object to append.", "description": "Adds a JSON object at the end of an array.", "example_code": "JSON array1 = [1, 2, 3]\nJSON array2 = [4, 5, 6]\n\nJSON combinedArray = ArrayAppend(array1, array2)\n\n// Output combinedArray", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON array1 = [1, 2, 3]\nJSON array2 = [4, 5, 6]\n\nJSON combinedArray = ArrayAppend(array1, array2)\n\n// Output combinedArray"}, {"name": "JSON.ArrayAppend (JSON, NUMBER)", "return_type": "JSON", "return_desc": "Returns a JSON array with the specified number appended to its end.", "parameter_desc": "JSON: array to append to; NUMBER: value to append.", "description": "Adds a number at the end of an array.", "example_code": "JSON jsonArray = [1, 2, 3]\nNUMBER numberToAdd = 4\nJSON numberAsJson = [numberToAdd]  // Convert the number to a JSON array\nJSON combinedArray = ArrayAppend(jsonArray, numberAsJson)\n// Debug: combinedArray", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON jsonArray = [1, 2, 3]\nNUMBER numberToAdd = 4\nJSON numberAsJson = [numberToAdd]  // Convert the number to a JSON array\nJSON combinedArray = ArrayAppend(jsonArray, numberAsJson)\n// Debug: combinedArray"}, {"name": "JSON.ArrayAppend (JSON, STRING)", "return_type": "JSON", "return_desc": "Returns the original JSON array with the specified string appended to the end.", "parameter_desc": "JSON: array to append to; STRING: value to append.", "description": "Adds a string at the end of an array.", "example_code": "JSON array1 = [\"{\\\"name\\\": \\\"John\\\"}\", \"{\\\"name\\\": \\\"Jane\\\"}\"]\nJSON array2 = [\"{\\\"name\\\": \\\"Doe\\\"}\", \"{\\\"name\\\": \\\"Smith\\\"}\"]\n\nJSON combinedArray = ArrayAppend(array1, array2)\n\n// Output: combinedArray", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON array1 = [\"{\"name\": \"John\"}\", \"{\"name\": \"Jane\"}\"]\nJSON array2 = [\"{\"name\": \"Doe\"}\", \"{\"name\": \"Smith\"}\"]\n\nJSON combinedArray = ArrayAppend(array1, array2)\n\n// Output: combinedArray"}, {"name": "JSON.ArrayInsertAt (JSON, NUMBER, JSON)", "return_type": "JSON", "return_desc": "Returns the original JSON array with the specified JSON element inserted at the specified position.", "parameter_desc": "JSON: JSON object to insert into; NUMBER: position to insert; JSON: element to insert.", "description": "Inserts the second JSON parameter into the input JSON array (first parameter) at the given position.", "example_code": "// Define the original JSON array\nJSON originalArray = JSON.Parse('[{\"name\": \"Alice\"}, {\"name\": \"Bob\"}]')\n\n// Define the JSON element to insert\nJSON newElement = JSON.Parse('{\"name\": \"Charlie\"}')\n\n// Define the position to insert the new element\nNUMBER position = 1\n\n// Insert the new element into the original array at the specified position\nJSON updatedArray = JSON.ArrayInsertAt(originalArray, position, newElement)\n\n// Print the updated JSON array to the console\n// updatedArray.ToString()\n\nIn this example:\n1. We start by defining an original JSON array with two elements.\n2. We then define a new JSON element that we want to insert into the array.\n3. We specify the position at which we want to insert the new element (in this case, position `1`).\n4. We use the `JSON.ArrayInsertAt` function to insert the new element into the original array at the specified position.\n5. Finally, we print the updated JSON array to the console using the `DEBUG` function.\n\nWhen this routine is executed, the output will be:\n\n[{\"name\": \"Alice\"}, {\"name\": \"Charlie\"}, {\"name\": \"Bob\"}]", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the original JSON array\nJSON originalArray = JSON.Parse('[{\"name\": \"Alice\"}, {\"name\": \"Bob\"}]')\n\n// Define the JSON element to insert\nJSON newElement = JSON.Parse('{\"name\": \"Charlie\"}')\n\n// Define the position to insert the new element\nNUMBER position = 1\n\n// Insert the new element into the original array at the specified position\nJSON updatedArray = JSON.ArrayInsertAt(originalArray, position, newElement)\n\n// Print the updated JSON array to the console\n// updatedArray.ToString()\n\nIn this example:\n1. We start by defining an original JSON array with two elements.\n2. We then define a new JSON element that we want to insert into the array.\n3. We specify the position at which we want to insert the new element (in this case, position `1`).\n4. We use the `JSON.ArrayInsertAt` function to insert the new element into the original array at the specified position.\n5. Finally, we print the updated JSON array to the console using the `DEBUG` function.\n\nWhen this routine is executed, the output will be:\n\n[{\"name\": \"Alice\"}, {\"name\": \"Charlie\"}, {\"name\": \"Bob\"}]"}, {"name": "JSON.ArrayRemove (JSON, NUMBER)", "return_type": "JSON", "return_desc": "Returns a JSON array with the n-th element removed.", "parameter_desc": "JSON: array to remove from; NUMBER: zero-based index of the value to be removed.", "description": "Removes the n-th value from a JSON array.", "example_code": "// Sample JSON array\nJSON jsonArray = JSON.Parse(\"[\\\"apple\\\", \\\"banana\\\", \\\"cherry\\\"]\")\n\n// Remove the second element (index 1)\nJSON updatedArray = JSON.ArrayRemove(jsonArray, 1)\n\n// Updated JSON Array: \" + JSON.Stringify(updatedArray)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Sample JSON array\nJSON jsonArray = JSON.Parse(\"[\"apple\", \"banana\", \"cherry\"]\")\n\n// Remove the second element (index 1)\nJSON updatedArray = JSON.ArrayRemove(jsonArray, 1)\n\n// Updated JSON Array: \" + JSON.Stringify(updatedArray)"}, {"name": "JSON.ArrayReplaceAt (JSON, NUMBER, JSON)", "return_type": "JSON", "return_desc": "Returns the original JSON array with the specified JSON element replacing what was at the specified position.", "parameter_desc": "JSON: JSON object to insert into; NUMBER: position to replace; JSON: element to replace with.", "description": "Replaces the JSON element at the specified position in the input JSON (first parameter) with the specified JSON element (last parameter).", "example_code": "// Original JSON array\nJSON originalArray = JSON.Parse('[{\"name\": \"Alice\"}, {\"name\": \"Bob\"}, {\"name\": \"Charlie\"}]')\n\n// New JSON element to replace with\nJSON newElement = JSON.Parse('{\"name\": \"David\"}')\n\n// Position to replace (0-based index)\nNUMBER position = 1\n\n// Replace the element at the specified position\nJSON updatedArray = JSON.ArrayReplaceAt(originalArray, position, newElement)\n\n// Print the updated JSON array to the console\n// updatedArray.ToString()\n\n// In this example:\n// - We start with an original JSON array containing three objects.\n// - We create a new JSON element that we want to insert into the array.\n// - We specify the position (index 1, which corresponds to the second element in the array) where we want to replace the existing element.\n// - We use the `JSON.ArrayReplaceAt` function to replace the element at the specified position with the new element.\n// - Finally, we print the updated JSON array to the console using the `DEBUG` function.\n\n// When executed, the output will be:\n\n// [{\"name\": \"Alice\"}, {\"name\": \"David\"}, {\"name\": \"Charlie\"}]", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Original JSON array\nJSON originalArray = JSON.Parse('[{\"name\": \"Alice\"}, {\"name\": \"Bob\"}, {\"name\": \"Charlie\"}]')\n\n// New JSON element to replace with\nJSON newElement = JSON.Parse('{\"name\": \"David\"}')\n\n// Position to replace (0-based index)\nNUMBER position = 1\n\n// Replace the element at the specified position\nJSON updatedArray = JSON.ArrayReplaceAt(originalArray, position, newElement)\n\n// Print the updated JSON array to the console\n// updatedArray.ToString()\n\n// In this example:\n// - We start with an original JSON array containing three objects.\n// - We create a new JSON element that we want to insert into the array.\n// - We specify the position (index 1, which corresponds to the second element in the array) where we want to replace the existing element.\n// - We use the `JSON.ArrayReplaceAt` function to replace the element at the specified position with the new element.\n// - Finally, we print the updated JSON array to the console using the `DEBUG` function.\n\n// When executed, the output will be:\n\n// [{\"name\": \"Alice\"}, {\"name\": \"David\"}, {\"name\": \"Charlie\"}]"}, {"name": "JSON.AsBool (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns the`BOOLEAN`representation of the provided JSON value.", "parameter_desc": "JSON: the value to be converted to a BOOLEAN.", "description": "Converts JSON value to a BOOLEAN.", "example_code": "// Example JSON object\nJSON exampleJson = {\"isActive\": true}\n\n// Extract the \"isActive\" field from the JSON object\nJSON isActiveField = exampleJson[\"isActive\"]\n\n// Convert the JSON field to a BOOLEAN\nBOOLEAN isActive = JSON.AsBool(isActiveField)\n\n// Use the BOOLEAN value in a condition\nIF isActive THEN {\n    // The isActive field is TRUE\n} ELSE {\n    // The isActive field is FALSE\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON exampleJson = {\"isActive\": true}\n\n// Extract the \"isActive\" field from the JSON object\nJSON isActiveField = exampleJson[\"isActive\"]\n\n// Convert the JSON field to a BOOLEAN\nBOOLEAN isActive = JSON.AsBool(isActiveField)\n\n// Use the BOOLEAN value in a condition\nIF isActive THEN {\n    // The isActive field is TRUE\n} ELSE {\n    // The isActive field is FALSE\n}"}, {"name": "JSON.AsDouble (JSON)", "return_type": "NUMBER", "return_desc": "Returns the numeric value extracted from the given JSON object.", "parameter_desc": "JSON: The JSON object containing the value to be converted to a NUMBER.", "description": "Converts JSON value to a number.", "example_code": "// Example JSON object\nJSON jsonObject = JSON.Parse('{\"value\": 42.5}')\n\n// Extract the numeric value from the JSON object\nNUMBER extractedValue = JSON.AsDouble(jsonObject.value)\n\n// Extracted Value: \n// + extractedValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON jsonObject = JSON.Parse('{\"value\": 42.5}')\n\n// Extract the numeric value from the JSON object\nNUMBER extractedValue = JSON.AsDouble(jsonObject.value)\n\n// Extracted Value: \n// + extractedValue"}, {"name": "JSON.AsInt64 (JSON)", "return_type": "NUMBER", "return_desc": "Returns the JSON value converted to a 64-bit integer (`NUMBER`).", "parameter_desc": "JSON: value to be converted to a NUMBER.", "description": "Converts JSON value to a number.", "example_code": "// Example JSON object\nJSON jsonObject = {\"value\": 12345}\n\n// Extract the value from the JSON object\nJSON jsonValue = jsonObject[\"value\"]\n\n// Convert the JSON value to a 64-bit integer\nNUMBER intValue = JSON.AsInt64(jsonValue)\n\n// Converted value: intValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON jsonObject = {\"value\": 12345}\n\n// Extract the value from the JSON object\nJSON jsonValue = jsonObject[\"value\"]\n\n// Convert the JSON value to a 64-bit integer\nNUMBER intValue = JSON.AsInt64(jsonValue)\n\n// Converted value: intValue"}, {"name": "JSON.AsNumber (JSON)", "return_type": "NUMBER", "return_desc": "Returns the numerical value extracted from the given JSON input.", "parameter_desc": "JSON: A JSON value to convert to a NUMBER.", "description": "Converts JSON value to a number.", "example_code": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"key1\": \"value1\",\n    \"key2\": 42,\n    \"key3\": 3.14\n}\n\n// Extract the number associated with \"key2\"\nNUMBER extractedNumber = JSON.GetAsNumber(jsonObject, \"key2\")\n\n// Extracted Number: 42\n// DEBUG(\"Extracted Number: \" + extractedNumber)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"key1\": \"value1\",\n    \"key2\": 42,\n    \"key3\": 3.14\n}\n\n// Extract the number associated with \"key2\"\nNUMBER extractedNumber = JSON.GetAsNumber(jsonObject, \"key2\")\n\n// Extracted Number: 42\n// DEBUG(\"Extracted Number: \" + extractedNumber)"}, {"name": "JSON.AsSTRING (JSON)", "return_type": "STRING", "return_desc": "Returns a string representation of the provided JSON.", "parameter_desc": "JSON: input value to convert to a STRING.", "description": "Converts JSON value to a string.", "example_code": "// Example JSON object\nJSON exampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Convert JSON object to STRING\nSTRING jsonString = JSON.AsString(exampleJson)\n\n// Print the STRING representation of the JSON object\n// jsonString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON exampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Convert JSON object to STRING\nSTRING jsonString = JSON.AsString(exampleJson)\n\n// Print the STRING representation of the JSON object\n// jsonString"}, {"name": "JSON.At (JSON, NUMBER)", "return_type": "JSON", "return_desc": "Returns the n-th element from a JSON array.", "parameter_desc": "JSON: array to retrieve from; NUMBER: position of value to retrieve.", "description": "Returns the n-th value of a JSON array.", "example_code": "// Sample JSON array\nJSON jsonArray = [\"{\\\"name\\\": \\\"John\\\"}\", \"{\\\"name\\\": \\\"Jane\\\"}\", \"{\\\"name\\\": \\\"Doe\\\"}\"]\n\n// Retrieve the third element (index 2, as indexing is zero-based)\nJSON thirdElement = JSON.At(jsonArray, 2)\n\n// This line was originally a DEBUG() function call to print the third element to the console\n// thirdElement", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Sample JSON array\nJSON jsonArray = [\"{\"name\": \"John\"}\", \"{\"name\": \"Jane\"}\", \"{\"name\": \"Doe\"}\"]\n\n// Retrieve the third element (index 2, as indexing is zero-based)\nJSON thirdElement = JSON.At(jsonArray, 2)\n\n// This line was originally a DEBUG() function call to print the third element to the console\n// thirdElement"}, {"name": "JSON.CreateEmptyArray ()", "return_type": "JSON", "return_desc": "Returns an empty JSON array.", "parameter_desc": "None", "description": "Creates an empty JSON array.", "example_code": "JSON emptyObject = JSON.CreateEmptyObject()\n// Created an empty JSON object: + emptyObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON emptyObject = JSON.CreateEmptyObject()\n// Created an empty JSON object: + emptyObject"}, {"name": "JSON.CreateEmptyObject ()", "return_type": "JSON", "return_desc": "Returns an empty JSON object.", "parameter_desc": "None", "description": "Creates an empty JSON object.", "example_code": "// Create an empty JSON object\nJSON emptyJson = JSON.CreateEmptyObject()\n\n// Print the empty JSON object to the console\n// emptyJson", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an empty JSON object\nJSON emptyJson = JSON.CreateEmptyObject()\n\n// Print the empty JSON object to the console\n// emptyJson"}, {"name": "JSON.CreateNull ()", "return_type": "JSON", "return_desc": "Returns a null JSON object.", "parameter_desc": "None", "description": "Creates a null JSON object.", "example_code": "// Create a null JSON object\nJSON nullObject = JSON.CreateNull()\n\n// Created JSON object: \" + nullObject\n// This line was originally a DEBUG() function call.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a null JSON object\nJSON nullObject = JSON.CreateNull()\n\n// Created JSON object: \" + nullObject\n// This line was originally a DEBUG() function call."}, {"name": "JSON.ElementMatching (JSON, STRING, NUMBER)", "return_type": "JSON", "return_desc": "Returns the JSON object from an array where the specified key equals the given value.", "parameter_desc": "JSON: the array to search; STRING: the key to match; NUMBER: the value to match.", "description": "Returns the object of an array of objects for which the given key matches a given value.", "example_code": "// Sample JSON object\nJSON sampleJson = {\n    \"items\": [\n        {\"id\": 1, \"name\": \"Item1\"},\n        {\"id\": 2, \"name\": \"Item2\"},\n        {\"id\": 3, \"name\": \"Item3\"}\n    ]\n}\n\n// Use JSON.ElementMatching to find an element with a specific id\nJSON matchingElement = JSON.ElementMatching(sampleJson, \"items.id\", 2)\n\n// Check if a matching element was found\nIF matchingElement != NULL THEN {\n    // Found matching element: + matchingElement\n} ELSE {\n    // No matching element found\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Sample JSON object\nJSON sampleJson = {\n    \"items\": [\n        {\"id\": 1, \"name\": \"Item1\"},\n        {\"id\": 2, \"name\": \"Item2\"},\n        {\"id\": 3, \"name\": \"Item3\"}\n    ]\n}\n\n// Use JSON.ElementMatching to find an element with a specific id\nJSON matchingElement = JSON.ElementMatching(sampleJson, \"items.id\", 2)\n\n// Check if a matching element was found\nIF matchingElement != NULL THEN {\n    // Found matching element: + matchingElement\n} ELSE {\n    // No matching element found\n}"}, {"name": "JSON.ElementMatching (JSON, STRING, STRING)", "return_type": "JSON", "return_desc": "Returns a JSON object from an array where the specified key has the specified value.", "parameter_desc": "JSON: the array to search; STRING: a key to match STRING: the desired value for that key.", "description": "Returns the object of an array of objects for which the given key matches a given value.", "example_code": "// Sample JSON array\nJSON jsonArray = [\n    {\"id\": \"1\", \"name\": \"Alice\"},\n    {\"id\": \"2\", \"name\": \"Bob\"},\n    {\"id\": \"3\", \"name\": \"Charlie\"}\n]\n\n// Key and value to match\nSTRING key = \"name\"\nSTRING value = \"Bob\"\n\n// Find elements matching the key-value pair\nJSON matchingElements = JSON.ElementMatching(jsonArray, key, value)\n\n// The matching elements would be printed to the console here\n// matchingElements\n\nIn this example:\n- We define a JSON array `jsonArray` containing several objects.\n- We specify the key `\"name\"` and the value `\"Bob\"` that we want to match.\n- We use the `JSON.ElementMatching` function to find elements in the `jsonArray` that have the key `\"name\"` with the value `\"Bob\"`.\n- Finally, we would print the matching elements to the console.\n\nWhen this code runs, it would output the JSON object(s) that match the specified key-value pair. In this case, it would output:\njson\n[\n    {\"id\": \"2\", \"name\": \"Bob\"}\n]", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Sample JSON array\nJSON jsonArray = [\n    {\"id\": \"1\", \"name\": \"Alice\"},\n    {\"id\": \"2\", \"name\": \"Bob\"},\n    {\"id\": \"3\", \"name\": \"Charlie\"}\n]\n\n// Key and value to match\nSTRING key = \"name\"\nSTRING value = \"Bob\"\n\n// Find elements matching the key-value pair\nJSON matchingElements = JSON.ElementMatching(jsonArray, key, value)\n\n// The matching elements would be printed to the console here\n// matchingElements\n\nIn this example:\n- We define a JSON array `jsonArray` containing several objects.\n- We specify the key `\"name\"` and the value `\"Bob\"` that we want to match.\n- We use the `JSON.ElementMatching` function to find elements in the `jsonArray` that have the key `\"name\"` with the value `\"Bob\"`.\n- Finally, we would print the matching elements to the console.\n\nWhen this code runs, it would output the JSON object(s) that match the specified key-value pair. In this case, it would output:\njson\n[\n    {\"id\": \"2\", \"name\": \"Bob\"}\n]"}, {"name": "JSON.Empty (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the JSON is an empty object, array, or null.", "parameter_desc": "JSON: the object or array to be checked for emptiness.", "description": "Returns TRUE if JSON is an empty object/array or null value.", "example_code": "// Assume jsonObject is initialized with some JSON data\nJSON jsonObject = ... \n\n// Check if the JSON object is empty\nIF JSON.Empty(jsonObject) THEN {\n    // The JSON object is empty.\n} ELSE {\n    // The JSON object is not empty.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume jsonObject is initialized with some JSON data\nJSON jsonObject = ... \n\n// Check if the JSON object is empty\nIF JSON.Empty(jsonObject) THEN {\n    // The JSON object is empty.\n} ELSE {\n    // The JSON object is not empty.\n}"}, {"name": "JSON.Equals (JSON, JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two JSON values are identical in content, otherwise`FALSE`", "parameter_desc": "The parameters are two JSON objects to be compared for content equality.", "description": "Compares the content of two JSON values.", "example_code": "JSON json1 = {\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}\nJSON json2 = {\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}\nJSON json3 = {\"name\": \"Jane\", \"age\": 25, \"city\": \"Los Angeles\"}\n\nIF JSON.Equals(json1, json2) THEN {\n    // json1 and json2 are identical.\n} ELSE {\n    // json1 and json2 are not identical.\n}\n\nIF JSON.Equals(json1, json3) THEN {\n    // json1 and json3 are identical.\n} ELSE {\n    // json1 and json3 are not identical.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON json1 = {\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}\nJSON json2 = {\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}\nJSON json3 = {\"name\": \"Jane\", \"age\": 25, \"city\": \"Los Angeles\"}\n\nIF JSON.Equals(json1, json2) THEN {\n    // json1 and json2 are identical.\n} ELSE {\n    // json1 and json2 are not identical.\n}\n\nIF JSON.Equals(json1, json3) THEN {\n    // json1 and json3 are identical.\n} ELSE {\n    // json1 and json3 are not identical.\n}"}, {"name": "JSON.FromBool (BOOLEAN)", "return_type": "JSON", "return_desc": "Returns JSON object from`BOOLEAN`value.", "parameter_desc": "BOOLEAN: the BOOLEAN value to convert", "description": "Returns JSON object from BOOLEAN value.", "example_code": "BOOLEAN isActive = TRUE\nJSON jsonObject = JSON.FromBool(isActive)\n// JSON Object: \" + jsonObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "BOOLEAN isActive = TRUE\nJSON jsonObject = JSON.FromBool(isActive)\n// JSON Object: \" + jsonObject"}, {"name": "JSON.FromNumber (NUMBER)", "return_type": "JSON", "return_desc": "Returns JSON object from `NUMBER` value.", "parameter_desc": "NUMBER: the NUMBER value to convert", "description": "Returns JSON object from `NUMBER` value.", "example_code": "NUMBER myNumber = 42\nJSON myJson = JSON.FromNumber(myNumber)\n// Converted JSON: \" + myJson", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER myNumber = 42\nJSON myJson = JSON.FromNumber(myNumber)\n// Converted JSON: \" + myJson"}, {"name": "JSON.FromNumberVector (VECTOR<NUMBER>)", "return_type": "JSON", "return_desc": "Returns JSON array object from `NUMBER` `VECTOR`", "parameter_desc": "VECTOR<NUMBER>: the NUMBER list to convert.", "description": "Returns JSON array object from `NUMBER` VECTOR.", "example_code": "// Initialize a VECTOR<NUMBER> with some values\nVECTOR<NUMBER> numberVector = 1, 2, 3.5, 4.75\n\n// Convert the VECTOR<NUMBER> to a JSON object\nJSON jsonObject = JSON.FromNumberVector(numberVector)\n\n// Print the JSON object to the console was here\n// jsonObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR<NUMBER> with some values\nVECTOR<NUMBER> numberVector = 1, 2, 3.5, 4.75\n\n// Convert the VECTOR<NUMBER> to a JSON object\nJSON jsonObject = JSON.FromNumberVector(numberVector)\n\n// Print the JSON object to the console was here\n// jsonObject"}, {"name": "JSON.FromSTRING (STRING)", "return_type": "JSON", "return_desc": "Returns a JSON object parsed from the input string.", "parameter_desc": "STRING: input text to be converted to a JSON object.", "description": "Converts a string to a JSON object.", "example_code": "// Define a JSON-formatted string\nSTRING jsonString = '{\"name\": \"John Doe\", \"age\": 30, \"isEmployee\": true}'\n\n// Convert the JSON-formatted string to a JSON object\nJSON jsonObject = JSON.FromString(jsonString)\n\n// Use the JSON object (for example, set a user-defined variable)\nMWG.SetUserDefinedVar(\"userInfo\", jsonObject)\n\n// Print the JSON object to the console for debugging\n// jsonObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a JSON-formatted string\nSTRING jsonString = '{\"name\": \"John Doe\", \"age\": 30, \"isEmployee\": true}'\n\n// Convert the JSON-formatted string to a JSON object\nJSON jsonObject = JSON.FromString(jsonString)\n\n// Use the JSON object (for example, set a user-defined variable)\nMWG.SetUserDefinedVar(\"userInfo\", jsonObject)\n\n// Print the JSON object to the console for debugging\n// jsonObject"}, {"name": "JSON.FromSTRINGIgnoreErrors (STRING)", "return_type": "JSON", "return_desc": "Returns a JSON object parsed from the input string, with errors in formatting ignored.", "parameter_desc": "STRING: input text to be converted to a JSON object.", "description": "Converts a string to a JSON object while ignoring bad format.", "example_code": "STRING jsonString = \"{ \\\"name\\\": \\\"John Doe\\\", \\\"age\\\": 30 }\"\nJSON jsonObject = JSON.FromStringIgnoreErrors(jsonString)\n\n// Converted JSON Object: \" + jsonObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING jsonString = \"{ \"name\": \"John Doe\", \"age\": 30 }\"\nJSON jsonObject = JSON.FromStringIgnoreErrors(jsonString)\n\n// Converted JSON Object: \" + jsonObject"}, {"name": "JSON.FromSTRINGVector (VECTOR<STRING>)", "return_type": "JSON", "return_desc": "Returns JSON array object from string vector.", "parameter_desc": "VECTOR<STRING>: the STRING list to be converted", "description": "Returns JSON array object from string vector.", "example_code": "// Initialize a VECTOR<STRING>\nVECTOR<STRING> stringVector = \"apple\", \"banana\", \"cherry\"\n\n// Convert the VECTOR<STRING> to a JSON object\nJSON jsonObject = JSON.FromStringVector(stringVector)\n\n// The following line would print the JSON object to the console for debugging\n// jsonObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR<STRING>\nVECTOR<STRING> stringVector = \"apple\", \"banana\", \"cherry\"\n\n// Convert the VECTOR<STRING> to a JSON object\nJSON jsonObject = JSON.FromStringVector(stringVector)\n\n// The following line would print the JSON object to the console for debugging\n// jsonObject"}, {"name": "JSON.Get (JSON, STRING)", "return_type": "JSON", "return_desc": "Returns the JSON value associated with the specified key in the given JSON object.", "parameter_desc": "JSON: the input JSON object to retrieve from; STRING: the key whose value is to be retrieved.", "description": "Returns JSON value at the given key of a JSON field.", "example_code": "// Sample JSON object\nJSON sampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Retrieve the value associated with the key \"email\"\nSTRING email = JSON.Get(sampleJson, \"email\")\n\n// Retrieved email: \"john.doe@example.com\"\n// DEBUG(\"Retrieved email: \" + email)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Sample JSON object\nJSON sampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Retrieve the value associated with the key \"email\"\nSTRING email = JSON.Get(sampleJson, \"email\")\n\n// Retrieved email: \"john.doe@example.com\"\n// DEBUG(\"Retrieved email: \" + email)"}, {"name": "JSON.GetAsBool (JSON, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns the specified JSON element as a`BOOLEAN`value.", "parameter_desc": "JSON: the JSON object to retrieve the value from; STRING: the key of the element to be retrieved.", "description": "Gets element and returns it as BOOLEAN.", "example_code": "// Assume we have a JSON object\nJSON jsonObject = JSON.Parse('{\"isActive\": true, \"isVerified\": false}')\n\n// Retrieve the boolean value for the key \"isActive\"\nBOOLEAN isActive = JSON.GetAsBool(jsonObject, \"isActive\")\n// \"isActive: \" + isActive\n\n// Retrieve the boolean value for the key \"isVerified\"\nBOOLEAN isVerified = JSON.GetAsBool(jsonObject, \"isVerified\")\n// \"isVerified: \" + isVerified\n\n// Conditional logic based on the boolean values\nIF isActive THEN {\n    // \"The user is active.\"\n} ELSE {\n    // \"The user is not active.\"\n}\n\nIF isVerified THEN {\n    // \"The user is verified.\"\n} ELSE {\n    // \"The user is not verified.\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a JSON object\nJSON jsonObject = JSON.Parse('{\"isActive\": true, \"isVerified\": false}')\n\n// Retrieve the boolean value for the key \"isActive\"\nBOOLEAN isActive = JSON.GetAsBool(jsonObject, \"isActive\")\n// \"isActive: \" + isActive\n\n// Retrieve the boolean value for the key \"isVerified\"\nBOOLEAN isVerified = JSON.GetAsBool(jsonObject, \"isVerified\")\n// \"isVerified: \" + isVerified\n\n// Conditional logic based on the boolean values\nIF isActive THEN {\n    // \"The user is active.\"\n} ELSE {\n    // \"The user is not active.\"\n}\n\nIF isVerified THEN {\n    // \"The user is verified.\"\n} ELSE {\n    // \"The user is not verified.\"\n}"}, {"name": "JSON.GetAsNumber (JSON, STRING)", "return_type": "NUMBER", "return_desc": "Returns the specified element from the JSON object as a number.", "parameter_desc": "JSON: the JSON object from which to extract the element; STRING: the key of the element to retrieve.", "description": "Gets element and returns it as number.", "example_code": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"temperature\": 23.5,\n    \"humidity\": 60,\n    \"pressure\": 1013\n}\n\n// Extract the temperature as a NUMBER\nNUMBER temperature = JSON.GetAsNumber(jsonObject, \"temperature\")\n// Temperature: \" + temperature\n\n// Extract the humidity as a NUMBER\nNUMBER humidity = JSON.GetAsNumber(jsonObject, \"humidity\")\n// Humidity: \" + humidity\n\n// Extract the pressure as a NUMBER\nNUMBER pressure = JSON.GetAsNumber(jsonObject, \"pressure\")\n// Pressure: \" + pressure", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"temperature\": 23.5,\n    \"humidity\": 60,\n    \"pressure\": 1013\n}\n\n// Extract the temperature as a NUMBER\nNUMBER temperature = JSON.GetAsNumber(jsonObject, \"temperature\")\n// Temperature: \" + temperature\n\n// Extract the humidity as a NUMBER\nNUMBER humidity = JSON.GetAsNumber(jsonObject, \"humidity\")\n// Humidity: \" + humidity\n\n// Extract the pressure as a NUMBER\nNUMBER pressure = JSON.GetAsNumber(jsonObject, \"pressure\")\n// Pressure: \" + pressure"}, {"name": "JSON.GetAsSTRING (JSON, STRING)", "return_type": "STRING", "return_desc": "Returns the JSON element corresponding to the provided key as a string.", "parameter_desc": "JSON: the JSON object from which to extrace the element; STRING: the key of the element to retrieve.", "description": "Gets element and returns it as string.", "example_code": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Extract the \"name\" field from the JSON object\nSTRING name = JSON.GetAsString(jsonObject, \"name\")\n// Name: John Doe\n\n// Extract the \"email\" field from the JSON object\nSTRING email = JSON.GetAsString(jsonObject, \"email\")\n// Email: john.doe@example.com", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Extract the \"name\" field from the JSON object\nSTRING name = JSON.GetAsString(jsonObject, \"name\")\n// Name: John Doe\n\n// Extract the \"email\" field from the JSON object\nSTRING email = JSON.GetAsString(jsonObject, \"email\")\n// Email: john.doe@example.com"}, {"name": "JSON.GetAsSTRINGVector (JSON, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns the specified JSON element as a vector of strings.", "parameter_desc": "JSON: the object to retrieve from; STRING: the key of the element to retrieve.", "description": "Gets element and returns it as vector.", "example_code": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"key1\": [\"value1\", \"value2\", \"value3\"],\n    \"key2\": [\"value4\", \"value5\"]\n}\n\n// Retrieve the values associated with \"key1\" as a VECTOR<STRING>\nVECTOR<STRING> values = JSON.GetAsStringVector(jsonObject, \"key1\")\n\n// Values for key1: \" + values", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"key1\": [\"value1\", \"value2\", \"value3\"],\n    \"key2\": [\"value4\", \"value5\"]\n}\n\n// Retrieve the values associated with \"key1\" as a VECTOR<STRING>\nVECTOR<STRING> values = JSON.GetAsStringVector(jsonObject, \"key1\")\n\n// Values for key1: \" + values"}, {"name": "JSON.HasMember (JSON, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the specified `STRING` member exists in the given JSON object, otherwise`FALSE`", "parameter_desc": "JSON: The JSON object to check.STRING: The name of the member to look for.", "description": "Returns if member exists.", "example_code": "// Example JSON object\nJSON exampleJson = JSON.Parse('{\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}')\n\n// Check if the JSON object has the member \"age\"\nIF JSON.HasMember(exampleJson, \"age\") THEN {\n    // The JSON object has the member 'age'.\n} ELSE {\n    // The JSON object does not have the member 'age'.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON exampleJson = JSON.Parse('{\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}')\n\n// Check if the JSON object has the member \"age\"\nIF JSON.HasMember(exampleJson, \"age\") THEN {\n    // The JSON object has the member 'age'.\n} ELSE {\n    // The JSON object does not have the member 'age'.\n}"}, {"name": "JSON.IsArray (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the provided JSON value is an array.", "parameter_desc": "JSON: value to be checked.", "description": "Returns TRUE if JSON value's native type is an array.", "example_code": "JSON jsonData = '{\"key1\": \"value1\", \"key2\": [\"item1\", \"item2\", \"item3\"]}'\n\nIF JSON.IsArray(jsonData.key2) THEN {\n    // The value associated with 'key2' is an array.\n} ELSE {\n    // The value associated with 'key2' is not an array.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON jsonData = '{\"key1\": \"value1\", \"key2\": [\"item1\", \"item2\", \"item3\"]}'\n\nIF JSON.IsArray(jsonData.key2) THEN {\n    // The value associated with 'key2' is an array.\n} ELSE {\n    // The value associated with 'key2' is not an array.\n}"}, {"name": "JSON.IsBool (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the provided JSON value is of`BOOLEAN`type.", "parameter_desc": "JSON: the value to be checked.", "description": "Returns TRUE if JSON value's native type is BOOLEAN.", "example_code": "JSON jsonValue = JSON.Parse('{\"key\": true}')\nJSON boolValue = jsonValue[\"key\"]\n\nIF JSON.IsBool(boolValue) THEN {\n    // The value is a boolean.\n} ELSE {\n    // The value is not a boolean.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON jsonValue = JSON.Parse('{\"key\": true}')\nJSON boolValue = jsonValue[\"key\"]\n\nIF JSON.IsBool(boolValue) THEN {\n    // The value is a boolean.\n} ELSE {\n    // The value is not a boolean.\n}"}, {"name": "JSON.IsDouble (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns true if the JSON value is a real number.", "parameter_desc": "JSON: the value to be checked.", "description": "Returns TRUE if JSON value's native type is a real `NUMBER` type.", "example_code": "// Example JSON object\nJSON exampleJson = JSON.Parse('{\"value\": 42.0}')\n\n// Extract the value from the JSON object\nJSON value = exampleJson[\"value\"]\n\n// Check if the value is a double\nBOOLEAN isDouble = JSON.IsDouble(value)\n\n// Print the result to the console\nIF isDouble THEN {\n    // The value is a double.\n} ELSE {\n    // The value is not a double.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON exampleJson = JSON.Parse('{\"value\": 42.0}')\n\n// Extract the value from the JSON object\nJSON value = exampleJson[\"value\"]\n\n// Check if the value is a double\nBOOLEAN isDouble = JSON.IsDouble(value)\n\n// Print the result to the console\nIF isDouble THEN {\n    // The value is a double.\n} ELSE {\n    // The value is not a double.\n}"}, {"name": "JSON.IsInt64 (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the JSON value is an integer `NUMBER`.", "parameter_desc": "JSON: the value to be checked.", "description": "Returns TRUE if JSON value's native type is an integer `NUMBER` type.", "example_code": "// Example JSON object\nJSON exampleJson = JSON.Parse('{\"value\": 12345}')\n\n// Extract the value from the JSON object\nJSON value = exampleJson[\"value\"]\n\n// Check if the value is an integer NUMBER\nIF JSON.IsInt64(value) THEN {\n    // The value is an integer NUMBER.\n} ELSE {\n    // The value is not an integer NUMBER.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON exampleJson = JSON.Parse('{\"value\": 12345}')\n\n// Extract the value from the JSON object\nJSON value = exampleJson[\"value\"]\n\n// Check if the value is an integer NUMBER\nIF JSON.IsInt64(value) THEN {\n    // The value is an integer NUMBER.\n} ELSE {\n    // The value is not an integer NUMBER.\n}"}, {"name": "JSON.IsNull (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the JSON value is null.", "parameter_desc": "JSON: the value to be checked.", "description": "Returns TRUE if JSON value's native type is null type.", "example_code": "JSON jsonData = JSON.Parse('{\"key1\": \"value1\", \"key2\": null}')\n\nIF JSON.IsNull(jsonData[\"key2\"]) THEN {\n    // The value of key2 is null.\n} ELSE {\n    // The value of key2 is not null.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON jsonData = JSON.Parse('{\"key1\": \"value1\", \"key2\": null}')\n\nIF JSON.IsNull(jsonData[\"key2\"]) THEN {\n    // The value of key2 is null.\n} ELSE {\n    // The value of key2 is not null.\n}"}, {"name": "JSON.IsNumber (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the JSON value is a `NUMBER`.", "parameter_desc": "JSON: the value to be checked.", "description": "Returns TRUE if JSON value's native type is any `NUMBER` type.", "example_code": "JSON jsonValue = JSON.Parse(\"{\\\"key\\\": 123}\")\n\nIF JSON.IsNumber(jsonValue[\"key\"]) THEN {\n    // The value is a number.\n} ELSE {\n    // The value is not a number.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON jsonValue = JSON.Parse(\"{\"key\": 123}\")\n\nIF JSON.IsNumber(jsonValue[\"key\"]) THEN {\n    // The value is a number.\n} ELSE {\n    // The value is not a number.\n}"}, {"name": "JSON.IsObject (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the given JSON value is an object.", "parameter_desc": "JSON: the value to be checked.", "description": "Returns TRUE if JSON value's native type is an object/field.", "example_code": "JSON jsonData = '{\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}'\n\nIF JSON.IsObject(jsonData) THEN {\n    // The JSON data is an object.\n} ELSE {\n    // The JSON data is not an object.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON jsonData = '{\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}'\n\nIF JSON.IsObject(jsonData) THEN {\n    // The JSON data is an object.\n} ELSE {\n    // The JSON data is not an object.\n}"}, {"name": "JSON.IsSTRING (JSON)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the provided JSON value is a `STRING`.", "parameter_desc": "JSON: The JSON value to be checked.", "description": "Returns true if JSON value's native type is a string.", "example_code": "// Assume we have a JSON object\nJSON jsonObject = JSON.Parse('{\"key\": \"value\"}')\n\n// Check if the value associated with \"key\" is a string\nIF JSON.IsString(jsonObject[\"key\"]) THEN {\n    // The value is a string.\n} ELSE {\n    // The value is not a string.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a JSON object\nJSON jsonObject = JSON.Parse('{\"key\": \"value\"}')\n\n// Check if the value associated with \"key\" is a string\nIF JSON.IsString(jsonObject[\"key\"]) THEN {\n    // The value is a string.\n} ELSE {\n    // The value is not a string.\n}"}, {"name": "JSON.IsValid (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the input `STRING` is a valid JSON.", "parameter_desc": "STRING: The input STRING to be validated as JSON.", "description": "Returns true if the string can be converted into a JSON.", "example_code": "STRING jsonString = '{\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}'\n\nIF JSON.IsValid(jsonString) THEN {\n    // The JSON string is valid.\n} ELSE {\n    // The JSON string is not valid.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING jsonString = '{\"name\": \"John\", \"age\": 30, \"city\": \"New York\"}'\n\nIF JSON.IsValid(jsonString) THEN {\n    // The JSON string is valid.\n} ELSE {\n    // The JSON string is not valid.\n}"}, {"name": "JSON.Keys (JSON)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing all the keys from a JSON object.", "parameter_desc": "JSON: the input JSON object from which the keys will be retrieved.", "description": "Returns all keys of a JSON field.", "example_code": "// Define a JSON object\nJSON jsonObject = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Retrieve the keys of the JSON object\nVECTOR<STRING> keys = JSON.Keys(jsonObject)\n\n// Print the keys to the console\nFOR STRING key IN keys {\n    // Key: \" + key\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a JSON object\nJSON jsonObject = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Retrieve the keys of the JSON object\nVECTOR<STRING> keys = JSON.Keys(jsonObject)\n\n// Print the keys to the console\nFOR STRING key IN keys {\n    // Key: \" + key\n}"}, {"name": "JSON.Remove (JSON, STRING)", "return_type": "JSON", "return_desc": "Returns a JSON object with the specified key removed.", "parameter_desc": "JSON: the object from which a key is to be removed; STRING: the key to be removed.", "description": "Removes a specific key from a JSON field.", "example_code": "// Sample JSON object\nJSON sampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Key to be removed\nSTRING keyToRemove = \"email\"\n\n// Remove the key from the JSON object\nJSON updatedJson = JSON.Remove(sampleJson, keyToRemove)\n\n// This line was originally a DEBUG statement. It was used to print the updated JSON object to the console.\n// updatedJson", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Sample JSON object\nJSON sampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Key to be removed\nSTRING keyToRemove = \"email\"\n\n// Remove the key from the JSON object\nJSON updatedJson = JSON.Remove(sampleJson, keyToRemove)\n\n// This line was originally a DEBUG statement. It was used to print the updated JSON object to the console.\n// updatedJson"}, {"name": "JSON.Set (JSON, STRING, BOOLEAN)", "return_type": "JSON", "return_desc": "Returns the updated JSON object after assigning the given Boolean value to the specified field.", "parameter_desc": "JSON: the object to be modified; STRING: the field name; BOOLEAN: the value to be assigned.", "description": "Assigns a BOOLEAN value to a JSON field.", "example_code": "// Initialize a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Set a BOOLEAN field in the JSON object\nmyJson = JSON.Set(myJson, \"isActive\", TRUE)\n\n// Print the updated JSON object to the console\n// JSON.Stringify(myJson)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Set a BOOLEAN field in the JSON object\nmyJson = JSON.Set(myJson, \"isActive\", TRUE)\n\n// Print the updated JSON object to the console\n// JSON.Stringify(myJson)"}, {"name": "JSON.Set (JSON, STRING, JSON)", "return_type": "JSON", "return_desc": "Returns the updated JSON object with the specified sub-object assigned to the given field.", "parameter_desc": "JSON: the original JSON object; STRING: the key in the JSON object; JSON the object to be assigned to the specified field.", "description": "Assigns a JSON sub-object to a JSON field.", "example_code": "// Create a JSON object\nJSON myJson = JSON.Parse('{\"name\": \"John\", \"age\": 30}')\n\n// Create a MAP to hold the new value\nMAP<STRING, MWG.InternalVariant> newValue\nnewValue[\"city\"] = MWG.InternalVariant(\"New York\")\n\n// Set the new value in the JSON object\nmyJson = JSON.Set(myJson, \"address\", newValue)\n\n// This line was originally a DEBUG() function to print the modified JSON object\n// JSON.Stringify(myJson)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object\nJSON myJson = JSON.Parse('{\"name\": \"John\", \"age\": 30}')\n\n// Create a MAP to hold the new value\nMAP<STRING, MWG.InternalVariant> newValue\nnewValue[\"city\"] = MWG.InternalVariant(\"New York\")\n\n// Set the new value in the JSON object\nmyJson = JSON.Set(myJson, \"address\", newValue)\n\n// This line was originally a DEBUG() function to print the modified JSON object\n// JSON.Stringify(myJson)"}, {"name": "JSON.Set (JSON, STRING, MAP<STRING, MWG.InternalVariant>)", "return_type": "JSON", "return_desc": "Returns the modified JSON object.", "parameter_desc": "JSON: object to modify; STRING: key of value to set; MAP<STRING, MWG.InternalVariant>: value to set.", "description": "Sets JSON.", "example_code": "// Initialize a JSON object\nJSON myJson = JSON.Parse('{\"name\": \"John\", \"age\": 30}')\n\n// Create a MAP to hold the new value\nMAP<STRING, MWG.InternalVariant> newValue\nnewValue[\"city\"] = MWG.InternalVariant(\"New York\")\n\n// Set the new key-value pair in the JSON object\nmyJson = JSON.Set(myJson, \"city\", newValue)\n\n// This line would print the modified JSON object to the console\n// myJson.ToString()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a JSON object\nJSON myJson = JSON.Parse('{\"name\": \"John\", \"age\": 30}')\n\n// Create a MAP to hold the new value\nMAP<STRING, MWG.InternalVariant> newValue\nnewValue[\"city\"] = MWG.InternalVariant(\"New York\")\n\n// Set the new key-value pair in the JSON object\nmyJson = JSON.Set(myJson, \"city\", newValue)\n\n// This line would print the modified JSON object to the console\n// myJson.ToString()"}, {"name": "JSON.Set (JSON, STRING, NUMBER)", "return_type": "JSON", "return_desc": "Returns the updated JSON with the specified field set to the given numeric value.", "parameter_desc": "JSON: the object to assign a value to; STRING: the field name; NUMBER: the value to assign to the specified field.", "description": "Assigns a numeric value to a JSON field.", "example_code": "// Create a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Create a MAP to hold the number value\nMAP<STRING, MWG.InternalVariant> numberMap\nnumberMap[\"value\"] = MWG.InternalVariant(42) // Assuming 42 is the number you want to set\n\n// Set the number in the JSON object\nmyJson = JSON.Set(myJson, \"myNumberKey\", numberMap)\n\n// Print the modified JSON object to the console\n// myJson", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Create a MAP to hold the number value\nMAP<STRING, MWG.InternalVariant> numberMap\nnumberMap[\"value\"] = MWG.InternalVariant(42) // Assuming 42 is the number you want to set\n\n// Set the number in the JSON object\nmyJson = JSON.Set(myJson, \"myNumberKey\", numberMap)\n\n// Print the modified JSON object to the console\n// myJson"}, {"name": "JSON.Set (JSON, STRING, NUMBER, STRING)", "return_type": "JSON", "return_desc": "Returns the modified JSON with the specified numeric value assigned to the given field.", "parameter_desc": "JSON: the object to modify; STRING: field name; NUMBER: the value to assign; STRING: the NUMBER type.", "description": "Assigns a numeric value with a specific `NUMBER` type to a JSON field.", "example_code": "// Create a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Set a value in the JSON object\nJSON.Set(myJson, \"user.age\", 30, \"number\")\n\n// Print the JSON object to the console\n// JSON.Stringify(myJson)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Set a value in the JSON object\nJSON.Set(myJson, \"user.age\", 30, \"number\")\n\n// Print the JSON object to the console\n// JSON.Stringify(myJson)"}, {"name": "JSON.Set (JSON, STRING, STRING)", "return_type": "JSON", "return_desc": "Returns a JSON object with the specified field set to the given `STRING` value.", "parameter_desc": "JSON: the object to modify; STRING: the key; STRING: the value to assign.", "description": "Assigns a string value to a JSON field.", "example_code": "// Create a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Create a map to hold the value to set\nMAP<STRING, MWG.InternalVariant> valueMap\nvalueMap[\"key1\"] = MWG.InternalVariant(\"value1\")\nvalueMap[\"key2\"] = MWG.InternalVariant(\"value2\")\n\n// Set the value in the JSON object\nmyJson = JSON.Set(myJson, \"myKey\", valueMap)\n\n// This line would print the modified JSON object to the console\n// JSON.Stringify(myJson)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object\nJSON myJson = JSON.Parse(\"{}\")\n\n// Create a map to hold the value to set\nMAP<STRING, MWG.InternalVariant> valueMap\nvalueMap[\"key1\"] = MWG.InternalVariant(\"value1\")\nvalueMap[\"key2\"] = MWG.InternalVariant(\"value2\")\n\n// Set the value in the JSON object\nmyJson = JSON.Set(myJson, \"myKey\", valueMap)\n\n// This line would print the modified JSON object to the console\n// JSON.Stringify(myJson)"}, {"name": "JSON.Set (JSON, STRING, VECTOR<STRING>)", "return_type": "JSON", "return_desc": "Returns the updated JSON with the specified vector assigned to the given string field.", "parameter_desc": "JSON: The JSON object to modify, STRING: The field name, VECTOR: The VECTOR value to assign.", "description": "Assigns a vector to a JSON field.", "example_code": "// Initialize a JSON object\nJSON jsonObject = JSON.Parse(\"{}\")\n\n// Initialize a VECTOR<STRING>\nVECTOR<STRING> stringVector = \"value1\", \"value2\", \"value3\"\n\n// Convert VECTOR<STRING> to MAP<STRING, MWG.InternalVariant>\nMAP<STRING, MWG.InternalVariant> mapVariant\nFOR STRING value IN stringVector {\n    mapVariant[value] = MWG.InternalVariant(value)\n}\n\n// Set the value in the JSON object\njsonObject = JSON.Set(jsonObject, \"key\", mapVariant)\n\n// Print the modified JSON object\n// jsonObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a JSON object\nJSON jsonObject = JSON.Parse(\"{}\")\n\n// Initialize a VECTOR<STRING>\nVECTOR<STRING> stringVector = \"value1\", \"value2\", \"value3\"\n\n// Convert VECTOR<STRING> to MAP<STRING, MWG.InternalVariant>\nMAP<STRING, MWG.InternalVariant> mapVariant\nFOR STRING value IN stringVector {\n    mapVariant[value] = MWG.InternalVariant(value)\n}\n\n// Set the value in the JSON object\njsonObject = JSON.Set(jsonObject, \"key\", mapVariant)\n\n// Print the modified JSON object\n// jsonObject"}, {"name": "JSON.Size (JSON)", "return_type": "NUMBER", "return_desc": "Returns the number of elements in the given JSON array.", "parameter_desc": "JSON: array to get size of.", "description": "Returns the size of a JSON array.", "example_code": "// Example JSON object\nJSON exampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Get the size of the JSON object\nNUMBER jsonSize = JSON.Size(exampleJson)\n\n// The JSON object contains \" + jsonSize + \" elements.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON exampleJson = {\n    \"name\": \"John Doe\",\n    \"age\": 30,\n    \"email\": \"john.doe@example.com\"\n}\n\n// Get the size of the JSON object\nNUMBER jsonSize = JSON.Size(exampleJson)\n\n// The JSON object contains \" + jsonSize + \" elements."}, {"name": "JSON.SubNode (JSON, STRING)", "return_type": "JSON", "return_desc": "Returns the JSON value located at the specified path within a complex JSON object.", "parameter_desc": "JSON: the complex JSON object; STRING: the path to the desired value within the JSON object.", "description": "Returns the JSON value at the given path of a complex JSON object.", "example_code": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"user\": {\n        \"id\": 123,\n        \"name\": \"John Doe\",\n        \"email\": \"john.doe@example.com\"\n    },\n    \"settings\": {\n        \"theme\": \"dark\",\n        \"notifications\": true\n    }\n}\n\n// Extract the sub-node for user information\nJSON userSubNode = JSON.SubNode(jsonObject, \"user\")\n\n// Previously printed the extracted sub-node to the console\n// userSubNode", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a JSON object\nJSON jsonObject = {\n    \"user\": {\n        \"id\": 123,\n        \"name\": \"John Doe\",\n        \"email\": \"john.doe@example.com\"\n    },\n    \"settings\": {\n        \"theme\": \"dark\",\n        \"notifications\": true\n    }\n}\n\n// Extract the sub-node for user information\nJSON userSubNode = JSON.SubNode(jsonObject, \"user\")\n\n// Previously printed the extracted sub-node to the console\n// userSubNode"}, {"name": "JSON.ToFormattedSTRING (JSON, STRING)", "return_type": "STRING", "return_desc": "Returns a human-readable formatted string representation of a JSON object with the specified indentation.", "parameter_desc": "JSON: the object to be formatted; STRING: the indentation to apply in the pretty printed output.", "description": "Converts a JSON object to a pretty string with given indentation.", "example_code": "// Create a JSON object\nJSON myJson = JSON.Parse('{\"name\": \"John Doe\", \"age\": 30, \"city\": \"New York\"}')\n\n// Convert the JSON object to a formatted string\nSTRING formattedJsonString = JSON.ToFormattedString(myJson, \"  \")\n\n// Print the formatted JSON string to the console\n// DEBUG(formattedJsonString)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object\nJSON myJson = JSON.Parse('{\"name\": \"John Doe\", \"age\": 30, \"city\": \"New York\"}')\n\n// Convert the JSON object to a formatted string\nSTRING formattedJsonString = JSON.ToFormattedString(myJson, \"  \")\n\n// Print the formatted JSON string to the console\n// DEBUG(formattedJsonString)"}, {"name": "JSON.ToSTRINGVector (JSON)", "return_type": "VECTOR<STRING>", "return_desc": "Returns JSON array as a string list.", "parameter_desc": "JSON: the JSON array to convert to a STRING list.", "description": "Returns JSON array as a string list.", "example_code": "// Example JSON object\nJSON jsonObject = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Convert JSON object to VECTOR<STRING>\nVECTOR<STRING> stringVector = JSON.ToStringVector(jsonObject)\n\n// Print each element in the VECTOR<STRING>\nFOR STRING element IN stringVector {\n    // element\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON object\nJSON jsonObject = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Convert JSON object to VECTOR<STRING>\nVECTOR<STRING> stringVector = JSON.ToStringVector(jsonObject)\n\n// Print each element in the VECTOR<STRING>\nFOR STRING element IN stringVector {\n    // element\n}"}, {"name": "JSON.UnionArrays (JSON, JSON)", "return_type": "JSON", "return_desc": "Returns a JSON array that combines elements from both input JSON arrays, appending the elements of the second array to the first.", "parameter_desc": "Parameters: Two JSON objects representing arrays to be merged, with the values of the second array appended to the first.", "description": "Appends the values of the second JSON array to the first array.", "example_code": "JSON array1 = [ {\"id\": 1, \"name\": \"Alice\"}, {\"id\": 2, \"name\": \"Bob\"} ]\nJSON array2 = [ {\"id\": 3, \"name\": \"Charlie\"}, {\"id\": 4, \"name\": \"Diana\"} ]\n\nJSON combinedArray = ArrayAppend(array1, array2)\n\n// DEBUG(combinedArray)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON array1 = [ {\"id\": 1, \"name\": \"Alice\"}, {\"id\": 2, \"name\": \"Bob\"} ]\nJSON array2 = [ {\"id\": 3, \"name\": \"Charlie\"}, {\"id\": 4, \"name\": \"Diana\"} ]\n\nJSON combinedArray = ArrayAppend(array1, array2)\n\n// DEBUG(combinedArray)"}, {"name": "Length (STRING)", "return_type": "NUMBER", "return_desc": "Returns the number of characters in the given string.", "parameter_desc": "STRING: The input text for which the length is to be calculated.", "description": "Returns the length of the string.", "example_code": "STRING exampleString = \"Hello, World!\"\nNUMBER stringLength = Length(exampleString)\n\n// The length of the string is: + stringLength\n\nIF stringLength > 10 THEN {\n    // The string is longer than 10 characters.\n} ELSE {\n    // The string is 10 characters or shorter.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING exampleString = \"Hello, World!\"\nNUMBER stringLength = Length(exampleString)\n\n// The length of the string is: + stringLength\n\nIF stringLength > 10 THEN {\n    // The string is longer than 10 characters.\n} ELSE {\n    // The string is 10 characters or shorter.\n}"}, {"name": "Math.Abs (NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the non-negative value of the given number.", "parameter_desc": "NUMBER: The NUMBER for which the absolute value is to be calculated.", "description": "Returns the absolute value of the given number.", "example_code": "NUMBER value = -42\nNUMBER absoluteValue\n\nIF value < 0 THEN {\n    absoluteValue = 0 - value\n} ELSE {\n    absoluteValue = value\n}\n\n// The absolute value is: \" + absoluteValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER value = -42\nNUMBER absoluteValue\n\nIF value < 0 THEN {\n    absoluteValue = 0 - value\n} ELSE {\n    absoluteValue = value\n}\n\n// The absolute value is: \" + absoluteValue"}, {"name": "Math.Ceil (NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the smallest integer greater than or equal to the given number.", "parameter_desc": "NUMBER: The NUMBER for which the ceiling value is to be found.", "description": "Returns the ceiling of the given number.", "example_code": "NUMBER value = 4.7\nNUMBER ceilingValue = Math.Ceil(value)\n// The ceiling value of value is ceilingValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER value = 4.7\nNUMBER ceilingValue = Math.Ceil(value)\n// The ceiling value of value is ceilingValue"}, {"name": "Math.Div (NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the quotient of the division of the first number by the second number, without the remainder.", "parameter_desc": "NUMBER: the numerator; NUMBER: the denominator.", "description": "Returns the result of integer division of the given two numbers.", "example_code": "NUMBER numerator = 10\nNUMBER denominator = 2\nNUMBER result = numerator / denominator\n// The result of the division is: result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER numerator = 10\nNUMBER denominator = 2\nNUMBER result = numerator / denominator\n// The result of the division is: result"}, {"name": "Math.Floor (NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the largest integer less than or equal to the given number.", "parameter_desc": "NUMBER: the value to be rounded.", "description": "Returns the rounded down value of the given number.", "example_code": "NUMBER originalValue = 5.75\nNUMBER flooredValue = Math.Floor(originalValue)\n\n// Original Value: 5.75\n// Floored Value: 5", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER originalValue = 5.75\nNUMBER flooredValue = Math.Floor(originalValue)\n\n// Original Value: 5.75\n// Floored Value: 5"}, {"name": "Math.Max (NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the larger of the two input numbers.", "parameter_desc": "Two NUMBERs for comparison.", "description": "Returns the maximum of the given numbers.", "example_code": "NUMBER a = 10\nNUMBER b = 20\nNUMBER max_value = Math.Max(a, b)\n// The maximum value is: max_value", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER a = 10\nNUMBER b = 20\nNUMBER max_value = Math.Max(a, b)\n// The maximum value is: max_value"}, {"name": "Math.Min (NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the smallest value between the two provided numbers.", "parameter_desc": "Two NUMBERs for comparison.", "description": "Returns the minimum of the given numbers.", "example_code": "NUMBER a = 10\nNUMBER b = 20\nNUMBER minValue = Math.Min(a, b)\n\n// The minimum value is: minValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER a = 10\nNUMBER b = 20\nNUMBER minValue = Math.Min(a, b)\n\n// The minimum value is: minValue"}, {"name": "Math.Modulus (NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the remainder when the first number is divided by the second number.", "parameter_desc": "NUMBER: the numerator; NUMBER: the denominator.", "description": "Computes the remainder of division (mod).", "example_code": "NUMBER numerator = 10\nNUMBER denominator = 3\nNUMBER result = Math.Modulus(numerator, denominator)\n\n// The remainder of numerator divided by denominator is result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER numerator = 10\nNUMBER denominator = 3\nNUMBER result = Math.Modulus(numerator, denominator)\n\n// The remainder of numerator divided by denominator is result"}, {"name": "Math.Pow (NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the value of the first number raised to the power of the second number.", "parameter_desc": "NUMBER: the base; NUMBER: the exponent.", "description": "Returns the result of base to the power of the exponent.", "example_code": "NUMBER base = 2\nNUMBER exponent = 3\nNUMBER result = Math.Pow(base, exponent)\n// The result of base raised to the power of exponent is result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER base = 2\nNUMBER exponent = 3\nNUMBER result = Math.Pow(base, exponent)\n// The result of base raised to the power of exponent is result"}, {"name": "Math.Round (NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the nearest integer to the given number, rounding 0.5 up to 1.", "parameter_desc": "NUMBER: The floating-point value to be rounded to the nearest integral value.", "description": "Returns the integral value that is nearest to the given number, with 0.5 rounded to 1.", "example_code": "NUMBER originalValue = 3.7\nNUMBER roundedValue = Math.Round(originalValue)\n// Original Value: 3.7\n// Rounded Value: 4", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER originalValue = 3.7\nNUMBER roundedValue = Math.Round(originalValue)\n// Original Value: 3.7\n// Rounded Value: 4"}, {"name": "Math.Sgn (NUMBER)", "return_type": "NUMBER", "return_desc": "Returns -1 if the number is negative, 0 if it is zero, and 1 if it is positive.", "parameter_desc": "NUMBER: input value to determine sign of.", "description": "Returns the sign of the given number (-1, 0, 1).", "example_code": "NUMBER value = -42\nNUMBER sign = Math.Sgn(value)\n\nIF sign == 1 THEN {\n    // The number is positive.\n} ELSE IF sign == -1 THEN {\n    // The number is negative.\n} ELSE {\n    // The number is zero.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER value = -42\nNUMBER sign = Math.Sgn(value)\n\nIF sign == 1 THEN {\n    // The number is positive.\n} ELSE IF sign == -1 THEN {\n    // The number is negative.\n} ELSE {\n    // The number is zero.\n}"}, {"name": "Math.Sqrt (NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the positive square root of the given number.", "parameter_desc": "NUMBER: The NUMBER for which you want to find the square root.", "description": "Returns the square root of the given number.", "example_code": "NUMBER value = 16\nNUMBER result = Math.Sqrt(value)\n// The square root of value is result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER value = 16\nNUMBER result = Math.Sqrt(value)\n// The square root of value is result"}, {"name": "MCP.Authenticate (MCP.Setting, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the given customer is authenticated.", "parameter_desc": "MCP.Setting: the specified setting; STRING: the customer ID.", "description": "Checks if a customer is authenticated.", "example_code": "// Initialize the MCP.Setting object with appropriate settings\nMCP.Setting authSetting = MCP.Setting()\nauthSetting.server = \"auth.example.com\"\nauthSetting.port = 389\nauthSetting.useSSL = TRUE\n\n// The username to authenticate\nSTRING username = \"exampleUser\"\n\n// Call the MCP.Authenticate function\nBOOLEAN isAuthenticated = MCP.Authenticate(authSetting, username)\n\n// Check the result of the authentication\nIF isAuthenticated THEN {\n    // User authenticated successfully.\n    // Additional code for authenticated users\n} ELSE {\n    // User authentication failed.\n    // Additional code for failed authentication\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize the MCP.Setting object with appropriate settings\nMCP.Setting authSetting = MCP.Setting()\nauthSetting.server = \"auth.example.com\"\nauthSetting.port = 389\nauthSetting.useSSL = TRUE\n\n// The username to authenticate\nSTRING username = \"exampleUser\"\n\n// Call the MCP.Authenticate function\nBOOLEAN isAuthenticated = MCP.Authenticate(authSetting, username)\n\n// Check the result of the authentication\nIF isAuthenticated THEN {\n    // User authenticated successfully.\n    // Additional code for authenticated users\n} ELSE {\n    // User authentication failed.\n    // Additional code for failed authentication\n}"}, {"name": "MCP.GetSetting (STRING)", "return_type": "MCP.Setting", "return_desc": "Returns setting from given identifier.", "parameter_desc": "STRING: identifier for the desired setting", "description": "Gets an MCP setting with an identifying string.", "example_code": "// Retrieve a setting value using MCP.GetSetting\nSTRING settingValue = MCP.GetSetting(\"exampleSetting\")\n\n// The value of exampleSetting is: settingValue\n\n// Use the retrieved setting value in some logic\nIF settingValue == \"block\" THEN {\n    MWG.Block(\"Blocked due to setting value\")\n} ELSE {\n    MWG.Allow(\"Allowed due to setting value\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve a setting value using MCP.GetSetting\nSTRING settingValue = MCP.GetSetting(\"exampleSetting\")\n\n// The value of exampleSetting is: settingValue\n\n// Use the retrieved setting value in some logic\nIF settingValue == \"block\" THEN {\n    MWG.Block(\"Blocked due to setting value\")\n} ELSE {\n    MWG.Allow(\"Allowed due to setting value\")\n}"}, {"name": "MediaType.Ensured ()", "return_type": "VECTOR<MediaType>", "return_desc": "Returns a vector indicating the detected media type.", "parameter_desc": "None", "description": "Detects media type.", "example_code": "// Ensure the media type of the content\nMediaType mediaType = MediaType.Ensured()\n\n// Ensured MediaType: \n// Commented out DEBUG statement. Original line: \"DEBUG(\"Ensured MediaType: \" + mediaType)\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Ensure the media type of the content\nMediaType mediaType = MediaType.Ensured()\n\n// Ensured MediaType: \n// Commented out DEBUG statement. Original line: \"DEBUG(\"Ensured MediaType: \" + mediaType)\""}, {"name": "MediaType.FindMatch (VECTOR<MediaType>, STRING)", "return_type": "NUMBER", "return_desc": "Returns the position of the first element that matches the given wildcard expression (-1 if there is no match).", "parameter_desc": "STRING: wildcard expression to search for.", "description": "Returns the position of the first element that matches the given wildcard expression. Returns -1 if there is no match.", "example_code": "// Define a vector of MediaType objects\nVECTOR<MediaType> mediaTypes = [\"application/json\", \"text/html\", \"image/png\"]\n\n// Define the media type string to search for\nSTRING mediaTypeToFind = \"text/html\"\n\n// Use MediaType.FindMatch to check if the media type exists in the vector\nBOOLEAN isMatch = MediaType.FindMatch(mediaTypes, mediaTypeToFind)\n\n// Print the result to the console\nIF isMatch THEN {\n    // Media type found: \" + mediaTypeToFind\n} ELSE {\n    // Media type not found: \" + mediaTypeToFind\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a vector of MediaType objects\nVECTOR<MediaType> mediaTypes = [\"application/json\", \"text/html\", \"image/png\"]\n\n// Define the media type string to search for\nSTRING mediaTypeToFind = \"text/html\"\n\n// Use MediaType.FindMatch to check if the media type exists in the vector\nBOOLEAN isMatch = MediaType.FindMatch(mediaTypes, mediaTypeToFind)\n\n// Print the result to the console\nIF isMatch THEN {\n    // Media type found: \" + mediaTypeToFind\n} ELSE {\n    // Media type not found: \" + mediaTypeToFind\n}"}, {"name": "MediaType.FromExtension ()", "return_type": "VECTOR<MediaType>", "return_desc": "Returns a vector containing the media types associated with the given file name extension.", "parameter_desc": "None", "description": "Determines media type based on file name extension.", "example_code": "STRING mediaType = \"application/json\"\nMediaType normalizedMediaType = MediaType.NormalizedName(mediaType)\n// Normalized Media Type: + normalizedMediaType", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mediaType = \"application/json\"\nMediaType normalizedMediaType = MediaType.NormalizedName(mediaType)\n// Normalized Media Type: + normalizedMediaType"}, {"name": "MediaType.FromHeader ()", "return_type": "MediaType", "return_desc": "Returns the media type specified in the HTTP header.", "parameter_desc": "None", "description": "Returns media type given in HTTP header.", "example_code": "// Retrieve the media type from the HTTP header\nMediaType mediaType = MediaType.FromHeader()\n\n// Media Type from Header: \n// mediaType\n\n// Example condition to block certain media types\nIF mediaType == \"application/json\" THEN {\n    MWG.Block(\"Blocking JSON content\")\n} ELSE {\n    MWG.Allow(\"Allowed content\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the media type from the HTTP header\nMediaType mediaType = MediaType.FromHeader()\n\n// Media Type from Header: \n// mediaType\n\n// Example condition to block certain media types\nIF mediaType == \"application/json\" THEN {\n    MWG.Block(\"Blocking JSON content\")\n} ELSE {\n    MWG.Allow(\"Allowed content\")\n}"}, {"name": "MediaType.IsArchive ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is an archive, otherwise`FALSE`", "parameter_desc": "None", "description": "Checks if the media type is an archive.", "example_code": "MediaType mediaType = MediaType()  // Assume this gets the media type of the current response\n\nIF mediaType.IsArchive() THEN {\n    // The media type is an archive.\n    // Additional logic for handling archive files can be added here\n} ELSE {\n    // The media type is not an archive.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MediaType mediaType = MediaType()  // Assume this gets the media type of the current response\n\nIF mediaType.IsArchive() THEN {\n    // The media type is an archive.\n    // Additional logic for handling archive files can be added here\n} ELSE {\n    // The media type is not an archive.\n}"}, {"name": "MediaType.IsAudio ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is audio.", "parameter_desc": "None", "description": "Checks if the media type is audio.", "example_code": "IF MediaType.IsAudio() THEN {\n    // The media type is audio.\n    // Additional actions can be taken here, such as allowing or blocking the request\n    MWG.Allow(\"Audio media type detected\")\n} ELSE {\n    // The media type is not audio.\n    // Additional actions can be taken here, such as allowing or blocking the request\n    MWG.Block(\"Non-audio media type detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsAudio() THEN {\n    // The media type is audio.\n    // Additional actions can be taken here, such as allowing or blocking the request\n    MWG.Allow(\"Audio media type detected\")\n} ELSE {\n    // The media type is not audio.\n    // Additional actions can be taken here, such as allowing or blocking the request\n    MWG.Block(\"Non-audio media type detected\")\n}"}, {"name": "MediaType.IsCompositeobject ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is a composite object.", "parameter_desc": "None", "description": "Checks if the media type is a composite object.", "example_code": "IF MediaType.IsCompositeobject() THEN {\n    // The media type is a composite object.\n} ELSE {\n    // The media type is not a composite object.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsCompositeobject() THEN {\n    // The media type is a composite object.\n} ELSE {\n    // The media type is not a composite object.\n}"}, {"name": "MediaType.IsDatabase ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is a database.", "parameter_desc": "None", "description": "Checks if the media type is a database.", "example_code": "IF MediaType.IsDatabase() THEN {\n    // The media type is a database.\n    MWG.Block(\"Access to database media types is not allowed.\")\n} ELSE {\n    // The media type is not a database.\n    MWG.Allow(\"Media type check passed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsDatabase() THEN {\n    // The media type is a database.\n    MWG.Block(\"Access to database media types is not allowed.\")\n} ELSE {\n    // The media type is not a database.\n    MWG.Allow(\"Media type check passed.\")\n}"}, {"name": "MediaType.IsDocument ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is a document.", "parameter_desc": "None", "description": "Checks if the media type is a document.", "example_code": "IF MediaType.IsDocument() THEN {\n    // The media type is a document.\n    // Additional actions can be taken here if the media type is a document\n} ELSE {\n    // The media type is not a document.\n    // Additional actions can be taken here if the media type is not a document\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsDocument() THEN {\n    // The media type is a document.\n    // Additional actions can be taken here if the media type is a document\n} ELSE {\n    // The media type is not a document.\n    // Additional actions can be taken here if the media type is not a document\n}"}, {"name": "MediaType.IsExecutable ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is executable,`FALSE`otherwise.", "parameter_desc": "None", "description": "Checks if the media type is executable.", "example_code": "IF MediaType.IsExecutable() THEN {\n    // Executable files are not allowed.\n    MWG.Block(\"Executable files are not allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsExecutable() THEN {\n    // Executable files are not allowed.\n    MWG.Block(\"Executable files are not allowed.\")\n}"}, {"name": "MediaType.IsImage ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is an image.", "parameter_desc": "None", "description": "Checks if the media type is an image.", "example_code": "IF MediaType.IsImage() THEN {\n    // The media type is an image.\n    // Additional actions can be taken here if the media type is an image\n} ELSE {\n    // The media type is not an image.\n    // Additional actions can be taken here if the media type is not an image\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsImage() THEN {\n    // The media type is an image.\n    // Additional actions can be taken here if the media type is an image\n} ELSE {\n    // The media type is not an image.\n    // Additional actions can be taken here if the media type is not an image\n}"}, {"name": "MediaType.IsMagicBytesMismatch ()", "return_type": "BOOLEAN", "return_desc": "Returns true if the media type magic bytes do not match the header.", "parameter_desc": "None", "description": "Checks media type magic bytes mismatches with header.", "example_code": "IF MediaType.IsMagicBytesMismatch() THEN {\n    // Magic bytes mismatch detected.\n    MWG.Block(\"Magic bytes mismatch detected in the file.\")\n} ELSE {\n    // No magic bytes mismatch detected.\n    MWG.Allow(\"No magic bytes mismatch detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsMagicBytesMismatch() THEN {\n    // Magic bytes mismatch detected.\n    MWG.Block(\"Magic bytes mismatch detected in the file.\")\n} ELSE {\n    // No magic bytes mismatch detected.\n    MWG.Allow(\"No magic bytes mismatch detected.\")\n}"}, {"name": "MediaType.IsText ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is text.", "parameter_desc": "None", "description": "Checks if the media type is text.", "example_code": "IF MediaType.IsText() THEN {\n    // The media type is text.\n    // Additional actions can be taken here if the media type is text\n} ELSE {\n    // The media type is not text.\n    // Additional actions can be taken here if the media type is not text\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsText() THEN {\n    // The media type is text.\n    // Additional actions can be taken here if the media type is text\n} ELSE {\n    // The media type is not text.\n    // Additional actions can be taken here if the media type is not text\n}"}, {"name": "MediaType.IsVideo ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the media type is video.", "parameter_desc": "None", "description": "Checks if the media type is video.", "example_code": "IF MediaType.IsVideo() THEN {\n    // The media type is a video.\n    // Additional actions can be taken here, such as blocking or allowing the request\n    MWG.Allow(\"Video content allowed\")\n} ELSE {\n    // The media type is not a video.\n    // Actions for non-video content\n    MWG.Block(\"Non-video content blocked\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MediaType.IsVideo() THEN {\n    // The media type is a video.\n    // Additional actions can be taken here, such as blocking or allowing the request\n    MWG.Allow(\"Video content allowed\")\n} ELSE {\n    // The media type is not a video.\n    // Actions for non-video content\n    MWG.Block(\"Non-video content blocked\")\n}"}, {"name": "MediaType.NormalizedName (STRING)", "return_type": "MediaType", "return_desc": "Returns normalized name for the input mime type.", "parameter_desc": "STRING: the media type.", "description": "Returns normalized name for the input mime type.", "example_code": "STRING mediaTypeString = \"application/json\"\nSTRING normalizedMediaType = MediaType.NormalizedName(mediaTypeString)\n\n// Original Media Type: application/json\n// Normalized Media Type: normalizedMediaType", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mediaTypeString = \"application/json\"\nSTRING normalizedMediaType = MediaType.NormalizedName(mediaTypeString)\n\n// Original Media Type: application/json\n// Normalized Media Type: normalizedMediaType"}, {"name": "MediaType.NotEnsured ()", "return_type": "VECTOR<MediaType>", "return_desc": "Returns mime types detected by signatures with low probability of detection.", "parameter_desc": "None", "description": "Gets mime types detected by signatures with low probability of detection.", "example_code": "VECTOR<MediaType> lowProbabilityMediaTypes = MediaType.NotEnsured()\n\nIF lowProbabilityMediaTypes != NULL THEN {\n    // Low probability media types detected:\n    FOR EACH mediaType IN lowProbabilityMediaTypes {\n        // mediaType\n    }\n} ELSE {\n    // No low probability media types detected.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MediaType> lowProbabilityMediaTypes = MediaType.NotEnsured()\n\nIF lowProbabilityMediaTypes != NULL THEN {\n    // Low probability media types detected:\n    FOR EACH mediaType IN lowProbabilityMediaTypes {\n        // mediaType\n    }\n} ELSE {\n    // No low probability media types detected.\n}"}, {"name": "MWG.Add (MWG.InternalParameterList, BOOLEAN)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; BOOLEAN: value to add.", "description": "Adds a BOOLEAN value to an MWG.InternalParameterList.", "example_code": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Add a BOOLEAN value to the parameter list\nparamList = MWG.Add(paramList, TRUE)\n\n// Add another BOOLEAN value to the parameter list\nparamList = MWG.Add(paramList, FALSE)\n\n// Parameter List: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Add a BOOLEAN value to the parameter list\nparamList = MWG.Add(paramList, TRUE)\n\n// Add another BOOLEAN value to the parameter list\nparamList = MWG.Add(paramList, FALSE)\n\n// Parameter List: \" + paramList"}, {"name": "MWG.Add (MWG.InternalParameterList, JSON)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; JSON: value to add.", "description": "Adds a JSON value to an MWG.InternalParameterList.", "example_code": "// Initialize an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a JSON object\nJSON jsonObject = JSON()\njsonObject[\"key1\"] = \"value1\"\njsonObject[\"key2\"] = \"value2\"\n\n// Add the JSON object to the InternalParameterList\nparamList = MWG.Add(paramList, jsonObject)\n\n// InternalParameterList after addition: \n// paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a JSON object\nJSON jsonObject = JSON()\njsonObject[\"key1\"] = \"value1\"\njsonObject[\"key2\"] = \"value2\"\n\n// Add the JSON object to the InternalParameterList\nparamList = MWG.Add(paramList, jsonObject)\n\n// InternalParameterList after addition: \n// paramList"}, {"name": "MWG.Add (MWG.InternalParameterList, MAP<STRING, MWG.InternalVariant>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; MAP<STRING, MWG.InternalVariant>: map to add to list.", "description": "Adds a MAP value to an MWG.InternalParameterList.", "example_code": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a MAP<STRING, MWG.InternalVariant> to add to the list\nMAP<STRING, MWG.InternalVariant> paramMap = MAP<STRING, MWG.InternalVariant>()\nparamMap[\"key1\"] = MWG.InternalVariant(\"value1\")\nparamMap[\"key2\"] = MWG.InternalVariant(1234)\nparamMap[\"key3\"] = MWG.InternalVariant(TRUE)\n\n// Add the MAP to the MWG.InternalParameterList\nparamList = MWG.Add(paramList, paramMap)\n\n// Updated parameter list: paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a MAP<STRING, MWG.InternalVariant> to add to the list\nMAP<STRING, MWG.InternalVariant> paramMap = MAP<STRING, MWG.InternalVariant>()\nparamMap[\"key1\"] = MWG.InternalVariant(\"value1\")\nparamMap[\"key2\"] = MWG.InternalVariant(1234)\nparamMap[\"key3\"] = MWG.InternalVariant(TRUE)\n\n// Add the MAP to the MWG.InternalParameterList\nparamList = MWG.Add(paramList, paramMap)\n\n// Updated parameter list: paramList"}, {"name": "MWG.Add (MWG.InternalParameterList, MWG.InternalVariant)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; MWG.InternalVariant: value to add.", "description": "Adds an MWG.InternalVariant value to an MWG.InternalParameterList.", "example_code": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create an MWG.InternalVariant value\nMWG.InternalVariant variantValue = MWG.InternalVariant(\"exampleValue\")\n\n// Add the MWG.InternalVariant value to the MWG.InternalParameterList\nparamList = MWG.Add(paramList, variantValue)\n\n// Updated parameter list: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create an MWG.InternalVariant value\nMWG.InternalVariant variantValue = MWG.InternalVariant(\"exampleValue\")\n\n// Add the MWG.InternalVariant value to the MWG.InternalParameterList\nparamList = MWG.Add(paramList, variantValue)\n\n// Updated parameter list: \" + paramList"}, {"name": "MWG.Add (MWG.InternalParameterList, Net.IP)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; Net.IP: value to add.", "description": "Adds a Net.IP value to an MWG.InternalParameterList.", "example_code": "// Create an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a Net.IP object\nNet.IP ipAddress = Net.IP(\"192.168.1.1\")\n\n// Add the IP address to the InternalParameterList\nparamList = MWG.Add(paramList, ipAddress)\n\n// IP Address added to InternalParameterList: \" + ipAddress", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a Net.IP object\nNet.IP ipAddress = Net.IP(\"192.168.1.1\")\n\n// Add the IP address to the InternalParameterList\nparamList = MWG.Add(paramList, ipAddress)\n\n// IP Address added to InternalParameterList: \" + ipAddress"}, {"name": "MWG.Add (MWG.InternalParameterList, NUMBER)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; NUMBER: value to add.", "description": "Adds a number value to an MWG.InternalParameterList.", "example_code": "MWG.InternalParameterList paramList = MWG.InternalParameterList()\nNUMBER valueToAdd = 42\n\nparamList = MWG.Add(paramList, valueToAdd)\n\n// Updated parameter list: \n// + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalParameterList paramList = MWG.InternalParameterList()\nNUMBER valueToAdd = 42\n\nparamList = MWG.Add(paramList, valueToAdd)\n\n// Updated parameter list: \n// + paramList"}, {"name": "MWG.Add (MWG.InternalParameterList, STRING)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; STRING: value to add.", "description": "Adds a string value to an MWG.InternalParameterList.", "example_code": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Add a string value to the parameter list\nparamList = MWG.Add(paramList, \"exampleValue1\")\nparamList = MWG.Add(paramList, \"exampleValue2\")\nparamList = MWG.Add(paramList, \"exampleValue3\")\n\n// Debug output to verify the values in the parameter list\n// Parameter List: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize an empty MWG.InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Add a string value to the parameter list\nparamList = MWG.Add(paramList, \"exampleValue1\")\nparamList = MWG.Add(paramList, \"exampleValue2\")\nparamList = MWG.Add(paramList, \"exampleValue3\")\n\n// Debug output to verify the values in the parameter list\n// Parameter List: \" + paramList"}, {"name": "MWG.Add (MWG.InternalParameterList, VECTOR<MWG.UrlCategory>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; VECTOR: value to add.", "description": "Adds a vector of values to an MWG.InternalParameterList.", "example_code": "// Initialize an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Define a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = MWG.UrlCategory(\"Social Media\"), MWG.UrlCategory(\"Streaming Media\")\n\n// Add the VECTOR of UrlCategories to the InternalParameterList\nparamList = MWG.Add(paramList, urlCategories)\n\n// Debug output to verify the addition\n// Updated InternalParameterList: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Define a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = MWG.UrlCategory(\"Social Media\"), MWG.UrlCategory(\"Streaming Media\")\n\n// Add the VECTOR of UrlCategories to the InternalParameterList\nparamList = MWG.Add(paramList, urlCategories)\n\n// Debug output to verify the addition\n// Updated InternalParameterList: \" + paramList"}, {"name": "MWG.Add (MWG.InternalParameterList, VECTOR<STRING>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the updated`MWG.InternalParameterList`", "parameter_desc": "MWG.InternalParameterList: list to be added to; VECTOR: value to add.", "description": "Adds a vector of values to an MWG.InternalParameterList.", "example_code": "// Initialize an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a VECTOR of STRINGs to add to the InternalParameterList\nVECTOR<STRING> valuesToAdd = \"value1\", \"value2\", \"value3\"\n\n// Add the VECTOR of STRINGs to the InternalParameterList\nparamList = MWG.Add(paramList, valuesToAdd)\n\n// Debug output to verify the addition\n// Updated InternalParameterList: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize an InternalParameterList\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Create a VECTOR of STRINGs to add to the InternalParameterList\nVECTOR<STRING> valuesToAdd = \"value1\", \"value2\", \"value3\"\n\n// Add the VECTOR of STRINGs to the InternalParameterList\nparamList = MWG.Add(paramList, valuesToAdd)\n\n// Debug output to verify the addition\n// Updated InternalParameterList: \" + paramList"}, {"name": "MWG.Anonymize (MWG.AnonymizationSetting, STRING)", "return_type": "STRING", "return_desc": "Returns the anonymous string.", "parameter_desc": "MWG.AnonymizationSetting: the settings you want to use when anonymizing; STRING: to be anonymized.", "description": "Encrypts a string.", "example_code": "// Define the anonymization setting\nMWG.AnonymizationSetting anonymizationSetting = [your_anonymization_setting]\n\n// Define the string to be anonymized\nSTRING sensitiveData = \"This is some sensitive data\"\n\n// Anonymize the string\nSTRING anonymizedData = MWG.Anonymize(anonymizationSetting, sensitiveData)\n\n// Print the anonymized data to the console for debugging\n// DEBUG(anonymizedData)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the anonymization setting\nMWG.AnonymizationSetting anonymizationSetting = [your_anonymization_setting]\n\n// Define the string to be anonymized\nSTRING sensitiveData = \"This is some sensitive data\"\n\n// Anonymize the string\nSTRING anonymizedData = MWG.Anonymize(anonymizationSetting, sensitiveData)\n\n// Print the anonymized data to the console for debugging\n// DEBUG(anonymizedData)"}, {"name": "MWG.ApplicationCategory ()", "return_type": "STRING", "return_desc": "Returns the name of an application category as a string.", "parameter_desc": "None", "description": "Returns the name of an application category.", "example_code": "STRING appCategory = MWG.ApplicationCategory()\n\nIF appCategory == \"Social Media\" THEN {\n    MWG.Block(\"Access to Social Media is not allowed\")\n} ELSE {\n    MWG.Allow(\"Application category is allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING appCategory = MWG.ApplicationCategory()\n\nIF appCategory == \"Social Media\" THEN {\n    MWG.Block(\"Access to Social Media is not allowed\")\n} ELSE {\n    MWG.Allow(\"Application category is allowed\")\n}"}, {"name": "MWG.ApplicationCategoryID ()", "return_type": "MWG.ApplicationCategoryType", "return_desc": "Returns the category type of an application.", "parameter_desc": "None", "description": "Returns the application category.", "example_code": "MWG.ApplicationCategoryType category = MWG.ApplicationCategoryID()\n\nIF category == \"Social Media\" THEN {\n    // Access to social media is not allowed\n    MWG.Block(\"Access to social media is not allowed\")\n} ELSE {\n    // Application category is allowed\n    MWG.Allow(\"Application category is allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ApplicationCategoryType category = MWG.ApplicationCategoryID()\n\nIF category == \"Social Media\" THEN {\n    // Access to social media is not allowed\n    MWG.Block(\"Access to social media is not allowed\")\n} ELSE {\n    // Application category is allowed\n    MWG.Allow(\"Application category is allowed\")\n}"}, {"name": "MWG.ApplicationHasHighRisk ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the application is assessed to have a high risk score.", "parameter_desc": "None", "description": "Returns TRUE if an application has a high risk score.", "example_code": "// Assuming MWG.ApplicationHasHighRisk() returns a BOOLEAN indicating if the application has high risk\nBOOLEAN isHighRisk = MWG.ApplicationHasHighRisk()\n\nIF isHighRisk THEN {\n    // High risk application detected.\n    MWG.Block(\"Access to high risk application is blocked.\")\n} ELSE {\n    // Application is not high risk.\n    MWG.Allow(\"Application is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assuming MWG.ApplicationHasHighRisk() returns a BOOLEAN indicating if the application has high risk\nBOOLEAN isHighRisk = MWG.ApplicationHasHighRisk()\n\nIF isHighRisk THEN {\n    // High risk application detected.\n    MWG.Block(\"Access to high risk application is blocked.\")\n} ELSE {\n    // Application is not high risk.\n    MWG.Allow(\"Application is allowed.\")\n}"}, {"name": "MWG.ApplicationHasLowRisk ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the application's risk score is low.", "parameter_desc": "None", "description": "Returns TRUE if an application has a low risk score.", "example_code": "IF MWG.ApplicationHasLowRisk() THEN {\n    // The application has a low risk score.\n    MWG.Allow(\"LowRiskApplication\")\n} ELSE {\n    // The application does not have a low risk score.\n    MWG.Block(\"HighRiskApplication\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.ApplicationHasLowRisk() THEN {\n    // The application has a low risk score.\n    MWG.Allow(\"LowRiskApplication\")\n} ELSE {\n    // The application does not have a low risk score.\n    MWG.Block(\"HighRiskApplication\")\n}"}, {"name": "MWG.ApplicationHasMediumRisk ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if an application has a medium risk score, otherwise`FALSE`", "parameter_desc": "None", "description": "Returns TRUE if an application has a medium risk score.", "example_code": "// Check if the application has a medium risk\nIF MWG.ApplicationHasMediumRisk() THEN {\n    // Log the medium risk application\n    // \"Application has medium risk\"\n\n    // Block the request and provide a reason\n    MWG.Block(\"Access to this application is blocked due to medium risk level\")\n} ELSE {\n    // Allow the request if the application does not have a medium risk\n    MWG.Allow(\"Application risk level is acceptable\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Check if the application has a medium risk\nIF MWG.ApplicationHasMediumRisk() THEN {\n    // Log the medium risk application\n    // \"Application has medium risk\"\n\n    // Block the request and provide a reason\n    MWG.Block(\"Access to this application is blocked due to medium risk level\")\n} ELSE {\n    // Allow the request if the application does not have a medium risk\n    MWG.Allow(\"Application risk level is acceptable\")\n}"}, {"name": "MWG.ApplicationHasUnverifiedRisc ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the risk level of the application has not been verified.", "parameter_desc": "None", "description": "Returns TRUE if application risk is unknown.", "example_code": "IF MWG.ApplicationHasUnverifiedRisc() THEN {\n    MWG.Block(\"Access blocked due to unverified application risk.\")\n} ELSE {\n    MWG.Allow(\"Application risk verified.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.ApplicationHasUnverifiedRisc() THEN {\n    MWG.Block(\"Access blocked due to unverified application risk.\")\n} ELSE {\n    MWG.Allow(\"Application risk verified.\")\n}"}, {"name": "MWG.ApplicationID ()", "return_type": "MWG.ApplicationType", "return_desc": "Returns the detected application type.", "parameter_desc": "None", "description": "Returns detected application type.", "example_code": "MWG.ApplicationType appType = MWG.ApplicationID()\n\nIF appType == \"SomeSpecificApplication\" THEN {\n    // Detected application is SomeSpecificApplication\n    MWG.Allow(\"Allowed due to specific application\")\n} ELSE {\n    // Detected application is not SomeSpecificApplication\n    MWG.Block(\"Blocked due to unrecognized application\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ApplicationType appType = MWG.ApplicationID()\n\nIF appType == \"SomeSpecificApplication\" THEN {\n    // Detected application is SomeSpecificApplication\n    MWG.Allow(\"Allowed due to specific application\")\n} ELSE {\n    // Detected application is not SomeSpecificApplication\n    MWG.Block(\"Blocked due to unrecognized application\")\n}"}, {"name": "MWG.ApplicationIsInServiceGroup (MWG.ApplicationServiceGroupType)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current application is in the specified service group, otherwise`FALSE`", "parameter_desc": "MWG.ApplicationServiceGroupType: the service group to check against for the current application.", "description": "Checks if the current application is in a given service group.", "example_code": "MWG.ApplicationServiceGroupType serviceGroup = \"SocialMedia\"\n\nIF MWG.ApplicationIsInServiceGroup(serviceGroup) THEN {\n    // The application is part of the Social Media service group.\n    MWG.Block(\"Access to Social Media applications is not allowed.\")\n} ELSE {\n    // The application is not part of the Social Media service group.\n    MWG.Allow(\"Application is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ApplicationServiceGroupType serviceGroup = \"SocialMedia\"\n\nIF MWG.ApplicationIsInServiceGroup(serviceGroup) THEN {\n    // The application is part of the Social Media service group.\n    MWG.Block(\"Access to Social Media applications is not allowed.\")\n} ELSE {\n    // The application is not part of the Social Media service group.\n    MWG.Allow(\"Application is allowed.\")\n}"}, {"name": "MWG.ApplicationIsInServiceGroup (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current application belongs to the specified service group.", "parameter_desc": "STRING: the name of the service group to check against the current application.", "description": "Checks if the current application is in a given service group.", "example_code": "STRING serviceGroupName = \"SocialMedia\"\n\nIF MWG.ApplicationIsInServiceGroup(serviceGroupName) THEN {\n    // The current application belongs to the service group: SocialMedia\n    MWG.Allow(\"Application is in the allowed service group\")\n} ELSE {\n    // The current application does not belong to the service group: SocialMedia\n    MWG.Block(\"Application is not in the allowed service group\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING serviceGroupName = \"SocialMedia\"\n\nIF MWG.ApplicationIsInServiceGroup(serviceGroupName) THEN {\n    // The current application belongs to the service group: SocialMedia\n    MWG.Allow(\"Application is in the allowed service group\")\n} ELSE {\n    // The current application does not belong to the service group: SocialMedia\n    MWG.Block(\"Application is not in the allowed service group\")\n}"}, {"name": "MWG.ApplicationRisk ()", "return_type": "NUMBER", "return_desc": "Returns the numerical risk score of an application.", "parameter_desc": "None", "description": "Returns the risk score of an application.", "example_code": "NUMBER riskScore = MWG.ApplicationRisk()\n\nIF riskScore > 50 THEN {\n    MWG.Block(\"Application risk score too high: \" + riskScore)\n} ELSE {\n    MWG.Allow(\"Application risk score acceptable: \" + riskScore)\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER riskScore = MWG.ApplicationRisk()\n\nIF riskScore > 50 THEN {\n    MWG.Block(\"Application risk score too high: \" + riskScore)\n} ELSE {\n    MWG.Allow(\"Application risk score acceptable: \" + riskScore)\n}"}, {"name": "MWG.ApplicationRiskType ()", "return_type": "STRING", "return_desc": "Returns the risk score range associated with an application as a string.", "parameter_desc": "None", "description": "Returns the risk score range of an application.", "example_code": "// Get the risk type of the current application\nSTRING riskType = MWG.ApplicationRiskType()\n\n// Application Risk Type: \" + riskType\n\n// Perform actions based on the risk type\nIF riskType == \"High\" THEN {\n    MWG.Block(\"Access to high-risk applications is not allowed.\")\n} ELSE IF riskType == \"Medium\" THEN {\n    // Medium risk application detected.\n} ELSE {\n    // Low risk or unknown application detected.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the risk type of the current application\nSTRING riskType = MWG.ApplicationRiskType()\n\n// Application Risk Type: \" + riskType\n\n// Perform actions based on the risk type\nIF riskType == \"High\" THEN {\n    MWG.Block(\"Access to high-risk applications is not allowed.\")\n} ELSE IF riskType == \"Medium\" THEN {\n    // Medium risk application detected.\n} ELSE {\n    // Low risk or unknown application detected.\n}"}, {"name": "MWG.ApplicationServiceGroup (MWG.ApplicationServiceGroupType)", "return_type": "VECTOR<MWG.ApplicationType>", "return_desc": "Returns a vector containing all the applications within a specified service group.", "parameter_desc": "MWG.ApplicationServiceGroupType: the type of service group for which the VECTOR of applications is returned.", "description": "Returns the vector of applications in a service group.", "example_code": "MWG.ApplicationServiceGroupType appServiceGroup = MWG.GetApplicationServiceGroup()\n\nIF appServiceGroup == \"SocialMedia\" THEN {\n    // Access to Social Media application service group detected.\n    MWG.Block(\"Access to Social Media is not allowed.\")\n} ELSE {\n    MWG.Allow(\"Application service group is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ApplicationServiceGroupType appServiceGroup = MWG.GetApplicationServiceGroup()\n\nIF appServiceGroup == \"SocialMedia\" THEN {\n    // Access to Social Media application service group detected.\n    MWG.Block(\"Access to Social Media is not allowed.\")\n} ELSE {\n    MWG.Allow(\"Application service group is allowed.\")\n}"}, {"name": "MWG.ApplicationServiceName ()", "return_type": "STRING", "return_desc": "Returns the application's name as a string.", "parameter_desc": "None", "description": "Returns the name of an application.", "example_code": "// Retrieve the application's name\nSTRING appName = MWG.ApplicationServiceName()\n\n// Application Service Name: \" + appName\n\n// Example condition: Block the request if the application service name is \"BlockedApp\"\nIF appName == \"BlockedApp\" THEN {\n    MWG.Block(\"Access to this application is blocked.\")\n} ELSE {\n    MWG.Allow(\"Application service is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the application's name\nSTRING appName = MWG.ApplicationServiceName()\n\n// Application Service Name: \" + appName\n\n// Example condition: Block the request if the application service name is \"BlockedApp\"\nIF appName == \"BlockedApp\" THEN {\n    MWG.Block(\"Access to this application is blocked.\")\n} ELSE {\n    MWG.Allow(\"Application service is allowed.\")\n}"}, {"name": "MWG.ApplicationSubCategory ()", "return_type": "STRING", "return_desc": "Returns the name of an application sub-category as a string.", "parameter_desc": "None", "description": "Returns the name of an application sub-category.", "example_code": "STRING subCategory = MWG.ApplicationSubCategory()\n\n// Checking if the subCategory is \"Social Media\"\nIF subCategory == \"Social Media\" THEN {\n    // Blocking access to Social Media sites\n    MWG.Block(\"Access to Social Media sites is not allowed.\")\n} ELSE {\n    // Allowing access if sub-category is not blocked\n    MWG.Allow(\"Sub-category is not blocked.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING subCategory = MWG.ApplicationSubCategory()\n\n// Checking if the subCategory is \"Social Media\"\nIF subCategory == \"Social Media\" THEN {\n    // Blocking access to Social Media sites\n    MWG.Block(\"Access to Social Media sites is not allowed.\")\n} ELSE {\n    // Allowing access if sub-category is not blocked\n    MWG.Allow(\"Sub-category is not blocked.\")\n}"}, {"name": "MWG.ApplicationSubCategoryID ()", "return_type": "MWG.ApplicationSubCategoryType", "return_desc": "Returns the detected application sub-category type as an `MWG.ApplicationSubCategoryType`.", "parameter_desc": "None", "description": "Returns the detected application sub-category type.", "example_code": "MWG.ApplicationSubCategoryType subCategory = MWG.GetApplicationSubCategory()\n\nIF subCategory == \"Social Media\" THEN {\n    // Output: Access to social media is not allowed\n    MWG.Block(\"Access to social media is not allowed\")\n} ELSE {\n    // Output: Application subcategory is allowed\n    MWG.Allow(\"Application subcategory is allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ApplicationSubCategoryType subCategory = MWG.GetApplicationSubCategory()\n\nIF subCategory == \"Social Media\" THEN {\n    // Output: Access to social media is not allowed\n    MWG.Block(\"Access to social media is not allowed\")\n} ELSE {\n    // Output: Application subcategory is allowed\n    MWG.Allow(\"Application subcategory is allowed\")\n}"}, {"name": "MWG.AuthenticationCacheRemainingTime ()", "return_type": "NUMBER", "return_desc": "Returns the amount of time, in numerical value, that credentials will remain in the authentication cache.", "parameter_desc": "None", "description": "\"Returns the remaining time credentials are stored in authentication cache. Not applicable for cloud.\"", "example_code": "NUMBER remainingTime = MWG.AuthenticationCacheRemainingTime()\n\nIF remainingTime < 60 THEN {\n    // \"Authentication cache time is less than 60 seconds.\"\n} ELSE {\n    // \"Authentication cache time is sufficient.\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER remainingTime = MWG.AuthenticationCacheRemainingTime()\n\nIF remainingTime < 60 THEN {\n    // \"Authentication cache time is less than 60 seconds.\"\n} ELSE {\n    // \"Authentication cache time is sufficient.\"\n}"}, {"name": "MWG.AuthenticationFailed ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the provided credentials fail to authenticate.", "parameter_desc": "None", "description": "Returns TRUE if credentials are provided but the authentication fails (not applicable for cloud).", "example_code": "STRING failureMessage = MWG.AuthenticationFailureMessage()\n// Authentication failed: \" + failureMessage\nMWG.Block(\"Authentication failed: \" + failureMessage)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING failureMessage = MWG.AuthenticationFailureMessage()\n// Authentication failed: \" + failureMessage\nMWG.Block(\"Authentication failed: \" + failureMessage)"}, {"name": "MWG.AuthenticationFailureID ()", "return_type": "NUMBER", "return_desc": "Returns a numeric ID representing the specific reason for authentication failure.", "parameter_desc": "None", "description": "Returns authentication failure reason ID, like invalid credentials or DC not available.", "example_code": "NUMBER authFailureID = MWG.AuthenticationFailureID()\n\nIF authFailureID == 1 THEN {\n    // Authentication failed: Invalid credentials\n    MWG.Block(\"Invalid credentials\")\n}\nELSE IF authFailureID == 2 THEN {\n    // Authentication failed: Domain controller not available\n    MWG.Block(\"Domain controller not available\")\n}\nELSE {\n    // Authentication failed: Unknown reason\n    MWG.Block(\"Unknown authentication failure\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER authFailureID = MWG.AuthenticationFailureID()\n\nIF authFailureID == 1 THEN {\n    // Authentication failed: Invalid credentials\n    MWG.Block(\"Invalid credentials\")\n}\nELSE IF authFailureID == 2 THEN {\n    // Authentication failed: Domain controller not available\n    MWG.Block(\"Domain controller not available\")\n}\nELSE {\n    // Authentication failed: Unknown reason\n    MWG.Block(\"Unknown authentication failure\")\n}"}, {"name": "MWG.AuthenticationFailureMessage ()", "return_type": "STRING", "return_desc": "Returns a string explaining why authentication failed.", "parameter_desc": "None", "description": "Returns authentication failure reason.", "example_code": "STRING failureMessage = MWG.AuthenticationFailureMessage()\n// \"Authentication failed: \" + failureMessage\nMWG.Block(\"Authentication failed: \" + failureMessage)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING failureMessage = MWG.AuthenticationFailureMessage()\n// \"Authentication failed: \" + failureMessage\nMWG.Block(\"Authentication failed: \" + failureMessage)"}, {"name": "MWG.AuthenticationGetRealm ()", "return_type": "STRING", "return_desc": "Returns the authentication realm as a string.", "parameter_desc": "None", "description": "Gets authentication realm.", "example_code": "STRING realm = MWG.AuthenticationGetRealm()\n// The authentication realm is: \" + realm\n\nIF realm == \"exampleRealm\" THEN {\n    MWG.Allow(\"Realm is exampleRealm\")\n} ELSE {\n    MWG.Block(\"Access denied: Invalid realm\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING realm = MWG.AuthenticationGetRealm()\n// The authentication realm is: \" + realm\n\nIF realm == \"exampleRealm\" THEN {\n    MWG.Allow(\"Realm is exampleRealm\")\n} ELSE {\n    MWG.Block(\"Access denied: Invalid realm\")\n}"}, {"name": "MWG.AuthenticationIsLandingOnServer ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the authentication is landing on the server.", "parameter_desc": "None", "description": "Returns TRUE if the authentication is landing on the server.", "example_code": "// Call the function to check if the authentication is landing on the server\nBOOLEAN isLanding = MWG.AuthenticationIsLandingOnServer()\n\n// Perform actions based on the result of the function\nIF isLanding THEN {\n    // \"Authentication is landing on the server.\"\n    // Additional logic for when authentication is landing on the server\n} ELSE {\n    // \"Authentication is not landing on the server.\"\n    // Additional logic for when authentication is not landing on the server\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Call the function to check if the authentication is landing on the server\nBOOLEAN isLanding = MWG.AuthenticationIsLandingOnServer()\n\n// Perform actions based on the result of the function\nIF isLanding THEN {\n    // \"Authentication is landing on the server.\"\n    // Additional logic for when authentication is landing on the server\n} ELSE {\n    // \"Authentication is not landing on the server.\"\n    // Additional logic for when authentication is not landing on the server\n}"}, {"name": "MWG.AuthenticationIsServerRequest ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the authentication is a server request.", "parameter_desc": "None", "description": "Returns TRUE if the authentication is a server request.", "example_code": "IF MWG.AuthenticationIsServerRequest() THEN {\n    // This is a server authentication request.\n    // Additional logic for server authentication requests can be added here\n} ELSE {\n    // This is not a server authentication request.\n    // Additional logic for non-server authentication requests can be added here\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.AuthenticationIsServerRequest() THEN {\n    // This is a server authentication request.\n    // Additional logic for server authentication requests can be added here\n} ELSE {\n    // This is not a server authentication request.\n    // Additional logic for non-server authentication requests can be added here\n}"}, {"name": "MWG.AuthenticationMethod ()", "return_type": "STRING", "return_desc": "Returns a string indicating the name of the most recently successful authentication method.", "parameter_desc": "None", "description": "Returns the name of the last successful authentication method.", "example_code": "MWG.AuthenticationSetMethod(\"Basic\")\n// Authentication method set to Basic", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.AuthenticationSetMethod(\"Basic\")\n// Authentication method set to Basic"}, {"name": "MWG.AuthenticationRawCredentials ()", "return_type": "STRING", "return_desc": "Returns a string containing the authentication credentials.", "parameter_desc": "None", "description": "Returns authentication credential string.", "example_code": "STRING credentials = MWG.AuthenticationRawCredentials()\n// \"Authentication Credentials: \" + credentials", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING credentials = MWG.AuthenticationRawCredentials()\n// \"Authentication Credentials: \" + credentials"}, {"name": "MWG.AuthenticationRawUsername ()", "return_type": "STRING", "return_desc": "Returns the unprocessed username used for authentication.", "parameter_desc": "None", "description": "Returns raw authentication user name.", "example_code": "STRING rawUsername = MWG.AuthenticationRawUsername()\n// Raw Username: + rawUsername", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING rawUsername = MWG.AuthenticationRawUsername()\n// Raw Username: + rawUsername"}, {"name": "MWG.AuthenticationToken ()", "return_type": "STRING", "return_desc": "Returns authentication token.", "parameter_desc": "None", "description": "Returns authentication token.", "example_code": "// Retrieve the authentication token\nSTRING authToken = MWG.AuthenticationToken()\n\n// Authentication Token: \" + authToken\n\n// Use the authentication token in some logic\nIF authToken != \"\" THEN {\n    // Allow the connection and log the rule\n    MWG.Allow(\"Authenticated with token\")\n} ELSE {\n    // Block the connection if no token is present\n    MWG.Block(\"No authentication token found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the authentication token\nSTRING authToken = MWG.AuthenticationToken()\n\n// Authentication Token: \" + authToken\n\n// Use the authentication token in some logic\nIF authToken != \"\" THEN {\n    // Allow the connection and log the rule\n    MWG.Allow(\"Authenticated with token\")\n} ELSE {\n    // Block the connection if no token is present\n    MWG.Block(\"No authentication token found\")\n}"}, {"name": "MWG.AVMitreTags (MWG.AntimalwareSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns list of MITRE tags.", "parameter_desc": "MWG.AntimalwareSetting: configuration settings.", "description": "Returns list of MITRE tags.", "example_code": "// Create an instance of MWG.AntimalwareSetting\nMWG.AntimalwareSetting antimalwareSetting = MWG.AntimalwareSetting()\n\n// Retrieve the MITRE tags\nVECTOR<STRING> mitreTags = MWG.AVMitreTags(antimalwareSetting)\n\n// Check if specific MITRE tag exists\nIF \"T1059\" IN mitreTags THEN {\n    // MITRE tag T1059 detected\n    MWG.Block(\"Detected MITRE tag T1059\")\n} ELSE {\n    // No relevant MITRE tags detected\n    MWG.Allow(\"No relevant MITRE tags\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of MWG.AntimalwareSetting\nMWG.AntimalwareSetting antimalwareSetting = MWG.AntimalwareSetting()\n\n// Retrieve the MITRE tags\nVECTOR<STRING> mitreTags = MWG.AVMitreTags(antimalwareSetting)\n\n// Check if specific MITRE tag exists\nIF \"T1059\" IN mitreTags THEN {\n    // MITRE tag T1059 detected\n    MWG.Block(\"Detected MITRE tag T1059\")\n} ELSE {\n    // No relevant MITRE tags detected\n    MWG.Allow(\"No relevant MITRE tags\")\n}"}, {"name": "MWG.BlockHeaders ()", "return_type": "MWG.HeaderMap", "return_desc": "Returns the headers configured for blocking network requests.", "parameter_desc": "None", "description": "Returns the header to be used in blocked requests.", "example_code": "// Retrieve the headers configured for blocking network requests\nMWG.HeaderMap blockHeaders = MWG.BlockHeaders()\n\n// Add a custom header to the block headers\nblockHeaders[\"X-Custom-Header\"] = \"Blocked by policy\"\n\n// Block the request with a custom message\nMWG.Block(\"Request blocked due to policy violation\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the headers configured for blocking network requests\nMWG.HeaderMap blockHeaders = MWG.BlockHeaders()\n\n// Add a custom header to the block headers\nblockHeaders[\"X-Custom-Header\"] = \"Blocked by policy\"\n\n// Block the request with a custom message\nMWG.Block(\"Request blocked due to policy violation\")"}, {"name": "MWG.BlockReason ()", "return_type": "STRING", "return_desc": "Returns a string that explains why an action was blocked.", "parameter_desc": "None", "description": "Returns the reason of block action.", "example_code": "STRING reason = \"Access to this site is blocked due to policy restrictions.\"\n// The following line blocks access with the given reason\n// MWG.Block(reason)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING reason = \"Access to this site is blocked due to policy restrictions.\"\n// The following line blocks access with the given reason\n// MWG.Block(reason)"}, {"name": "MWG.BlockReasonId ()", "return_type": "NUMBER", "return_desc": "Returns the numeric identifier associated with the reason for a block.", "parameter_desc": "None", "description": "Returns the numeric ID of the block reason.", "example_code": "NUMBER blockReasonId = MWG.BlockReasonId()\n// \"Block Reason ID: \" + blockReasonId", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER blockReasonId = MWG.BlockReasonId()\n// \"Block Reason ID: \" + blockReasonId"}, {"name": "MWG.Body (MWG.RequestResponse)", "return_type": "STREAM", "return_desc": "Returns the body of the request or response as a stream.", "parameter_desc": "MWG.RequestResponse: The request or response object containing the body to be streamed.", "description": "Returns the body as a stream.", "example_code": "MWG.RequestResponse response = MWG.Url()\nSTREAM responseBody = MWG.Body(response)\n\n// Assuming there's a function to convert STREAM to STRING for debugging\nSTRING responseBodyString = ConvertStreamToString(responseBody)\n\n// Debug: responseBodyString\n\n// Helper function to convert STREAM to STRING (hypothetical, for illustration purposes)\nFUNCTION ConvertStreamToString(STREAM stream) RETURNS STRING {\n    // Implementation to convert stream to string\n    // This is just a placeholder and may not be an actual MOWGLI function\n    RETURN \"Converted Stream Content\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.RequestResponse response = MWG.Url()\nSTREAM responseBody = MWG.Body(response)\n\n// Assuming there's a function to convert STREAM to STRING for debugging\nSTRING responseBodyString = ConvertStreamToString(responseBody)\n\n// Debug: responseBodyString\n\n// Helper function to convert STREAM to STRING (hypothetical, for illustration purposes)\nFUNCTION ConvertStreamToString(STREAM stream) RETURNS STRING {\n    // Implementation to convert stream to string\n    // This is just a placeholder and may not be an actual MOWGLI function\n    RETURN \"Converted Stream Content\"\n}"}, {"name": "MWG.BodyAllMemberCount ()", "return_type": "NUMBER", "return_desc": "Returns the total number of embedded objects within archives or documents.", "parameter_desc": "None", "description": "Returns number of embedded objects for archives or documents.", "example_code": "NUMBER embeddedObjectCount = MWG.BodyAllMemberCount()\n\nIF embeddedObjectCount > 0 THEN {\n    // Number of embedded objects: \" + embeddedObjectCount\n} ELSE {\n    // No embedded objects found.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER embeddedObjectCount = MWG.BodyAllMemberCount()\n\nIF embeddedObjectCount > 0 THEN {\n    // Number of embedded objects: \" + embeddedObjectCount\n} ELSE {\n    // No embedded objects found.\n}"}, {"name": "MWG.BodyAllMemberNames ()", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing members in the archive.", "parameter_desc": "None", "description": "Returns a list of all members of the archive.", "example_code": "VECTOR<STRING> memberNames = MWG.BodyAllMemberNames()\n// Members in the archive:  + memberNames", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> memberNames = MWG.BodyAllMemberNames()\n// Members in the archive:  + memberNames"}, {"name": "MWG.BodyAsNumber (NUMBER, NUMBER, BOOLEAN)", "return_type": "NUMBER", "return_desc": "Returns the body as a number.", "parameter_desc": "NUMBER: The starting position; NUMBER: The length to use; BOOLEAN: TRUE for little endian.", "description": "Returns the body as a number.", "example_code": "// Define the starting position, length, and endianness\nNUMBER startPosition = 0\nNUMBER length = 4\nBOOLEAN isLittleEndian = TRUE\n\n// Extract the number from the body\nNUMBER extractedNumber = MWG.BodyAsNumber(startPosition, length, isLittleEndian)\n\n// Print the extracted number to the debug console\n// \"Extracted Number: \" + extractedNumber", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the starting position, length, and endianness\nNUMBER startPosition = 0\nNUMBER length = 4\nBOOLEAN isLittleEndian = TRUE\n\n// Extract the number from the body\nNUMBER extractedNumber = MWG.BodyAsNumber(startPosition, length, isLittleEndian)\n\n// Print the extracted number to the debug console\n// \"Extracted Number: \" + extractedNumber"}, {"name": "MWG.BodyAsSTRING (NUMBER, NUMBER)", "return_type": "STRING", "return_desc": "Returns the substring of the body found between the two specified numerical indices.", "parameter_desc": "NUMBER: the starting position; NUMBER: the ending position.", "description": "Returns the body between the given parameters.", "example_code": "// Define the start and end positions for the substring\nNUMBER startPosition = 10\nNUMBER endPosition = 50\n\n// Use the MWG.BodyAsString function to get the substring\nSTRING bodySubstring = MWG.BodyAsString(startPosition, endPosition)\n\n// Extracted Substring: \" + bodySubstring", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the start and end positions for the substring\nNUMBER startPosition = 10\nNUMBER endPosition = 50\n\n// Use the MWG.BodyAsString function to get the substring\nSTRING bodySubstring = MWG.BodyAsString(startPosition, endPosition)\n\n// Extracted Substring: \" + bodySubstring"}, {"name": "MWG.BodyClassID ()", "return_type": "STRING", "return_desc": "Returns the class ID of embedded Microsoft Windows objects as a string.", "parameter_desc": "None", "description": "Returns the class ID for embedded Microsoft Windows objects.", "example_code": "STRING classID = MWG.BodyClassID()\n// The class ID of the embedded Microsoft Windows object is: \" + classID\n\nIF classID == \"desired_class_id\" THEN {\n    MWG.Allow(\"Class ID matched\")\n} ELSE {\n    MWG.Block(\"Class ID did not match\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING classID = MWG.BodyClassID()\n// The class ID of the embedded Microsoft Windows object is: \" + classID\n\nIF classID == \"desired_class_id\" THEN {\n    MWG.Allow(\"Class ID matched\")\n} ELSE {\n    MWG.Block(\"Class ID did not match\")\n}"}, {"name": "MWG.BodyData (MWG.RequestResponse)", "return_type": "DATAREF", "return_desc": "Returns the body as a `DATAREF`.", "parameter_desc": "", "description": "Returns the body as a `DATAREF`.", "example_code": "// Retrieve the body data of the current response\nDATAREF bodyData = MWG.BodyData(Web.Response)\n\n// Convert the DATAREF to a STRING for debugging purposes\nSTRING bodyString = bodyData.ToString()\n\n// Body Data: bodyString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the body data of the current response\nDATAREF bodyData = MWG.BodyData(Web.Response)\n\n// Convert the DATAREF to a STRING for debugging purposes\nSTRING bodyString = bodyData.ToString()\n\n// Body Data: bodyString"}, {"name": "MWG.BodyEqualsPattern (NUMBER, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the specified pattern exists at the specified position in the body.", "parameter_desc": "NUMBER: the position in the body to check for the pattern; STRING: the pattern to match within the body.", "description": "Returns TRUE if the body contains a given pattern at a given position.", "example_code": "NUMBER bodyIndex = 0\nSTRING pattern = \"examplePattern\"\n\nIF MWG.BodyEqualsPattern(bodyIndex, pattern) THEN {\n    // Pattern matched in the body of the response\n    MWG.Block(\"Blocked due to pattern match in response body\")\n} ELSE {\n    // Pattern not found in the body of the response\n    MWG.Allow(\"No pattern match found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER bodyIndex = 0\nSTRING pattern = \"examplePattern\"\n\nIF MWG.BodyEqualsPattern(bodyIndex, pattern) THEN {\n    // Pattern matched in the body of the response\n    MWG.Block(\"Blocked due to pattern match in response body\")\n} ELSE {\n    // Pattern not found in the body of the response\n    MWG.Allow(\"No pattern match found\")\n}"}, {"name": "MWG.BodyExtractedText ()", "return_type": "STRING", "return_desc": "Returns the text extracted from the current object.", "parameter_desc": "None", "description": "Returns the extracted text from the current object.", "example_code": "// Extract text from the current object\nSTRING extractedText = MWG.BodyExtractedText()\n\n// Extracted Text: \" + extractedText\n\n// Check if the extracted text contains a specific keyword\nIF extractedText CONTAINS \"confidential\" THEN {\n    // Block the connection if the keyword is found\n    MWG.Block(\"Blocked due to presence of confidential information\")\n} ELSE {\n    // Allow the connection if the keyword is not found\n    MWG.Allow(\"No confidential information found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Extract text from the current object\nSTRING extractedText = MWG.BodyExtractedText()\n\n// Extracted Text: \" + extractedText\n\n// Check if the extracted text contains a specific keyword\nIF extractedText CONTAINS \"confidential\" THEN {\n    // Block the connection if the keyword is found\n    MWG.Block(\"Blocked due to presence of confidential information\")\n} ELSE {\n    // Allow the connection if the keyword is not found\n    MWG.Allow(\"No confidential information found\")\n}"}, {"name": "MWG.BodyFileName ()", "return_type": "STRING", "return_desc": "Returns the filename of the body as a string.", "parameter_desc": "None", "description": "Returns the filename of the body.", "example_code": "// Retrieve the filename of the body\nSTRING bodyFileName = MWG.BodyFileName()\n\n// The filename of the body is: \" + bodyFileName\n// Formerly: DEBUG(\"The filename of the body is: \" + bodyFileName)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the filename of the body\nSTRING bodyFileName = MWG.BodyFileName()\n\n// The filename of the body is: \" + bodyFileName\n// Formerly: DEBUG(\"The filename of the body is: \" + bodyFileName)"}, {"name": "MWG.BodyFullFileName ()", "return_type": "STRING", "return_desc": "Returns the full filename of the body as a string.", "parameter_desc": "None", "description": "Returns the full filename of the body, including the parent archive with each file name separated by vertical pipes. For example, index.html inside of xyz.zip would be represented as ?\u00c7\u00a3xyz.zip|index.html?\u00c7\u00a5.", "example_code": "// Retrieve the full file name of the body content\nSTRING fileName = MWG.BodyFullFileName()\n\n// The full file name is: \" + fileName\n\n// Check if the file name contains a specific extension\nIF fileName CONTAINS \".exe\" THEN {\n    // Block the request if the file is an executable\n    MWG.Block(\"Executable files are not allowed.\")\n} ELSE {\n    // Allow the request if the file is not an executable\n    MWG.Allow(\"File is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the full file name of the body content\nSTRING fileName = MWG.BodyFullFileName()\n\n// The full file name is: \" + fileName\n\n// Check if the file name contains a specific extension\nIF fileName CONTAINS \".exe\" THEN {\n    // Block the request if the file is an executable\n    MWG.Block(\"Executable files are not allowed.\")\n} ELSE {\n    // Allow the request if the file is not an executable\n    MWG.Allow(\"File is allowed.\")\n}"}, {"name": "MWG.BodyHash ()", "return_type": "STRING", "return_desc": "Returns the SHA1 hash of the body.", "parameter_desc": "None", "description": "Returns the SHA1 hash of the body.", "example_code": "STRING hashAlgorithm = \"SHA-256\"\nSTRING bodyHash = MWG.BodyHash(hashAlgorithm)\n// The hash of the body using SHA-256 is: bodyHash", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING hashAlgorithm = \"SHA-256\"\nSTRING bodyHash = MWG.BodyHash(hashAlgorithm)\n// The hash of the body using SHA-256 is: bodyHash"}, {"name": "MWG.BodyHash (STRING)", "return_type": "STRING", "return_desc": "Returns hash of body using given hash algorithm.", "parameter_desc": "STRING: the hashing algorithm.", "description": "Returns the hash of the body.", "example_code": "STRING hashAlgorithm = \"SHA-256\"\nSTRING bodyHash = MWG.BodyHash(hashAlgorithm)\n// The hash of the body using SHA-256 is: bodyHash", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING hashAlgorithm = \"SHA-256\"\nSTRING bodyHash = MWG.BodyHash(hashAlgorithm)\n// The hash of the body using SHA-256 is: bodyHash"}, {"name": "MWG.BodyHasMimeHeader (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the specified Mime header is found, otherwise`FALSE`", "parameter_desc": "STRING: the name of the mime header to check for.", "description": "Checks whether input Mime header is present.", "example_code": "STRING mimeHeader = \"Content-Type: application/json\"\n\nIF MWG.BodyHasMimeHeader(mimeHeader) THEN {\n    // MIME header found: \" + mimeHeader\n    // Additional actions can be taken here if the MIME header is found\n} ELSE {\n    // MIME header not found: \" + mimeHeader\n    // Actions to take if the MIME header is not found\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mimeHeader = \"Content-Type: application/json\"\n\nIF MWG.BodyHasMimeHeader(mimeHeader) THEN {\n    // MIME header found: \" + mimeHeader\n    // Additional actions can be taken here if the MIME header is found\n} ELSE {\n    // MIME header not found: \" + mimeHeader\n    // Actions to take if the MIME header is not found\n}"}, {"name": "MWG.BodyHasMimeHeaderParameter (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the MIME header contains the specified parameter, otherwise`FALSE`", "parameter_desc": "STRING: the mime header to check; STRING: the parameter to find within the mime header.", "description": "Checks whether Mime header has the parameter.", "example_code": "STRING headerName = \"Content-Type\"\nSTRING headerValue = \"text/html\"\n\nIF MWG.BodyHasMimeHeaderParameter(headerName, headerValue) THEN {\n    // MIME header parameter found\n    MWG.Allow(\"MIME header parameter found\")\n} ELSE {\n    // MIME header parameter not found\n    MWG.Block(\"MIME header parameter not found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING headerName = \"Content-Type\"\nSTRING headerValue = \"text/html\"\n\nIF MWG.BodyHasMimeHeaderParameter(headerName, headerValue) THEN {\n    // MIME header parameter found\n    MWG.Allow(\"MIME header parameter found\")\n} ELSE {\n    // MIME header parameter not found\n    MWG.Block(\"MIME header parameter not found\")\n}"}, {"name": "MWG.BodyInfected (MWG.AntimalwareSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the body is detected to be infected with a virus using the GAM method.", "parameter_desc": "MWG.AntimalwareSetting: the configuration settings for the antimalware scan.", "description": "Returns TRUE if the body is virus infected (via GAM).", "example_code": "MWG.AntimalwareSetting antimalwareSettings = [YourAntimalwareSettings]\n\nIF MWG.BodyInfected(antimalwareSettings) THEN {\n    MWG.Block(\"Virus detected in the body of the request/response.\")\n} ELSE {\n    MWG.Allow(\"No virus detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.AntimalwareSetting antimalwareSettings = [YourAntimalwareSettings]\n\nIF MWG.BodyInfected(antimalwareSettings) THEN {\n    MWG.Block(\"Virus detected in the body of the request/response.\")\n} ELSE {\n    MWG.Allow(\"No virus detected.\")\n}"}, {"name": "MWG.BodyInfected (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the body contains a virus infection, otherwise`FALSE`", "parameter_desc": "MWG.InternalSetting: a configuration settings object required for the function to check if the body is virus infected.", "description": "Logging: Returns true if the body is virus infected.", "example_code": "MWG.InternalSetting settings = // Initialize or obtain the necessary settings object\n\nIF MWG.BodyInfected(settings) THEN {\n    // Virus detected in the body. Blocking the request/response.\n    MWG.Block(\"The content is infected with a virus.\")\n} ELSE {\n    // No virus detected in the body. Allowing the request/response.\n    MWG.Allow(\"No virus detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting settings = // Initialize or obtain the necessary settings object\n\nIF MWG.BodyInfected(settings) THEN {\n    // Virus detected in the body. Blocking the request/response.\n    MWG.Block(\"The content is infected with a virus.\")\n} ELSE {\n    // No virus detected in the body. Allowing the request/response.\n    MWG.Allow(\"No virus detected.\")\n}"}, {"name": "MWG.BodyInfected (MWG.MATDSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the body is infected by a virus as determined by ATD.", "parameter_desc": "MWG.MATDSetting: the Advanced Threat Detection (ATD) settings required to determine if the body is virus infected.", "description": "Returns TRUE if the body is virus infected (via ATD).", "example_code": "MWG.MATDSetting atdSettings = [\"Default ATD Settings\"]\n\nIF MWG.BodyInfected(atdSettings) THEN {\n    MWG.Block(\"The content is infected with a virus.\")\n} ELSE {\n    MWG.Allow(\"Content is clean.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.MATDSetting atdSettings = [\"Default ATD Settings\"]\n\nIF MWG.BodyInfected(atdSettings) THEN {\n    MWG.Block(\"The content is infected with a virus.\")\n} ELSE {\n    MWG.Allow(\"Content is clean.\")\n}"}, {"name": "MWG.BodyIsAccessRestrictedObject ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current object has access permission restriction (PDF).", "parameter_desc": "None", "description": "Returns TRUE if the current object has access permission restriction (PDF).", "example_code": "IF MWG.BodyIsAccessRestrictedObject() THEN {\n    // Access restriction detected on the object.\n    MWG.Block(\"Access to this document is restricted due to permission settings.\")\n} ELSE {\n    // No access restrictions detected on the object.\n    MWG.Allow(\"No access restrictions\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.BodyIsAccessRestrictedObject() THEN {\n    // Access restriction detected on the object.\n    MWG.Block(\"Access to this document is restricted due to permission settings.\")\n} ELSE {\n    // No access restrictions detected on the object.\n    MWG.Allow(\"No access restrictions\")\n}"}, {"name": "MWG.BodyIsCompleteWithTimeout (NUMBER)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the body is complete.", "parameter_desc": "NUMBER: the timeout", "description": "Checks if the body is complete with a given timeout.", "example_code": "NUMBER timeout = 10  // Timeout period in seconds\n\nIF MWG.BodyIsCompleteWithTimeout(timeout) THEN {\n    // Body is complete within the timeout period.\n    MWG.Allow(\"BodyComplete\")\n} ELSE {\n    // Body is not complete within the timeout period.\n    MWG.Block(\"Request body not complete within timeout.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER timeout = 10  // Timeout period in seconds\n\nIF MWG.BodyIsCompleteWithTimeout(timeout) THEN {\n    // Body is complete within the timeout period.\n    MWG.Allow(\"BodyComplete\")\n} ELSE {\n    // Body is not complete within the timeout period.\n    MWG.Block(\"Request body not complete within timeout.\")\n}"}, {"name": "MWG.BodyIsCorruptedObject ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current object is detected to be corrupted.", "parameter_desc": "None", "description": "Returns TRUE if the current object is corrupted.", "example_code": "IF MWG.BodyIsCorruptedObject() THEN {\n    // The object is corrupted.\n    MWG.Block(\"The object is corrupted and cannot be processed.\")\n} ELSE {\n    // The object is not corrupted.\n    MWG.Allow(\"Object is clean and allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.BodyIsCorruptedObject() THEN {\n    // The object is corrupted.\n    MWG.Block(\"The object is corrupted and cannot be processed.\")\n} ELSE {\n    // The object is not corrupted.\n    MWG.Allow(\"Object is clean and allowed.\")\n}"}, {"name": "MWG.BodyIsEncryptedObject ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the examined object in the current context is encrypted.", "parameter_desc": "None", "description": "Returns TRUE if the current object is encrypted.", "example_code": "IF MWG.BodyIsEncryptedObject() THEN {\n    // The body of the response is encrypted.\n    MWG.Block(\"Access to encrypted content is blocked.\")\n} ELSE {\n    // The body of the response is not encrypted.\n    MWG.Allow(\"Content is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.BodyIsEncryptedObject() THEN {\n    // The body of the response is encrypted.\n    MWG.Block(\"Access to encrypted content is blocked.\")\n} ELSE {\n    // The body of the response is not encrypted.\n    MWG.Allow(\"Content is allowed.\")\n}"}, {"name": "MWG.BodyIsModified ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current body has been altered.", "parameter_desc": "None", "description": "Returns TRUE if the current body is modified.", "example_code": "IF MWG.BodyIsModified() THEN {\n    // The body has been modified.\n} ELSE {\n    // The body has not been modified.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.BodyIsModified() THEN {\n    // The body has been modified.\n} ELSE {\n    // The body has not been modified.\n}"}, {"name": "MWG.BodyIsMultipartObject ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current object is a multipart archive. Otherwise, it returns`FALSE`", "parameter_desc": "None", "description": "Returns TRUE if the current object is a multipart archive.", "example_code": "IF MWG.BodyIsMultipartObject() THEN {\n    // The current object is a multipart archive.\n    // Additional actions can be taken here if the object is a multipart archive\n} ELSE {\n    // The current object is not a multipart archive.\n    // Additional actions can be taken here if the object is not a multipart archive\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.BodyIsMultipartObject() THEN {\n    // The current object is a multipart archive.\n    // Additional actions can be taken here if the object is a multipart archive\n} ELSE {\n    // The current object is not a multipart archive.\n    // Additional actions can be taken here if the object is not a multipart archive\n}"}, {"name": "MWG.BodyIsSupportedByOpener ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current file can be extracted by the opener.", "parameter_desc": "None", "description": "Returns TRUE if the opener can extract data from the current file.", "example_code": "IF MWG.BodyIsSupportedByOpener() THEN {\n    // The body is supported by the opener.\n} ELSE {\n    // The body is not supported by the opener.\n    MWG.Block(\"Unsupported body format\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.BodyIsSupportedByOpener() THEN {\n    // The body is supported by the opener.\n} ELSE {\n    // The body is not supported by the opener.\n    MWG.Block(\"Unsupported body format\")\n}"}, {"name": "MWG.BodyMediaTypeFromHeader ()", "return_type": "MediaType", "return_desc": "Returns the MIME type extracted from the content-type header of the current body.", "parameter_desc": "None", "description": "Returns MIME type, extracted from content-type header of current body.", "example_code": "MediaType mediaType = MWG.BodyMediaTypeFromHeader()\n// The media type of the current body is: \" + mediaType\n\nIF mediaType == \"application/json\" THEN {\n    // The content is JSON.\n} ELSE {\n    // The content is not JSON.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MediaType mediaType = MWG.BodyMediaTypeFromHeader()\n// The media type of the current body is: \" + mediaType\n\nIF mediaType == \"application/json\" THEN {\n    // The content is JSON.\n} ELSE {\n    // The content is not JSON.\n}"}, {"name": "MWG.BodyMimeHeaderParameterValue (STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the string representation of the mime header parameter's value.", "parameter_desc": "STRING: the name of the mime header; STRING: the desired parameter within the mime header.", "description": "Returns the Mime header parameter value.", "example_code": "// Define the MIME header and parameter you want to check\nSTRING mimeHeader = \"Content-Type\"\nSTRING parameter = \"charset\"\n\n// Retrieve the value of the specified parameter from the MIME header\nSTRING charsetValue = MWG.BodyMimeHeaderParameterValue(mimeHeader, parameter)\n\n// Charset value: \" + charsetValue\n\n// Perform an action based on the retrieved value\nIF charsetValue == \"utf-8\" THEN {\n    // The charset is UTF-8\n} ELSE {\n    // The charset is not UTF-8\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the MIME header and parameter you want to check\nSTRING mimeHeader = \"Content-Type\"\nSTRING parameter = \"charset\"\n\n// Retrieve the value of the specified parameter from the MIME header\nSTRING charsetValue = MWG.BodyMimeHeaderParameterValue(mimeHeader, parameter)\n\n// Charset value: \" + charsetValue\n\n// Perform an action based on the retrieved value\nIF charsetValue == \"utf-8\" THEN {\n    // The charset is UTF-8\n} ELSE {\n    // The charset is not UTF-8\n}"}, {"name": "MWG.BodyMimeHeaderValue (STRING)", "return_type": "STRING", "return_desc": "Returns the same MIME header value that is provided as input.", "parameter_desc": "STRING: the mime header value to be returned.", "description": "Returns the input Mime header value.", "example_code": "STRING mimeHeader = \"Content-Type\"\nSTRING headerValue = MWG.BodyMimeHeaderValue(mimeHeader)\n// The MIME header value for Content-Type is: headerValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mimeHeader = \"Content-Type\"\nSTRING headerValue = MWG.BodyMimeHeaderValue(mimeHeader)\n// The MIME header value for Content-Type is: headerValue"}, {"name": "MWG.BodyNestedArchiveLevel ()", "return_type": "NUMBER", "return_desc": "Returns the current level of the nested archive as a numeric value.", "parameter_desc": "None", "description": "Returns the current archive level.", "example_code": "NUMBER nestedLevel = MWG.BodyNestedArchiveLevel()\n\nIF nestedLevel > 3 THEN {\n    MWG.Block(\"The archive is nested too deeply.\")\n} ELSE {\n    MWG.Allow(\"Archive nesting level is acceptable.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER nestedLevel = MWG.BodyNestedArchiveLevel()\n\nIF nestedLevel > 3 THEN {\n    MWG.Block(\"The archive is nested too deeply.\")\n} ELSE {\n    MWG.Allow(\"Archive nesting level is acceptable.\")\n}"}, {"name": "MWG.BodyPositionOfPattern (STRING, NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the position of the given string in the body.", "parameter_desc": "STRING: Pattern to search for; NUMBER: Starting position; NUMBER: Length to search.", "description": "Gets the position of the given string in the body.", "example_code": "STRING pattern = \"examplePattern\"\nNUMBER startPosition = 0\nNUMBER lengthToSearch = 1000\n\nNUMBER position = MWG.BodyPositionOfPattern(pattern, startPosition, lengthToSearch)\n\nIF position >= 0 THEN {\n    // Pattern found at position: \" + position\n    MWG.Block(\"Pattern found in request body\")\n} ELSE {\n    // Pattern not found in the specified range\n    MWG.Allow(\"Pattern not found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING pattern = \"examplePattern\"\nNUMBER startPosition = 0\nNUMBER lengthToSearch = 1000\n\nNUMBER position = MWG.BodyPositionOfPattern(pattern, startPosition, lengthToSearch)\n\nIF position >= 0 THEN {\n    // Pattern found at position: \" + position\n    MWG.Block(\"Pattern found in request body\")\n} ELSE {\n    // Pattern not found in the specified range\n    MWG.Allow(\"Pattern not found\")\n}"}, {"name": "MWG.BodyReputationIsBad (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the GTI cloud service identifies the current body as a virus.", "parameter_desc": "MWG.InternalSetting: specifies the internal configuration used to check the reputation of the body with the GTI cloud service.", "description": "Logging: Returns true if the GTI cloud service rates the current body as a virus.", "example_code": "MWG.URL url = MWG.Url()\nSTRING reputation = GetReputation(url)  // Assuming GetReputation is a function that returns the reputation of the URL\n\nIF reputation == \"bad\" THEN {\n    MWG.Block(\"Content blocked due to bad reputation\")\n} ELSE {\n    MWG.Allow(\"Content allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL url = MWG.Url()\nSTRING reputation = GetReputation(url)  // Assuming GetReputation is a function that returns the reputation of the URL\n\nIF reputation == \"bad\" THEN {\n    MWG.Block(\"Content blocked due to bad reputation\")\n} ELSE {\n    MWG.Allow(\"Content allowed\")\n}"}, {"name": "MWG.BodyReputationIsBad (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the GTI cloud service identifies the current body as a virus.", "parameter_desc": "MWG.UrlCategorizationSetting: The url categorization setting used to assess the body reputation via the GTI cloud service.", "description": "Returns TRUE if GTI cloud service rates current body as virus.", "example_code": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize your categorization setting here\n\nIF NOT MWG.BodyReputationIsGood(categorizationSetting) THEN {\n    // Body reputation is bad\n    MWG.Block(\"The content has been blocked due to bad body reputation.\")\n} ELSE {\n    // Body reputation is good\n    MWG.Allow(\"Body reputation check passed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize your categorization setting here\n\nIF NOT MWG.BodyReputationIsGood(categorizationSetting) THEN {\n    // Body reputation is bad\n    MWG.Block(\"The content has been blocked due to bad body reputation.\")\n} ELSE {\n    // Body reputation is good\n    MWG.Allow(\"Body reputation check passed\")\n}"}, {"name": "MWG.BodyReputationIsGood (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the GTI cloud service verifies that the current body is clean.", "parameter_desc": "MWG.InternalSetting: Configuration setting used internally by MWG to evaluate the body's reputation through the GTI cloud service.", "description": "Logging: Returns TRUE if GTI cloud service rates the current body as clean.", "example_code": "MWG.InternalSetting bodyReputationSetting = MWG.BodyReputationIsGood()\nSTRING reputationResult = MWG.ExecuteEvent(bodyReputationSetting, \"CheckReputation\", MWG.InternalParameterList())\n\nIF reputationResult == \"Good\" THEN {\n    // Body reputation is good. Allowing the response.\n    MWG.Allow(\"BodyReputationCheck\")\n} ELSE {\n    // Body reputation is not good. Blocking the response.\n    MWG.Block(\"BodyReputationCheck\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting bodyReputationSetting = MWG.BodyReputationIsGood()\nSTRING reputationResult = MWG.ExecuteEvent(bodyReputationSetting, \"CheckReputation\", MWG.InternalParameterList())\n\nIF reputationResult == \"Good\" THEN {\n    // Body reputation is good. Allowing the response.\n    MWG.Allow(\"BodyReputationCheck\")\n} ELSE {\n    // Body reputation is not good. Blocking the response.\n    MWG.Block(\"BodyReputationCheck\")\n}"}, {"name": "MWG.BodyReputationIsGood (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the GTI cloud service determines that the current body is clean.", "parameter_desc": "MWG.UrlCategorizationSetting: The categorization settings used to determine if the current body is rated as clean by the GTI cloud service.", "description": "Returns TRUE if GTI cloud service rates current body as clean.", "example_code": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize with appropriate settings\n\nIF MWG.BodyReputationIsGood(categorizationSetting) THEN {\n    // Body reputation is good\n    MWG.Allow(\"Body reputation is good\")\n} ELSE {\n    // Body reputation is not good\n    MWG.Block(\"Body reputation is not good\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize with appropriate settings\n\nIF MWG.BodyReputationIsGood(categorizationSetting) THEN {\n    // Body reputation is good\n    MWG.Allow(\"Body reputation is good\")\n} ELSE {\n    // Body reputation is not good\n    MWG.Block(\"Body reputation is not good\")\n}"}, {"name": "MWG.BodyReputationIsKnown (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the GTI cloud service has a rating available for the current body.", "parameter_desc": "MWG.InternalSetting: A configuration or status object used to check if the GTI cloud service has a rating for the current body.", "description": "Logging: Returns true if GTI cloud service has a rating for the current body.", "example_code": "MWG.InternalSetting setting = // Initialize or obtain the appropriate MWG.InternalSetting object\n\nIF MWG.BodyReputationIsKnown(setting) THEN {\n    // GTI cloud service has a rating for the current body.\n    // Additional actions can be taken here, such as allowing the connection\n    MWG.Allow(\"Body reputation known\")\n} ELSE {\n    // GTI cloud service does not have a rating for the current body.\n    // Additional actions can be taken here, such as blocking the connection\n    MWG.Block(\"Body reputation unknown\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting setting = // Initialize or obtain the appropriate MWG.InternalSetting object\n\nIF MWG.BodyReputationIsKnown(setting) THEN {\n    // GTI cloud service has a rating for the current body.\n    // Additional actions can be taken here, such as allowing the connection\n    MWG.Allow(\"Body reputation known\")\n} ELSE {\n    // GTI cloud service does not have a rating for the current body.\n    // Additional actions can be taken here, such as blocking the connection\n    MWG.Block(\"Body reputation unknown\")\n}"}, {"name": "MWG.BodyReputationIsKnown (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the GTI cloud service has a rating for the specified `MWG URL categorization`.", "parameter_desc": "MWG.UrlCategorizationSetting: The configuration setting dictating how URLs are categorized.", "description": "Returns TRUE if GTI cloud service has a rating for the current body.", "example_code": "MWG.UrlCategorizationSetting categorizationSetting = MWG.UrlCategorizationSetting()\n\nIF MWG.BodyReputationIsGood(categorizationSetting) THEN {\n    // Body reputation is good.\n    MWG.Allow(\"BodyReputationCheck\")\n} ELSE {\n    // Body reputation is not good.\n    MWG.Block(\"BodyReputationCheck\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting categorizationSetting = MWG.UrlCategorizationSetting()\n\nIF MWG.BodyReputationIsGood(categorizationSetting) THEN {\n    // Body reputation is good.\n    MWG.Allow(\"BodyReputationCheck\")\n} ELSE {\n    // Body reputation is not good.\n    MWG.Block(\"BodyReputationCheck\")\n}"}, {"name": "MWG.BodySize ()", "return_type": "NUMBER", "return_desc": "Returns the numeric value representing the size of the body.", "parameter_desc": "None", "description": "Returns the size of the body.", "example_code": "NUMBER bodySize = MWG.BodySize()\n// The size of the body is: bodySize\n\nIF bodySize > 1000000 THEN {\n    MWG.Block(\"The body size exceeds the allowed limit.\")\n} ELSE {\n    MWG.Allow(\"Body size is within the allowed limit.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER bodySize = MWG.BodySize()\n// The size of the body is: bodySize\n\nIF bodySize > 1000000 THEN {\n    MWG.Block(\"The body size exceeds the allowed limit.\")\n} ELSE {\n    MWG.Allow(\"Body size is within the allowed limit.\")\n}"}, {"name": "MWG.BodyTextLanguage ()", "return_type": "STRING", "return_desc": "Returns the ISO 639-1 code representing the detected language of the extracted text.", "parameter_desc": "None", "description": "Returns the detected language (ISO 639-1 code) for the extracted text.", "example_code": "STRING detectedLanguage = MWG.BodyTextLanguage()\n\nIF detectedLanguage == \"en\" THEN {\n    // The detected language is English.\n    MWG.Allow(\"Language is English\")\n} ELSE {\n    // The detected language is not English. It is: \" + detectedLanguage\n    MWG.Block(\"Non-English content is not allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING detectedLanguage = MWG.BodyTextLanguage()\n\nIF detectedLanguage == \"en\" THEN {\n    // The detected language is English.\n    MWG.Allow(\"Language is English\")\n} ELSE {\n    // The detected language is not English. It is: \" + detectedLanguage\n    MWG.Block(\"Non-English content is not allowed.\")\n}"}, {"name": "MWG.BodyUncompressedSize ()", "return_type": "NUMBER", "return_desc": "Returns the size of an archive or document in its uncompressed form.", "parameter_desc": "None", "description": "Returns the uncompressed size of an archive or document.", "example_code": "NUMBER uncompressedSize = MWG.BodyUncompressedSize()\nNUMBER sizeThreshold = 10485760  // 10 MB in bytes\n\nIF uncompressedSize > sizeThreshold THEN {\n    MWG.Block(\"The uncompressed size of the document exceeds the allowed limit of 10 MB.\")\n} ELSE {\n    MWG.Allow(\"Uncompressed size is within the allowed limit.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER uncompressedSize = MWG.BodyUncompressedSize()\nNUMBER sizeThreshold = 10485760  // 10 MB in bytes\n\nIF uncompressedSize > sizeThreshold THEN {\n    MWG.Block(\"The uncompressed size of the document exceeds the allowed limit of 10 MB.\")\n} ELSE {\n    MWG.Allow(\"Uncompressed size is within the allowed limit.\")\n}"}, {"name": "MWG.BodyWordCount (STRING)", "return_type": "NUMBER", "return_desc": "Returns the count of specified words in the current text body.", "parameter_desc": "STRING: the text to count words from.", "description": "Returns the number of given words in text, extracted from the current body.", "example_code": "STRING bodyContent = MWG.Body()\nNUMBER wordCount = MWG.BodyWordCount(bodyContent)\n\nIF wordCount > 1000 THEN {\n    // Request blocked: Body word count exceeds limit.\n    MWG.Block()\n} ELSE {\n    // Body word count within acceptable range.\n    MWG.Allow()\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING bodyContent = MWG.Body()\nNUMBER wordCount = MWG.BodyWordCount(bodyContent)\n\nIF wordCount > 1000 THEN {\n    // Request blocked: Body word count exceeds limit.\n    MWG.Block()\n} ELSE {\n    // Body word count within acceptable range.\n    MWG.Allow()\n}"}, {"name": "MWG.BytesRecvFromClient ()", "return_type": "NUMBER", "return_desc": "Returns the number of bytes received from the client.", "parameter_desc": "None", "description": "Returns the number of bytes received from client.", "example_code": "NUMBER bytesReceived = MWG.BytesRecvFromClient()\n// \"Bytes received from client: \" + bytesReceived", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER bytesReceived = MWG.BytesRecvFromClient()\n// \"Bytes received from client: \" + bytesReceived"}, {"name": "MWG.BytesRecvFromServer ()", "return_type": "NUMBER", "return_desc": "Returns the number of bytes received from server.", "parameter_desc": "None", "description": "Returns the number of bytes received from the server.", "example_code": "NUMBER bytesReceived = MWG.BytesRecvFromServer()\n// \"Bytes received from server: \" + bytesReceived", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER bytesReceived = MWG.BytesRecvFromServer()\n// \"Bytes received from server: \" + bytesReceived"}, {"name": "MWG.BytesSentToClient ()", "return_type": "NUMBER", "return_desc": "Returns the number of bytes sent to client.", "parameter_desc": "None", "description": "Logging: Returns the number of bytes sent to client.", "example_code": "NUMBER bytesSent = MWG.BytesSentToClient()\n// Bytes sent to client: + bytesSent", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER bytesSent = MWG.BytesSentToClient()\n// Bytes sent to client: + bytesSent"}, {"name": "MWG.BytesSentToServer ()", "return_type": "NUMBER", "return_desc": "Logging: Returns the number of bytes sent to server.", "parameter_desc": "None", "description": "Logging: Returns the number of bytes sent to server.", "example_code": "NUMBER bytesSent = MWG.BytesSentToServer()\n// \"Bytes sent to server: \" + bytesSent", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER bytesSent = MWG.BytesSentToServer()\n// \"Bytes sent to server: \" + bytesSent"}, {"name": "MWG.CacheListMatchInfo (BOOLEAN, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns the`BOOLEAN`value it was given.", "parameter_desc": "BOOLEAN: whether the list matched or not; STRING: the name of the list.", "description": "Caches the list match info in the context and returns the match result.", "example_code": "STRING ruleName = \"exampleRule\"\n\n// Store the list match info for the specified rule\nMWG.StoreListMatchInfo(ruleName)\n\n// Additional logic can be added here\n// List match info stored for rule: \" + ruleName", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING ruleName = \"exampleRule\"\n\n// Store the list match info for the specified rule\nMWG.StoreListMatchInfo(ruleName)\n\n// Additional logic can be added here\n// List match info stored for rule: \" + ruleName"}, {"name": "MWG.CAListByName (STRING)", "return_type": "MWG.CertificateAuthorityList", "return_desc": "Returns a list of certificate authorities.", "parameter_desc": "STRING: the name of the CA list.", "description": "Retrieves a CertificateAuthority list by list name.", "example_code": "STRING caListName = \"ExampleCAList\"\nMWG.CertificateAuthorityList caList = MWG.CAListByName(caListName)\n\n// Retrieved CA List: \" + caList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING caListName = \"ExampleCAList\"\nMWG.CertificateAuthorityList caList = MWG.CAListByName(caListName)\n\n// Retrieved CA List: \" + caList"}, {"name": "MWG.CAListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the certificate authority list exists.", "parameter_desc": "STRING: the name of the CA list.", "description": "Returns TRUE if CertificateAuthority list with the name exists.", "example_code": "STRING caListName = \"MyCAList\"\n\nIF MWG.CAListByNameExists(caListName) THEN {\n    // The CA list + caListName + exists.\n} ELSE {\n    // The CA list + caListName + does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING caListName = \"MyCAList\"\n\nIF MWG.CAListByNameExists(caListName) THEN {\n    // The CA list + caListName + exists.\n} ELSE {\n    // The CA list + caListName + does not exist.\n}"}, {"name": "MWG.ClientCertRequested ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a client certificate was requested during the initial TLS handshake.", "parameter_desc": "None", "description": "Returns TRUE if a client certificate was requested during the initial TLS handshake.", "example_code": "BOOLEAN clientCertRequested = MWG.ClientCertRequested()\n\nIF clientCertRequested THEN {\n    // Client certificate is requested.\n} ELSE {\n    // Client certificate is not requested.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "BOOLEAN clientCertRequested = MWG.ClientCertRequested()\n\nIF clientCertRequested THEN {\n    // Client certificate is requested.\n} ELSE {\n    // Client certificate is not requested.\n}"}, {"name": "MWG.ClientEGressIP ()", "return_type": "Net.IP", "return_desc": "Returns the IP address of the client connection.", "parameter_desc": "None", "description": "Returns the IP address of the client connection.", "example_code": "Net.IP clientIP = MWG.ClientEGressIP()\n// Client Egress IP: + clientIP", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP clientIP = MWG.ClientEGressIP()\n// Client Egress IP: + clientIP"}, {"name": "MWG.ClientEGressPort ()", "return_type": "NUMBER", "return_desc": "Returns the port of the client connection.", "parameter_desc": "None", "description": "Returns the port of the client connection.", "example_code": "NUMBER clientPort = MWG.ClientEGressPort()\n\nIF clientPort == 80 THEN {\n    // Client is using HTTP port 80\n} ELSE IF clientPort == 443 THEN {\n    // Client is using HTTPS port 443\n} ELSE {\n    // Client is using a different port: \" + clientPort\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER clientPort = MWG.ClientEGressPort()\n\nIF clientPort == 80 THEN {\n    // Client is using HTTP port 80\n} ELSE IF clientPort == 443 THEN {\n    // Client is using HTTPS port 443\n} ELSE {\n    // Client is using a different port: \" + clientPort\n}"}, {"name": "MWG.ClientIP ()", "return_type": "Net.IP", "return_desc": "Returns the IP address of the client.", "parameter_desc": "None", "description": "Returns the IP address of the client.", "example_code": "Net.IP clientIP = MWG.ClientIP()\n// \"Client IP Address: \" + clientIP", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP clientIP = MWG.ClientIP()\n// \"Client IP Address: \" + clientIP"}, {"name": "MWG.ClientLocation ()", "return_type": "STRING", "return_desc": "Returns the client location name.", "parameter_desc": "None", "description": "Returns the client location name.", "example_code": "STRING clientLocation = MWG.ClientLocation()\n// Client Location: \" + clientLocation\n\nIF clientLocation == \"Office\" THEN {\n    MWG.Allow(\"Access from Office\")\n} ELSE {\n    MWG.Block(\"Access restricted to Office only\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING clientLocation = MWG.ClientLocation()\n// Client Location: \" + clientLocation\n\nIF clientLocation == \"Office\" THEN {\n    MWG.Allow(\"Access from Office\")\n} ELSE {\n    MWG.Block(\"Access restricted to Office only\")\n}"}, {"name": "MWG.ClientLocationDetected ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the client location type is set.", "parameter_desc": "None", "description": "Returns TRUE if the client location type is set.", "example_code": "STRING clientLocation = MWG.ClientLocation()\n// Client location detected: + clientLocation\n\nIF clientLocation == \"RestrictedArea\" THEN {\n    MWG.Block(\"Access from this location is not allowed.\")\n} ELSE {\n    MWG.Allow(\"Client location is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING clientLocation = MWG.ClientLocation()\n// Client location detected: + clientLocation\n\nIF clientLocation == \"RestrictedArea\" THEN {\n    MWG.Block(\"Access from this location is not allowed.\")\n} ELSE {\n    MWG.Allow(\"Client location is allowed.\")\n}"}, {"name": "MWG.ClientLocationID ()", "return_type": "STRING", "return_desc": "Returns the client location ID.", "parameter_desc": "None", "description": "Returns the client location ID.", "example_code": "STRING clientLocation = MWG.ClientLocation()\n// Client Location: \" + clientLocation", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING clientLocation = MWG.ClientLocation()\n// Client Location: \" + clientLocation"}, {"name": "MWG.ClientProcessExePath ()", "return_type": "STRING", "return_desc": "Returns the process exe path of the HTTP(S) client (MCP only).", "parameter_desc": "None", "description": "Returns the process exe path of the HTTP(S) client (MCP only).", "example_code": "STRING clientExePath = MWG.ClientProcessExePath()\n// Client Process Executable Path: \" + clientExePath", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING clientExePath = MWG.ClientProcessExePath()\n// Client Process Executable Path: \" + clientExePath"}, {"name": "MWG.ClientProcessName ()", "return_type": "STRING", "return_desc": "Returns the process name of the HTTP(S) client (MCP only).", "parameter_desc": "None", "description": "Returns the process name of the HTTP(S) client (MCP only).", "example_code": "STRING clientProcessName = MWG.ClientProcessName()\n\nIF clientProcessName == \"unwanted_process.exe\" THEN {\n    MWG.Block(\"Access blocked due to unwanted process\")\n} ELSE {\n    MWG.Allow(\"Process allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING clientProcessName = MWG.ClientProcessName()\n\nIF clientProcessName == \"unwanted_process.exe\" THEN {\n    MWG.Block(\"Access blocked due to unwanted process\")\n} ELSE {\n    MWG.Allow(\"Process allowed\")\n}"}, {"name": "MWG.ClientSystemInfo ()", "return_type": "JSON", "return_desc": "Returns the system info as provided by MCP.", "parameter_desc": "None", "description": "Returns the system info as provided by MCP.", "example_code": "// Retrieve client system information\nMAP<STRING><STRING> clientInfo = MWG.ClientSystemInfo()\n\n// Extract specific information from the clientInfo map\nSTRING os = clientInfo[\"os\"]\nSTRING browser = clientInfo[\"browser\"]\nSTRING ip = clientInfo[\"ip\"]\n\n// Log the client system information\n// Client OS: \" + os\n// Client Browser: \" + browser\n// Client IP: \" + ip", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve client system information\nMAP<STRING><STRING> clientInfo = MWG.ClientSystemInfo()\n\n// Extract specific information from the clientInfo map\nSTRING os = clientInfo[\"os\"]\nSTRING browser = clientInfo[\"browser\"]\nSTRING ip = clientInfo[\"ip\"]\n\n// Log the client system information\n// Client OS: \" + os\n// Client Browser: \" + browser\n// Client IP: \" + ip"}, {"name": "MWG.CloudServiceID ()", "return_type": "MWG.ApplicationType", "return_desc": "Returns detected application type without activity.", "parameter_desc": "None", "description": "Returns detected application type without activity.", "example_code": "STRING cloudServiceName = MWG.CloudServiceName()\n// Cloud Service Name: + cloudServiceName", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING cloudServiceName = MWG.CloudServiceName()\n// Cloud Service Name: + cloudServiceName"}, {"name": "MWG.CloudServiceName ()", "return_type": "STRING", "return_desc": "Returns the name of an application without activity.", "parameter_desc": "None", "description": "Returns the name of an application without activity.", "example_code": "STRING cloudServiceName = MWG.CloudServiceName()\n\nIF cloudServiceName == \"ExampleService\" THEN {\n    // The cloud service name is ExampleService\n} ELSE {\n    // The cloud service name is \" + cloudServiceName\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING cloudServiceName = MWG.CloudServiceName()\n\nIF cloudServiceName == \"ExampleService\" THEN {\n    // The cloud service name is ExampleService\n} ELSE {\n    // The cloud service name is \" + cloudServiceName\n}"}, {"name": "MWG.CommandCategories ()", "return_type": "VECTOR<STRING>", "return_desc": "Returns the categories for a particular protocol command.", "parameter_desc": "None", "description": "Returns the categories for a particular protocol command.", "example_code": "VECTOR<STRING> categories = MWG.CommandCategories()\n\n// Command Categories: + categories\n\nIF \"Malicious\" IN categories THEN {\n    MWG.Block(\"Blocked due to malicious command category\")\n} ELSE {\n    MWG.Allow(\"Allowed as no malicious command category found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> categories = MWG.CommandCategories()\n\n// Command Categories: + categories\n\nIF \"Malicious\" IN categories THEN {\n    MWG.Block(\"Blocked due to malicious command category\")\n} ELSE {\n    MWG.Allow(\"Allowed as no malicious command category found\")\n}"}, {"name": "MWG.CommandName ()", "return_type": "STRING", "return_desc": "Returns the command name. E.g. GET, POST.", "parameter_desc": "None", "description": "Returns command name, e.g. GET, POST.", "example_code": "STRING command = MWG.CommandName()\n\nIF command == \"POST\" THEN {\n    // This is a POST request.\n} ELSE IF command == \"GET\" THEN {\n    // This is a GET request.\n} ELSE {\n    // This is a different type of request: \" + command\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING command = MWG.CommandName()\n\nIF command == \"POST\" THEN {\n    // This is a POST request.\n} ELSE IF command == \"GET\" THEN {\n    // This is a GET request.\n} ELSE {\n    // This is a different type of request: \" + command\n}"}, {"name": "MWG.ConnectionID ()", "return_type": "STRING", "return_desc": "Returns a unique ID for the connection.", "parameter_desc": "None", "description": "Returns a unique ID for the connection.", "example_code": "STRING connectionID = MWG.ConnectionID()\n// Connection ID: + connectionID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING connectionID = MWG.ConnectionID()\n// Connection ID: + connectionID"}, {"name": "MWG.ConnectionProtocol ()", "return_type": "STRING", "return_desc": "Returns the connection protocol as a string. E.g. HTTP, HTTPS, FTP.", "parameter_desc": "None", "description": "Returns connection protocol as a string, e.g. HTTP, HTTPS, FTP.", "example_code": "STRING protocol = MWG.ConnectionProtocol()\n// The connection protocol is: \" + protocol\n\nIF protocol == \"HTTPS\" THEN {\n    // Secure connection detected.\n} ELSE {\n    // Non-secure connection detected.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING protocol = MWG.ConnectionProtocol()\n// The connection protocol is: \" + protocol\n\nIF protocol == \"HTTPS\" THEN {\n    // Secure connection detected.\n} ELSE {\n    // Non-secure connection detected.\n}"}, {"name": "MWG.ConnectionProtocolIsIM ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the connection is instant messaging.", "parameter_desc": "None", "description": "Returns TRUE if the connection is instant messaging.", "example_code": "IF MWG.ConnectionProtocolIsIM() THEN {\n    // The connection is using an instant messaging protocol.\n    MWG.Block(\"Instant messaging is not allowed.\")\n} ELSE {\n    // The connection is not using an instant messaging protocol.\n    MWG.Allow(\"Non-IM traffic allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.ConnectionProtocolIsIM() THEN {\n    // The connection is using an instant messaging protocol.\n    MWG.Block(\"Instant messaging is not allowed.\")\n} ELSE {\n    // The connection is not using an instant messaging protocol.\n    MWG.Allow(\"Non-IM traffic allowed.\")\n}"}, {"name": "MWG.ConnectionTracingID ()", "return_type": "STRING", "return_desc": "Returns the connection tracing ID (empty, if tracing is turned off).", "parameter_desc": "None", "description": "Returns the connection tracing ID (empty, if tracing is turned off).", "example_code": "STRING connectionID = MWG.ConnectionID()\n// Connection ID: connectionID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING connectionID = MWG.ConnectionID()\n// Connection ID: connectionID"}, {"name": "MWG.ConnectionVariablesGet (STRING)", "return_type": "STRING", "return_desc": "Returns a string representing the value of a connection-scoped variable.", "parameter_desc": "STRING: the name of the variable to retrieve within the connection scope.", "description": "Retrieves variable (connection scope).", "example_code": "// Define the name of the connection variable to retrieve\nSTRING variableName = \"exampleVariable\"\n\n// Retrieve the value of the connection variable\nSTRING variableValue = MWG.ConnectionVariablesGet(variableName)\n\n// The value of \" + variableName + \" is: \" + variableValue\n\n// Use the connection variable in a conditional statement\nIF variableValue == \"someValue\" THEN {\n    MWG.Block(\"Blocking because the connection variable matched 'someValue'\")\n} ELSE {\n    MWG.Allow(\"Allowing because the connection variable did not match 'someValue'\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the name of the connection variable to retrieve\nSTRING variableName = \"exampleVariable\"\n\n// Retrieve the value of the connection variable\nSTRING variableValue = MWG.ConnectionVariablesGet(variableName)\n\n// The value of \" + variableName + \" is: \" + variableValue\n\n// Use the connection variable in a conditional statement\nIF variableValue == \"someValue\" THEN {\n    MWG.Block(\"Blocking because the connection variable matched 'someValue'\")\n} ELSE {\n    MWG.Allow(\"Allowing because the connection variable did not match 'someValue'\")\n}"}, {"name": "MWG.ConnectionVariablesHave (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the specified connection scope contains the specified variable.", "parameter_desc": "STRING: the name of the variable to check for.", "description": "Returns TRUE if it has variables (connection scope).", "example_code": "STRING key = \"exampleKey\"\n\nIF MWG.ConnectionVariablesHave(key) THEN {\n    // Connection variable with key 'exampleKey' exists.\n} ELSE {\n    // Connection variable with key 'exampleKey' does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING key = \"exampleKey\"\n\nIF MWG.ConnectionVariablesHave(key) THEN {\n    // Connection variable with key 'exampleKey' exists.\n} ELSE {\n    // Connection variable with key 'exampleKey' does not exist.\n}"}, {"name": "MWG.CreateCertificateAuthorityList ()", "return_type": "MWG.CertificateAuthorityList", "return_desc": "Returns an empty`MWG.CertificateAuthorityList`object.", "parameter_desc": "None", "description": "Creates an empty list of certificate authorities.", "example_code": "// Create an empty Certificate Authority List\nMWG.CertificateAuthorityList caList = MWG.CreateCertificateAuthorityList()\n\n// Created an empty Certificate Authority List\n\n// Further processing can be done here, such as adding certificates to the list\n// For example:\n// caList.AddCertificate(\"path/to/certificate\")\n\n// Example of using the caList in some context\n// MWG.SomeFunctionThatUsesCAList(caList)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an empty Certificate Authority List\nMWG.CertificateAuthorityList caList = MWG.CreateCertificateAuthorityList()\n\n// Created an empty Certificate Authority List\n\n// Further processing can be done here, such as adding certificates to the list\n// For example:\n// caList.AddCertificate(\"path/to/certificate\")\n\n// Example of using the caList in some context\n// MWG.SomeFunctionThatUsesCAList(caList)"}, {"name": "MWG.CreateParams ()", "return_type": "MWG.InternalParameterList", "return_desc": "Returns an empty internal parameter list.", "parameter_desc": "None", "description": "Creates an empty internal parameter list.", "example_code": "// Create a list of parameters\nMWG.InternalParameterList params = MWG.CreateParams()\n\n// Add parameters to the list\nparams.Add(\"param1\", \"value1\")\nparams.Add(\"param2\", \"value2\")\n\n// Use the parameters in a function call\nMWG.ExecuteEvent(\"SomeEvent\", params)\n\n// Parameters created and event executed with params: \n// + params.ToString()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a list of parameters\nMWG.InternalParameterList params = MWG.CreateParams()\n\n// Add parameters to the list\nparams.Add(\"param1\", \"value1\")\nparams.Add(\"param2\", \"value2\")\n\n// Use the parameters in a function call\nMWG.ExecuteEvent(\"SomeEvent\", params)\n\n// Parameters created and event executed with params: \n// + params.ToString()"}, {"name": "MWG.CreateParams (JSON)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "JSON: initial list value.", "description": "Creates an internal parameter list with the provided JSON object.", "example_code": "// Create a JSON object with parameters\nJSON params = {\n    \"param1\": \"value1\",\n    \"param2\": \"value2\",\n    \"param3\": \"value3\"\n}\n\n// Use the MWG.CreateParams function with the JSON object\nMWG.CreateParams(params)\n\n// Parameters created: \" + params", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object with parameters\nJSON params = {\n    \"param1\": \"value1\",\n    \"param2\": \"value2\",\n    \"param3\": \"value3\"\n}\n\n// Use the MWG.CreateParams function with the JSON object\nMWG.CreateParams(params)\n\n// Parameters created: \" + params"}, {"name": "MWG.CreateParams (MAP<STRING, MWG.InternalVariant>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "MAP<STRING, MWG.InternalVariant>: initial list value.", "description": "Creates an internal parameter list with the provided map.", "example_code": "// Create a map to hold the parameters\nMAP<STRING, MWG.InternalVariant> paramsMap\n\n// Add some parameters to the map\nparamsMap[\"param1\"] = MWG.InternalVariant(\"value1\")\nparamsMap[\"param2\"] = MWG.InternalVariant(12345)\nparamsMap[\"param3\"] = MWG.InternalVariant(TRUE)\n\n// Create the internal parameter list using the map\nMWG.InternalParameterList paramsList = MWG.CreateParams(paramsMap)\n\n// Created internal parameter list with the following parameters:\n// param1: \" + paramsList[\"param1\"].ToString()\n// param2: \" + paramsList[\"param2\"].ToString()\n// param3: \" + paramsList[\"param3\"].ToString()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a map to hold the parameters\nMAP<STRING, MWG.InternalVariant> paramsMap\n\n// Add some parameters to the map\nparamsMap[\"param1\"] = MWG.InternalVariant(\"value1\")\nparamsMap[\"param2\"] = MWG.InternalVariant(12345)\nparamsMap[\"param3\"] = MWG.InternalVariant(TRUE)\n\n// Create the internal parameter list using the map\nMWG.InternalParameterList paramsList = MWG.CreateParams(paramsMap)\n\n// Created internal parameter list with the following parameters:\n// param1: \" + paramsList[\"param1\"].ToString()\n// param2: \" + paramsList[\"param2\"].ToString()\n// param3: \" + paramsList[\"param3\"].ToString()"}, {"name": "MWG.CreateParams (MAP<STRING, STRING>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "MAP<STRING,STRING>: initial list value.", "description": "Creates an internal parameter list with the provided map.", "example_code": "// Create a map with initial values\nMAP<STRING, STRING> initialParams = {\n    \"param1\": \"value1\",\n    \"param2\": \"value2\",\n    \"param3\": \"value3\"\n}\n\n// Create an internal parameter list using the map\nMWG.InternalParameterList paramsList = MWG.CreateParams(initialParams)\n\n// Created parameter list: paramsList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a map with initial values\nMAP<STRING, STRING> initialParams = {\n    \"param1\": \"value1\",\n    \"param2\": \"value2\",\n    \"param3\": \"value3\"\n}\n\n// Create an internal parameter list using the map\nMWG.InternalParameterList paramsList = MWG.CreateParams(initialParams)\n\n// Created parameter list: paramsList"}, {"name": "MWG.CreateParams (MediaType)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "MediaType: initial list value.", "description": "Creates an internal parameter list with the provided media type.", "example_code": "// Define a MediaType object\nMediaType mediaType = \"application/json\"\n\n// Create an internal parameter list using the MediaType\nMWG.InternalParameterList params = MWG.CreateParams(mediaType)\n\n// Created internal parameter list with media type: \" + mediaType", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a MediaType object\nMediaType mediaType = \"application/json\"\n\n// Create an internal parameter list using the MediaType\nMWG.InternalParameterList params = MWG.CreateParams(mediaType)\n\n// Created internal parameter list with media type: \" + mediaType"}, {"name": "MWG.CreateParams (MWG.InternalVariant)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "MWG.InternalVariant: initial list value.", "description": "Creates an internal parameter list with the provided internal variant.", "example_code": "// Create an internal variant with some initial value\nMWG.InternalVariant initialVariant = MWG.InternalVariant()\ninitialVariant.someProperty = \"initialValue\"\n\n// Create an internal parameter list using the initial variant\nMWG.InternalParameterList paramList = MWG.CreateParams(initialVariant)\n\n// Use the parameter list in some way\n// Created parameter list with initial variant value: \" + paramList\n\n// Additional logic can be added here", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an internal variant with some initial value\nMWG.InternalVariant initialVariant = MWG.InternalVariant()\ninitialVariant.someProperty = \"initialValue\"\n\n// Create an internal parameter list using the initial variant\nMWG.InternalParameterList paramList = MWG.CreateParams(initialVariant)\n\n// Use the parameter list in some way\n// Created parameter list with initial variant value: \" + paramList\n\n// Additional logic can be added here"}, {"name": "MWG.CreateParams (Net.IP)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "Net.IP: initial list value.", "description": "Creates an internal parameter list with the provided Net.IP.", "example_code": "// Define an initial IP value\nNet.IP initialIP = \"192.168.1.1\"\n\n// Create an internal parameter list with the initial IP value\nMWG.InternalParameterList paramList = MWG.CreateParams(initialIP)\n\n// Created parameter list: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define an initial IP value\nNet.IP initialIP = \"192.168.1.1\"\n\n// Create an internal parameter list with the initial IP value\nMWG.InternalParameterList paramList = MWG.CreateParams(initialIP)\n\n// Created parameter list: \" + paramList"}, {"name": "MWG.CreateParams (NUMBER)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "NUMBER: initial list value.", "description": "Creates an internal parameter list with the provided number.", "example_code": "// Assume we have an MWG.InternalVariant that contains a NUMBER\nMWG.InternalVariant numberVariant = MWG.InternalVariant(42)\n\n// Create an internal parameter list using the numberVariant\nMWG.InternalParameterList paramList = MWG.CreateParams(numberVariant)\n\n// Created parameter list with number: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant that contains a NUMBER\nMWG.InternalVariant numberVariant = MWG.InternalVariant(42)\n\n// Create an internal parameter list using the numberVariant\nMWG.InternalParameterList paramList = MWG.CreateParams(numberVariant)\n\n// Created parameter list with number: \" + paramList"}, {"name": "MWG.CreateParams (STRING)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "STRING: initial list value.", "description": "Creates an internal parameter list with the provided string.", "example_code": "MAP<STRING, STRING> params = {\n    \"param1\" : \"value1\",\n    \"param2\" : \"value2\",\n    \"param3\" : \"value3\"\n}\n\nMWG.InternalParameterList paramList = MWG.CreateParams(params)\n\n// Created parameter list: + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MAP<STRING, STRING> params = {\n    \"param1\" : \"value1\",\n    \"param2\" : \"value2\",\n    \"param3\" : \"value3\"\n}\n\nMWG.InternalParameterList paramList = MWG.CreateParams(params)\n\n// Created parameter list: + paramList"}, {"name": "MWG.CreateParams (VECTOR<MediaType>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "VECTOR<MediaType>: initial list value.", "description": "Creates an internal parameter list with the provided vector.", "example_code": "// Define a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = \"application/json\", \"text/html\", \"image/png\"\n\n// Create an internal parameter list using the mediaTypes VECTOR\nMWG.InternalParameterList params = MWG.CreateParams(mediaTypes)\n\n// Internal Parameter List created with media types: \n// params", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = \"application/json\", \"text/html\", \"image/png\"\n\n// Create an internal parameter list using the mediaTypes VECTOR\nMWG.InternalParameterList params = MWG.CreateParams(mediaTypes)\n\n// Internal Parameter List created with media types: \n// params"}, {"name": "MWG.CreateParams (VECTOR<MWG.UrlCategory>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "VECTOR<MWG.UrlCategory>: initial list value.", "description": "Creates an internal parameter list with the provided vector.", "example_code": "// Define a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"SocialMedia\", \"StreamingMedia\", \"Shopping\"]\n\n// Create an internal parameter list using the MWG.CreateParams function\nMWG.InternalParameterList params = MWG.CreateParams(urlCategories)\n\n// Created internal parameter list with URL categories: \" + params", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"SocialMedia\", \"StreamingMedia\", \"Shopping\"]\n\n// Create an internal parameter list using the MWG.CreateParams function\nMWG.InternalParameterList params = MWG.CreateParams(urlCategories)\n\n// Created internal parameter list with URL categories: \" + params"}, {"name": "MWG.CreateParams (VECTOR<Net.IP>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "VECTOR<Net.IP>: initial list value.", "description": "Creates an internal parameter list with the provided vector.", "example_code": "// Define a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"\n\n// Create an internal parameter list using the VECTOR of Net.IP\nMWG.InternalParameterList params = MWG.CreateParams(ipList)\n\n// Internal Parameter List created with IPs: \n// Commented out DEBUG line: DEBUG(\"Internal Parameter List created with IPs: \" + params)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"\n\n// Create an internal parameter list using the VECTOR of Net.IP\nMWG.InternalParameterList params = MWG.CreateParams(ipList)\n\n// Internal Parameter List created with IPs: \n// Commented out DEBUG line: DEBUG(\"Internal Parameter List created with IPs: \" + params)"}, {"name": "MWG.CreateParams (VECTOR<NUMBER>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "VECTOR<NUMBER>: initial list value.", "description": "Creates an internal parameter list with the provided vector.", "example_code": "VECTOR<NUMBER> params = 1, 2, 3, 4, 5\nMWG.CreateParams(params)\n// Parameters created: \" + params", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> params = 1, 2, 3, 4, 5\nMWG.CreateParams(params)\n// Parameters created: \" + params"}, {"name": "MWG.CreateParams (VECTOR<STRING>)", "return_type": "MWG.InternalParameterList", "return_desc": "Returns the created internal parameter list.", "parameter_desc": "VECTOR<STRING>: initial list value.", "description": "Creates an internal parameter list with the provided vector.", "example_code": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> initialParams = \"param1\", \"param2\", \"param3\"\n\n// Create an internal parameter list using the VECTOR\nMWG.InternalParameterList paramList = MWG.CreateParams(initialParams)\n\n// Created parameter list: \" + paramList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> initialParams = \"param1\", \"param2\", \"param3\"\n\n// Create an internal parameter list using the VECTOR\nMWG.InternalParameterList paramList = MWG.CreateParams(initialParams)\n\n// Created parameter list: \" + paramList"}, {"name": "MWG.CRLFSTRING ()", "return_type": "STRING", "return_desc": "Returns a string containing a carriage-return and line-feed character sequence.", "parameter_desc": "None", "description": "Returns carriage-return line-feed string.", "example_code": "// Get the CRLF string\nSTRING crlf = MWG.CRLFString()\n\n// Construct a multi-line message using the CRLF string\nSTRING message = \"Hello,\" + crlf + \"World!\"\n\n// Print the message to the console\n// DEBUG(message)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the CRLF string\nSTRING crlf = MWG.CRLFString()\n\n// Construct a multi-line message using the CRLF string\nSTRING message = \"Hello,\" + crlf + \"World!\"\n\n// Print the message to the console\n// DEBUG(message)"}, {"name": "MWG.CurrentRequestOrResponse ()", "return_type": "MWG.RequestResponse", "return_desc": "Returns either a request or response header and body.", "parameter_desc": "None", "description": "Returns either a request or response header and body.", "example_code": "MWG.RequestResponse request = MWG.Request()\n// \"Request URL: \" + request.Url", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.RequestResponse request = MWG.Request()\n// \"Request URL: \" + request.Url"}, {"name": "MWG.CycleName ()", "return_type": "STRING", "return_desc": "Returns the name of the current cycle (Request, Response, EmbeddedObject).", "parameter_desc": "None", "description": "Returns the name of the current cycle (Request, Response, EmbeddedObject).", "example_code": "STRING cycleName = MWG.CycleName()\n// Current cycle name: + cycleName\n\nIF cycleName == \"Web.Request\" THEN {\n    // This is a Web Request cycle.\n} ELSE IF cycleName == \"Web.Response\" THEN {\n    // This is a Web Response cycle.\n} ELSE IF cycleName == \"EmbeddedObject\" THEN {\n    // This is an Embedded Object cycle.\n} ELSE {\n    // Unknown cycle.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING cycleName = MWG.CycleName()\n// Current cycle name: + cycleName\n\nIF cycleName == \"Web.Request\" THEN {\n    // This is a Web Request cycle.\n} ELSE IF cycleName == \"Web.Response\" THEN {\n    // This is a Web Response cycle.\n} ELSE IF cycleName == \"EmbeddedObject\" THEN {\n    // This is an Embedded Object cycle.\n} ELSE {\n    // Unknown cycle.\n}"}, {"name": "MWG.CycleTopName ()", "return_type": "STRING", "return_desc": "Returns the name of the top cycle (Request, Response).", "parameter_desc": "None", "description": "Returns the name of the top cycle (Request, Response).", "example_code": "// Retrieve the name of the topmost cycle\nSTRING topCycleName = MWG.CycleTopName()\n\n// The top cycle name is: \" + topCycleName\n\n// Perform an action based on the top cycle name\nIF topCycleName == \"BlockCycle\" THEN {\n    MWG.Block(\"Access blocked due to BlockCycle\")\n} ELSE {\n    MWG.Allow(\"Access allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the name of the topmost cycle\nSTRING topCycleName = MWG.CycleTopName()\n\n// The top cycle name is: \" + topCycleName\n\n// Perform an action based on the top cycle name\nIF topCycleName == \"BlockCycle\" THEN {\n    MWG.Block(\"Access blocked due to BlockCycle\")\n} ELSE {\n    MWG.Allow(\"Access allowed\")\n}"}, {"name": "MWG.DataTricklingEnabled ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if data trickling is enabled.", "parameter_desc": "None", "description": "Returns TRUE if data trickling is enabled.", "example_code": "MWG.DataTricklingSetting dataTricklingSetting = MWG.DataTricklingSetting()\ndataTricklingSetting.enable = TRUE\ndataTricklingSetting.chunkSize = 1024  // Set the chunk size to 1024 bytes\ndataTricklingSetting.interval = 5      // Set the interval to 5 seconds\n\n// Apply the data trickling setting\nMWG.ApplyDataTricklingSetting(dataTricklingSetting)\n\n// Data trickling has been enabled with chunk size 1024 bytes and interval 5 seconds.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DataTricklingSetting dataTricklingSetting = MWG.DataTricklingSetting()\ndataTricklingSetting.enable = TRUE\ndataTricklingSetting.chunkSize = 1024  // Set the chunk size to 1024 bytes\ndataTricklingSetting.interval = 5      // Set the interval to 5 seconds\n\n// Apply the data trickling setting\nMWG.ApplyDataTricklingSetting(dataTricklingSetting)\n\n// Data trickling has been enabled with chunk size 1024 bytes and interval 5 seconds."}, {"name": "MWG.DayOfMonthIsInRange (STRING)", "return_type": "BOOLEAN", "return_desc": "\"Returns`TRUE`if the day falls within the input days range. Month day or a range of month days can be mentioned using hyphen separated by comma without white space. Month day ranges from 1-31 (e.g. 3-7,25).\".", "parameter_desc": "STRING: desired range.", "description": "\"Returns TRUE if the day falls within the input days range. Month day or a range of month days can be mentioned using hyphen separated by comma without white space. Month day ranges from 1-31 (e.g. 3-7,25).\"", "example_code": "STRING dayRange = \"3-7,25\"\n\nIF MWG.DayOfMonthIsInRange(dayRange) THEN {\n    // The current day is within the specified range.\n    MWG.Allow(\"DayInRange\")\n} ELSE {\n    // The current day is not within the specified range.\n    MWG.Block(\"DayOutOfRange\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING dayRange = \"3-7,25\"\n\nIF MWG.DayOfMonthIsInRange(dayRange) THEN {\n    // The current day is within the specified range.\n    MWG.Allow(\"DayInRange\")\n} ELSE {\n    // The current day is not within the specified range.\n    MWG.Block(\"DayOutOfRange\")\n}"}, {"name": "MWG.DayOfWeekIsInRange (STRING)", "return_type": "BOOLEAN", "return_desc": "\"Returns`TRUE`if the day falls within the input days range. Weekday ranges from 0-6, 0 as Sunday followed by 6 as Saturday. Range can be mentioned using hyphen (no whitespace) and multiple ranges can be provided using comma (e.g. 0,3-4,6).\".", "parameter_desc": "STRING: desired range.", "description": "\"Returns TRUE if the day falls within the input days range. Weekday ranges from 0-6, 0 as Sunday followed by 6 as Saturday. Range can be mentioned using hyphen (no whitespace) and multiple ranges can be provided using comma (e.g. 0,3-4,6).\"", "example_code": "IF MWG.DayOfWeekIsInRange(\"1-5\") THEN {\n    MWG.Allow(\"Access allowed on weekdays\")\n} ELSE {\n    MWG.Block(\"Access is only allowed on weekdays\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.DayOfWeekIsInRange(\"1-5\") THEN {\n    MWG.Allow(\"Access allowed on weekdays\")\n} ELSE {\n    MWG.Block(\"Access is only allowed on weekdays\")\n}"}, {"name": "MWG.DayOfYearIsInRange (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the day falls within the input days range. Year day or a range of year days can be mentioned using hyphen separated by comma without white space. Year day ranges from 0-365, 0 as January 1 (e.g.5,110-115,230).", "parameter_desc": "STRING: desired range.", "description": "\"Returns TRUE if the day falls within the input days range. Year day or a range of year days can be mentioned using hyphen separated by comma without white space. Year day ranges from 0-365, 0 as January 1 (e.g. 5,110-115,230).\"", "example_code": "IF MWG.DayOfYearIsInRange(\"5,110-115,230\") THEN {\n    MWG.Block(\"Access is blocked on these specific days of the year.\")\n} ELSE {\n    MWG.Allow(\"Access is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.DayOfYearIsInRange(\"5,110-115,230\") THEN {\n    MWG.Block(\"Access is blocked on these specific days of the year.\")\n} ELSE {\n    MWG.Allow(\"Access is allowed.\")\n}"}, {"name": "MWG.DestinationIP ()", "return_type": "Net.IP", "return_desc": "Returns one IP address of the destination.", "parameter_desc": "None", "description": "Returns one IP address of the destination.", "example_code": "Net.IP destinationIP = MWG.DestinationIP()\n// Destination IP: destinationIP\n\n// Example condition to block a specific IP\nIF destinationIP == \"192.168.1.1\" THEN {\n    MWG.Block(\"Access to this IP is blocked.\")\n} ELSE {\n    MWG.Allow(\"Destination IP is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP destinationIP = MWG.DestinationIP()\n// Destination IP: destinationIP\n\n// Example condition to block a specific IP\nIF destinationIP == \"192.168.1.1\" THEN {\n    MWG.Block(\"Access to this IP is blocked.\")\n} ELSE {\n    MWG.Allow(\"Destination IP is allowed.\")\n}"}, {"name": "MWG.DiscardedHost ()", "return_type": "STRING", "return_desc": "Returns the hostname of the discarded resource.", "parameter_desc": "None", "description": "Returns the host of the requested resource that was discarded.", "example_code": "// Get the discarded host\nSTRING discardedHost = MWG.DiscardedHost()\n\n// Discarded Host: \" + discardedHost\n\n// Perform some action based on the discarded host\nIF discardedHost == \"example.com\" THEN {\n    MWG.Block(\"Access to example.com is blocked due to discarded host.\")\n} ELSE {\n    MWG.Allow(\"Host is not discarded.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the discarded host\nSTRING discardedHost = MWG.DiscardedHost()\n\n// Discarded Host: \" + discardedHost\n\n// Perform some action based on the discarded host\nIF discardedHost == \"example.com\" THEN {\n    MWG.Block(\"Access to example.com is blocked due to discarded host.\")\n} ELSE {\n    MWG.Allow(\"Host is not discarded.\")\n}"}, {"name": "MWG.DLPClassificationMatchedClassifications (MWG.DLPClassificationSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a list of classifications that match the given classification setting in the body text.", "parameter_desc": "MWG.DLPClassificationSetting: the classification settings to be matched against the body text.", "description": "Lists classifications that match the classification in body text.", "example_code": "// Define the DLP classification setting\nMWG.DLPClassificationSetting dlpSetting = MWG.GetDLPClassificationSetting(\"example_setting\")\n\n// Define the text to be classified\nSTRING textToClassify = \"This is a sample text that needs to be classified.\"\n\n// Get the matched classifications\nVECTOR<STRING> matchedClassifications = MWG.DLPClassificationMatchedClassifications(dlpSetting, textToClassify)\n\n// Check if there are any matched classifications\nIF matchedClassifications.SIZE() > 0 THEN {\n    // Log the matched classifications\n    // DLP classifications matched: \" + matchedClassifications.SIZE()\n    FOR STRING classification IN matchedClassifications {\n        // Matched classification: \" + classification\n    }\n\n    // Block the request with a message indicating a DLP policy violation\n    MWG.Block(\"DLP policy violation detected\")\n} ELSE {\n    // Allow the request to proceed\n    MWG.Allow(\"No DLP policy violations\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the DLP classification setting\nMWG.DLPClassificationSetting dlpSetting = MWG.GetDLPClassificationSetting(\"example_setting\")\n\n// Define the text to be classified\nSTRING textToClassify = \"This is a sample text that needs to be classified.\"\n\n// Get the matched classifications\nVECTOR<STRING> matchedClassifications = MWG.DLPClassificationMatchedClassifications(dlpSetting, textToClassify)\n\n// Check if there are any matched classifications\nIF matchedClassifications.SIZE() > 0 THEN {\n    // Log the matched classifications\n    // DLP classifications matched: \" + matchedClassifications.SIZE()\n    FOR STRING classification IN matchedClassifications {\n        // Matched classification: \" + classification\n    }\n\n    // Block the request with a message indicating a DLP policy violation\n    MWG.Block(\"DLP policy violation detected\")\n} ELSE {\n    // Allow the request to proceed\n    MWG.Allow(\"No DLP policy violations\")\n}"}, {"name": "MWG.DLPClassificationMatchedClassifications (MWG.DLPClassificationSetting, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing classifications that match the specified classification within the provided text.", "parameter_desc": "MWG.DLPClassificationSetting: The classification settings to be used; STRING: the text to be classified.", "description": "Lists classifications that match the classification in text.", "example_code": "MWG.DLPDictionarySetting dlpSetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text containing sensitive information.\"\n\nIF MWG.DLPDictionaryMatches(dlpSetting, textToCheck) THEN {\n    // Sensitive data detected in the request.\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    // No sensitive data detected.\n    MWG.Allow(\"No sensitive data detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPDictionarySetting dlpSetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text containing sensitive information.\"\n\nIF MWG.DLPDictionaryMatches(dlpSetting, textToCheck) THEN {\n    // Sensitive data detected in the request.\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    // No sensitive data detected.\n    MWG.Allow(\"No sensitive data detected.\")\n}"}, {"name": "MWG.DLPClassificationMatchedClassifications (MWG.InternalSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing classifications that match the classification found in the body text.", "parameter_desc": "MWG.InternalSetting: Configuration settings for the classification matching process.", "description": "Logs: Lists of classifications that match the classification in body text.", "example_code": "MWG.InternalSetting setting = MWG.DLPClassificationMatchedClassifications()\nSTRING classification = \"Confidential\"\nMWG.InternalParameterList params = MWG.InternalParameterList()\n\n// Add parameters to the list if needed\nparams.Add(\"Classification\", classification)\n\n// Execute the event with the internal setting, a string identifier, and the parameter list\nMWG.ExecuteEvent(setting, \"CheckClassification\", params)\n\n// Example condition to block based on classification\nIF classification == \"Confidential\" THEN {\n    MWG.Block(\"Access to confidential data is not allowed.\")\n} ELSE {\n    MWG.Allow(\"Classification check passed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting setting = MWG.DLPClassificationMatchedClassifications()\nSTRING classification = \"Confidential\"\nMWG.InternalParameterList params = MWG.InternalParameterList()\n\n// Add parameters to the list if needed\nparams.Add(\"Classification\", classification)\n\n// Execute the event with the internal setting, a string identifier, and the parameter list\nMWG.ExecuteEvent(setting, \"CheckClassification\", params)\n\n// Example condition to block based on classification\nIF classification == \"Confidential\" THEN {\n    MWG.Block(\"Access to confidential data is not allowed.\")\n} ELSE {\n    MWG.Allow(\"Classification check passed.\")\n}"}, {"name": "MWG.DLPClassificationMatchedTerms (MWG.DLPClassificationSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing a list of terms that match the specified classification in the body text.", "parameter_desc": "MWG.DLPClassificationSetting: Configuration specifying the classification criteria to match terms in the body text.", "description": "Lists terms that match the classification in body text.", "example_code": "// Define the DLP classification setting\nMWG.DLPClassificationSetting dlpSetting = [\"YourDLPClassificationSetting\"]\n\n// Define the text to be analyzed\nSTRING textToAnalyze = \"This is a sample text containing sensitive information like credit card numbers and social security numbers.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPClassificationMatchedTerms(dlpSetting, textToAnalyze)\n\n// Matched Terms: \n// DEBUG(\"Matched Terms: \" + matchedTerms)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the DLP classification setting\nMWG.DLPClassificationSetting dlpSetting = [\"YourDLPClassificationSetting\"]\n\n// Define the text to be analyzed\nSTRING textToAnalyze = \"This is a sample text containing sensitive information like credit card numbers and social security numbers.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPClassificationMatchedTerms(dlpSetting, textToAnalyze)\n\n// Matched Terms: \n// DEBUG(\"Matched Terms: \" + matchedTerms)"}, {"name": "MWG.DLPClassificationMatchedTerms (MWG.DLPClassificationSetting, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing terms from the text that match the DLP classification settings.", "parameter_desc": "MWG.DLPClassificationSetting: configuration settings for data loss prevention classifcation; STRING: the text to be analyzed for matching terms.", "description": "Lists terms that match the classification in text.", "example_code": "// Define the DLP classification setting\nMWG.DLPClassificationSetting dlpSetting = [\"MyDLPClassificationSetting\"]\n\n// Define the text to be analyzed\nSTRING textToAnalyze = \"This is a sample text containing sensitive information like credit card numbers and social security numbers.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPClassificationMatchedTerms(dlpSetting, textToAnalyze)\n\n// Check if there are any matched terms\nIF matchedTerms.SIZE() > 0 THEN {\n    // Matched DLP Terms: \" + matchedTerms.TO_STRING()\n    // Block the connection with a reason\n    MWG.Block(\"Sensitive information detected: \" + matchedTerms.TO_STRING())\n} ELSE {\n    // Allow the connection if no sensitive information is detected\n    MWG.Allow(\"No sensitive information detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the DLP classification setting\nMWG.DLPClassificationSetting dlpSetting = [\"MyDLPClassificationSetting\"]\n\n// Define the text to be analyzed\nSTRING textToAnalyze = \"This is a sample text containing sensitive information like credit card numbers and social security numbers.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPClassificationMatchedTerms(dlpSetting, textToAnalyze)\n\n// Check if there are any matched terms\nIF matchedTerms.SIZE() > 0 THEN {\n    // Matched DLP Terms: \" + matchedTerms.TO_STRING()\n    // Block the connection with a reason\n    MWG.Block(\"Sensitive information detected: \" + matchedTerms.TO_STRING())\n} ELSE {\n    // Allow the connection if no sensitive information is detected\n    MWG.Allow(\"No sensitive information detected\")\n}"}, {"name": "MWG.DLPClassificationMatchedTerms (MWG.InternalSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing terms from the body text that match the specified classification.", "parameter_desc": "MWG.InternalSetting: specifies configuration settings.", "description": "Logs: List of terms that match the classification in body text.", "example_code": "// Define the DLP classification settings\nMWG.DLPClassificationSetting dlpSettings = ... // Initialize with appropriate settings\n\n// Define the text to be analyzed\nSTRING textToAnalyze = \"This is a sample text containing sensitive information.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPClassificationMatchedTerms(dlpSettings, textToAnalyze)\n\n// Matched Terms: \" + matchedTerms", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the DLP classification settings\nMWG.DLPClassificationSetting dlpSettings = ... // Initialize with appropriate settings\n\n// Define the text to be analyzed\nSTRING textToAnalyze = \"This is a sample text containing sensitive information.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPClassificationMatchedTerms(dlpSettings, textToAnalyze)\n\n// Matched Terms: \" + matchedTerms"}, {"name": "MWG.DLPClassificationMatches (MWG.DLPClassificationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns a`BOOLEAN`indicating whether classification matches were found in the body text.", "parameter_desc": "MWG.DLPClassificationSetting: the settings used for detecting classification matches in the body text.", "description": "Searches for classification matches in body text.", "example_code": "MWG.DLPDictionarySetting dictionarySetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text containing sensitive information.\"\n\nIF MWG.DLPDictionaryMatches(dictionarySetting, textToCheck) THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data found.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPDictionarySetting dictionarySetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text containing sensitive information.\"\n\nIF MWG.DLPDictionaryMatches(dictionarySetting, textToCheck) THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data found.\")\n}"}, {"name": "MWG.DLPClassificationMatches (MWG.DLPClassificationSetting, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns whether the provided text contains any classification matches based on the specified DLP classification setting.", "parameter_desc": "MWG.DLPClassificationSetting: The configuration settings for data loss prevention classification.STRING: The text to be searched for classification matches.", "description": "Searches for classification matches in text.", "example_code": "MWG.DLPClassificationSetting dlpSetting = [\"DLP_Setting_Name\"]\nSTRING classificationToCheck = \"Confidential\"\n\nIF MWG.DLPClassificationMatches(dlpSetting, classificationToCheck) THEN {\n    // DLP classification matches: Confidential\n    MWG.Block(\"Access to confidential information is not allowed.\")\n} ELSE {\n    // DLP classification does not match: Confidential\n    MWG.Allow(\"DLP check passed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPClassificationSetting dlpSetting = [\"DLP_Setting_Name\"]\nSTRING classificationToCheck = \"Confidential\"\n\nIF MWG.DLPClassificationMatches(dlpSetting, classificationToCheck) THEN {\n    // DLP classification matches: Confidential\n    MWG.Block(\"Access to confidential information is not allowed.\")\n} ELSE {\n    // DLP classification does not match: Confidential\n    MWG.Allow(\"DLP check passed\")\n}"}, {"name": "MWG.DLPClassificationMatches (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if classification matches are found in the body text, otherwise`FALSE`", "parameter_desc": "MWG.InternalSetting: configuration settings used for searching classification matches in the body text.", "description": "Searches for classification matches in body text.", "example_code": "MWG.DLPDictionarySetting dlpSetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text containing sensitive information.\"\n\nIF MWG.DLPDictionaryMatches(dlpSetting, textToCheck) THEN {\n    // DLP match found. Blocking the request.\n    MWG.Block(\"Sensitive data detected.\")\n} ELSE {\n    // No DLP match found. Allowing the request.\n    MWG.Allow(\"No sensitive data detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPDictionarySetting dlpSetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text containing sensitive information.\"\n\nIF MWG.DLPDictionaryMatches(dlpSetting, textToCheck) THEN {\n    // DLP match found. Blocking the request.\n    MWG.Block(\"Sensitive data detected.\")\n} ELSE {\n    // No DLP match found. Allowing the request.\n    MWG.Allow(\"No sensitive data detected.\")\n}"}, {"name": "MWG.DLPDictionaryMatchedTerms (MWG.DLPDictionarySetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector of terms that match the specified dictionary within the body text.", "parameter_desc": "MWG.DLPDictionarySetting: settings to use for matching terms in the body text.", "description": "Lists terms that match the dictionary in body text.", "example_code": "MWG.DLPDictionarySetting myDLPDictionarySetting = [\"myDLPDictionary\"]\nSTRING textToCheck = \"This is a sample text to check against the DLP dictionary.\"\n\nVECTOR<STRING> matchedTerms = MWG.DLPDictionaryMatchedTerms(myDLPDictionarySetting, textToCheck)\n\nIF matchedTerms.SIZE() > 0 THEN {\n    // Matched terms found: \" + matchedTerms.TO_STRING()\n    MWG.Block(\"DLP policy violation: Sensitive terms detected.\")\n} ELSE {\n    // No matched terms found.\n    MWG.Allow(\"No DLP policy violation.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPDictionarySetting myDLPDictionarySetting = [\"myDLPDictionary\"]\nSTRING textToCheck = \"This is a sample text to check against the DLP dictionary.\"\n\nVECTOR<STRING> matchedTerms = MWG.DLPDictionaryMatchedTerms(myDLPDictionarySetting, textToCheck)\n\nIF matchedTerms.SIZE() > 0 THEN {\n    // Matched terms found: \" + matchedTerms.TO_STRING()\n    MWG.Block(\"DLP policy violation: Sensitive terms detected.\")\n} ELSE {\n    // No matched terms found.\n    MWG.Allow(\"No DLP policy violation.\")\n}"}, {"name": "MWG.DLPDictionaryMatchedTerms (MWG.DLPDictionarySetting, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing terms from the text that match entries in the specified dictionary setting.", "parameter_desc": "MWG.DLPDictionarySetting: the dictionary settings to match against; STRING: the text to search.", "description": "Lists terms that match the dictionary in text.", "example_code": "// Define the DLP dictionary setting\nMWG.DLPDictionarySetting dictionarySetting = [\"SensitiveTermsDictionary\"]\n\n// Define the text to search\nSTRING textToSearch = \"This is a sample text containing sensitive information.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPDictionaryMatchedTerms(dictionarySetting, textToSearch)\n\n// Check if there are any matched terms\nIF matchedTerms.SIZE() > 0 THEN {\n    // Block the connection if sensitive terms are found\n    MWG.Block(\"Sensitive terms detected: \" + matchedTerms.TO_STRING())\n} ELSE {\n    // Allow the connection if no sensitive terms are found\n    MWG.Allow(\"No sensitive terms detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the DLP dictionary setting\nMWG.DLPDictionarySetting dictionarySetting = [\"SensitiveTermsDictionary\"]\n\n// Define the text to search\nSTRING textToSearch = \"This is a sample text containing sensitive information.\"\n\n// Get the matched terms\nVECTOR<STRING> matchedTerms = MWG.DLPDictionaryMatchedTerms(dictionarySetting, textToSearch)\n\n// Check if there are any matched terms\nIF matchedTerms.SIZE() > 0 THEN {\n    // Block the connection if sensitive terms are found\n    MWG.Block(\"Sensitive terms detected: \" + matchedTerms.TO_STRING())\n} ELSE {\n    // Allow the connection if no sensitive terms are found\n    MWG.Allow(\"No sensitive terms detected\")\n}"}, {"name": "MWG.DLPDictionaryMatchedTerms (MWG.InternalSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector of terms from the body text that match the dictionary specified in `MWG.InternalSetting`.", "parameter_desc": "MWG.InternalSetting: configuration settings for filtering or processing the body text.", "description": "Logs: Lists of terms that match the dictionary in body text.", "example_code": "MWG.DLPDictionarySetting dictionarySetting = [\"example_dictionary\"]\nSTRING textToSearch = \"This is a sample text to search for dictionary terms.\"\n\nVECTOR<STRING> matchedTerms = MWG.DLPDictionaryMatchedTerms(dictionarySetting, textToSearch)\n\nIF matchedTerms.SIZE() > 0 THEN {\n    // Matched terms found: \" + matchedTerms.TO_STRING()\n} ELSE {\n    // No matched terms found.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPDictionarySetting dictionarySetting = [\"example_dictionary\"]\nSTRING textToSearch = \"This is a sample text to search for dictionary terms.\"\n\nVECTOR<STRING> matchedTerms = MWG.DLPDictionaryMatchedTerms(dictionarySetting, textToSearch)\n\nIF matchedTerms.SIZE() > 0 THEN {\n    // Matched terms found: \" + matchedTerms.TO_STRING()\n} ELSE {\n    // No matched terms found.\n}"}, {"name": "MWG.DLPDictionaryMatches (MWG.DLPDictionarySetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if dictionary matches are found in the body text, otherwise`FALSE`", "parameter_desc": "MWG.DLPDictionarySetting: Configuration settings for the dictionary against which the body text will be checked.", "description": "Searches for dictionary matches in body text.", "example_code": "MWG.DLPDictionarySetting dlpSetting = [\"SensitiveDataDictionary\"]\nSTRING requestData = \"This is some sample text to check for sensitive data.\"\n\nIF MWG.DLPDictionaryMatches(dlpSetting, requestData) THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPDictionarySetting dlpSetting = [\"SensitiveDataDictionary\"]\nSTRING requestData = \"This is some sample text to check for sensitive data.\"\n\nIF MWG.DLPDictionaryMatches(dlpSetting, requestData) THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data detected.\")\n}"}, {"name": "MWG.DLPDictionaryMatches (MWG.DLPDictionarySetting, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if dictionary matches are found in the provided text, otherwise`FALSE`", "parameter_desc": "MWG.DLPDictionarySetting: dictionary settings; STRING: the text to search.", "description": "Searches for dictionary matches in text.", "example_code": "// Define the DLP dictionary setting\nMWG.DLPDictionarySetting dlpDictionary = [\"SensitiveDataDictionary\"]\n\n// Define the text to search\nSTRING textToSearch = \"This is a sample text containing sensitive information.\"\n\n// Check for dictionary matches\nBOOLEAN hasMatches = MWG.DLPDictionaryMatches(dlpDictionary, textToSearch)\n\n// Take action based on the result\nIF hasMatches THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the DLP dictionary setting\nMWG.DLPDictionarySetting dlpDictionary = [\"SensitiveDataDictionary\"]\n\n// Define the text to search\nSTRING textToSearch = \"This is a sample text containing sensitive information.\"\n\n// Check for dictionary matches\nBOOLEAN hasMatches = MWG.DLPDictionaryMatches(dlpDictionary, textToSearch)\n\n// Take action based on the result\nIF hasMatches THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data detected.\")\n}"}, {"name": "MWG.DLPDictionaryMatches (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns a`BOOLEAN`indicating whether any dictionary matches were found in the body text based on the internal setting.", "parameter_desc": "MWG.InternalSetting: configuration settings.", "description": "Searches for dictionary matches in body text.", "example_code": "MWG.DLPDictionarySetting dictionarySetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text that might contain sensitive data.\"\n\nIF MWG.DLPDictionaryMatches(dictionarySetting, textToCheck) THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data found.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.DLPDictionarySetting dictionarySetting = [\"SensitiveDataDictionary\"]\nSTRING textToCheck = \"This is a sample text that might contain sensitive data.\"\n\nIF MWG.DLPDictionaryMatches(dictionarySetting, textToCheck) THEN {\n    MWG.Block(\"Sensitive data detected in the request.\")\n} ELSE {\n    MWG.Allow(\"No sensitive data found.\")\n}"}, {"name": "MWG.DNSLookupHost (STRING)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns a vector containing the DNS records for the specified host.", "parameter_desc": "STRING: the hostname", "description": "Performs a DNS lookup for the given host.", "example_code": "STRING host = \"example.com\"\nSTRING ipAddress = MWG.DNSLookupHost(host)\n\n// The IP address for example.com is: ipAddress", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING host = \"example.com\"\nSTRING ipAddress = MWG.DNSLookupHost(host)\n\n// The IP address for example.com is: ipAddress"}, {"name": "MWG.DNSLookupHostReverse (Net.IP)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing the domain names associated with the given IP address.", "parameter_desc": "Net.IP: The IP address for which the reverse DNS lookup is to be performed.", "description": "Performs reverse DNS lookup for given IP.", "example_code": "// Define the IP address for which to perform the reverse DNS lookup\nNet.IP ipAddress = \"8.8.8.8\"\n\n// Perform the reverse DNS lookup\nVECTOR<STRING> domainNames = MWG.DNSLookupHostReverse(ipAddress)\n\n// Reverse DNS lookup results for IP \nFOR EACH domainName IN domainNames {\n    // domainName\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the IP address for which to perform the reverse DNS lookup\nNet.IP ipAddress = \"8.8.8.8\"\n\n// Perform the reverse DNS lookup\nVECTOR<STRING> domainNames = MWG.DNSLookupHostReverse(ipAddress)\n\n// Reverse DNS lookup results for IP \nFOR EACH domainName IN domainNames {\n    // domainName\n}"}, {"name": "MWG.Domain (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the domain name extracted from the given URL.", "parameter_desc": "MWG.URL: The URL from which the domain needs to be extracted.", "description": "Returns the domain of a request.", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING domainSuffix = MWG.DomainSuffix(currentUrl)\n\n// The domain suffix of the current URL is: domainSuffix\n\nIF domainSuffix == \"com\" THEN {\n    MWG.Allow(\"Allowed .com domain\")\n} ELSE {\n    MWG.Block(\"Blocked non-.com domain\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING domainSuffix = MWG.DomainSuffix(currentUrl)\n\n// The domain suffix of the current URL is: domainSuffix\n\nIF domainSuffix == \"com\" THEN {\n    MWG.Allow(\"Allowed .com domain\")\n} ELSE {\n    MWG.Block(\"Blocked non-.com domain\")\n}"}, {"name": "MWG.Domain (STRING)", "return_type": "STRING", "return_desc": "Returns the domain name extracted from the given host string.", "parameter_desc": "STRING: The host from which to extract the domain.", "description": "Returns the domain for the given host.", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING domain = currentUrl.Domain()\n\nIF domain == \"example.com\" THEN {\n    // Access to example.com is not allowed.\n    MWG.Block()\n} ELSE {\n    // Domain is allowed.\n    MWG.Allow()\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING domain = currentUrl.Domain()\n\nIF domain == \"example.com\" THEN {\n    // Access to example.com is not allowed.\n    MWG.Block()\n} ELSE {\n    // Domain is allowed.\n    MWG.Allow()\n}"}, {"name": "MWG.DomainSuffix (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the top-level domain (TLD) part of a given URL as a string.", "parameter_desc": "MWG.URL: The URL from which the domain suffix will be extracted.", "description": "Returns the domain suffix of a request.", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING domainSuffix = MWG.DomainSuffix(currentUrl)\n// The domain suffix of the current URL is: domainSuffix", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING domainSuffix = MWG.DomainSuffix(currentUrl)\n// The domain suffix of the current URL is: domainSuffix"}, {"name": "MWG.DomainSuffix (STRING)", "return_type": "STRING", "return_desc": "Returns the top-level domain suffix of the specified host name.", "parameter_desc": "STRING: the host name.", "description": "Returns the domain suffix for the given host.", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING domainSuffix = MWG.DomainSuffix(currentUrl)\n// The domain suffix is: domainSuffix", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING domainSuffix = MWG.DomainSuffix(currentUrl)\n// The domain suffix is: domainSuffix"}, {"name": "MWG.EndUserMessageCollection ()", "return_type": "STRING", "return_desc": "Returns the name of the collection containing error messages that is valid after executing a block action.", "parameter_desc": "None", "description": "Returns the collection name of error messages. Only valid after a block action is executed.", "example_code": "// Create a new EndUserMessageCollection object\nMWG.EndUserMessageCollection messageCollection = MWG.EndUserMessageCollection()\n\n// Add a message to the collection\nmessageCollection.AddMessage(\"This is a test message for the end user.\")\n\n// Add another message to the collection\nmessageCollection.AddMessage(\"Please follow the instructions provided.\")\n\n// Display the messages to the end user\nmessageCollection.Display()\n\n// Optionally, block the connection with a custom message\nMWG.Block(\"End user messages have been displayed.\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a new EndUserMessageCollection object\nMWG.EndUserMessageCollection messageCollection = MWG.EndUserMessageCollection()\n\n// Add a message to the collection\nmessageCollection.AddMessage(\"This is a test message for the end user.\")\n\n// Add another message to the collection\nmessageCollection.AddMessage(\"Please follow the instructions provided.\")\n\n// Display the messages to the end user\nmessageCollection.Display()\n\n// Optionally, block the connection with a custom message\nMWG.Block(\"End user messages have been displayed.\")"}, {"name": "MWG.EndUserURL ()", "return_type": "STRING", "return_desc": "Returns an internal URL as a string to handle end user requests such as error messages.", "parameter_desc": "None", "description": "Provides internal path to address end user requests (i.e., error messages).", "example_code": "MWG.URL currentUrl = MWG.Url()\n// The current URL is: + currentUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\n// The current URL is: + currentUrl"}, {"name": "MWG.EndUserURLGlobalResource ()", "return_type": "STRING", "return_desc": "Returns the internal path for global resources as a string to address end-user requests, such as error messages.", "parameter_desc": "None", "description": "Provides internal path to address end user requests (i.e., error messages), but always to global resources.", "example_code": "// Retrieve the URL of the global resource for the end user\nMWG.URL endUserResourceURL = MWG.EndUserURLGlobalResource()\n\n// End User Global Resource URL: \" + endUserResourceURL\n\n// Example condition to block access based on the URL\nIF endUserResourceURL == \"http://example.com/restricted\" THEN {\n    MWG.Block(\"Access to this resource is restricted.\")\n} ELSE {\n    MWG.Allow(\"Access granted to the resource.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the URL of the global resource for the end user\nMWG.URL endUserResourceURL = MWG.EndUserURLGlobalResource()\n\n// End User Global Resource URL: \" + endUserResourceURL\n\n// Example condition to block access based on the URL\nIF endUserResourceURL == \"http://example.com/restricted\" THEN {\n    MWG.Block(\"Access to this resource is restricted.\")\n} ELSE {\n    MWG.Allow(\"Access granted to the resource.\")\n}"}, {"name": "MWG.ExternalDataLastConfig ()", "return_type": "STRING", "return_desc": "Returns the name of the configuration used for the most recent query to an external data source.", "parameter_desc": "None", "description": "Returns the configuration name of the last queried external data source.", "example_code": "STRING lastConfig = MWG.ExternalDataLastConfig()\n// The last external data configuration used was: \" + lastConfig\n\nIF lastConfig == \"SpecificConfigName\" THEN {\n    MWG.Allow(\"Allowed based on specific external data configuration\")\n} ELSE {\n    MWG.Block(\"Blocked because the external data configuration did not match\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING lastConfig = MWG.ExternalDataLastConfig()\n// The last external data configuration used was: \" + lastConfig\n\nIF lastConfig == \"SpecificConfigName\" THEN {\n    MWG.Allow(\"Allowed based on specific external data configuration\")\n} ELSE {\n    MWG.Block(\"Blocked because the external data configuration did not match\")\n}"}, {"name": "MWG.FileExtension (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the file extension portion of the provided URL as a string.", "parameter_desc": "MWG.URL: A STRING representing the URL from which to extract the file extension.", "description": "Returns the file extension of a URL.", "example_code": "// Retrieve the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Get the file extension from the URL\nSTRING fileExtension = MWG.FileExtension(currentUrl)\n\n// Check if the file extension is \"exe\"\nIF fileExtension == \"exe\" THEN {\n    // Block the request if the file extension is \"exe\"\n    MWG.Block(\"Executable files are not allowed\")\n} ELSE {\n    // Allow the request if the file extension is not \"exe\"\n    MWG.Allow(\"File extension check passed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Get the file extension from the URL\nSTRING fileExtension = MWG.FileExtension(currentUrl)\n\n// Check if the file extension is \"exe\"\nIF fileExtension == \"exe\" THEN {\n    // Block the request if the file extension is \"exe\"\n    MWG.Block(\"Executable files are not allowed\")\n} ELSE {\n    // Allow the request if the file extension is not \"exe\"\n    MWG.Allow(\"File extension check passed\")\n}"}, {"name": "MWG.FileName (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the file name extracted from the given URL as a string.", "parameter_desc": "MWG.URL: The full URL from which to extract the file name.", "description": "Returns the file name of a URL.", "example_code": "MWG.URL currentUrl = MWG.Url()\n// Current URL: + currentUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\n// Current URL: + currentUrl"}, {"name": "MWG.FirstSentFirstReceivedClient ()", "return_type": "NUMBER", "return_desc": "Returns the duration between the first byte received from the client and when that first byte was sent back.", "parameter_desc": "None", "description": "Returns the duration between the first byte received from the client and when that first byte was sent back.", "example_code": "// Call the MWG.FirstSentFirstReceivedClient() function\nBOOLEAN result = MWG.FirstSentFirstReceivedClient()\n\n// Check the result and take action based on it\nIF result THEN {\n    // First sent first received client detected.\n    // Additional actions can be taken here\n} ELSE {\n    // First sent first received client not detected.\n    // Additional actions can be taken here\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Call the MWG.FirstSentFirstReceivedClient() function\nBOOLEAN result = MWG.FirstSentFirstReceivedClient()\n\n// Check the result and take action based on it\nIF result THEN {\n    // First sent first received client detected.\n    // Additional actions can be taken here\n} ELSE {\n    // First sent first received client not detected.\n    // Additional actions can be taken here\n}"}, {"name": "MWG.FirstSentFirstReceivedServer ()", "return_type": "NUMBER", "return_desc": "Returns the duration between the first byte sent to the server and when that first byte was actually received.", "parameter_desc": "None", "description": "Returns the duration between the first byte sent to the server and when that first byte was actually received.", "example_code": "// Get the duration between the first byte sent to the server and when it was received\nNUMBER responseTime = MWG.FirstSentFirstReceivedServer()\n\n// Server response time (first byte sent to first byte received): \" + responseTime\n\n// Implement logic based on the response time\nIF responseTime > 1000 THEN {\n    // If the response time is greater than 1000 milliseconds, block the connection\n    MWG.Block(\"Server response time too high: \" + responseTime + \" ms\")\n} ELSE {\n    // Otherwise, allow the connection\n    MWG.Allow(\"Server response time acceptable: \" + responseTime + \" ms\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the duration between the first byte sent to the server and when it was received\nNUMBER responseTime = MWG.FirstSentFirstReceivedServer()\n\n// Server response time (first byte sent to first byte received): \" + responseTime\n\n// Implement logic based on the response time\nIF responseTime > 1000 THEN {\n    // If the response time is greater than 1000 milliseconds, block the connection\n    MWG.Block(\"Server response time too high: \" + responseTime + \" ms\")\n} ELSE {\n    // Otherwise, allow the connection\n    MWG.Allow(\"Server response time acceptable: \" + responseTime + \" ms\")\n}"}, {"name": "MWG.Get (MWG.HeaderMap, STRING)", "return_type": "STRING", "return_desc": "Returns the value of a specified header from `MWG.HeaderMap `as a string.", "parameter_desc": "MWG.HeaderMap: the map of headers to retrieve from; STRING: the name of the header to retrieve the value for.", "description": "Returns a single header value.", "example_code": "MWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING userAgent = MWG.Get(headers, \"User-Agent\")\n// User-Agent: \" + userAgent", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING userAgent = MWG.Get(headers, \"User-Agent\")\n// User-Agent: \" + userAgent"}, {"name": "MWG.GetAll (MWG.HeaderMap, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing all values associated with the specified header name in the header map.", "parameter_desc": "MWG.HeaderMap: the map of headers to retrieve from; STRING: the name of the header to retrieve the value for.", "description": "", "example_code": "// Assume headers is an MWG.HeaderMap object containing the request headers\nMWG.HeaderMap headers = ... // This would be initialized with the actual header map\n\n// Retrieve all values for the \"User-Agent\" header\nVECTOR<STRING> userAgentValues = MWG.GetAll(headers, \"User-Agent\")\n\n// Print all User-Agent values to the console\nFOR EACH value IN userAgentValues {\n    // User-Agent: \" + value\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume headers is an MWG.HeaderMap object containing the request headers\nMWG.HeaderMap headers = ... // This would be initialized with the actual header map\n\n// Retrieve all values for the \"User-Agent\" header\nVECTOR<STRING> userAgentValues = MWG.GetAll(headers, \"User-Agent\")\n\n// Print all User-Agent values to the console\nFOR EACH value IN userAgentValues {\n    // User-Agent: \" + value\n}"}, {"name": "MWG.GetAllCookies (MWG.HeaderMap)", "return_type": "MAP<STRING,STRING>", "return_desc": "Returns a map containing all cookie names and their corresponding values.", "parameter_desc": "MWG.HeaderMap: The input parameter represents the HTTP headers from which the function will extract cookies.", "description": "", "example_code": "// Assume headers is an MWG.HeaderMap object representing the HTTP headers\nMWG.HeaderMap headers = ... // Obtain the headers from the request context\n\n// Get all cookies from the headers\nMAP<STRING, STRING> cookies = MWG.GetAllCookies(headers)\n\n// Iterate through the cookies and print each name and value\nFOR EACH cookieName IN cookies {\n    STRING cookieValue = cookies[cookieName]\n    // Cookie Name: \" + cookieName + \", Cookie Value: \" + cookieValue\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume headers is an MWG.HeaderMap object representing the HTTP headers\nMWG.HeaderMap headers = ... // Obtain the headers from the request context\n\n// Get all cookies from the headers\nMAP<STRING, STRING> cookies = MWG.GetAllCookies(headers)\n\n// Iterate through the cookies and print each name and value\nFOR EACH cookieName IN cookies {\n    STRING cookieValue = cookies[cookieName]\n    // Cookie Name: \" + cookieName + \", Cookie Value: \" + cookieValue\n}"}, {"name": "MWG.GetAllMatching (MWG.HeaderMap, STRING, RegExJSi)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing all headers that match the specified name and regular expression.", "parameter_desc": "MWG.HeaderMap: the map of headers to search through; STRING: the name of the headers to match; RegExJSi: the regular expression used for matching header values.", "description": "", "example_code": "MWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING headerKey = \"X-Custom-Header\"\nRegExJSi regex = RegExJSi(\"pattern\")\n\nMWG.RemoveAllMatching(headers, headerKey, regex)\n// Removed all matching headers", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING headerKey = \"X-Custom-Header\"\nRegExJSi regex = RegExJSi(\"pattern\")\n\nMWG.RemoveAllMatching(headers, headerKey, regex)\n// Removed all matching headers"}, {"name": "MWG.GetAnyMatching (MWG.HeaderMap, STRING, RegExJSi)", "return_type": "STRING", "return_desc": "Returns the first header that matches the specified name and regular expression criteria.", "parameter_desc": "MWG.HeaderMap: the collection of headers; STRING: the header name; RegExJSi: the regular expression to match against.", "description": "", "example_code": "// Define the header map, header name, and regular expression\nMWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING headerName = \"User-Agent\"\nRegExJSi regex = RegExJSi(\".*Mozilla.*\")\n\n// Use MWG.GetAnyMatching to find the first matching header\nSTRING matchingHeader = MWG.GetAnyMatching(headers, headerName, regex)\n\n// Matching Header: + matchingHeader", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the header map, header name, and regular expression\nMWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING headerName = \"User-Agent\"\nRegExJSi regex = RegExJSi(\".*Mozilla.*\")\n\n// Use MWG.GetAnyMatching to find the first matching header\nSTRING matchingHeader = MWG.GetAnyMatching(headers, headerName, regex)\n\n// Matching Header: + matchingHeader"}, {"name": "MWG.GetBlockPage (MWG.BlockSetting, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the name of the block page.", "parameter_desc": "MWG.BlockSetting: the block setting; STRING: the rule; STRING: the ruleset.", "description": "", "example_code": "// Create a block setting object\nMWG.BlockSetting blockSetting = MWG.BlockSetting()\n\n// Set some properties on the block setting (example properties)\nblockSetting.title = \"Access Denied\"\nblockSetting.message = \"You are not allowed to access this site.\"\n\n// Define the URL and reason for blocking\nSTRING url = \"http://example.com\"\nSTRING reason = \"Blocked by policy\"\n\n// Get the block page\nSTRING blockPage = MWG.GetBlockPage(blockSetting, url, reason)\n\n// Block the connection and display the block page\nMWG.Block(blockPage)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a block setting object\nMWG.BlockSetting blockSetting = MWG.BlockSetting()\n\n// Set some properties on the block setting (example properties)\nblockSetting.title = \"Access Denied\"\nblockSetting.message = \"You are not allowed to access this site.\"\n\n// Define the URL and reason for blocking\nSTRING url = \"http://example.com\"\nSTRING reason = \"Blocked by policy\"\n\n// Get the block page\nSTRING blockPage = MWG.GetBlockPage(blockSetting, url, reason)\n\n// Block the connection and display the block page\nMWG.Block(blockPage)"}, {"name": "MWG.GetBooleanProperty (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns the`BOOLEAN`setting of the given property.", "parameter_desc": "STRING: the property to check.", "description": "", "example_code": "STRING propertyName = \"example.property\"\nBOOLEAN propertyValue = MWG.GetBooleanProperty(propertyName)\n\nIF propertyValue THEN {\n    // The property is set to TRUE\n} ELSE {\n    // The property is set to FALSE\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING propertyName = \"example.property\"\nBOOLEAN propertyValue = MWG.GetBooleanProperty(propertyName)\n\nIF propertyValue THEN {\n    // The property is set to TRUE\n} ELSE {\n    // The property is set to FALSE\n}"}, {"name": "MWG.GetConnectionRunTime ()", "return_type": "NUMBER", "return_desc": "Returns the current duration of connection in seconds.", "parameter_desc": "None", "description": "Returns the current duration of connection in seconds", "example_code": "NUMBER connectionRunTime = MWG.GetConnectionRunTime()\n// Connection Run Time: connectionRunTime", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER connectionRunTime = MWG.GetConnectionRunTime()\n// Connection Run Time: connectionRunTime"}, {"name": "MWG.GetCookie (MWG.HeaderMap, STRING)", "return_type": "STRING", "return_desc": "Returns the value of the specified cookie.", "parameter_desc": "MWG.HeaderMap: the header map containing cookies; STRING: the name of the cookie to retrieve.", "description": "Return a single cookie value of the given cookie name", "example_code": "// Assume headers is an MWG.HeaderMap object containing the HTTP headers\nMWG.HeaderMap headers = MWG.GetRequestHeaders()\n\n// The name of the cookie we want to retrieve\nSTRING cookieName = \"session_id\"\n\n// Retrieve the value of the specified cookie\nSTRING cookieValue = MWG.GetCookie(headers, cookieName)\n\n// The value of the cookie session_id is: cookieValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume headers is an MWG.HeaderMap object containing the HTTP headers\nMWG.HeaderMap headers = MWG.GetRequestHeaders()\n\n// The name of the cookie we want to retrieve\nSTRING cookieName = \"session_id\"\n\n// Retrieve the value of the specified cookie\nSTRING cookieValue = MWG.GetCookie(headers, cookieName)\n\n// The value of the cookie session_id is: cookieValue"}, {"name": "MWG.GetCustomer ()", "return_type": "STRING", "return_desc": "Returns the current customer.", "parameter_desc": "None", "description": "Get current customer.", "example_code": "STRING customer = MWG.GetCustomer()\n// Current customer: \" + customer", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING customer = MWG.GetCustomer()\n// Current customer: \" + customer"}, {"name": "MWG.GetCustomerResourceAsJSON (STRING, STRING)", "return_type": "JSON", "return_desc": "Returns a JSON representation of a specified policy resource.", "parameter_desc": "STRING: Customer ID; STRING: relative path to resource;", "description": "Retrieve any policy resource as JSON", "example_code": "// Define the parameters for the function\nSTRING resourceType = \"config\"\nSTRING resourceName = \"customerSettings\"\n\n// Call the function and store the result in a JSON variable\nJSON customerResource = MWG.GetCustomerResourceAsJSON(resourceType, resourceName)\n\n// Check if the resource was successfully retrieved\nIF customerResource != NULL THEN {\n    // Customer Resource JSON: \n    // customerResource.toString()\n} ELSE {\n    // Failed to retrieve customer resource.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the parameters for the function\nSTRING resourceType = \"config\"\nSTRING resourceName = \"customerSettings\"\n\n// Call the function and store the result in a JSON variable\nJSON customerResource = MWG.GetCustomerResourceAsJSON(resourceType, resourceName)\n\n// Check if the resource was successfully retrieved\nIF customerResource != NULL THEN {\n    // Customer Resource JSON: \n    // customerResource.toString()\n} ELSE {\n    // Failed to retrieve customer resource.\n}"}, {"name": "MWG.GetDLPClassifier ()", "return_type": "DLP.Classifier", "return_desc": "Returns a DLP classifier with all attributes set according to the`MWG specifications`", "parameter_desc": "None", "description": "create a DLP classifier and set all MWG attributes", "example_code": "DLP.Classifier classifier = MWG.GetDLPClassifier()\n\nIF classifier != NULL THEN {\n    // DLP Classifier found: \" + classifier\n} ELSE {\n    // No DLP Classifier found.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "DLP.Classifier classifier = MWG.GetDLPClassifier()\n\nIF classifier != NULL THEN {\n    // DLP Classifier found: \" + classifier\n} ELSE {\n    // No DLP Classifier found.\n}"}, {"name": "MWG.GetEnduserMessageLanguage ()", "return_type": "STRING", "return_desc": "Returns a short string representing the language code for a block message.", "parameter_desc": "None", "description": "Returns a short STRING (i.e. en, de, ja) specifying the language for a block message", "example_code": "STRING language = \"en\"\nMWG.SetEnduserMessageLanguage(language)\n// End-user message language set to: en", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING language = \"en\"\nMWG.SetEnduserMessageLanguage(language)\n// End-user message language set to: en"}, {"name": "MWG.GetErrorId ()", "return_type": "NUMBER", "return_desc": "Returns the error ID.", "parameter_desc": "None", "description": "Returns the error id", "example_code": "// Hypothetical function to get the error ID\nNUMBER errorId = MWG.GetErrorId()\n\n// Check if an error ID was retrieved\nIF errorId != 0 THEN {\n    // Error ID: \" + errorId\n    // Block the connection with a message including the error ID\n    MWG.Block(\"Connection blocked due to error ID: \" + errorId)\n} ELSE {\n    // Allow the connection if no error ID is found\n    MWG.Allow(\"No error detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Hypothetical function to get the error ID\nNUMBER errorId = MWG.GetErrorId()\n\n// Check if an error ID was retrieved\nIF errorId != 0 THEN {\n    // Error ID: \" + errorId\n    // Block the connection with a message including the error ID\n    MWG.Block(\"Connection blocked due to error ID: \" + errorId)\n} ELSE {\n    // Allow the connection if no error ID is found\n    MWG.Allow(\"No error detected\")\n}"}, {"name": "MWG.GetHTTPHeader (MWG.HeaderMap)", "return_type": "HTTPHeader", "return_desc": "Returns the HTTP header from a header map.", "parameter_desc": "MWG.HeaderMap: the map of headers to retrieve the HTTP header from", "description": "Get the HTTP Header from a header map.", "example_code": "// Assume headersMap is a predefined MWG.HeaderMap object containing HTTP headers\nMWG.HeaderMap headersMap = ... // This would be defined elsewhere in your actual code\n\n// Retrieve a specific HTTP header from the headers map\nHTTPHeader header = MWG.GetHTTPHeader(headersMap)\n\n// Retrieved HTTP Header: \" + header", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume headersMap is a predefined MWG.HeaderMap object containing HTTP headers\nMWG.HeaderMap headersMap = ... // This would be defined elsewhere in your actual code\n\n// Retrieve a specific HTTP header from the headers map\nHTTPHeader header = MWG.GetHTTPHeader(headersMap)\n\n// Retrieved HTTP Header: \" + header"}, {"name": "MWG.GetHTTPOriginalHeaders (MWG.HeaderMap)", "return_type": "STRING", "return_desc": "Returns a single string containing all original headers from the request/response, concatenated and separated by \"??? ???\".", "parameter_desc": "MWG.HeaderMap: A map  structure containing the  headers from a request or response.", "description": "Returns a concatenated STRING of all original headers (separated by ??? ???) from request/response.", "example_code": "// Create a variable to hold the headers map\nMWG.HeaderMap headersMap = MWG.GetRequestHeaders()\n\n// Get the original headers as a concatenated string\nSTRING originalHeaders = MWG.GetHTTPOriginalHeaders(headersMap)\n\n// Original Headers: \" + originalHeaders", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a variable to hold the headers map\nMWG.HeaderMap headersMap = MWG.GetRequestHeaders()\n\n// Get the original headers as a concatenated string\nSTRING originalHeaders = MWG.GetHTTPOriginalHeaders(headersMap)\n\n// Original Headers: \" + originalHeaders"}, {"name": "MWG.GetIPSecDevice ()", "return_type": "STRING", "return_desc": "Returns the name of the IPSec device as a string.", "parameter_desc": "None", "description": "Returns IPSec Device Name", "example_code": "STRING ipSecDeviceName = MWG.GetIPSecDevice()\n// IPSec Device Name: \" + ipSecDeviceName\n\nIF ipSecDeviceName == \"ExpectedDeviceName\" THEN {\n    MWG.Allow(\"IPSec device is as expected\")\n} ELSE {\n    MWG.Block(\"Unexpected IPSec device\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING ipSecDeviceName = MWG.GetIPSecDevice()\n// IPSec Device Name: \" + ipSecDeviceName\n\nIF ipSecDeviceName == \"ExpectedDeviceName\" THEN {\n    MWG.Allow(\"IPSec device is as expected\")\n} ELSE {\n    MWG.Block(\"Unexpected IPSec device\")\n}"}, {"name": "MWG.GetLogStorageRegion ()", "return_type": "STRING", "return_desc": "Returns a string indicating the storage region of the log files.", "parameter_desc": "None", "description": "Get the storage region of the log files.", "example_code": "STRING logRegion = MWG.GetLogStorageRegion()\n// The current log storage region is: \" + logRegion\n\nIF logRegion == \"US\" THEN {\n    // Log storage region is set to US.\n} ELSE {\n    // Log storage region is not set to US.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING logRegion = MWG.GetLogStorageRegion()\n// The current log storage region is: \" + logRegion\n\nIF logRegion == \"US\" THEN {\n    // Log storage region is set to US.\n} ELSE {\n    // Log storage region is not set to US.\n}"}, {"name": "MWG.GetMapByName (STRING)", "return_type": "MAP<STRING,STRING>", "return_desc": "Returns a map by the given name.", "parameter_desc": "STRING: name of the map.", "description": "Retrieves a MAP<STRING, STRING> by map name", "example_code": "// Retrieve a map by its name\nMAP<STRING><NUMBER> exampleMap = MWG.GetMapByName(\"example_map_name\")\n\n// Check if a specific key exists in the map\nIF \"example_key\" IN exampleMap THEN {\n    // Retrieve the value associated with the key\n    NUMBER value = exampleMap[\"example_key\"]\n    // The value for 'example_key' is: value\n} ELSE {\n    // The key 'example_key' does not exist in the map.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve a map by its name\nMAP<STRING><NUMBER> exampleMap = MWG.GetMapByName(\"example_map_name\")\n\n// Check if a specific key exists in the map\nIF \"example_key\" IN exampleMap THEN {\n    // Retrieve the value associated with the key\n    NUMBER value = exampleMap[\"example_key\"]\n    // The value for 'example_key' is: value\n} ELSE {\n    // The key 'example_key' does not exist in the map.\n}"}, {"name": "MWG.GetMessageTemplateName ()", "return_type": "STRING", "return_desc": "Returns the template name for a block message.", "parameter_desc": "None", "description": "Returns the template name for a block message", "example_code": "STRING templateName = MWG.GetMessageTemplateName()\n// Current message template name: \" + templateName\n\nIF templateName == \"BlockPage\" THEN {\n    // The message template is set to BlockPage.\n    // Additional logic for BlockPage template\n} ELSE {\n    // The message template is not BlockPage.\n    // Additional logic for other templates\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING templateName = MWG.GetMessageTemplateName()\n// Current message template name: \" + templateName\n\nIF templateName == \"BlockPage\" THEN {\n    // The message template is set to BlockPage.\n    // Additional logic for BlockPage template\n} ELSE {\n    // The message template is not BlockPage.\n    // Additional logic for other templates\n}"}, {"name": "MWG.GetMWGNHPAddress ()", "return_type": "STRING", "return_desc": "Returns the address of Next Hop Proxy (host:port) used for this connection.", "parameter_desc": "None", "description": "Returns the address of Next Hop Proxy (host:port) used for this connection", "example_code": "STRING nhpAddress = MWG.GetMWGNHPAddress()\n// Next Hop Proxy Address: + nhpAddress", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING nhpAddress = MWG.GetMWGNHPAddress()\n// Next Hop Proxy Address: + nhpAddress"}, {"name": "MWG.GetNumberProperty (STRING)", "return_type": "NUMBER", "return_desc": "Returns the number setting of the given property.", "parameter_desc": "STRING: the property to check.", "description": "Get the NUMBER value of what a property is currently set to.", "example_code": "// Retrieve a numerical property\nNUMBER propertyValue = MWG.GetNumberProperty(\"exampleProperty\")\n\n// The value of 'exampleProperty' is: \" + propertyValue\n\n// Use the retrieved property value in a conditional statement\nIF propertyValue > 10 THEN {\n    // The property value is greater than 10.\n} ELSE {\n    // The property value is 10 or less.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve a numerical property\nNUMBER propertyValue = MWG.GetNumberProperty(\"exampleProperty\")\n\n// The value of 'exampleProperty' is: \" + propertyValue\n\n// Use the retrieved property value in a conditional statement\nIF propertyValue > 10 THEN {\n    // The property value is greater than 10.\n} ELSE {\n    // The property value is 10 or less.\n}"}, {"name": "MWG.GetPOSTFormElement (STRING)", "return_type": "STRING", "return_desc": "Returns the value of the specified element from the POST request body.", "parameter_desc": "STRING: the element name to be extracted from the POST body.", "description": "Extracts the given element of a POST body", "example_code": "// Define the name of the form element you want to retrieve\nSTRING formElementName = \"username\"\n\n// Retrieve the value of the form element\nSTRING formElementValue = MWG.GetPOSTFormElement(formElementName)\n\n// Check if the form element value is empty\nIF formElementValue == \"\" THEN {\n    // Block the request if the form element is empty\n    MWG.Block(\"Form element 'username' is missing or empty.\")\n} ELSE {\n    // Allow the request and log the form element value\n    // Form element 'username' has value: \" + formElementValue\n    MWG.Allow(\"Form element 'username' is present.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the name of the form element you want to retrieve\nSTRING formElementName = \"username\"\n\n// Retrieve the value of the form element\nSTRING formElementValue = MWG.GetPOSTFormElement(formElementName)\n\n// Check if the form element value is empty\nIF formElementValue == \"\" THEN {\n    // Block the request if the form element is empty\n    MWG.Block(\"Form element 'username' is missing or empty.\")\n} ELSE {\n    // Allow the request and log the form element value\n    // Form element 'username' has value: \" + formElementValue\n    MWG.Allow(\"Form element 'username' is present.\")\n}"}, {"name": "MWG.GetPropertyValue (STRING)", "return_type": "MWG.InternalVariant", "return_desc": "Returns the value of the specified property.", "parameter_desc": "STRING: the name of the property.", "description": "Get the value of a property from the internal parameters.", "example_code": "// Retrieve the value of a property\nSTRING propertyValue = MWG.GetStringProperty(\"exampleProperty\")\n\n// The value of exampleProperty is: \" + propertyValue\n\n// Use the property value in a conditional statement\nIF propertyValue == \"someValue\" THEN {\n    // Perform some action if the property value matches \"someValue\"\n    MWG.Allow(\"Property value matched\")\n} ELSE {\n    // Perform a different action if the property value does not match\n    MWG.Block(\"Property value did not match\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the value of a property\nSTRING propertyValue = MWG.GetStringProperty(\"exampleProperty\")\n\n// The value of exampleProperty is: \" + propertyValue\n\n// Use the property value in a conditional statement\nIF propertyValue == \"someValue\" THEN {\n    // Perform some action if the property value matches \"someValue\"\n    MWG.Allow(\"Property value matched\")\n} ELSE {\n    // Perform a different action if the property value does not match\n    MWG.Block(\"Property value did not match\")\n}"}, {"name": "MWG.GetPropertyValue (STRING, MWG.InternalParameterList)", "return_type": "MWG.InternalVariant", "return_desc": "Returns the value of the specified property.", "parameter_desc": "STRING: name of property; MWG.InternalParameterList: list to check.", "description": "Get the value of a property in an internal parameter list.", "example_code": "// Define the internal parameter list\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Add some properties to the parameter list (for demonstration purposes)\nparamList.Add(\"exampleProperty\", \"exampleValue\")\n\n// Retrieve the value of the property\nMWG.InternalVariant propertyValue = MWG.GetPropertyValue(\"exampleProperty\", paramList)\n\n// The value of 'exampleProperty' is: \" + propertyValue.ToString()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the internal parameter list\nMWG.InternalParameterList paramList = MWG.InternalParameterList()\n\n// Add some properties to the parameter list (for demonstration purposes)\nparamList.Add(\"exampleProperty\", \"exampleValue\")\n\n// Retrieve the value of the property\nMWG.InternalVariant propertyValue = MWG.GetPropertyValue(\"exampleProperty\", paramList)\n\n// The value of 'exampleProperty' is: \" + propertyValue.ToString()"}, {"name": "MWG.GetPropertyValueWithConfig (MWG.InternalSetting, STRING)", "return_type": "MWG.InternalVariant", "return_desc": "Returns the value of the specified property.", "parameter_desc": "MWG.InternalSetting: configuration; STRING: name of property.", "description": "Get the value of a property from the internal parameters with a config.", "example_code": "// Define the internal setting configuration\nMWG.InternalSetting config = MWG.InternalSetting()\n\n// Define the property name you want to retrieve\nSTRING propertyName = \"exampleProperty\"\n\n// Retrieve the property value using the configuration and property name\nMWG.InternalVariant propertyValue = MWG.GetPropertyValueWithConfig(config, propertyName)\n\n// The value of the property is: \" + propertyValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the internal setting configuration\nMWG.InternalSetting config = MWG.InternalSetting()\n\n// Define the property name you want to retrieve\nSTRING propertyName = \"exampleProperty\"\n\n// Retrieve the property value using the configuration and property name\nMWG.InternalVariant propertyValue = MWG.GetPropertyValueWithConfig(config, propertyName)\n\n// The value of the property is: \" + propertyValue"}, {"name": "MWG.GetPropertyValueWithConfig (MWG.InternalSetting, STRING, MWG.InternalParameterList)", "return_type": "MWG.InternalVariant", "return_desc": "Returns the value of the specified property.", "parameter_desc": "MWG.InternalSetting: configuration; STRING: name of property; MWG.InternalParamterList: list to check.", "description": "Get the value of a property in an internal parameter list with a config.", "example_code": "// Define the internal setting\nMWG.InternalSetting config = ... // Initialize with your specific configuration\n\n// Define the property name you want to get the value of\nSTRING propertyName = \"exampleProperty\"\n\n// Define the internal parameter list\nMWG.InternalParameterList paramList = ... // Initialize with your specific parameter list\n\n// Get the property value using MWG.GetPropertyValueWithConfig\nMWG.InternalVariant propertyValue = MWG.GetPropertyValueWithConfig(config, propertyName, paramList)\n\n// Property Value: \n// Commented out DEBUG line: \"Property Value: \" + propertyValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the internal setting\nMWG.InternalSetting config = ... // Initialize with your specific configuration\n\n// Define the property name you want to get the value of\nSTRING propertyName = \"exampleProperty\"\n\n// Define the internal parameter list\nMWG.InternalParameterList paramList = ... // Initialize with your specific parameter list\n\n// Get the property value using MWG.GetPropertyValueWithConfig\nMWG.InternalVariant propertyValue = MWG.GetPropertyValueWithConfig(config, propertyName, paramList)\n\n// Property Value: \n// Commented out DEBUG line: \"Property Value: \" + propertyValue"}, {"name": "MWG.GetSAMLConfiguration (STRING)", "return_type": "MWG.SAMLConfiguration", "return_desc": "Returns the SAML configuration associated with the specified ID.", "parameter_desc": "STRING: the ID of the SAML configuration to retrieve.", "description": "Returns SAML configuration by ID", "example_code": "STRING samlConfigID = \"exampleID\"\nMWG.SAMLConfiguration samlConfig = MWG.GetSAMLConfiguration(samlConfigID)\n\n// Retrieved SAML Configuration:", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING samlConfigID = \"exampleID\"\nMWG.SAMLConfiguration samlConfig = MWG.GetSAMLConfiguration(samlConfigID)\n\n// Retrieved SAML Configuration:"}, {"name": "MWG.GetServiceAssignmentFromTenant (STRING, STRING)", "return_type": "JSON", "return_desc": "Returns a JSON object containing the assignment details for a specified tenantID and service from the GSD.", "parameter_desc": "STRING: the tenantID; STRING: the service name.", "description": "Query the GSD to get the assignment for a given tenantID and service", "example_code": "// Define the tenant ID and service name\nSTRING tenantID = \"exampleTenantID\"\nSTRING serviceName = \"exampleService\"\n\n// Call the function to get the service assignment\nJSON assignmentDetails = MWG.GetServiceAssignmentFromTenant(tenantID, serviceName)\n\n// Assignment Details: \" + assignmentDetails.toString()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the tenant ID and service name\nSTRING tenantID = \"exampleTenantID\"\nSTRING serviceName = \"exampleService\"\n\n// Call the function to get the service assignment\nJSON assignmentDetails = MWG.GetServiceAssignmentFromTenant(tenantID, serviceName)\n\n// Assignment Details: \" + assignmentDetails.toString()"}, {"name": "MWG.GetSSLClientCertificateSerial ()", "return_type": "STRING", "return_desc": "Returns the SSL client certificate serial.", "parameter_desc": "None", "description": "Returns the SSL client certificate serial", "example_code": "STRING certificateSerial = MWG.GetSSLClientCertificateSerial()\n// SSL Client Certificate Serial: \" + certificateSerial\n\n// You can add additional logic here based on the certificate serial\nIF certificateSerial == \"1234567890ABCDEF\" THEN {\n    MWG.Allow(\"Valid Certificate\")\n} ELSE {\n    MWG.Block(\"Invalid Certificate\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING certificateSerial = MWG.GetSSLClientCertificateSerial()\n// SSL Client Certificate Serial: \" + certificateSerial\n\n// You can add additional logic here based on the certificate serial\nIF certificateSerial == \"1234567890ABCDEF\" THEN {\n    MWG.Allow(\"Valid Certificate\")\n} ELSE {\n    MWG.Block(\"Invalid Certificate\")\n}"}, {"name": "MWG.GetSTRINGProperty (STRING)", "return_type": "STRING", "return_desc": "Returns the string value of the given property.", "parameter_desc": "STRING: the property to check.", "description": "Get the STRING value of what a property is currently set to.", "example_code": "// Define the property name you want to retrieve\nSTRING propertyName = \"example.property.name\"\n\n// Get the value of the property\nSTRING propertyValue = MWG.GetStringProperty(propertyName)\n\n// The value of the property is: \n// propertyValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the property name you want to retrieve\nSTRING propertyName = \"example.property.name\"\n\n// Get the value of the property\nSTRING propertyValue = MWG.GetStringProperty(propertyName)\n\n// The value of the property is: \n// propertyValue"}, {"name": "MWG.GetUserAzureGroups (MWG.AzureDirLookupSetting, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns the Azure AD group list for the given user.", "parameter_desc": "MWG.AzureDirLookupSetting: configuration settings; STRING: user to lookup for.", "description": "Retrieve Azure AD group list for user", "example_code": "// Define the Azure Directory Lookup Setting\nMWG.AzureDirLookupSetting azureSetting = MWG.AzureDirLookupSetting()\n\n// Define the user for whom to retrieve the Azure groups\nSTRING username = \"user@example.com\"\n\n// Retrieve the Azure groups for the specified user\nVECTOR<STRING> userGroups = MWG.GetUserAzureGroups(azureSetting, username)\n\n// Azure AD Groups for user@example.com: userGroups\n\n// Example condition to block access if the user is not in a specific group\nIF \"required-group\" NOT IN userGroups THEN {\n    MWG.Block(\"User is not in the required Azure AD group.\")\n} ELSE {\n    MWG.Allow(\"User is in the required Azure AD group.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the Azure Directory Lookup Setting\nMWG.AzureDirLookupSetting azureSetting = MWG.AzureDirLookupSetting()\n\n// Define the user for whom to retrieve the Azure groups\nSTRING username = \"user@example.com\"\n\n// Retrieve the Azure groups for the specified user\nVECTOR<STRING> userGroups = MWG.GetUserAzureGroups(azureSetting, username)\n\n// Azure AD Groups for user@example.com: userGroups\n\n// Example condition to block access if the user is not in a specific group\nIF \"required-group\" NOT IN userGroups THEN {\n    MWG.Block(\"User is not in the required Azure AD group.\")\n} ELSE {\n    MWG.Allow(\"User is in the required Azure AD group.\")\n}"}, {"name": "MWG.GlobOrRegExToRegEx (STRING)", "return_type": "STRING", "return_desc": "Returns a regular expression in the `RegExJSi` format converted from an XML-`MWG glob or regular `expression.", "parameter_desc": "STRING: a glob or regular expression in XML-MWG format to be converted to a RegExJSi object.", "description": "IGONRE Converts glob expression or regular expression from XML-MWG to an RegExJSi object", "example_code": "// Define a glob pattern\nSTRING globPattern = \"*.example.com/*\"\n\n// Convert the glob pattern to a regular expression\nSTRING regexPattern = MWG.GlobOrRegExToRegEx(globPattern)\n\n// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Check if the current URL matches the converted regular expression\nIF currentUrl MATCHES regexPattern THEN {\n    // The URL matches the pattern.\n    // Perform some action, e.g., allow the request\n    MWG.Allow(\"MatchedPattern\")\n} ELSE {\n    // The URL does not match the pattern.\n    // Perform some other action, e.g., block the request\n    MWG.Block(\"PatternMismatch\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a glob pattern\nSTRING globPattern = \"*.example.com/*\"\n\n// Convert the glob pattern to a regular expression\nSTRING regexPattern = MWG.GlobOrRegExToRegEx(globPattern)\n\n// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Check if the current URL matches the converted regular expression\nIF currentUrl MATCHES regexPattern THEN {\n    // The URL matches the pattern.\n    // Perform some action, e.g., allow the request\n    MWG.Allow(\"MatchedPattern\")\n} ELSE {\n    // The URL does not match the pattern.\n    // Perform some other action, e.g., block the request\n    MWG.Block(\"PatternMismatch\")\n}"}, {"name": "MWG.GMTTimeIsInRange (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current time is within the input times in GMT format (e.g., 1 September 2012 09:06:03 PM or Thu, 1 September 2012 21:06:03).", "parameter_desc": "STRING: start time in GMT format; STRING: end time in GMT format.", "description": "Returns TRUE if the current time is within the input times in GMT format(e.g. 1 September 2012 09:06:03 PM or Thu, 1 September 2012 21:06:03)", "example_code": "STRING startTime = \"08:00\"\nSTRING endTime = \"17:00\"\n\nIF MWG.GMTTimeIsInRange(startTime, endTime) THEN {\n    // Current time is within the range.\n    MWG.Allow(\"TimeRangeCheck\")\n} ELSE {\n    // Current time is outside the range.\n    MWG.Block(\"Access outside allowed time range.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING startTime = \"08:00\"\nSTRING endTime = \"17:00\"\n\nIF MWG.GMTTimeIsInRange(startTime, endTime) THEN {\n    // Current time is within the range.\n    MWG.Allow(\"TimeRangeCheck\")\n} ELSE {\n    // Current time is outside the range.\n    MWG.Block(\"Access outside allowed time range.\")\n}"}, {"name": "MWG.HandleConnectToServer ()", "return_type": "NUMBER", "return_desc": "Returns the time taken to complete the TCP handshake with the server in numerical format.", "parameter_desc": "None", "description": "Returns the duration of the TCP handshake with the server", "example_code": "STRING serverUrl = MWG.ConnectionVariablesGet(\"server.url\")\n// Attempting to connect to server: \" + serverUrl\n\n// Handle the connection to the server\nMWG.HandleConnectToServer(serverUrl)\n\n// Additional logic can be added here\nIF serverUrl == \"http://example.com\" THEN {\n    MWG.Block(\"Access to example.com is blocked\")\n} ELSE {\n    MWG.Allow(\"Connection allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING serverUrl = MWG.ConnectionVariablesGet(\"server.url\")\n// Attempting to connect to server: \" + serverUrl\n\n// Handle the connection to the server\nMWG.HandleConnectToServer(serverUrl)\n\n// Additional logic can be added here\nIF serverUrl == \"http://example.com\" THEN {\n    MWG.Block(\"Access to example.com is blocked\")\n} ELSE {\n    MWG.Allow(\"Connection allowed\")\n}"}, {"name": "MWG.HasHeader (MWG.HeaderMap, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the specified header exists in the given header map.", "parameter_desc": "MWG.HeaderMap: a map containing headers of the request/response; STRING: the specific header name to check for.", "description": "Returns TRUE if the request/response has a header", "example_code": "MWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING headerName = \"User-Agent\"\n\nIF MWG.HasHeader(headers, headerName) THEN {\n    // Header User-Agent exists in the request.\n} ELSE {\n    // Header User-Agent does not exist in the request.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.HeaderMap headers = MWG.GetRequestHeaders()\nSTRING headerName = \"User-Agent\"\n\nIF MWG.HasHeader(headers, headerName) THEN {\n    // Header User-Agent exists in the request.\n} ELSE {\n    // Header User-Agent does not exist in the request.\n}"}, {"name": "MWG.HasMatchingCertificate (MWG.ClientContextRevProxySetting, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a certificate is available for the specified host.", "parameter_desc": "MWG.ClientContextRevProxySetting: Specifies the reverse proxy settings; STRING: The host name to check.", "description": "Returns if a certificate is available for given host", "example_code": "MWG.ClientContextRevProxySetting revProxySetting = // Initialize your reverse proxy settings here\nSTRING hostName = \"example.com\"\n\nBOOLEAN hasCertificate = MWG.HasMatchingCertificate(revProxySetting, hostName)\n\nIF hasCertificate THEN {\n    // A matching certificate is available for \" + hostName\n} ELSE {\n    // No matching certificate found for \" + hostName\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ClientContextRevProxySetting revProxySetting = // Initialize your reverse proxy settings here\nSTRING hostName = \"example.com\"\n\nBOOLEAN hasCertificate = MWG.HasMatchingCertificate(revProxySetting, hostName)\n\nIF hasCertificate THEN {\n    // A matching certificate is available for \" + hostName\n} ELSE {\n    // No matching certificate found for \" + hostName\n}"}, {"name": "MWG.HasMatchingHeader (MWG.HeaderMap, STRING, RegExJSi)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any header in the given `MWG.HeaderMap `matches the specified regular expression.", "parameter_desc": "MWG.HeaderMap: the map containing headers; STRING: the specific header name to be checked; RegExJSi: the regular expression used to match the header value.", "description": "Returns TRUE if a request/response has a header that matches the given regular expression", "example_code": "MWG.HeaderMap headers = MWG.RequestHeaders()\nSTRING headerName = \"User-Agent\"\nRegExJSi regex = RegExJSi(\"Mozilla\")\n\nIF MWG.HasMatchingHeader(headers, headerName, regex) THEN {\n    // Blocked due to User-Agent containing 'Mozilla'\n    MWG.Block(\"Blocked due to User-Agent containing 'Mozilla'\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.HeaderMap headers = MWG.RequestHeaders()\nSTRING headerName = \"User-Agent\"\nRegExJSi regex = RegExJSi(\"Mozilla\")\n\nIF MWG.HasMatchingHeader(headers, headerName, regex) THEN {\n    // Blocked due to User-Agent containing 'Mozilla'\n    MWG.Block(\"Blocked due to User-Agent containing 'Mozilla'\")\n}"}, {"name": "MWG.HasOpener ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if data extraction for the file type is supported, otherwise`FALSE`", "parameter_desc": "None", "description": "Checks if data extraction for this file type is supported", "example_code": "// Check if the opener for a specific content type is available\nIF MWG.HasOpener(\"application/pdf\") THEN {\n    // PDF opener is available.\n} ELSE {\n    // PDF opener is not available.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Check if the opener for a specific content type is available\nIF MWG.HasOpener(\"application/pdf\") THEN {\n    // PDF opener is available.\n} ELSE {\n    // PDF opener is not available.\n}"}, {"name": "MWG.HasParameter (MWG.URL, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the specified URL contains the specified parameter(s).", "parameter_desc": "MWG.URL: the web address to check for parameters; STRING: the specific parameter name to look for within the URL.", "description": "Returns TRUE if the URL has a parameter(s)", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING parameterToCheck = \"exampleParam\"\n\nIF MWG.HasParameter(currentUrl, parameterToCheck) THEN {\n    // The URL has the parameter: exampleParam\n} ELSE {\n    // The URL does not have the parameter: exampleParam\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING parameterToCheck = \"exampleParam\"\n\nIF MWG.HasParameter(currentUrl, parameterToCheck) THEN {\n    // The URL has the parameter: exampleParam\n} ELSE {\n    // The URL does not have the parameter: exampleParam\n}"}, {"name": "MWG.Headers (MWG.RequestResponse)", "return_type": "MWG.HeaderMap", "return_desc": "Returns a map of headers from the given request or response.", "parameter_desc": "MWG.RequestResponse: the request or response object.", "description": "Returns the header of a request or response", "example_code": "// Retrieve the headers from the web request\nMWG.HeaderMap headers = MWG.Headers(Web.Request)\n\n// Iterate through the headers and print each one\nFOR EACH header IN headers {\n    // Header: \" + header + \" Value: \" + headers[header]\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the headers from the web request\nMWG.HeaderMap headers = MWG.Headers(Web.Request)\n\n// Iterate through the headers and print each one\nFOR EACH header IN headers {\n    // Header: \" + header + \" Value: \" + headers[header]\n}"}, {"name": "MWG.Host (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the host part of a given URL as a string.", "parameter_desc": "MWG.URL: The URL from which to extract and return the host as a STRING.", "description": "Return the host of an URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING host = MWG.Host(currentUrl)\n// The host part of the URL is: + host", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING host = MWG.Host(currentUrl)\n// The host part of the URL is: + host"}, {"name": "MWG.HostAndCertificateListByName (STRING)", "return_type": "VECTOR<MWG.HostAndCertificate>", "return_desc": "Returns the HostAndCertificate list with the specified name.", "parameter_desc": "STRING: name of list to retrieve", "description": "Retrieves a HostAndCertificate list by list name", "example_code": "// Define the name of the Host and Certificate list you want to retrieve\nSTRING listName = \"trustedHosts\"\n\n// Retrieve the Host and Certificate list by name\nVECTOR<MWG.HostAndCertificate> hostAndCertList = MWG.HostAndCertificateListByName(listName)\n\n// Check if the list is not empty\nIF hostAndCertList != NULL AND hostAndCertList.SIZE() > 0 THEN {\n    // Host and Certificate list 'listName' retrieved successfully.\n    \n    // Iterate through the list and perform some action\n    FOR EACH hostAndCert IN hostAndCertList DO {\n        // Host: hostAndCert.Host, Certificate: hostAndCert.Certificate\n        // Additional logic based on the host and certificate\n    }\n} ELSE {\n    // Host and Certificate list 'listName' is empty or not found.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the name of the Host and Certificate list you want to retrieve\nSTRING listName = \"trustedHosts\"\n\n// Retrieve the Host and Certificate list by name\nVECTOR<MWG.HostAndCertificate> hostAndCertList = MWG.HostAndCertificateListByName(listName)\n\n// Check if the list is not empty\nIF hostAndCertList != NULL AND hostAndCertList.SIZE() > 0 THEN {\n    // Host and Certificate list 'listName' retrieved successfully.\n    \n    // Iterate through the list and perform some action\n    FOR EACH hostAndCert IN hostAndCertList DO {\n        // Host: hostAndCert.Host, Certificate: hostAndCert.Certificate\n        // Additional logic based on the host and certificate\n    }\n} ELSE {\n    // Host and Certificate list 'listName' is empty or not found.\n}"}, {"name": "MWG.HostAndCertificateListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the HostAndCertificate list with the name exists.", "parameter_desc": "STRING: name of list to check.", "description": "Returns TRUE if HostAndCertificate list with the name exists", "example_code": "STRING listName = \"example_list_name\"\n\nIF MWG.HostAndCertificateListByNameExists(listName) THEN {\n    // The host and certificate list exists.\n} ELSE {\n    // The host and certificate list does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING listName = \"example_list_name\"\n\nIF MWG.HostAndCertificateListByNameExists(listName) THEN {\n    // The host and certificate list exists.\n} ELSE {\n    // The host and certificate list does not exist.\n}"}, {"name": "MWG.HostIsIP (MWG.URL)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the host part of the provided URL is an IP address.", "parameter_desc": "MWG.URL: The URL whose host is to be checked for being an IP address.", "description": "Returns TRUE if the host of the given URL is an IP address", "example_code": "MWG.URL currentUrl = MWG.Url()\nBOOLEAN isIP = MWG.HostIsIP(currentUrl)\n\nIF isIP THEN {\n    // The host is an IP address.\n    MWG.Block(\"Access to IP addresses is not allowed.\")\n} ELSE {\n    // The host is not an IP address.\n    MWG.Allow(\"Host is not an IP address.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nBOOLEAN isIP = MWG.HostIsIP(currentUrl)\n\nIF isIP THEN {\n    // The host is an IP address.\n    MWG.Block(\"Access to IP addresses is not allowed.\")\n} ELSE {\n    // The host is not an IP address.\n    MWG.Allow(\"Host is not an IP address.\")\n}"}, {"name": "MWG.HostIsSubdomainOfAny (MWG.URL, VECTOR<STRING>)", "return_type": "BOOLEAN", "return_desc": "Returns whether the host of the given URL is a subdomain of any of the provided domains.", "parameter_desc": "MWG.URL: the URL with the host to look for; VECTOR: a list of domains to check against.", "description": "Returns whether the host of the given URL is a subdomain of any of the provided domains", "example_code": "MWG.URL currentUrl = MWG.Url()\nVECTOR<STRING> allowedDomains = \"example.com\", \"test.com\", \"sample.org\"\n\nIF MWG.HostIsSubdomainOfAny(currentUrl, allowedDomains) THEN {\n    // The host is a subdomain of one of the allowed domains.\n    MWG.Allow(\"Subdomain check passed\")\n} ELSE {\n    // The host is not a subdomain of any allowed domains.\n    MWG.Block(\"Access denied: Host is not a subdomain of allowed domains\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nVECTOR<STRING> allowedDomains = \"example.com\", \"test.com\", \"sample.org\"\n\nIF MWG.HostIsSubdomainOfAny(currentUrl, allowedDomains) THEN {\n    // The host is a subdomain of one of the allowed domains.\n    MWG.Allow(\"Subdomain check passed\")\n} ELSE {\n    // The host is not a subdomain of any allowed domains.\n    MWG.Block(\"Access denied: Host is not a subdomain of allowed domains\")\n}"}, {"name": "MWG.HostName ()", "return_type": "STRING", "return_desc": "Returns the hostname of the proxy.", "parameter_desc": "None", "description": "Return the hostname of the proxy", "example_code": "// Call the MWG.HostName() function to get the hostname of the proxy\nSTRING proxyHostName = MWG.HostName()\n\n// The hostname of the proxy is: \" + proxyHostName", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Call the MWG.HostName() function to get the hostname of the proxy\nSTRING proxyHostName = MWG.HostName()\n\n// The hostname of the proxy is: \" + proxyHostName"}, {"name": "MWG.HTMLElementName ()", "return_type": "STRING", "return_desc": "Returns the element name in HTML opener.", "parameter_desc": "None", "description": "Returns the element name in HTML opener", "example_code": "// Get the name of the HTML element\nSTRING elementName = MWG.HTMLElementName()\n\n// Check if the element name is \"script\"\nIF elementName == \"script\" THEN {\n    // Block the response if the element is a script\n    MWG.Block(\"Blocking script elements for security reasons\")\n} ELSE {\n    // Allow the response if the element is not a script\n    MWG.Allow(\"Element is not a script\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the name of the HTML element\nSTRING elementName = MWG.HTMLElementName()\n\n// Check if the element name is \"script\"\nIF elementName == \"script\" THEN {\n    // Block the response if the element is a script\n    MWG.Block(\"Blocking script elements for security reasons\")\n} ELSE {\n    // Allow the response if the element is not a script\n    MWG.Allow(\"Element is not a script\")\n}"}, {"name": "MWG.HTTPTunnelEnabled ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if HTTP Tunnel is enabled.", "parameter_desc": "None", "description": "Returns TRUE if HTTP Tunnel is enabled", "example_code": "IF MWG.HTTPTunnelEnabled() THEN {\n    // HTTP Tunnel is enabled\n    // Additional actions can be taken here if HTTP Tunnel is enabled\n} ELSE {\n    // HTTP Tunnel is not enabled\n    // Additional actions can be taken here if HTTP Tunnel is not enabled\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.HTTPTunnelEnabled() THEN {\n    // HTTP Tunnel is enabled\n    // Additional actions can be taken here if HTTP Tunnel is enabled\n} ELSE {\n    // HTTP Tunnel is not enabled\n    // Additional actions can be taken here if HTTP Tunnel is not enabled\n}"}, {"name": "MWG.IAMAuthErrorMessage ()", "return_type": "STRING", "return_desc": "Returns the IAM Auth Error message.", "parameter_desc": "None", "description": "Get the IAM Auth Error message.", "example_code": "STRING errorMessage = MWG.IAMAuthErrorMessage()\n\nIF errorMessage != \"\" THEN {\n    // IAM Authentication Error: \" + errorMessage\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING errorMessage = MWG.IAMAuthErrorMessage()\n\nIF errorMessage != \"\" THEN {\n    // IAM Authentication Error: \" + errorMessage\n}"}, {"name": "MWG.IAMAuthorized (STRING)", "return_type": "STRING", "return_desc": "Returns a string containing authorized scopes.", "parameter_desc": "STRING: the expected audience", "description": "Get authorized scopes.", "example_code": "STRING user = \"exampleUser\"\nSTRING resource = \"exampleResource\"\n\n// Check if the user is authorized to access the resource\nSTRING authorizationStatus = MWG.IAMAuthorized(user + \":\" + resource)\n\nIF authorizationStatus == \"AUTHORIZED\" THEN {\n    MWG.Allow(\"User is authorized\")\n} ELSE {\n    MWG.Block(\"User is not authorized\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING user = \"exampleUser\"\nSTRING resource = \"exampleResource\"\n\n// Check if the user is authorized to access the resource\nSTRING authorizationStatus = MWG.IAMAuthorized(user + \":\" + resource)\n\nIF authorizationStatus == \"AUTHORIZED\" THEN {\n    MWG.Allow(\"User is authorized\")\n} ELSE {\n    MWG.Block(\"User is not authorized\")\n}"}, {"name": "MWG.ICAPClientReqModHeaders (MWG.ICAPClientSetting)", "return_type": "MWG.HeaderMap", "return_desc": "Returns the ICAP request headers as a `MWG.HeaderMap`.", "parameter_desc": "MWG.ICAPClientSetting: the ICAP client configurations for retrieving the request headers.", "description": "Get ICAP request headers", "example_code": "MWG.ICAPClientSetting icapSetting = ... // Initialize your ICAP client setting here\n\n// Add a custom header to the ICAP request\nMWG.ICAPClientAddRequestHeader(icapSetting, \"X-Custom-Header\", \"CustomValue\")\n\n// Optionally, you can add more headers as needed\nMWG.ICAPClientAddRequestHeader(icapSetting, \"X-Another-Header\", \"AnotherValue\")\n\n// Continue with other logic or allow the request\nMWG.Allow(\"ICAP headers added\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ICAPClientSetting icapSetting = ... // Initialize your ICAP client setting here\n\n// Add a custom header to the ICAP request\nMWG.ICAPClientAddRequestHeader(icapSetting, \"X-Custom-Header\", \"CustomValue\")\n\n// Optionally, you can add more headers as needed\nMWG.ICAPClientAddRequestHeader(icapSetting, \"X-Another-Header\", \"AnotherValue\")\n\n// Continue with other logic or allow the request\nMWG.Allow(\"ICAP headers added\")"}, {"name": "MWG.ICAPClientReqModSatisfaction (MWG.ICAPClientSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the ICAP server responds to a ReqMod request with a response header.", "parameter_desc": "MWG.ICAPClientSetting: the configuration settings for the ICAP server.", "description": "Returns TRUE if the ICAP server responds to a ReqMod request with a response header", "example_code": "// Create an ICAP client setting object\nMWG.ICAPClientSetting icapSetting = MWG.ICAPClientSetting()\n\n// Assuming MWG.ICAPClientReqModSatisfaction is a function that takes an ICAP client setting\nMWG.ICAPClientReqModSatisfaction(icapSetting)\n\n// Called MWG.ICAPClientReqModSatisfaction with the ICAP client setting", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an ICAP client setting object\nMWG.ICAPClientSetting icapSetting = MWG.ICAPClientSetting()\n\n// Assuming MWG.ICAPClientReqModSatisfaction is a function that takes an ICAP client setting\nMWG.ICAPClientReqModSatisfaction(icapSetting)\n\n// Called MWG.ICAPClientReqModSatisfaction with the ICAP client setting"}, {"name": "MWG.ICAPClientRespModEncapsulatedHTTPChanged (MWG.ICAPClientSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the ICAP server changes the HTTP state of the response.", "parameter_desc": "MWG.ICAPClientSetting: the configuration settings for the ICAP server.", "description": "Returns TRUE if the ICAP server changes the HTTP state of the response", "example_code": "MWG.ICAPClientSetting icapSettings = ... // Initialize with appropriate settings\n\nIF MWG.ICAPClientRespModEncapsulatedHTTPChanged(icapSettings) THEN {\n    // ICAP server changed the HTTP state of the response.\n    // Additional logic if the HTTP state was changed\n} ELSE {\n    // ICAP server did not change the HTTP state of the response.\n    // Additional logic if the HTTP state was not changed\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ICAPClientSetting icapSettings = ... // Initialize with appropriate settings\n\nIF MWG.ICAPClientRespModEncapsulatedHTTPChanged(icapSettings) THEN {\n    // ICAP server changed the HTTP state of the response.\n    // Additional logic if the HTTP state was changed\n} ELSE {\n    // ICAP server did not change the HTTP state of the response.\n    // Additional logic if the HTTP state was not changed\n}"}, {"name": "MWG.ICAPClientRespModHeaders (MWG.ICAPClientSetting)", "return_type": "MWG.HeaderMap", "return_desc": "Returns a map of response headers from an ICAP client.", "parameter_desc": "MWG.ICAPClientSetting: Configuration settings for the ICAP client.", "description": "Get ICAP response headers", "example_code": "MWG.ICAPClientSetting icapSetting = ... // Initialize your ICAP client setting here\nSTRING headerName = \"X-Custom-Header\"\nSTRING headerValue = \"CustomValue\"\n\nMWG.ICAPClientAddRequestHeader(icapSetting, headerName, headerValue)\n// Added ICAP request header: \" + headerName + \" with value: \" + headerValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ICAPClientSetting icapSetting = ... // Initialize your ICAP client setting here\nSTRING headerName = \"X-Custom-Header\"\nSTRING headerValue = \"CustomValue\"\n\nMWG.ICAPClientAddRequestHeader(icapSetting, headerName, headerValue)\n// Added ICAP request header: \" + headerName + \" with value: \" + headerValue"}, {"name": "MWG.InCustomerControlledPolicy ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current policy is customer controlled.", "parameter_desc": "None", "description": "Returns TRUE if the current policy is customer controlled", "example_code": "IF MWG.InCustomerControlledPolicy() THEN {\n    // \"Request is within customer-controlled policy.\"\n    // Additional logic for requests within customer-controlled policy\n} ELSE {\n    // \"Request is not within customer-controlled policy.\"\n    // Additional logic for requests outside customer-controlled policy\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.InCustomerControlledPolicy() THEN {\n    // \"Request is within customer-controlled policy.\"\n    // Additional logic for requests within customer-controlled policy\n} ELSE {\n    // \"Request is not within customer-controlled policy.\"\n    // Additional logic for requests outside customer-controlled policy\n}"}, {"name": "MWG.InternalOriginalURL ()", "return_type": "STRING", "return_desc": "Returns the original URL used in redirects as a string.", "parameter_desc": "None", "description": "Original URL, used in redirects", "example_code": "STRING originalUrl = \"http://internal.example.com/resource\"\nMWG.SetOriginalInternalUrl(originalUrl)\n// Original internal URL set to: \" + originalUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalUrl = \"http://internal.example.com/resource\"\nMWG.SetOriginalInternalUrl(originalUrl)\n// Original internal URL set to: \" + originalUrl"}, {"name": "MWG.InTheCloud ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the code is executing in a cloud environment. Otherwise, it returns`FALSE`", "parameter_desc": "None", "description": "Returns TRUE if running in the cloud", "example_code": "IF MWG.InTheCloud() THEN {\n    // \"Running in the cloud environment.\"\n} ELSE {\n    // \"Running in an on-premises environment.\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.InTheCloud() THEN {\n    // \"Running in the cloud environment.\"\n} ELSE {\n    // \"Running in an on-premises environment.\"\n}"}, {"name": "MWG.IPAuthGetTenant (MWG.IPRangeAuthentication, Net.IP)", "return_type": "STRING", "return_desc": "Returns the name of the tenant.", "parameter_desc": "MWG.IPRangeAuthentication:customer?\u00c7\u00d6s ip range; Net.IP: ip address to check.", "description": "Get tenant based on IP address", "example_code": "MWG.IPRangeAuthentication ipRangeAuth = ... // Initialize or obtain the IP range authentication object\nNet.IP clientIP = ... // Initialize or obtain the client's IP address\n\nSTRING tenantName = MWG.IPAuthGetTenant(ipRangeAuth, clientIP)\n\nIF tenantName != \"\" THEN {\n    // \"Tenant Name: \" + tenantName\n} ELSE {\n    // \"No tenant found for the given IP address.\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.IPRangeAuthentication ipRangeAuth = ... // Initialize or obtain the IP range authentication object\nNet.IP clientIP = ... // Initialize or obtain the client's IP address\n\nSTRING tenantName = MWG.IPAuthGetTenant(ipRangeAuth, clientIP)\n\nIF tenantName != \"\" THEN {\n    // \"Tenant Name: \" + tenantName\n} ELSE {\n    // \"No tenant found for the given IP address.\"\n}"}, {"name": "MWG.IPListByID (STRING)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns a vector corresponding to the provided list ID.", "parameter_desc": "STRING: the identifier of the list to be retrieved.", "description": "Retrieves a VECTOR by list ID", "example_code": "STRING ipListID = \"example_ip_list_id\"\nVECTOR<Net.IP> ipList = MWG.IPListByID(ipListID)\n\nNet.IP clientIP = MWG.ClientIP()\n\nIF clientIP IN ipList THEN {\n    // Access denied: Your IP is in the restricted list.\n    MWG.Block(\"Access denied: Your IP is in the restricted list.\")\n} ELSE {\n    // IP not in restricted list\n    MWG.Allow(\"IP not in restricted list\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING ipListID = \"example_ip_list_id\"\nVECTOR<Net.IP> ipList = MWG.IPListByID(ipListID)\n\nNet.IP clientIP = MWG.ClientIP()\n\nIF clientIP IN ipList THEN {\n    // Access denied: Your IP is in the restricted list.\n    MWG.Block(\"Access denied: Your IP is in the restricted list.\")\n} ELSE {\n    // IP not in restricted list\n    MWG.Allow(\"IP not in restricted list\")\n}"}, {"name": "MWG.IPListByName (STRING)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns a vector corresponding to the specified list name.", "parameter_desc": "STRING: the name of the list to retrieve.", "description": "Retrieves a VECTOR by list name", "example_code": "VECTOR<Net.IPRange> ipRanges = MWG.IPRangeListByName(\"trusted_ip_ranges\")\n\nNet.IP clientIP = MWG.Client.IP()\n\nBOOLEAN isTrusted = FALSE\n\nFOR EACH Net.IPRange range IN ipRanges {\n    IF range.Contains(clientIP) THEN {\n        isTrusted = TRUE\n        BREAK\n    }\n}\n\nIF isTrusted THEN {\n    // Client IP is in trusted range\n    MWG.Allow(\"Client IP is in trusted range\")\n} ELSE {\n    // Client IP is not in trusted range\n    MWG.Block(\"Client IP is not in trusted range\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> ipRanges = MWG.IPRangeListByName(\"trusted_ip_ranges\")\n\nNet.IP clientIP = MWG.Client.IP()\n\nBOOLEAN isTrusted = FALSE\n\nFOR EACH Net.IPRange range IN ipRanges {\n    IF range.Contains(clientIP) THEN {\n        isTrusted = TRUE\n        BREAK\n    }\n}\n\nIF isTrusted THEN {\n    // Client IP is in trusted range\n    MWG.Allow(\"Client IP is in trusted range\")\n} ELSE {\n    // Client IP is not in trusted range\n    MWG.Block(\"Client IP is not in trusted range\")\n}"}, {"name": "MWG.IPListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a VECTOR<`Net.IP`> list with the name exists.", "parameter_desc": "STRING: name of list to check for.", "description": "Returns TRUE if VECTOR<Net.IP> list with the name exists", "example_code": "STRING listName = \"example_ip_list\"\n\nIF MWG.IPListByNameExists(listName) THEN {\n    // The IP list exists.\n} ELSE {\n    // The IP list does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING listName = \"example_ip_list\"\n\nIF MWG.IPListByNameExists(listName) THEN {\n    // The IP list exists.\n} ELSE {\n    // The IP list does not exist.\n}"}, {"name": "MWG.IPRangeListByID (STRING)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns a vector of IP ranges associated with the specified ID.", "parameter_desc": "STRING: the unique identifier used to retrieve the VECTOR.", "description": "Retrieves a VECTOR by ID", "example_code": "// Define the ID of the IP range list you want to retrieve\nSTRING ipRangeListID = \"example_ip_range_list_id\"\n\n// Retrieve the IP range list using the ID\nNet.IPRange ipRangeList = MWG.IPRangeListByID(ipRangeListID)\n\n// Set a user-defined variable with the retrieved IP range list\nMWG.SetUserDefinedVar(\"UserIPRange\", ipRangeList)\n\n// Debug output to verify the IP range list\n// Retrieved IP Range List: \" + ipRangeList\n\n// Example condition to block a request if the client's IP is within the retrieved IP range\nIF MWG.Client.IP IN ipRangeList THEN {\n    MWG.Block(\"Access denied: Your IP is within a restricted range.\")\n} ELSE {\n    MWG.Allow(\"IP is not in the restricted range.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the ID of the IP range list you want to retrieve\nSTRING ipRangeListID = \"example_ip_range_list_id\"\n\n// Retrieve the IP range list using the ID\nNet.IPRange ipRangeList = MWG.IPRangeListByID(ipRangeListID)\n\n// Set a user-defined variable with the retrieved IP range list\nMWG.SetUserDefinedVar(\"UserIPRange\", ipRangeList)\n\n// Debug output to verify the IP range list\n// Retrieved IP Range List: \" + ipRangeList\n\n// Example condition to block a request if the client's IP is within the retrieved IP range\nIF MWG.Client.IP IN ipRangeList THEN {\n    MWG.Block(\"Access denied: Your IP is within a restricted range.\")\n} ELSE {\n    MWG.Allow(\"IP is not in the restricted range.\")\n}"}, {"name": "MWG.IPRangeListByName (STRING)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns a vector of IP ranges associated with the specified name.", "parameter_desc": "STRING: the name of the list to retrieve.", "description": "Retrieves a VECTOR by list name", "example_code": "// Retrieve the IP ranges associated with the list name \"example_ip_list\"\nVECTOR<Net.IPRange> ipRanges = MWG.IPRangeListByName(\"example_ip_list\")\n\n// Iterate through the IP ranges and print each one\nFOR EACH ipRange IN ipRanges {\n    // ipRange\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the IP ranges associated with the list name \"example_ip_list\"\nVECTOR<Net.IPRange> ipRanges = MWG.IPRangeListByName(\"example_ip_list\")\n\n// Iterate through the IP ranges and print each one\nFOR EACH ipRange IN ipRanges {\n    // ipRange\n}"}, {"name": "MWG.IPRangeListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns true if a Vector<Net.IPRange> list with the name exists.", "parameter_desc": "STRING: name of list to check for.", "description": "Returns TRUE if VECTOR<Net.IPRange> list with the name exists", "example_code": "STRING listName = \"example_ip_range_list\"\n\nIF MWG.IPRangeListByNameExists(listName) THEN {\n    // The IP range list 'example_ip_range_list' exists.\n} ELSE {\n    // The IP range list 'example_ip_range_list' does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING listName = \"example_ip_range_list\"\n\nIF MWG.IPRangeListByNameExists(listName) THEN {\n    // The IP range list 'example_ip_range_list' exists.\n} ELSE {\n    // The IP range list 'example_ip_range_list' does not exist.\n}"}, {"name": "MWG.IsAuthenticated ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the user is authenticated.", "parameter_desc": "None", "description": "Returns TRUE if user is authenticated", "example_code": "BOOLEAN isAuthenticated = MWG.IsAuthenticated()\n\nIF isAuthenticated THEN {\n    // User is authenticated\n    MWG.Allow()\n} ELSE {\n    // User is not authenticated\n    MWG.Block()\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "BOOLEAN isAuthenticated = MWG.IsAuthenticated()\n\nIF isAuthenticated THEN {\n    // User is authenticated\n    MWG.Allow()\n} ELSE {\n    // User is not authenticated\n    MWG.Block()\n}"}, {"name": "MWG.IsGRE ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`when the connection originates from a GRE tunnel.", "parameter_desc": "None", "description": "Returns TRUE when connection originates from GRE tunnel", "example_code": "IF MWG.IsGRE() THEN {\n    // \"GRE packet detected\"\n    MWG.Block(\"GRE packets are not allowed\")\n} ELSE {\n    // \"Non-GRE packet detected\"\n    MWG.Allow(\"Non-GRE traffic\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.IsGRE() THEN {\n    // \"GRE packet detected\"\n    MWG.Block(\"GRE packets are not allowed\")\n} ELSE {\n    // \"Non-GRE packet detected\"\n    MWG.Allow(\"Non-GRE traffic\")\n}"}, {"name": "MWG.IsIPSec ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`when the connection originates from an IPSec tunnel.", "parameter_desc": "None", "description": "Returns TRUE when connection originates from IPSec tunnel", "example_code": "IF MWG.IsIPSec() THEN {\n    // The connection is using IPSec.\n} ELSE {\n    // The connection is not using IPSec.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.IsIPSec() THEN {\n    // The connection is using IPSec.\n} ELSE {\n    // The connection is not using IPSec.\n}"}, {"name": "MWG.IsServerCertSelfSigned ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the server certificate is self-signed.", "parameter_desc": "None", "description": "Returns TRUE if the server certificate is self signed", "example_code": "BOOLEAN isSelfSigned = MWG.IsServerCertSelfSigned()\n\nIF isSelfSigned THEN {\n    // The server certificate is self-signed.\n    MWG.Block(\"Self-signed certificates are not allowed.\")\n} ELSE {\n    // The server certificate is not self-signed.\n    MWG.Allow(\"Certificate is valid.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "BOOLEAN isSelfSigned = MWG.IsServerCertSelfSigned()\n\nIF isSelfSigned THEN {\n    // The server certificate is self-signed.\n    MWG.Block(\"Self-signed certificates are not allowed.\")\n} ELSE {\n    // The server certificate is not self-signed.\n    MWG.Allow(\"Certificate is valid.\")\n}"}, {"name": "MWG.IsSSLClientContextApplied ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if TLS client context is applied.", "parameter_desc": "None", "description": "Returns TRUE if TLS client context is applied", "example_code": "IF MWG.IsSSLClientContextApplied() THEN {\n    // \"SSL Client Context is applied.\"\n} ELSE {\n    // \"SSL Client Context is not applied.\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.IsSSLClientContextApplied() THEN {\n    // \"SSL Client Context is applied.\"\n} ELSE {\n    // \"SSL Client Context is not applied.\"\n}"}, {"name": "MWG.IsStream ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the body is an audio or video stream.", "parameter_desc": "None", "description": "Returns TRUE if the body is an audio or video stream", "example_code": "IF MWG.IsStream() THEN {\n    // This is a stream.\n} ELSE {\n    // This is not a stream.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.IsStream() THEN {\n    // This is a stream.\n} ELSE {\n    // This is not a stream.\n}"}, {"name": "MWG.IsTransparentTLS ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a TLS connection is transparent.", "parameter_desc": "None", "description": "Returns TRUE if a TLS connection is transparent", "example_code": "IF MWG.IsTransparentTLS() THEN {\n    // The TLS connection is transparent.\n    // Additional actions can be taken here if the connection is transparent\n} ELSE {\n    // The TLS connection is not transparent.\n    // Additional actions can be taken here if the connection is not transparent\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.IsTransparentTLS() THEN {\n    // The TLS connection is transparent.\n    // Additional actions can be taken here if the connection is transparent\n} ELSE {\n    // The TLS connection is not transparent.\n    // Additional actions can be taken here if the connection is not transparent\n}"}, {"name": "MWG.IsUpload ()", "return_type": "BOOLEAN", "return_desc": "Returns if the filtered object is an upload.", "parameter_desc": "None", "description": "Returns if the filtered object is an upload", "example_code": "IF MWG.IsUpload() THEN {\n    // This is an upload request.\n    // Additional logic for handling upload requests\n} ELSE {\n    // This is not an upload request.\n    // Additional logic for handling non-upload requests\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.IsUpload() THEN {\n    // This is an upload request.\n    // Additional logic for handling upload requests\n} ELSE {\n    // This is not an upload request.\n    // Additional logic for handling non-upload requests\n}"}, {"name": "MWG.KerberosProtectionLevel ()", "return_type": "NUMBER", "return_desc": "Returns Kerberos protection level for the connection.", "parameter_desc": "None", "description": "Returns Kerberos protection level for the connection", "example_code": "// Retrieve the Kerberos protection level\nSTRING protectionLevel = MWG.KerberosProtectionLevel()\n\n// Kerberos Protection Level: \" + protectionLevel\n\n// Perform actions based on the protection level\nIF protectionLevel == \"HIGH\" THEN {\n    // High level of Kerberos protection detected.\n    // Additional logic for high protection level\n} ELSE IF protectionLevel == \"MEDIUM\" THEN {\n    // Medium level of Kerberos protection detected.\n    // Additional logic for medium protection level\n} ELSE IF protectionLevel == \"LOW\" THEN {\n    // Low level of Kerberos protection detected.\n    // Additional logic for low protection level\n} ELSE {\n    // Unknown Kerberos protection level detected.\n    // Additional logic for unknown protection level\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the Kerberos protection level\nSTRING protectionLevel = MWG.KerberosProtectionLevel()\n\n// Kerberos Protection Level: \" + protectionLevel\n\n// Perform actions based on the protection level\nIF protectionLevel == \"HIGH\" THEN {\n    // High level of Kerberos protection detected.\n    // Additional logic for high protection level\n} ELSE IF protectionLevel == \"MEDIUM\" THEN {\n    // Medium level of Kerberos protection detected.\n    // Additional logic for medium protection level\n} ELSE IF protectionLevel == \"LOW\" THEN {\n    // Low level of Kerberos protection detected.\n    // Additional logic for low protection level\n} ELSE {\n    // Unknown Kerberos protection level detected.\n    // Additional logic for unknown protection level\n}"}, {"name": "MWG.Keys (MWG.HeaderMap)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing all the keys from the given header map.", "parameter_desc": "MWG.HeaderMap: The map from which to extract the keys.", "description": "Returns the keys of a header map", "example_code": "// Assume headers is an MWG.HeaderMap object containing HTTP headers\nMWG.HeaderMap headers = MWG.GetRequestHeaders()\n\n// Retrieve the keys from the headers\nVECTOR<STRING> headerKeys = MWG.Keys(headers)\n\n// Iterate over the keys and print them\nFOR EACH key IN headerKeys {\n    // Header Key: \" + key\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume headers is an MWG.HeaderMap object containing HTTP headers\nMWG.HeaderMap headers = MWG.GetRequestHeaders()\n\n// Retrieve the keys from the headers\nVECTOR<STRING> headerKeys = MWG.Keys(headers)\n\n// Iterate over the keys and print them\nFOR EACH key IN headerKeys {\n    // Header Key: \" + key\n}"}, {"name": "MWG.LAST_USED_config ()", "return_type": "MWG.InternalSetting", "return_desc": "Returns the last used configuration settings.", "parameter_desc": "None", "description": "Get the last used configuration settings.", "example_code": "// Retrieve the last used configuration settings\nMWG.InternalSetting lastConfig = MWG.LAST_USED_config()\n\n// Last used configuration settings: \" + lastConfig\n\n// Execute an event with the retrieved configuration settings and a string parameter\nMWG.ExecuteEvent(lastConfig, \"ExampleEvent\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the last used configuration settings\nMWG.InternalSetting lastConfig = MWG.LAST_USED_config()\n\n// Last used configuration settings: \" + lastConfig\n\n// Execute an event with the retrieved configuration settings and a string parameter\nMWG.ExecuteEvent(lastConfig, \"ExampleEvent\")"}, {"name": "MWG.LastRule ()", "return_type": "STRING", "return_desc": "Returns the 'rule' that terminates the policy processing (`MWG.Exit,`MWG.Allow,`MWG.Block,`MWG.Redirect`)`", "parameter_desc": "None", "description": "Returns the 'rule' that terminates the policy processing (MWG.Exit, MWG.Allow, MWG.Block, MWG.Redirect)", "example_code": "STRING lastRule = MWG.LastRule()\n// The last rule that terminated the policy processing is: + lastRule", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING lastRule = MWG.LastRule()\n// The last rule that terminated the policy processing is: + lastRule"}, {"name": "MWG.LastRuleSetPath ()", "return_type": "STRING", "return_desc": "Returns the Rule Set that terminates the policy processing (`MWG.Exit,`MWG.Allow,`MWG.Block,`MWG.Redirect`)`", "parameter_desc": "None", "description": "Returns the Rule Set that terminates the policy processing (MWG.Exit, MWG.Allow, MWG.Block, MWG.Redirect)", "example_code": "STRING lastRuleSetPath = MWG.LastRuleSetPath()\n// The last rule set path that terminated the policy processing is: \" + lastRuleSetPath", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING lastRuleSetPath = MWG.LastRuleSetPath()\n// The last rule set path that terminated the policy processing is: \" + lastRuleSetPath"}, {"name": "MWG.LastSentFirstReceivedServer ()", "return_type": "NUMBER", "return_desc": "Returns the duration between the last byte sent to server and when the first byte was actually received, if any.", "parameter_desc": "None", "description": "Returns the duration between the last byte sent to server and when the first byte was actually received if any.", "example_code": "// Call the MWG.LastSentFirstReceivedServer() function and store the result in a variable\nSTRING lastServer = MWG.LastSentFirstReceivedServer()\n\n// Last sent first received server: \" + lastServer\n\n// Example condition to block a request based on the server address\nIF lastServer == \"malicious.server.com\" THEN {\n    MWG.Block(\"Access to this server is blocked due to security concerns.\")\n} ELSE {\n    MWG.Allow(\"Server is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Call the MWG.LastSentFirstReceivedServer() function and store the result in a variable\nSTRING lastServer = MWG.LastSentFirstReceivedServer()\n\n// Last sent first received server: \" + lastServer\n\n// Example condition to block a request based on the server address\nIF lastServer == \"malicious.server.com\" THEN {\n    MWG.Block(\"Access to this server is blocked due to security concerns.\")\n} ELSE {\n    MWG.Allow(\"Server is allowed.\")\n}"}, {"name": "MWG.LastSentLastReceivedClient ()", "return_type": "NUMBER", "return_desc": "Returns the duration between the last byte received from the client and when that last byte was sent back.", "parameter_desc": "None", "description": "Returns the duration between the last byte received from client and when that last byte was sent back", "example_code": "NUMBER duration = MWG.LastSentLastReceivedClient()\nNUMBER threshold = 1000  // Example threshold in milliseconds\n\nIF duration > threshold THEN {\n    // Warning: Response time exceeded threshold. Duration: \" + duration + \" ms\n} ELSE {\n    // Response time is within acceptable limits. Duration: \" + duration + \" ms\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER duration = MWG.LastSentLastReceivedClient()\nNUMBER threshold = 1000  // Example threshold in milliseconds\n\nIF duration > threshold THEN {\n    // Warning: Response time exceeded threshold. Duration: \" + duration + \" ms\n} ELSE {\n    // Response time is within acceptable limits. Duration: \" + duration + \" ms\n}"}, {"name": "MWG.LastSentLastReceivedServer ()", "return_type": "NUMBER", "return_desc": "Returns the duration between the last byte sent to the server and when that last byte was actually received.", "parameter_desc": "None", "description": "Returns the duration between the last byte sent to server and when that last byte was actually received", "example_code": "// Hypothetical function to get the last sent and last received server information\nSTRING lastServerInfo = MWG.LastSentLastReceivedServer()\n\n// Check if the last server information contains a specific server name\nIF lastServerInfo CONTAINS \"example.com\" THEN {\n    // Block the connection if the server is \"example.com\"\n    MWG.Block(\"Connection to example.com is not allowed.\")\n} ELSE {\n    // Allow the connection otherwise\n    MWG.Allow(\"Connection allowed.\")\n}\n\n// Debug output for logging purposes\n// \"Last sent/received server info: \" + lastServerInfo", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Hypothetical function to get the last sent and last received server information\nSTRING lastServerInfo = MWG.LastSentLastReceivedServer()\n\n// Check if the last server information contains a specific server name\nIF lastServerInfo CONTAINS \"example.com\" THEN {\n    // Block the connection if the server is \"example.com\"\n    MWG.Block(\"Connection to example.com is not allowed.\")\n} ELSE {\n    // Allow the connection otherwise\n    MWG.Allow(\"Connection allowed.\")\n}\n\n// Debug output for logging purposes\n// \"Last sent/received server info: \" + lastServerInfo"}, {"name": "MWG.LFSTRING ()", "return_type": "STRING", "return_desc": "Returns line-feed string.", "parameter_desc": "None", "description": "Returns line-feed STRING", "example_code": "STRING message = \"This is the first line.\" + MWG.LFString() + \"This is the second line.\"\n// This line was originally a DEBUG() function that printed the message to the console. The message is a concatenation of two strings with a line-feed string (returned by MWG.LFString()) in between. When this line runs, it would output: \"This is the first line. This is the second line.\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING message = \"This is the first line.\" + MWG.LFString() + \"This is the second line.\"\n// This line was originally a DEBUG() function that printed the message to the console. The message is a concatenation of two strings with a line-feed string (returned by MWG.LFString()) in between. When this line runs, it would output: \"This is the first line. This is the second line.\""}, {"name": "MWG.ListLastMatches ()", "return_type": "STRING", "return_desc": "Returns the element found in the most recent list search operation.", "parameter_desc": "None", "description": "element of last list find operation", "example_code": "// Assume some list search operation has been performed before this routine is triggered\n\n// Retrieve the last match from the list search operation\nSTRING lastMatch = MWG.ListLastMatches()\n\n// Check if a match was found\nIF lastMatch != NULL THEN {\n    // Last match found: \" + lastMatch\n} ELSE {\n    // No matches found.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume some list search operation has been performed before this routine is triggered\n\n// Retrieve the last match from the list search operation\nSTRING lastMatch = MWG.ListLastMatches()\n\n// Check if a match was found\nIF lastMatch != NULL THEN {\n    // Last match found: \" + lastMatch\n} ELSE {\n    // No matches found.\n}"}, {"name": "MWG.MalwareProbability (MWG.AntimalwareSetting)", "return_type": "NUMBER", "return_desc": "Returns the numerical probability that a file is malware based on GAM analysis of the provided antimalware settings.", "parameter_desc": "MWG.AntimalwareSetting: the antimalware configuration settings.", "description": "Returns the malware probability (via GAM)", "example_code": "// Create an instance of MWG.AntimalwareSetting\nMWG.AntimalwareSetting antimalwareSetting\n\n// Enable the anti-malware stream scanner with the given settings\nMWG.AntimalwareEnableStreamScanner(antimalwareSetting)\n\n// Antimalware stream scanner enabled.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of MWG.AntimalwareSetting\nMWG.AntimalwareSetting antimalwareSetting\n\n// Enable the anti-malware stream scanner with the given settings\nMWG.AntimalwareEnableStreamScanner(antimalwareSetting)\n\n// Antimalware stream scanner enabled."}, {"name": "MWG.MalwareProbability (MWG.InternalSetting)", "return_type": "NUMBER", "return_desc": "Returns a numerical representation of the likelihood of malware.", "parameter_desc": "MWG.InternalSetting (Object): Internal setting parameters required for calculating malware probability.", "description": "Returns the malware probability", "example_code": "MWG.InternalSetting malwareProbabilitySetting = MWG.GetInternalSetting(\"MalwareProbability\")\n\nIF malwareProbabilitySetting > 0.8 THEN {\n    // High probability of malware detected\n    MWG.Block(\"High probability of malware detected\")\n} ELSE {\n    // Malware check passed\n    MWG.Allow(\"Malware check passed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting malwareProbabilitySetting = MWG.GetInternalSetting(\"MalwareProbability\")\n\nIF malwareProbabilitySetting > 0.8 THEN {\n    // High probability of malware detected\n    MWG.Block(\"High probability of malware detected\")\n} ELSE {\n    // Malware check passed\n    MWG.Allow(\"Malware check passed\")\n}"}, {"name": "MWG.MalwareProbability (MWG.MATDSetting)", "return_type": "NUMBER", "return_desc": "Returns the likelihood of malware presence, as determined by ATD.", "parameter_desc": "MWG.MATDSetting: configures the Adaptive Threat Detection settings for calculating malware probability.", "description": "Returns the malware probability (via ATD)", "example_code": "// Create an instance of MWG.MATDSetting\nMWG.MATDSetting matdSetting = MWG.MATDSetting()\n\n// Configure the MATD setting as needed\n// This is a placeholder for actual configuration\n// For example, you might set some properties on the matdSetting object\n// matdSetting.SetProperty(\"exampleProperty\", \"exampleValue\")\n\n// Call the MWG.MalwareProbability function with the configured MATD setting\nNUMBER probability = MWG.MalwareProbability(matdSetting)\n\n// Malware Probability: \" + probability\n\n// Check the probability and take action\nIF probability > 0.5 THEN {\n    MWG.Block(\"High malware probability detected\")\n} ELSE {\n    MWG.Allow(\"Low malware probability\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of MWG.MATDSetting\nMWG.MATDSetting matdSetting = MWG.MATDSetting()\n\n// Configure the MATD setting as needed\n// This is a placeholder for actual configuration\n// For example, you might set some properties on the matdSetting object\n// matdSetting.SetProperty(\"exampleProperty\", \"exampleValue\")\n\n// Call the MWG.MalwareProbability function with the configured MATD setting\nNUMBER probability = MWG.MalwareProbability(matdSetting)\n\n// Malware Probability: \" + probability\n\n// Check the probability and take action\nIF probability > 0.5 THEN {\n    MWG.Block(\"High malware probability detected\")\n} ELSE {\n    MWG.Allow(\"Low malware probability\")\n}"}, {"name": "MWG.MapInList (VECTOR<STRING>, VECTOR<STRING>, STRING)", "return_type": "STRING", "return_desc": "Returns the string from the second vector corresponding to the index of the string found in the first vector.", "parameter_desc": "VECTOR<STRING>: List to search; VECTOR<STRING>: list to return from; STRING: value to search for.", "description": "Checks for input STRING in first STRING list, if found returns the STRING from the same index in second STRING list", "example_code": "VECTOR<STRING> urls = \"example.com\", \"testsite.com\", \"mywebsite.org\"\nVECTOR<STRING> categories = \"News\", \"Blog\", \"Personal\"\n\nSTRING currentUrl = MWG.Url().ToString()\nSTRING category = MWG.MapInList(urls, categories, currentUrl)\n\nIF category != \"\" THEN {\n    // The category for currentUrl is category\n} ELSE {\n    // The URL currentUrl is not in the list.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> urls = \"example.com\", \"testsite.com\", \"mywebsite.org\"\nVECTOR<STRING> categories = \"News\", \"Blog\", \"Personal\"\n\nSTRING currentUrl = MWG.Url().ToString()\nSTRING category = MWG.MapInList(urls, categories, currentUrl)\n\nIF category != \"\" THEN {\n    // The category for currentUrl is category\n} ELSE {\n    // The URL currentUrl is not in the list.\n}"}, {"name": "MWG.MapMatchInList (VECTOR<STRING>, VECTOR<STRING>, STRING)", "return_type": "STRING", "return_desc": "Returns the string from the second vector corresponding to the index of the string found in the first vector.", "parameter_desc": "VECTOR<STRING>: List to search; VECTOR<STRING>: list to return from; STRING: wildcard value to search for.", "description": "Checks for input wildcard STRING in first STRING list, if found returns the STRING from the same index in second STRING list", "example_code": "VECTOR<STRING> urlPatterns = \"example.com/*\", \"test.com/*\", \"sample.org/*\"\nVECTOR<STRING> actions = \"Block\", \"Allow\", \"Monitor\"\nSTRING currentUrl = MWG.Url().ToString()\n\nSTRING action = MWG.MapMatchInList(urlPatterns, actions, currentUrl)\n\nIF action == \"Block\" THEN {\n    MWG.Block(\"Access to this site is blocked.\")\n} ELSE IF action == \"Allow\" THEN {\n    MWG.Allow(\"Access to this site is allowed.\")\n} ELSE IF action == \"Monitor\" THEN {\n    // Monitoring access to this site.\n} ELSE {\n    // No matching pattern found for the URL.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> urlPatterns = \"example.com/*\", \"test.com/*\", \"sample.org/*\"\nVECTOR<STRING> actions = \"Block\", \"Allow\", \"Monitor\"\nSTRING currentUrl = MWG.Url().ToString()\n\nSTRING action = MWG.MapMatchInList(urlPatterns, actions, currentUrl)\n\nIF action == \"Block\" THEN {\n    MWG.Block(\"Access to this site is blocked.\")\n} ELSE IF action == \"Allow\" THEN {\n    MWG.Allow(\"Access to this site is allowed.\")\n} ELSE IF action == \"Monitor\" THEN {\n    // Monitoring access to this site.\n} ELSE {\n    // No matching pattern found for the URL.\n}"}, {"name": "MWG.MediaTypeListByName (STRING)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns `MediaType` list with specified name.", "parameter_desc": "STRING: name of media list to get.", "description": "Retrieves a MediaType list by list name", "example_code": "// Define the name of the media type list to retrieve\nSTRING mediaTypeListName = \"example_media_type_list\"\n\n// Retrieve the media type list\nVECTOR<MediaType> mediaTypes = MWG.MediaTypeListByName(mediaTypeListName)\n\n// Iterate through the media types and print them to the console\nFOR EACH MediaType mediaType IN mediaTypes {\n    // Media Type: \" + mediaType\n}\n\n// Example condition to block a request if a certain media type is found\nIF \"application/json\" IN mediaTypes THEN {\n    MWG.Block(\"Blocked due to media type application/json\")\n} ELSE {\n    MWG.Allow(\"Media type check passed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the name of the media type list to retrieve\nSTRING mediaTypeListName = \"example_media_type_list\"\n\n// Retrieve the media type list\nVECTOR<MediaType> mediaTypes = MWG.MediaTypeListByName(mediaTypeListName)\n\n// Iterate through the media types and print them to the console\nFOR EACH MediaType mediaType IN mediaTypes {\n    // Media Type: \" + mediaType\n}\n\n// Example condition to block a request if a certain media type is found\nIF \"application/json\" IN mediaTypes THEN {\n    MWG.Block(\"Blocked due to media type application/json\")\n} ELSE {\n    MWG.Allow(\"Media type check passed\")\n}"}, {"name": "MWG.MediaTypeListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if `MediaType` list with the name exists.", "parameter_desc": "STRING: name of media list to check for.", "description": "Returns TRUE if MediaType list with the name exists", "example_code": "STRING listName = \"example_media_type_list\"\n\nIF MWG.MediaTypeListByNameExists(listName) THEN {\n    // Media type list exists: \" + listName\n} ELSE {\n    // Media type list does not exist: \" + listName\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING listName = \"example_media_type_list\"\n\nIF MWG.MediaTypeListByNameExists(listName) THEN {\n    // Media type list exists: \" + listName\n} ELSE {\n    // Media type list does not exist: \" + listName\n}"}, {"name": "MWG.ModuloNumber (NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns the remainder when the first number is divided by the second number.", "parameter_desc": "NUMBER: the numerator; NUMBER: the denominator.", "description": "Returns the modulo", "example_code": "NUMBER numerator = 10\nNUMBER denominator = 3\nNUMBER result = MWG.ModuloNumber(numerator, denominator)\n\n// The result of 10 % 3 is 1", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER numerator = 10\nNUMBER denominator = 3\nNUMBER result = MWG.ModuloNumber(numerator, denominator)\n\n// The result of 10 % 3 is 1"}, {"name": "MWG.NumberListByName (STRING)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns the list with the specified name.", "parameter_desc": "STRING: name of list to get.", "description": "Retrieves a VECTOR<NUMBER> by list name", "example_code": "// Define the name of the number list\nSTRING listName = \"exampleNumberList\"\n\n// Retrieve the number list by name\nVECTOR<NUMBER> numberList = MWG.NumberListByName(listName)\n\n// Check if the number list is not empty\nIF numberList.SIZE > 0 THEN {\n    // Iterate through the number list and print each number\n    FOR NUMBER num IN numberList {\n        // Number: num\n    }\n\n    // Example condition to block if a specific number is found in the list\n    IF 42 IN numberList THEN {\n        MWG.Block(\"Access blocked due to number 42 in the list\")\n    } ELSE {\n        MWG.Allow(\"Access allowed\")\n    }\n} ELSE {\n    // The number list is empty\n    MWG.Allow(\"Access allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the name of the number list\nSTRING listName = \"exampleNumberList\"\n\n// Retrieve the number list by name\nVECTOR<NUMBER> numberList = MWG.NumberListByName(listName)\n\n// Check if the number list is not empty\nIF numberList.SIZE > 0 THEN {\n    // Iterate through the number list and print each number\n    FOR NUMBER num IN numberList {\n        // Number: num\n    }\n\n    // Example condition to block if a specific number is found in the list\n    IF 42 IN numberList THEN {\n        MWG.Block(\"Access blocked due to number 42 in the list\")\n    } ELSE {\n        MWG.Allow(\"Access allowed\")\n    }\n} ELSE {\n    // The number list is empty\n    MWG.Allow(\"Access allowed\")\n}"}, {"name": "MWG.NumberListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if VECTOR<`NUMBER`> list with the name exists.", "parameter_desc": "STRING: name of list to check for.", "description": "Returns TRUE if VECTOR<NUMBER> list with the name exists", "example_code": "STRING listName = \"example_number_list\"\n\nIF MWG.NumberListByNameExists(listName) THEN {\n    // The number list 'example_number_list' exists.\n    // Additional actions can be taken here if the list exists\n} ELSE {\n    // The number list 'example_number_list' does not exist.\n    // Additional actions can be taken here if the list does not exist\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING listName = \"example_number_list\"\n\nIF MWG.NumberListByNameExists(listName) THEN {\n    // The number list 'example_number_list' exists.\n    // Additional actions can be taken here if the list exists\n} ELSE {\n    // The number list 'example_number_list' does not exist.\n    // Additional actions can be taken here if the list does not exist\n}"}, {"name": "MWG.OriginalDestinationIP ()", "return_type": "Net.IP", "return_desc": "Returns the IP address of the intended destination when operating in transparent mode.", "parameter_desc": "None", "description": "Return the IP address of original destination in transparent mode", "example_code": "Net.IP destinationIP = MWG.DestinationIP()\n// Destination IP: destinationIP\n\n// Example condition to block a specific IP\nIF destinationIP == \"192.168.1.1\" THEN {\n    MWG.Block(\"Access to this IP is blocked.\")\n} ELSE {\n    MWG.Allow(\"IP is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP destinationIP = MWG.DestinationIP()\n// Destination IP: destinationIP\n\n// Example condition to block a specific IP\nIF destinationIP == \"192.168.1.1\" THEN {\n    MWG.Block(\"Access to this IP is blocked.\")\n} ELSE {\n    MWG.Allow(\"IP is allowed.\")\n}"}, {"name": "MWG.OutboundIPFromPool (NUMBER)", "return_type": "Net.IP", "return_desc": "Returns the Proxy outbound IP address.", "parameter_desc": "NUMBER: the index to use", "description": "Get a Proxy outbound IP address from pool", "example_code": "NUMBER ipIndex = 2\nSTRING selectedIP = MWG.OutboundIPFromPool(ipIndex)\n\n// Selected Outbound IP: + selectedIP", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER ipIndex = 2\nSTRING selectedIP = MWG.OutboundIPFromPool(ipIndex)\n\n// Selected Outbound IP: + selectedIP"}, {"name": "MWG.OutboundPort ()", "return_type": "NUMBER", "return_desc": "Returns outbound port.", "parameter_desc": "None", "description": "Returns outboud port", "example_code": "NUMBER port = MWG.OutboundPort()\n\nIF port == 80 THEN {\n    MWG.Allow(\"Allowed outbound port 80\")\n} ELSE {\n    MWG.Block(\"Blocked outbound port\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER port = MWG.OutboundPort()\n\nIF port == 80 THEN {\n    MWG.Allow(\"Allowed outbound port 80\")\n} ELSE {\n    MWG.Block(\"Blocked outbound port\")\n}"}, {"name": "MWG.Parameter (MWG.URL, STRING)", "return_type": "STRING", "return_desc": "Returns the requested query parameter of a URL as a string.", "parameter_desc": "MWG.URL: The full URL STRING; STRING: The name of the parameter to retrieve.", "description": "Return a specific parameter portion of a URL as a STRING", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING key = \"exampleKey\"\nSTRING value = \"exampleValue\"\n\nMWG.SetParameter(currentUrl, key, value)\n\n// Modified URL: currentUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING key = \"exampleKey\"\nSTRING value = \"exampleValue\"\n\nMWG.SetParameter(currentUrl, key, value)\n\n// Modified URL: currentUrl"}, {"name": "MWG.Parameters (MWG.URL)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing the parameters extracted from the given URL.", "parameter_desc": "MWG.URL: the web address from which to extract the parameters.", "description": "Extract parameters of the URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING parameterName = \"exampleParam\"\nSTRING parameterValue = MWG.Parameter(currentUrl, parameterName)\n\n// The value of the parameter 'exampleParam' is: parameterValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING parameterName = \"exampleParam\"\nSTRING parameterValue = MWG.Parameter(currentUrl, parameterName)\n\n// The value of the parameter 'exampleParam' is: parameterValue"}, {"name": "MWG.ParameterSTRING (MWG.URL)", "return_type": "STRING", "return_desc": "Returns a string that contains all the parameters extracted from a given URL.", "parameter_desc": "MWG.URL: the URL to extract parameters from.", "description": "Return all parameters of a URL as a STRING", "example_code": "MWG.URL currentUrl = MWG.Url()\nMWG.SetParameter(currentUrl, \"key\", \"value\")\n// Modified URL: + currentUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nMWG.SetParameter(currentUrl, \"key\", \"value\")\n// Modified URL: + currentUrl"}, {"name": "MWG.Path (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the path component of a given URL as a string.", "parameter_desc": "MWG.URL: the URL to extract the path from.", "description": "Return the path of an URL", "example_code": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Extract the path from the URL\nSTRING urlPath = MWG.Path(currentUrl)\n\n// The path of the current URL is: \" + urlPath", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Extract the path from the URL\nSTRING urlPath = MWG.Path(currentUrl)\n\n// The path of the current URL is: \" + urlPath"}, {"name": "MWG.PolicyExecutionDuration ()", "return_type": "NUMBER", "return_desc": "Returns the time spent for policy evaluation (without waiting time).", "parameter_desc": "None", "description": "Returns the time spent for policy evaluation (without waiting time)", "example_code": "NUMBER duration = MWG.PolicyExecutionDuration()\n// Policy execution duration: \" + duration + \" milliseconds", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER duration = MWG.PolicyExecutionDuration()\n// Policy execution duration: \" + duration + \" milliseconds"}, {"name": "MWG.PolicyExecutionError ()", "return_type": "STRING", "return_desc": "Returns error description for policy execution errors.", "parameter_desc": "None", "description": "Returns error description for policy execution errors", "example_code": "STRING errorDescription = MWG.PolicyExecutionError()\n\nIF errorDescription != \"\" THEN {\n    // Policy Execution Error: \" + errorDescription\n} ELSE {\n    // No policy execution errors.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING errorDescription = MWG.PolicyExecutionError()\n\nIF errorDescription != \"\" THEN {\n    // Policy Execution Error: \" + errorDescription\n} ELSE {\n    // No policy execution errors.\n}"}, {"name": "MWG.Port (MWG.URL)", "return_type": "NUMBER", "return_desc": "Returns the port number specified in the given URL.", "parameter_desc": "MWG.URL: the URL to extract the port NUMBER from.", "description": "Return the port of a URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nNUMBER port = MWG.Port(currentUrl)\n\n// The port number is: \" + port\n\nIF port == 80 THEN {\n    // The request is using the standard HTTP port.\n} ELSE IF port == 443 THEN {\n    // The request is using the standard HTTPS port.\n} ELSE {\n    // The request is using a non-standard port: \" + port\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nNUMBER port = MWG.Port(currentUrl)\n\n// The port number is: \" + port\n\nIF port == 80 THEN {\n    // The request is using the standard HTTP port.\n} ELSE IF port == 443 THEN {\n    // The request is using the standard HTTPS port.\n} ELSE {\n    // The request is using a non-standard port: \" + port\n}"}, {"name": "MWG.ProgressPageEnabled ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a progress page has been enabled for this request.", "parameter_desc": "None", "description": "Returns whether a progress page has been enabled for this request", "example_code": "MWG.ProgressPageSetting progressPageSetting = MWG.ProgressPageSetting()\n// Configure your progressPageSetting as needed\n// For example, you might set some properties on the progressPageSetting object here\n\nMWG.EnableProgressPage(progressPageSetting)\n// Progress page has been enabled with the specified settings.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.ProgressPageSetting progressPageSetting = MWG.ProgressPageSetting()\n// Configure your progressPageSetting as needed\n// For example, you might set some properties on the progressPageSetting object here\n\nMWG.EnableProgressPage(progressPageSetting)\n// Progress page has been enabled with the specified settings."}, {"name": "MWG.ProgressPageSent ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a progress page has been sent for this request.", "parameter_desc": "None", "description": "Returns whether a progress page has been sent for this request", "example_code": "IF MWG.ProgressPageSent() THEN {\n    // A progress page has been sent for this request.\n} ELSE {\n    // No progress page has been sent for this request.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.ProgressPageSent() THEN {\n    // A progress page has been sent for this request.\n} ELSE {\n    // No progress page has been sent for this request.\n}"}, {"name": "MWG.Protocol (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the protocol part of a given URL as a string.", "parameter_desc": "MWG.URL: A STRING representing the URL from which to extract the protocol.", "description": "Return the protocol of a URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING protocol = currentUrl.Protocol\n\nIF protocol == \"https\" THEN {\n    // The protocol is HTTPS\n} ELSE {\n    // The protocol is not HTTPS\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING protocol = currentUrl.Protocol\n\nIF protocol == \"https\" THEN {\n    // The protocol is HTTPS\n} ELSE {\n    // The protocol is not HTTPS\n}"}, {"name": "MWG.ProtocolAndVersion (MWG.RequestResponse)", "return_type": "STRING", "return_desc": "Returns the protocol and version of a request or response (e.g., HTTP/1.1).", "parameter_desc": "MWG.RequestResponse: the provided request or response to check", "description": "Returns the protocol and version of a request or response (e.g. HTTP/1.1)", "example_code": "MWG.RequestResponse request = MWG.RequestResponse()\nSTRING protocolVersion = MWG.ProtocolAndVersion(request)\n\n// Protocol and Version: protocolVersion\n\nIF protocolVersion == \"HTTP/1.1\" THEN {\n    MWG.Allow(\"HTTP/1.1 request allowed\")\n} ELSE {\n    MWG.Block(\"Unsupported protocol version\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.RequestResponse request = MWG.RequestResponse()\nSTRING protocolVersion = MWG.ProtocolAndVersion(request)\n\n// Protocol and Version: protocolVersion\n\nIF protocolVersion == \"HTTP/1.1\" THEN {\n    MWG.Allow(\"HTTP/1.1 request allowed\")\n} ELSE {\n    MWG.Block(\"Unsupported protocol version\")\n}"}, {"name": "MWG.ProtocolFailureDescription ()", "return_type": "STRING", "return_desc": "Returns the failure description.", "parameter_desc": "None", "description": "Returns the failure description", "example_code": "STRING failureDescription = MWG.ProtocolFailureDescription()\n\nIF failureDescription != \"\" THEN {\n    // Protocol Failure Detected: \" + failureDescription\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING failureDescription = MWG.ProtocolFailureDescription()\n\nIF failureDescription != \"\" THEN {\n    // Protocol Failure Detected: \" + failureDescription\n}"}, {"name": "MWG.ProtocolIsWebSocket ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if upgraded to WebSocket.", "parameter_desc": "None", "description": "Returns TRUE if upgraded to WebSocket", "example_code": "IF MWG.ProtocolIsWebSocket() THEN {\n    // The current protocol is WebSocket.\n    // Add additional logic for WebSocket connections here\n} ELSE {\n    // The current protocol is not WebSocket.\n    // Add additional logic for non-WebSocket connections here\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.ProtocolIsWebSocket() THEN {\n    // The current protocol is WebSocket.\n    // Add additional logic for WebSocket connections here\n} ELSE {\n    // The current protocol is not WebSocket.\n    // Add additional logic for non-WebSocket connections here\n}"}, {"name": "MWG.ProxyPort ()", "return_type": "NUMBER", "return_desc": "Returns ingress proxy port.", "parameter_desc": "None", "description": "Return ingress proxy port", "example_code": "NUMBER port = MWG.ProxyPort()\n// The ingress proxy port is: port\n\nIF port == 8080 THEN {\n    // The proxy port is 8080, allowing the connection.\n    MWG.Allow(\"Port 8080\")\n} ELSE {\n    // The proxy port is not 8080, blocking the connection.\n    MWG.Block(\"Blocked due to incorrect proxy port\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER port = MWG.ProxyPort()\n// The ingress proxy port is: port\n\nIF port == 8080 THEN {\n    // The proxy port is 8080, allowing the connection.\n    MWG.Allow(\"Port 8080\")\n} ELSE {\n    // The proxy port is not 8080, blocking the connection.\n    MWG.Block(\"Blocked due to incorrect proxy port\")\n}"}, {"name": "MWG.RandomNumber (NUMBER, NUMBER)", "return_type": "NUMBER", "return_desc": "Returns a random integer within the specified range.", "parameter_desc": "NUMBER: Minimum value; NUMBER: Maximum value.", "description": "random integer NUMBER", "example_code": "NUMBER min = 1\nNUMBER max = 100\nNUMBER randomNumber = MWG.RandomNumber(min, max)\n// Generated random number: \" + randomNumber", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER min = 1\nNUMBER max = 100\nNUMBER randomNumber = MWG.RandomNumber(min, max)\n// Generated random number: \" + randomNumber"}, {"name": "MWG.Raw (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the URL as a raw string.", "parameter_desc": "MWG.URL: The URL to be converted to a raw STRING format.", "description": "Return a URL as a STRING in raw format", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING rawUrl = MWG.Raw(currentUrl)\n// The raw URL is: \" + rawUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING rawUrl = MWG.Raw(currentUrl)\n// The raw URL is: \" + rawUrl"}, {"name": "MWG.RegexListByID (STRING)", "return_type": "RegExJSi.List", "return_desc": "Returns a `RegExJSi`.List corresponding to the specified list ID.", "parameter_desc": "STRING: the list ID.", "description": "Retrieves a RegExJSi.List by list ID", "example_code": "STRING regexListID = \"example_regex_list_id\"\nMWG.URL currentURL = MWG.Url()\n\nIF MWG.RegexListByID(regexListID).Matches(currentURL) THEN {\n    // URL matches the regex list\n    MWG.Block(\"Access to this URL is blocked based on regex list\")\n} ELSE {\n    // URL does not match the regex list\n    MWG.Allow(\"URL allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING regexListID = \"example_regex_list_id\"\nMWG.URL currentURL = MWG.Url()\n\nIF MWG.RegexListByID(regexListID).Matches(currentURL) THEN {\n    // URL matches the regex list\n    MWG.Block(\"Access to this URL is blocked based on regex list\")\n} ELSE {\n    // URL does not match the regex list\n    MWG.Allow(\"URL allowed\")\n}"}, {"name": "MWG.RegexListByName (STRING)", "return_type": "RegExJSi.List", "return_desc": "Returns a list of regular expressions identified by the given list name.", "parameter_desc": "STRING: the name of the list to retrieve.", "description": "Retrieves a RegExJSi.List by list name", "example_code": "// Retrieve the list of regular expressions by name\nRegExJSi.List regexList = MWG.RegexListByName(\"example_regex_list\")\n\n// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Iterate through the regex list and check if the URL matches any regex\nFOR EACH regex IN regexList {\n    IF regex.Matches(currentUrl.ToString()) THEN {\n        // If a match is found, block the request and provide a reason\n        MWG.Block(\"URL matches a blocked pattern\")\n        RETURN\n    }\n}\n\n// If no match is found, allow the request\nMWG.Allow(\"No matching regex found\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the list of regular expressions by name\nRegExJSi.List regexList = MWG.RegexListByName(\"example_regex_list\")\n\n// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Iterate through the regex list and check if the URL matches any regex\nFOR EACH regex IN regexList {\n    IF regex.Matches(currentUrl.ToString()) THEN {\n        // If a match is found, block the request and provide a reason\n        MWG.Block(\"URL matches a blocked pattern\")\n        RETURN\n    }\n}\n\n// If no match is found, allow the request\nMWG.Allow(\"No matching regex found\")"}, {"name": "MWG.RegexListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a regex list with the specified name exists.", "parameter_desc": "STRING: the name of the regular expression list to check for.", "description": "Returns TRUE if RegexList with the name exists", "example_code": "STRING regexListName = \"example_regex_list\"\n\nIF MWG.RegexListByNameExists(regexListName) THEN {\n    // The regex list exists.\n} ELSE {\n    // The regex list does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING regexListName = \"example_regex_list\"\n\nIF MWG.RegexListByNameExists(regexListName) THEN {\n    // The regex list exists.\n} ELSE {\n    // The regex list does not exist.\n}"}, {"name": "MWG.Request ()", "return_type": "MWG.RequestResponse", "return_desc": "Returns a request object.", "parameter_desc": "None", "description": "Returns a request object", "example_code": "MWG.RequestResponse request = MWG.Request()\nSTRING url = request.Url()\nSTRING method = request.Method()\n\n// Request URL: \" + url\n// Request Method: \" + method", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.RequestResponse request = MWG.Request()\nSTRING url = request.Url()\nSTRING method = request.Method()\n\n// Request URL: \" + url\n// Request Method: \" + method"}, {"name": "MWG.RequestFirstLine ()", "return_type": "STRING", "return_desc": "Returns the first line of the request.", "parameter_desc": "None", "description": "Returns the first line of the request", "example_code": "STRING requestLine = MWG.RequestFirstLine()\n// \"Request First Line: \" + requestLine", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING requestLine = MWG.RequestFirstLine()\n// \"Request First Line: \" + requestLine"}, {"name": "MWG.RequestID ()", "return_type": "STRING", "return_desc": "Returns a unique identifier string for the current request.", "parameter_desc": "None", "description": "Generates a unique ID for this request", "example_code": "STRING requestID = MWG.RequestID()\n// \"Request ID: \" + requestID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING requestID = MWG.RequestID()\n// \"Request ID: \" + requestID"}, {"name": "MWG.ResolveHostViaDNS ()", "return_type": "NUMBER", "return_desc": "Returns the duration for DNS lookup for the host.", "parameter_desc": "None", "description": "Returns the duration for DNS lookup for the host", "example_code": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Extract the host from the URL\nSTRING host = currentUrl.Host\n\n// Resolve the host via DNS\nSTRING ipAddress = MWG.ResolveHostViaDNS(host)\n\n// Resolved IP Address: \n// ipAddress\n\n// Allow the request to proceed\nMWG.Allow(\"DNS Resolution Completed\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Extract the host from the URL\nSTRING host = currentUrl.Host\n\n// Resolve the host via DNS\nSTRING ipAddress = MWG.ResolveHostViaDNS(host)\n\n// Resolved IP Address: \n// ipAddress\n\n// Allow the request to proceed\nMWG.Allow(\"DNS Resolution Completed\")"}, {"name": "MWG.Response ()", "return_type": "MWG.RequestResponse", "return_desc": "Returns a response object.", "parameter_desc": "None", "description": "Returns a response object", "example_code": "STRING responseBody = \"This is a custom response body.\"\nMWG.GenerateResponse(responseBody)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING responseBody = \"This is a custom response body.\"\nMWG.GenerateResponse(responseBody)"}, {"name": "MWG.SAMLAttributes ()", "return_type": "MAP<STRING,STRING>", "return_desc": "Returns a list of SAML attributes.", "parameter_desc": "None", "description": "Return a list of SAML attributes", "example_code": "// Retrieve SAML attributes\nMAP<STRING><STRING> samlAttributes = MWG.SAMLAttributes()\n\n// Check if a specific attribute exists\nIF samlAttributes[\"role\"] == \"admin\" THEN {\n    // User has admin role\n    MWG.Allow(\"Admin access granted\")\n} ELSE {\n    // User does not have admin role\n    MWG.Block(\"Access denied: Admin role required\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve SAML attributes\nMAP<STRING><STRING> samlAttributes = MWG.SAMLAttributes()\n\n// Check if a specific attribute exists\nIF samlAttributes[\"role\"] == \"admin\" THEN {\n    // User has admin role\n    MWG.Allow(\"Admin access granted\")\n} ELSE {\n    // User does not have admin role\n    MWG.Block(\"Access denied: Admin role required\")\n}"}, {"name": "MWG.SamlConfigByLocation ()", "return_type": "STRING", "return_desc": "Returns the SAML configuration ID. Calls after`MWG.DetermineClientLocationProperties`", "parameter_desc": "None", "description": "Returns the SAML configuration ID. Call after MWG.DetermineClientLocationProperties", "example_code": "// First, determine the client location properties\nMWG.DetermineClientLocationProperties()\n\n// Get the SAML configuration ID based on the client location\nSTRING samlConfigID = MWG.SamlConfigByLocation()\n\n// SAML Configuration ID: \" + samlConfigID\n// was printed to the console for debugging purposes", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// First, determine the client location properties\nMWG.DetermineClientLocationProperties()\n\n// Get the SAML configuration ID based on the client location\nSTRING samlConfigID = MWG.SamlConfigByLocation()\n\n// SAML Configuration ID: \" + samlConfigID\n// was printed to the console for debugging purposes"}, {"name": "MWG.SAMLCreateAuthnRequest (MWG.SamlAuthnRequestSetting, STRING)", "return_type": "STRING", "return_desc": "Returns a string representing the generated SAML authentication request.", "parameter_desc": "MWG.SamlAuthnRequestSetting: the settings for the request; STRING: the access URL.", "description": "Create a SAML authentication request", "example_code": "// Define the SAML authentication request settings\nMWG.SamlAuthnRequestSetting samlSettings = MWG.SamlAuthnRequestSetting()\n\n// Set the necessary properties for the SAML settings\nsamlSettings.Issuer = \"https://example.com/issuer\"\nsamlSettings.Destination = \"https://idp.example.com/sso\"\nsamlSettings.AssertionConsumerServiceURL = \"https://sp.example.com/acs\"\nsamlSettings.ProtocolBinding = \"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\"\nsamlSettings.NameIDFormat = \"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress\"\n\n// Define the target URL for the SAML request\nSTRING targetURL = \"https://sp.example.com/target\"\n\n// Create the SAML authentication request\nSTRING samlRequest = MWG.SAMLCreateAuthnRequest(samlSettings, targetURL)\n\n// Print the SAML request to the debug console\n// samlRequest", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the SAML authentication request settings\nMWG.SamlAuthnRequestSetting samlSettings = MWG.SamlAuthnRequestSetting()\n\n// Set the necessary properties for the SAML settings\nsamlSettings.Issuer = \"https://example.com/issuer\"\nsamlSettings.Destination = \"https://idp.example.com/sso\"\nsamlSettings.AssertionConsumerServiceURL = \"https://sp.example.com/acs\"\nsamlSettings.ProtocolBinding = \"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST\"\nsamlSettings.NameIDFormat = \"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress\"\n\n// Define the target URL for the SAML request\nSTRING targetURL = \"https://sp.example.com/target\"\n\n// Create the SAML authentication request\nSTRING samlRequest = MWG.SAMLCreateAuthnRequest(samlSettings, targetURL)\n\n// Print the SAML request to the debug console\n// samlRequest"}, {"name": "MWG.SAMLError ()", "return_type": "STRING", "return_desc": "Returns the SAML response validation error description.", "parameter_desc": "None", "description": "Returns the SAML response validation error description", "example_code": "STRING samlError = MWG.SAMLError()\n\nIF samlError != \"\" THEN {\n    // \"SAML Error: \" + samlError\n    MWG.Block(\"SAML Authentication Failed: \" + samlError)\n} ELSE {\n    MWG.Allow(\"SAML Authentication Successful\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING samlError = MWG.SAMLError()\n\nIF samlError != \"\" THEN {\n    // \"SAML Error: \" + samlError\n    MWG.Block(\"SAML Authentication Failed: \" + samlError)\n} ELSE {\n    MWG.Allow(\"SAML Authentication Successful\")\n}"}, {"name": "MWG.SAMLGetProcessingOptions (STRING, STRING)", "return_type": "JSON", "return_desc": "Returns the configured processing options for SAML for the given tenant and config.", "parameter_desc": "STRING: The tenant ID; STRING: The config ID.", "description": "Get the configured processing options for SAML for the given tenant and config.", "example_code": "STRING param1 = \"exampleParam1\"\nSTRING param2 = \"exampleParam2\"\n\n// Assuming MWG.SAMLGetProcessingOptions returns some value\n// Replace 'resultType' with the actual return type of the function\nresultType result = MWG.SAMLGetProcessingOptions(param1, param2)\n\n// Use the result in some way\n// The result of MWG.SAMLGetProcessingOptions is: result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING param1 = \"exampleParam1\"\nSTRING param2 = \"exampleParam2\"\n\n// Assuming MWG.SAMLGetProcessingOptions returns some value\n// Replace 'resultType' with the actual return type of the function\nresultType result = MWG.SAMLGetProcessingOptions(param1, param2)\n\n// Use the result in some way\n// The result of MWG.SAMLGetProcessingOptions is: result"}, {"name": "MWG.SAMLGetRequestSetting (STRING, STRING)", "return_type": "MWG.SamlAuthnRequestSetting", "return_desc": "Returns the configured request settings for SAML for the given tenant and config.", "parameter_desc": "STRING: The tenant ID; STRING: The config ID.", "description": "Get the configured Request settings for SAML for the given tenant and config.", "example_code": "// Define the tenant ID and config ID\nSTRING tenantID = \"tenant123\"\nSTRING configID = \"configABC\"\n\n// Retrieve the SAML request settings\nMWG.SamlAuthnRequestSetting samlRequestSettings = MWG.SAMLGetRequestSetting(tenantID, configID)\n\n// Perform some action with the retrieved settings\n// For demonstration, we'll just print the settings to the debug console\n// SAML Request Settings: \" + samlRequestSettings", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the tenant ID and config ID\nSTRING tenantID = \"tenant123\"\nSTRING configID = \"configABC\"\n\n// Retrieve the SAML request settings\nMWG.SamlAuthnRequestSetting samlRequestSettings = MWG.SAMLGetRequestSetting(tenantID, configID)\n\n// Perform some action with the retrieved settings\n// For demonstration, we'll just print the settings to the debug console\n// SAML Request Settings: \" + samlRequestSettings"}, {"name": "MWG.SAMLGetResponseSetting (STRING, STRING)", "return_type": "MWG.SamlAuthnResponseSetting", "return_desc": "Returns the configured response settings for SAML for the given tenant and config.", "parameter_desc": "STRING: The tenant ID; STRING: The config ID.", "description": "Get the configured Response settings for SAML for the given tenant and config.", "example_code": "// Define the tenant ID and config ID\nSTRING tenantID = \"tenant123\"\nSTRING configID = \"config456\"\n\n// Retrieve the SAML response settings\nMWG.SamlAuthnResponseSetting responseSetting = MWG.SAMLGetResponseSetting(tenantID, configID)\n\n// Perform some action based on the response settings\nIF responseSetting != NULL THEN {\n    // SAML Response Setting retrieved successfully.\n    // Additional logic can be added here to work with the responseSetting object\n} ELSE {\n    // Failed to retrieve SAML Response Setting.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the tenant ID and config ID\nSTRING tenantID = \"tenant123\"\nSTRING configID = \"config456\"\n\n// Retrieve the SAML response settings\nMWG.SamlAuthnResponseSetting responseSetting = MWG.SAMLGetResponseSetting(tenantID, configID)\n\n// Perform some action based on the response settings\nIF responseSetting != NULL THEN {\n    // SAML Response Setting retrieved successfully.\n    // Additional logic can be added here to work with the responseSetting object\n} ELSE {\n    // Failed to retrieve SAML Response Setting.\n}"}, {"name": "MWG.SAMLGetTenantByMailDomain (MWG.SAMLDomainAuthentication, STRING)", "return_type": "STRING", "return_desc": "Returns the tenant ID for the given mail domain.", "parameter_desc": "MWG.SAMLDomainAuthentication: configurations for the SAML authentication; STRING: The mail domain.", "description": "Get the tenant associated with a mail domain.", "example_code": "STRING mailDomain = \"example.com\"\nSTRING tenantID = MWG.SAMLGetTenantByMailDomain(mailDomain)\n// Tenant ID for example.com is tenantID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mailDomain = \"example.com\"\nSTRING tenantID = MWG.SAMLGetTenantByMailDomain(mailDomain)\n// Tenant ID for example.com is tenantID"}, {"name": "MWG.SAMLGetTenantByMailDomain (STRING)", "return_type": "STRING", "return_desc": "Returns the tenant ID for the given mail domain.", "parameter_desc": "STRING: The mail domain.", "description": "Get the tenant associated with a mail domain.", "example_code": "STRING mailDomain = \"example.com\"\nSTRING tenantID = MWG.SAMLGetTenantByMailDomain(mailDomain)\n// The tenant ID for the mail domain example.com is tenantID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mailDomain = \"example.com\"\nSTRING tenantID = MWG.SAMLGetTenantByMailDomain(mailDomain)\n// The tenant ID for the mail domain example.com is tenantID"}, {"name": "MWG.SAMLIDPSSOEndpoint ()", "return_type": "STRING", "return_desc": "Returns the SAML IDP SSO Endpoint.", "parameter_desc": "None", "description": "Returns the SAML IDP SSO Endpoint", "example_code": "// Initialize the SAML IDP SSO Endpoint\nMWG.SAMLIDPSSOEndpoint samlEndpoint = MWG.SAMLIDPSSOEndpoint()\n\n// Set some properties for the SAML endpoint\nsamlEndpoint.setURL(\"https://idp.example.com/sso\")\nsamlEndpoint.setBinding(\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\")\n\n// Perform some action with the SAML endpoint\nIF samlEndpoint.isValid() THEN {\n    // SAML IDP SSO Endpoint is valid.\n    // Additional logic can be added here\n} ELSE {\n    // SAML IDP SSO Endpoint is not valid.\n    MWG.Block(\"Invalid SAML IDP SSO Endpoint\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize the SAML IDP SSO Endpoint\nMWG.SAMLIDPSSOEndpoint samlEndpoint = MWG.SAMLIDPSSOEndpoint()\n\n// Set some properties for the SAML endpoint\nsamlEndpoint.setURL(\"https://idp.example.com/sso\")\nsamlEndpoint.setBinding(\"urn:oasis:names:tc:SAML:2.0:bindings:HTTP-Redirect\")\n\n// Perform some action with the SAML endpoint\nIF samlEndpoint.isValid() THEN {\n    // SAML IDP SSO Endpoint is valid.\n    // Additional logic can be added here\n} ELSE {\n    // SAML IDP SSO Endpoint is not valid.\n    MWG.Block(\"Invalid SAML IDP SSO Endpoint\")\n}"}, {"name": "MWG.SAMLParseAuthnResponse (MWG.SamlAuthnResponseSetting, STRING, STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns a`BOOLEAN`indicating whether the SAML response was successfully parsed.", "parameter_desc": "MWG.SamlAuthnResponseSetting: configuration settings for parsing, STRING: the HTTP method, STRING: the issuer URL, STRING: the SAML response.", "description": "Parse a SAML response", "example_code": "// Define the SAML response settings\nMWG.SamlAuthnResponseSetting samlSettings = MWG.SamlAuthnResponseSetting()\n\n// Define the HTTP method, issuer URL, and SAML response\nSTRING httpMethod = \"POST\"\nSTRING issuerUrl = \"https://example.com/issuer\"\nSTRING samlResponse = \"base64-encoded-saml-response\"\n\n// Parse the SAML response\nBOOLEAN isParsed = MWG.SAMLParseAuthnResponse(samlSettings, httpMethod, issuerUrl, samlResponse)\n\n// Check if the SAML response was successfully parsed\nIF isParsed THEN {\n    // SAML response parsed successfully.\n} ELSE {\n    // Failed to parse SAML response.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the SAML response settings\nMWG.SamlAuthnResponseSetting samlSettings = MWG.SamlAuthnResponseSetting()\n\n// Define the HTTP method, issuer URL, and SAML response\nSTRING httpMethod = \"POST\"\nSTRING issuerUrl = \"https://example.com/issuer\"\nSTRING samlResponse = \"base64-encoded-saml-response\"\n\n// Parse the SAML response\nBOOLEAN isParsed = MWG.SAMLParseAuthnResponse(samlSettings, httpMethod, issuerUrl, samlResponse)\n\n// Check if the SAML response was successfully parsed\nIF isParsed THEN {\n    // SAML response parsed successfully.\n} ELSE {\n    // Failed to parse SAML response.\n}"}, {"name": "MWG.SAMLRelayState ()", "return_type": "STRING", "return_desc": "Returns the SAML Relay state.", "parameter_desc": "None", "description": "Returns the SAML Relay state", "example_code": "STRING relayState = MWG.SAMLRelayState()\n// SAML Relay State: \" + relayState\n\nIF relayState == \"expectedState\" THEN {\n    MWG.Allow(\"Relay state is as expected\")\n} ELSE {\n    MWG.Block(\"Unexpected SAML Relay State\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING relayState = MWG.SAMLRelayState()\n// SAML Relay State: \" + relayState\n\nIF relayState == \"expectedState\" THEN {\n    MWG.Allow(\"Relay state is as expected\")\n} ELSE {\n    MWG.Block(\"Unexpected SAML Relay State\")\n}"}, {"name": "MWG.ServerCertAlternativeCNs ()", "return_type": "VECTOR<STRING>", "return_desc": "Returns alternative CNs of web server certificate.", "parameter_desc": "None", "description": "Returns alternative CNs of web server certificate", "example_code": "STRING commonName = MWG.ServerCertCN()\n// Server Certificate Common Name: \" + commonName\n\nIF commonName == \"example.com\" THEN {\n    MWG.Allow(\"Certificate is valid\")\n} ELSE {\n    MWG.Block(\"Invalid server certificate\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING commonName = MWG.ServerCertCN()\n// Server Certificate Common Name: \" + commonName\n\nIF commonName == \"example.com\" THEN {\n    MWG.Allow(\"Certificate is valid\")\n} ELSE {\n    MWG.Block(\"Invalid server certificate\")\n}"}, {"name": "MWG.ServerCertCN ()", "return_type": "STRING", "return_desc": "Returns the Common Name of a web server certificate.", "parameter_desc": "None", "description": "Returns the Common Name of a web server certificate", "example_code": "IF MWG.ServerCertCNHasWildCard() THEN {\n    // The server certificate has a wildcard.\n    MWG.Block(\"Access blocked due to wildcard in server certificate.\")\n} ELSE {\n    // The server certificate does not have a wildcard.\n    MWG.Allow(\"No wildcard in server certificate.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.ServerCertCNHasWildCard() THEN {\n    // The server certificate has a wildcard.\n    MWG.Block(\"Access blocked due to wildcard in server certificate.\")\n} ELSE {\n    // The server certificate does not have a wildcard.\n    MWG.Allow(\"No wildcard in server certificate.\")\n}"}, {"name": "MWG.ServerCertCNHasWildCard ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the server certificate has wildcards.", "parameter_desc": "None", "description": "Returns TRUE if the server certificate has wildcards", "example_code": "IF MWG.ServerCertCNHasWildCard() THEN {\n    // The server certificate's CN contains a wildcard.\n    MWG.Block(\"Access blocked due to wildcard in server certificate CN.\")\n} ELSE {\n    // The server certificate's CN does not contain a wildcard.\n    MWG.Allow(\"No wildcard in server certificate CN.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF MWG.ServerCertCNHasWildCard() THEN {\n    // The server certificate's CN contains a wildcard.\n    MWG.Block(\"Access blocked due to wildcard in server certificate CN.\")\n} ELSE {\n    // The server certificate's CN does not contain a wildcard.\n    MWG.Allow(\"No wildcard in server certificate CN.\")\n}"}, {"name": "MWG.ServerCertDaysExpired ()", "return_type": "NUMBER", "return_desc": "Returns the number of days until a server certificate is expired.", "parameter_desc": "None", "description": "Returns the NUMBER of days until a server certificate is expired", "example_code": "NUMBER daysExpired = MWG.ServerCertDaysExpired()\n\nIF daysExpired > 0 THEN {\n    // The server certificate expired \" + daysExpired + \" days ago.\n    MWG.Block(\"The server certificate has expired.\")\n} ELSE {\n    // The server certificate is valid.\n    MWG.Allow(\"Certificate is valid\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER daysExpired = MWG.ServerCertDaysExpired()\n\nIF daysExpired > 0 THEN {\n    // The server certificate expired \" + daysExpired + \" days ago.\n    MWG.Block(\"The server certificate has expired.\")\n} ELSE {\n    // The server certificate is valid.\n    MWG.Allow(\"Certificate is valid\")\n}"}, {"name": "MWG.ServerCertSha1Digest ()", "return_type": "STRING", "return_desc": "Returns the hex-encoded SHA1 digest of the server certificate.", "parameter_desc": "None", "description": "Returns the hex-encoded sha1 digest of the server certificate", "example_code": "STRING certDigest = MWG.ServerCertSha1Digest()\n// Server Certificate SHA1 Digest: \" + certDigest", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING certDigest = MWG.ServerCertSha1Digest()\n// Server Certificate SHA1 Digest: \" + certDigest"}, {"name": "MWG.ServerCertSha256Digest ()", "return_type": "STRING", "return_desc": "Returns the hex-encoded SHA256 digest of the server certificate.", "parameter_desc": "None", "description": "Returns the hex-encoded sha256 digest of the server certificate", "example_code": "STRING certDigest = MWG.ServerCertSha256Digest()\n// Server Certificate SHA-256 Digest:", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING certDigest = MWG.ServerCertSha256Digest()\n// Server Certificate SHA-256 Digest:"}, {"name": "MWG.ServerCertSignatureMethod ()", "return_type": "STRING", "return_desc": "Returns the signature method of the server certificate.", "parameter_desc": "None", "description": "Returns the signature method of server certificate", "example_code": "STRING signatureMethod = MWG.ServerCertSignatureMethod()\n// Server Certificate Signature Method: \" + signatureMethod", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING signatureMethod = MWG.ServerCertSignatureMethod()\n// Server Certificate Signature Method: \" + signatureMethod"}, {"name": "MWG.ServerChainComplete (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the server certificate chain ends with a self-signed root CA.", "parameter_desc": "MWG.CertificateVerificationSetting: The configuration settings for verifying the server certificate.MWG.CertificateAuthorityList: The list of trusted Certificate Authorities against which the server certificate is verified.", "description": "Returns TRUE if the server certificate chain ends with a self signed root CA", "example_code": "// Define the certificate verification settings\nMWG.CertificateVerificationSetting certVerificationSetting = MWG.CertificateVerificationSetting()\n\n// Define the certificate authority list\nMWG.CertificateAuthorityList certAuthorityList = MWG.CertificateAuthorityList()\n\n// Check if the server certificate chain is complete\nBOOLEAN isChainComplete = MWG.ServerChainComplete(certVerificationSetting, certAuthorityList)\n\n// Take action based on the result\nIF isChainComplete THEN {\n    // Server certificate chain is complete.\n    MWG.Allow(\"Certificate chain verified\")\n} ELSE {\n    // Server certificate chain is incomplete.\n    MWG.Block(\"Incomplete certificate chain\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the certificate verification settings\nMWG.CertificateVerificationSetting certVerificationSetting = MWG.CertificateVerificationSetting()\n\n// Define the certificate authority list\nMWG.CertificateAuthorityList certAuthorityList = MWG.CertificateAuthorityList()\n\n// Check if the server certificate chain is complete\nBOOLEAN isChainComplete = MWG.ServerChainComplete(certVerificationSetting, certAuthorityList)\n\n// Take action based on the result\nIF isChainComplete THEN {\n    // Server certificate chain is complete.\n    MWG.Allow(\"Certificate chain verified\")\n} ELSE {\n    // Server certificate chain is incomplete.\n    MWG.Block(\"Incomplete certificate chain\")\n}"}, {"name": "MWG.ServerChainContainsExpiredCA (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the server certificate chain includes any expired certificate authority (CA).", "parameter_desc": "MWG.CertificateVerificationSetting: Configuration for certificate verification; MWG.CertificateAuthorityList: List of trusted certificate authorities.", "description": "Returns TRUE if the server certificate chain contains an expired CA", "example_code": "MWG.CertificateVerificationSetting certVerificationSetting\nMWG.CertificateAuthorityList caList\n\n// Assuming certVerificationSetting and caList are initialized and configured appropriately\n\nBOOLEAN containsExpiredCA = MWG.ServerChainContainsExpiredCA(certVerificationSetting, caList)\n\nIF containsExpiredCA THEN {\n    MWG.Block(\"Connection blocked due to expired CA in the server certificate chain.\")\n} ELSE {\n    MWG.Allow(\"No expired CA found in the server certificate chain.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.CertificateVerificationSetting certVerificationSetting\nMWG.CertificateAuthorityList caList\n\n// Assuming certVerificationSetting and caList are initialized and configured appropriately\n\nBOOLEAN containsExpiredCA = MWG.ServerChainContainsExpiredCA(certVerificationSetting, caList)\n\nIF containsExpiredCA THEN {\n    MWG.Block(\"Connection blocked due to expired CA in the server certificate chain.\")\n} ELSE {\n    MWG.Allow(\"No expired CA found in the server certificate chain.\")\n}"}, {"name": "MWG.ServerChainContainsRevoked (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any certificate in the server's certificate chain is revoked.", "parameter_desc": "MWG.CertificateVerificationSetting: the configuration settings for certificate verification; MWG.CertificateAuthorityList: the list of trusted certificate authorities.", "description": "Returns TRUE if the server certificate chain contains a revoked CA", "example_code": "// Initialize the certificate verification settings\nMWG.CertificateVerificationSetting certVerificationSetting = ... // Initialize with appropriate settings\n\n// Initialize the list of trusted certificate authorities\nMWG.CertificateAuthorityList caList = ... // Initialize with the list of trusted certificate authorities\n\n// Check if the server's certificate chain contains a revoked certificate\nIF MWG.ServerChainContainsRevoked(certVerificationSetting, caList) THEN {\n    // Block the connection if a revoked certificate is found\n    MWG.Block(\"Connection blocked due to revoked certificate in the server's certificate chain.\")\n} ELSE {\n    // Allow the connection if no revoked certificate is found\n    MWG.Allow(\"Certificate chain is valid.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize the certificate verification settings\nMWG.CertificateVerificationSetting certVerificationSetting = ... // Initialize with appropriate settings\n\n// Initialize the list of trusted certificate authorities\nMWG.CertificateAuthorityList caList = ... // Initialize with the list of trusted certificate authorities\n\n// Check if the server's certificate chain contains a revoked certificate\nIF MWG.ServerChainContainsRevoked(certVerificationSetting, caList) THEN {\n    // Block the connection if a revoked certificate is found\n    MWG.Block(\"Connection blocked due to revoked certificate in the server's certificate chain.\")\n} ELSE {\n    // Allow the connection if no revoked certificate is found\n    MWG.Allow(\"Certificate chain is valid.\")\n}"}, {"name": "MWG.ServerChainContainsViolation (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if there is a violation detected within the server's certificate chain.", "parameter_desc": "MWG.CertificateVerificationSetting: Specifies the verification settings for the certificate; MWG.CertificateAuthorityList: Lists the trusted certificate authorities.", "description": "Returns TRUE if the server certificate chain contains a violation", "example_code": "MWG.CertificateVerificationSetting certVerificationSetting = ... // Initialize with appropriate settings\nMWG.CertificateAuthorityList certAuthorityList = ... // Initialize with appropriate CA list\n\nBOOLEAN hasViolation = MWG.ServerChainContainsViolation(certVerificationSetting, certAuthorityList)\n\nIF hasViolation THEN {\n    MWG.Block(\"Certificate chain contains a violation.\")\n} ELSE {\n    MWG.Allow(\"Certificate chain is valid.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.CertificateVerificationSetting certVerificationSetting = ... // Initialize with appropriate settings\nMWG.CertificateAuthorityList certAuthorityList = ... // Initialize with appropriate CA list\n\nBOOLEAN hasViolation = MWG.ServerChainContainsViolation(certVerificationSetting, certAuthorityList)\n\nIF hasViolation THEN {\n    MWG.Block(\"Certificate chain contains a violation.\")\n} ELSE {\n    MWG.Allow(\"Certificate chain is valid.\")\n}"}, {"name": "MWG.ServerChainFirstKnownCAIsTrusted (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first known certificate authority in a server's certificate chain is trusted based on specified verification settings and authority list.", "parameter_desc": "MWG.CertificateVerificationSetting: Specifies the verification settings for the certificate; MWG.CertificateAuthorityList: Lists the trusted certificate authorities.", "description": "Returns TRUE if the first known CA on a server certificate chain is trusted", "example_code": "// Initialize the certificate verification setting\nMWG.CertificateVerificationSetting certVerificationSetting = // Obtain or define the certificate verification setting\n\n// Initialize the certificate authority list\nMWG.CertificateAuthorityList caList = // Obtain or define the certificate authority list\n\n// Check if the first known CA in the server chain is trusted\nBOOLEAN isTrusted = MWG.ServerChainFirstKnownCAIsTrusted(certVerificationSetting, caList)\n\n// Take action based on whether the CA is trusted\nIF isTrusted THEN {\n    // The first known CA in the server chain is trusted.\n    MWG.Allow(\"CA is trusted\")\n} ELSE {\n    // The first known CA in the server chain is not trusted.\n    MWG.Block(\"CA is not trusted\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize the certificate verification setting\nMWG.CertificateVerificationSetting certVerificationSetting = // Obtain or define the certificate verification setting\n\n// Initialize the certificate authority list\nMWG.CertificateAuthorityList caList = // Obtain or define the certificate authority list\n\n// Check if the first known CA in the server chain is trusted\nBOOLEAN isTrusted = MWG.ServerChainFirstKnownCAIsTrusted(certVerificationSetting, caList)\n\n// Take action based on whether the CA is trusted\nIF isTrusted THEN {\n    // The first known CA in the server chain is trusted.\n    MWG.Allow(\"CA is trusted\")\n} ELSE {\n    // The first known CA in the server chain is not trusted.\n    MWG.Block(\"CA is not trusted\")\n}"}, {"name": "MWG.ServerChainFoundKnownCA (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the provided server certificate chain includes a certificate authority from the known CA list.", "parameter_desc": "MWG.CertificateVerificationSetting: Specifies the verification settings for the certificate; MWG.CertificateAuthorityList: Lists the trusted certificate authorities.", "description": "Returns TRUE if the server certificate chain contains a known CA", "example_code": "// Define the certificate verification settings\nMWG.CertificateVerificationSetting certVerificationSetting\n// Define the known CA list\nMWG.CertificateAuthorityList knownCAList = [\"KnownCAList\"]\n\n// Check if the server certificate chain is found in the known CA list\nBOOLEAN isKnownCA = MWG.ServerChainFoundKnownCA(certVerificationSetting, knownCAList)\n\n// Take action based on the result\nIF isKnownCA THEN {\n    // Server certificate chain is found in the known CA list.\n    MWG.Allow(\"Certificate verified with known CA\")\n} ELSE {\n    // Server certificate chain is NOT found in the known CA list.\n    MWG.Block(\"Certificate verification failed: Unknown CA\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the certificate verification settings\nMWG.CertificateVerificationSetting certVerificationSetting\n// Define the known CA list\nMWG.CertificateAuthorityList knownCAList = [\"KnownCAList\"]\n\n// Check if the server certificate chain is found in the known CA list\nBOOLEAN isKnownCA = MWG.ServerChainFoundKnownCA(certVerificationSetting, knownCAList)\n\n// Take action based on the result\nIF isKnownCA THEN {\n    // Server certificate chain is found in the known CA list.\n    MWG.Allow(\"Certificate verified with known CA\")\n} ELSE {\n    // Server certificate chain is NOT found in the known CA list.\n    MWG.Block(\"Certificate verification failed: Unknown CA\")\n}"}, {"name": "MWG.ServerChainIssuerCNs (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a list of the common names (CNs) of the issuers in the server certificate and its chain.", "parameter_desc": "MWG.CertificateVerificationSetting: Specifies the verification settings for the certificate; MWG.CertificateAuthorityList: Lists the trusted certificate authorities.", "description": "Returns a list of the issuing CNs of server certificate and the server certificate chain", "example_code": "// Define the certificate verification settings and the certificate authority list\nMWG.CertificateVerificationSetting certVerificationSetting = ... // your certificate verification settings\nMWG.CertificateAuthorityList certAuthorityList = ... // your certificate authority list\n\n// Get the list of issuer CNs from the server certificate and its chain\nVECTOR<STRING> issuerCNs = MWG.ServerChainIssuerCNs(certVerificationSetting, certAuthorityList)\n\n// Issuer CNs: issuerCNs\n\n// Example logic: Block the request if a specific issuer CN is found\nIF \"UntrustedIssuerCN\" IN issuerCNs THEN {\n    MWG.Block(\"Connection blocked due to untrusted issuer CN\")\n} ELSE {\n    MWG.Allow(\"Issuer CNs are trusted\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the certificate verification settings and the certificate authority list\nMWG.CertificateVerificationSetting certVerificationSetting = ... // your certificate verification settings\nMWG.CertificateAuthorityList certAuthorityList = ... // your certificate authority list\n\n// Get the list of issuer CNs from the server certificate and its chain\nVECTOR<STRING> issuerCNs = MWG.ServerChainIssuerCNs(certVerificationSetting, certAuthorityList)\n\n// Issuer CNs: issuerCNs\n\n// Example logic: Block the request if a specific issuer CN is found\nIF \"UntrustedIssuerCN\" IN issuerCNs THEN {\n    MWG.Block(\"Connection blocked due to untrusted issuer CN\")\n} ELSE {\n    MWG.Allow(\"Issuer CNs are trusted\")\n}"}, {"name": "MWG.ServerChainLength (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "NUMBER", "return_desc": "Returns the number of certificates in the server certificate chain.", "parameter_desc": "MWG.CertificateVerificationSetting: Specifies the verification settings for the certificate; MWG.CertificateAuthorityList: Lists the trusted certificate authorities.", "description": "Returns the length of server certificate chain", "example_code": "// Initialize or obtain the certificate verification setting\nMWG.CertificateVerificationSetting certVerificationSetting = // Your initialization code here\n\n// Initialize or obtain the certificate authority list\nMWG.CertificateAuthorityList certAuthorityList = // Your initialization code here\n\n// Get the length of the server certificate chain\nNUMBER chainLength = MWG.ServerChainLength(certVerificationSetting, certAuthorityList)\n\n// Server chain length: \" + chainLength\n\n// Conditional check to block or allow based on chain length\nIF chainLength > 5 THEN {\n    MWG.Block(\"Certificate chain length exceeds the allowed limit.\")\n} ELSE {\n    MWG.Allow(\"Certificate chain length is within the allowed limit.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize or obtain the certificate verification setting\nMWG.CertificateVerificationSetting certVerificationSetting = // Your initialization code here\n\n// Initialize or obtain the certificate authority list\nMWG.CertificateAuthorityList certAuthorityList = // Your initialization code here\n\n// Get the length of the server certificate chain\nNUMBER chainLength = MWG.ServerChainLength(certVerificationSetting, certAuthorityList)\n\n// Server chain length: \" + chainLength\n\n// Conditional check to block or allow based on chain length\nIF chainLength > 5 THEN {\n    MWG.Block(\"Certificate chain length exceeds the allowed limit.\")\n} ELSE {\n    MWG.Allow(\"Certificate chain length is within the allowed limit.\")\n}"}, {"name": "MWG.ServerChainRevocationStatiKnown (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if it can determine the revocation status of the server certificate or the entire server certificate chain.", "parameter_desc": "MWG.CertificateVerificationSetting: Specifies the verification settings for the certificate; MWG.CertificateAuthorityList: Lists the trusted certificate authorities.", "description": "Returns TRUE if the revocation status of server certificate or server certificate chain is known", "example_code": "// Initialize the certificate verification setting\nMWG.CertificateVerificationSetting certVerificationSetting = MWG.CertificateVerificationSetting()\n\n// Initialize the certificate authority list\nMWG.CertificateAuthorityList certAuthorityList = MWG.CertificateAuthorityList()\n\n// Call the function to check if the server chain revocation status is known\nBOOLEAN isRevocationStatusKnown = MWG.ServerChainRevocationStatiKnown(certVerificationSetting, certAuthorityList)\n\n// Take action based on the revocation status\nIF isRevocationStatusKnown THEN {\n    // Certificate revocation status is known.\n    // Additional logic if revocation status is known\n} ELSE {\n    // Certificate revocation status is not known.\n    // Additional logic if revocation status is not known\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize the certificate verification setting\nMWG.CertificateVerificationSetting certVerificationSetting = MWG.CertificateVerificationSetting()\n\n// Initialize the certificate authority list\nMWG.CertificateAuthorityList certAuthorityList = MWG.CertificateAuthorityList()\n\n// Call the function to check if the server chain revocation status is known\nBOOLEAN isRevocationStatusKnown = MWG.ServerChainRevocationStatiKnown(certVerificationSetting, certAuthorityList)\n\n// Take action based on the revocation status\nIF isRevocationStatusKnown THEN {\n    // Certificate revocation status is known.\n    // Additional logic if revocation status is known\n} ELSE {\n    // Certificate revocation status is not known.\n    // Additional logic if revocation status is not known\n}"}, {"name": "MWG.ServerChainSignatureAlgorithms (MWG.CertificateVerificationSetting, MWG.CertificateAuthorityList)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing the algorithms used in the server certificate chain signatures.", "parameter_desc": "MWG.CertificateVerificationSetting: Specifies the verification settings for the certificate; MWG.CertificateAuthorityList: Lists the trusted certificate authorities.", "description": "Returns a list of the algorithms in server certificate chain signatures", "example_code": "MWG.CertificateVerificationSetting certVerificationSetting = // Initialize with appropriate settings\nMWG.CertificateAuthorityList certAuthorityList = // Initialize with appropriate CA list\n\nVECTOR<STRING> signatureAlgorithms = MWG.ServerChainSignatureAlgorithms(certVerificationSetting, certAuthorityList)\n\n// Server Chain Signature Algorithms: \" + signatureAlgorithms", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.CertificateVerificationSetting certVerificationSetting = // Initialize with appropriate settings\nMWG.CertificateAuthorityList certAuthorityList = // Initialize with appropriate CA list\n\nVECTOR<STRING> signatureAlgorithms = MWG.ServerChainSignatureAlgorithms(certVerificationSetting, certAuthorityList)\n\n// Server Chain Signature Algorithms: \" + signatureAlgorithms"}, {"name": "MWG.ServerHostAndCert ()", "return_type": "MWG.HostAndCertificate", "return_desc": "Returns the server hostname and certificate.", "parameter_desc": "None", "description": "Returns the server hostname and certificate", "example_code": "MWG.HostAndCertificate serverInfo = MWG.ServerHostAndCert()\n// Server Hostname: \" + serverInfo.Hostname\n// Server Certificate: \" + serverInfo.Certificate", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.HostAndCertificate serverInfo = MWG.ServerHostAndCert()\n// Server Hostname: \" + serverInfo.Hostname\n// Server Certificate: \" + serverInfo.Certificate"}, {"name": "MWG.ServerKeyExChangeBits ()", "return_type": "NUMBER", "return_desc": "Returns the number of bits used for the key exchange with the server.", "parameter_desc": "None", "description": "Returns the NUMBER of bits used for the key exchange with the server", "example_code": "NUMBER keyExchangeBits = MWG.ServerKeyExChangeBits()\n\nIF keyExchangeBits < 2048 THEN {\n    // Key exchange bits are less than 2048. Blocking connection.\n    MWG.Block(\"Insecure key exchange: less than 2048 bits\")\n} ELSE {\n    // Key exchange bits are secure.\n    MWG.Allow(\"Secure key exchange\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER keyExchangeBits = MWG.ServerKeyExChangeBits()\n\nIF keyExchangeBits < 2048 THEN {\n    // Key exchange bits are less than 2048. Blocking connection.\n    MWG.Block(\"Insecure key exchange: less than 2048 bits\")\n} ELSE {\n    // Key exchange bits are secure.\n    MWG.Allow(\"Secure key exchange\")\n}"}, {"name": "MWG.ServerOnlyCert ()", "return_type": "MWG.HostAndCertificate", "return_desc": "Returns the server certificate.", "parameter_desc": "None", "description": "Returns the server certificate", "example_code": "MWG.HostAndCertificate serverCert = MWG.ServerOnlyCert()\n\n// Server Certificate: \" + serverCert\n\n// You can add additional logic here to inspect the certificate and take action\n// For example, blocking the request if the certificate is not trusted\nIF NOT serverCert.isTrusted THEN {\n    MWG.Block(\"Untrusted server certificate\")\n} ELSE {\n    MWG.Allow(\"Server certificate is trusted\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.HostAndCertificate serverCert = MWG.ServerOnlyCert()\n\n// Server Certificate: \" + serverCert\n\n// You can add additional logic here to inspect the certificate and take action\n// For example, blocking the request if the certificate is not trusted\nIF NOT serverCert.isTrusted THEN {\n    MWG.Block(\"Untrusted server certificate\")\n} ELSE {\n    MWG.Allow(\"Server certificate is trusted\")\n}"}, {"name": "MWG.ServiceAndActivityContained (VECTOR<MWG.ServiceCategoryAndActivityType>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current service subcategory and activity are present in the provided list, otherwise`FALSE`", "parameter_desc": "VECTOR: A list of service subcategories and activities to be checked against.", "description": "check if the current service subcategory and activity are contained in the list", "example_code": "VECTOR<MWG.ServiceCategoryAndActivityType> serviceActivities = [\"example_service_activity_list\"]\n\nIF MWG.ServiceAndActivityContained(serviceActivities) THEN {\n    // Service and Activity are contained in the list.\n    MWG.Allow(\"Service and Activity Check Passed\")\n} ELSE {\n    // Service and Activity are NOT contained in the list.\n    MWG.Block(\"Service and Activity Check Failed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.ServiceCategoryAndActivityType> serviceActivities = [\"example_service_activity_list\"]\n\nIF MWG.ServiceAndActivityContained(serviceActivities) THEN {\n    // Service and Activity are contained in the list.\n    MWG.Allow(\"Service and Activity Check Passed\")\n} ELSE {\n    // Service and Activity are NOT contained in the list.\n    MWG.Block(\"Service and Activity Check Failed\")\n}"}, {"name": "MWG.ServiceAndActivityContained (VECTOR<MWG.ServiceGroupAndActivityType>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current service and activity are found in the provided list, otherwise returns`FALSE`", "parameter_desc": "VECTOR: the list in which the functino checks if the current service and activity are contained.", "description": "check if the current service and activity are contained in list", "example_code": "VECTOR<MWG.ServiceGroupAndActivityType> serviceAndActivityList = [\"example_service_and_activity_list\"]\n\nIF MWG.ServiceAndActivityContained(serviceAndActivityList) THEN {\n    // Service and Activity is contained in the list.\n    MWG.Allow(\"Service and Activity allowed\")\n} ELSE {\n    // Service and Activity is not contained in the list.\n    MWG.Block(\"Service and Activity blocked\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.ServiceGroupAndActivityType> serviceAndActivityList = [\"example_service_and_activity_list\"]\n\nIF MWG.ServiceAndActivityContained(serviceAndActivityList) THEN {\n    // Service and Activity is contained in the list.\n    MWG.Allow(\"Service and Activity allowed\")\n} ELSE {\n    // Service and Activity is not contained in the list.\n    MWG.Block(\"Service and Activity blocked\")\n}"}, {"name": "MWG.ServiceAndActivityContained (VECTOR<MWG.ServiceSubCategoryAndActivityType>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current service subcategory and activity are in the provided list, otherwise`FALSE`", "parameter_desc": "VECTOR: A list containing potential service subcategories and activities to be checked against.", "description": "check if the current service subcategory and activity are contained in the list", "example_code": "// Define a vector of MWG.ServiceSubCategoryAndActivityType\nVECTOR<MWG.ServiceSubCategoryAndActivityType> serviceActivities = [\"SocialMedia\", \"StreamingMedia\"]\n\n// Check if the current request's service and activity type is contained in the vector\nIF MWG.ServiceAndActivityContained(serviceActivities) THEN {\n    // Block the request if the service and activity type is contained in the vector\n    MWG.Block(\"Access to this service and activity type is not allowed.\")\n} ELSE {\n    // Allow the request if the service and activity type is not contained in the vector\n    MWG.Allow(\"Service and activity type is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a vector of MWG.ServiceSubCategoryAndActivityType\nVECTOR<MWG.ServiceSubCategoryAndActivityType> serviceActivities = [\"SocialMedia\", \"StreamingMedia\"]\n\n// Check if the current request's service and activity type is contained in the vector\nIF MWG.ServiceAndActivityContained(serviceActivities) THEN {\n    // Block the request if the service and activity type is contained in the vector\n    MWG.Block(\"Access to this service and activity type is not allowed.\")\n} ELSE {\n    // Allow the request if the service and activity type is not contained in the vector\n    MWG.Allow(\"Service and activity type is allowed.\")\n}"}, {"name": "MWG.ServiceIsContainedInServiceGroups (VECTOR<MWG.ApplicationServiceGroupType>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current service is part of the specified service groups, otherwise`FALSE`", "parameter_desc": "VECTOR: A list of service groups to check against the current service.", "description": "check if the current service is contained in one of service groups", "example_code": "VECTOR<MWG.ApplicationServiceGroupType> serviceGroups = [\"Group1\", \"Group2\", \"Group3\"]\n\nIF MWG.ServiceIsContainedInServiceGroups(serviceGroups) THEN {\n    // The service is contained in one of the specified groups.\n    MWG.Allow(\"Service is allowed because it is in the specified groups\")\n} ELSE {\n    // The service is not contained in any of the specified groups.\n    MWG.Block(\"Service is blocked because it is not in the specified groups\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.ApplicationServiceGroupType> serviceGroups = [\"Group1\", \"Group2\", \"Group3\"]\n\nIF MWG.ServiceIsContainedInServiceGroups(serviceGroups) THEN {\n    // The service is contained in one of the specified groups.\n    MWG.Allow(\"Service is allowed because it is in the specified groups\")\n} ELSE {\n    // The service is not contained in any of the specified groups.\n    MWG.Block(\"Service is blocked because it is not in the specified groups\")\n}"}, {"name": "MWG.SmartMatch (MWG.URL, MWG.SmartMatchList)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the provided URL matches any pattern in the SmartMatchList.", "parameter_desc": "MWG.URL: the URL to be evaluated for a match.MWG.SmartMatchList: the list of criteria used to determine a match against the URL.", "description": "Returns TRUE if Smart Match matches a URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nVECTOR<STRING> smartMatchList = [\"example_smart_match_list\"]\n\nIF MWG.SmartMatch(currentUrl, smartMatchList) THEN {\n    // URL matches the smart match list\n    MWG.Block(\"Access to this URL is blocked as it matches a restricted category.\")\n} ELSE {\n    // URL does not match the smart match list\n    MWG.Allow(\"URL is allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nVECTOR<STRING> smartMatchList = [\"example_smart_match_list\"]\n\nIF MWG.SmartMatch(currentUrl, smartMatchList) THEN {\n    // URL matches the smart match list\n    MWG.Block(\"Access to this URL is blocked as it matches a restricted category.\")\n} ELSE {\n    // URL does not match the smart match list\n    MWG.Allow(\"URL is allowed\")\n}"}, {"name": "MWG.SmartMatch (MWG.URL, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the given URL matches the specified pattern.", "parameter_desc": "MWG.URL: The URL to be matched, STRING: The STRING to match against the URL.", "description": "Returns TRUE if Smart Match matches a URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING pattern = \"example.com\"\n\nIF MWG.SmartMatch(currentUrl, pattern) THEN {\n    // The URL matches the pattern: \" + pattern\n    MWG.Block(\"Access to this URL is blocked.\")\n} ELSE {\n    // The URL does not match the pattern: \" + pattern\n    MWG.Allow(\"URL does not match the block pattern.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING pattern = \"example.com\"\n\nIF MWG.SmartMatch(currentUrl, pattern) THEN {\n    // The URL matches the pattern: \" + pattern\n    MWG.Block(\"Access to this URL is blocked.\")\n} ELSE {\n    // The URL does not match the pattern: \" + pattern\n    MWG.Allow(\"URL does not match the block pattern.\")\n}"}, {"name": "MWG.SortJSONArray (STRING)", "return_type": "STRING", "return_desc": "Returns a string containing sorted vectors from the provided unsorted JSON array.", "parameter_desc": "STRING: the unsorted JSON array input", "description": "generate Mowgli sorted VECTORs out of unsorted data", "example_code": "// Example JSON array input\nSTRING jsonArray = '[{\"name\":\"John\",\"age\":30},{\"name\":\"Jane\",\"age\":25},{\"name\":\"Doe\",\"age\":35}]'\n\n// Call the MWG.SortJSONArray function to sort the JSON array\nSTRING sortedJsonArray = MWG.SortJSONArray(jsonArray)\n\n// Print the sorted JSON array to the console\n// sortedJsonArray", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Example JSON array input\nSTRING jsonArray = '[{\"name\":\"John\",\"age\":30},{\"name\":\"Jane\",\"age\":25},{\"name\":\"Doe\",\"age\":35}]'\n\n// Call the MWG.SortJSONArray function to sort the JSON array\nSTRING sortedJsonArray = MWG.SortJSONArray(jsonArray)\n\n// Print the sorted JSON array to the console\n// sortedJsonArray"}, {"name": "MWG.SSLClientCipher ()", "return_type": "STRING", "return_desc": "Returns the SSL client cipher.", "parameter_desc": "None", "description": "Returns the SSL client cipher", "example_code": "STRING cipher = MWG.SSLClientCipher()\n\nIF cipher == \"TLS_AES_128_GCM_SHA256\" THEN {\n    // Client is using a secure cipher: + cipher\n    MWG.Allow(\"SecureCipher\")\n} ELSE {\n    // Client is using an insecure cipher: + cipher\n    MWG.Block(\"InsecureCipher\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING cipher = MWG.SSLClientCipher()\n\nIF cipher == \"TLS_AES_128_GCM_SHA256\" THEN {\n    // Client is using a secure cipher: + cipher\n    MWG.Allow(\"SecureCipher\")\n} ELSE {\n    // Client is using an insecure cipher: + cipher\n    MWG.Block(\"InsecureCipher\")\n}"}, {"name": "MWG.SSLClientCipherKeyExchangeBits ()", "return_type": "NUMBER", "return_desc": "Returns the SSL client cipher key exchange bits.", "parameter_desc": "None", "description": "Returns the SSL client cipher key exchange bits", "example_code": "NUMBER keyExchangeBits = MWG.SSLClientCipherKeyExchangeBits()\n\nIF keyExchangeBits < 128 THEN {\n    // Connection blocked due to weak SSL cipher key exchange bits\n    MWG.Block(\"Connection blocked due to weak SSL cipher key exchange bits: \" + keyExchangeBits)\n} ELSE {\n    // SSL cipher key exchange bits are strong enough\n    MWG.Allow(\"SSL cipher key exchange bits are strong enough: \" + keyExchangeBits)\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER keyExchangeBits = MWG.SSLClientCipherKeyExchangeBits()\n\nIF keyExchangeBits < 128 THEN {\n    // Connection blocked due to weak SSL cipher key exchange bits\n    MWG.Block(\"Connection blocked due to weak SSL cipher key exchange bits: \" + keyExchangeBits)\n} ELSE {\n    // SSL cipher key exchange bits are strong enough\n    MWG.Allow(\"SSL cipher key exchange bits are strong enough: \" + keyExchangeBits)\n}"}, {"name": "MWG.SSLClientProtocol ()", "return_type": "STRING", "return_desc": "Returns the SSL client protocol.", "parameter_desc": "None", "description": "Returns the SSL client protocol", "example_code": "// Assuming MWG.SSLClientProtocol() is a function that takes no parameters and returns some value\n// Replace the following line with the correct usage of MWG.SSLClientProtocol()\nresult = MWG.SSLClientProtocol()\n\n// Example of using the result in some conditional logic\nIF result THEN {\n    // SSL Client Protocol is enabled\n} ELSE {\n    // SSL Client Protocol is not enabled\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assuming MWG.SSLClientProtocol() is a function that takes no parameters and returns some value\n// Replace the following line with the correct usage of MWG.SSLClientProtocol()\nresult = MWG.SSLClientProtocol()\n\n// Example of using the result in some conditional logic\nIF result THEN {\n    // SSL Client Protocol is enabled\n} ELSE {\n    // SSL Client Protocol is not enabled\n}"}, {"name": "MWG.SSLServerCipher ()", "return_type": "STRING", "return_desc": "Returns cipher/algorithms between proxy and server (e.g. ECDHE-RSA-AES256-GCM-SHA384).", "parameter_desc": "None", "description": "Returns cipher/algorithms between proxy and server (e.g. ECDHE-RSA-AES256-GCM-SHA384).", "example_code": "STRING cipher = MWG.SSLServerCipher()\n// The SSL server cipher is: \" + cipher\n\nIF cipher == \"ECDHE-RSA-AES256-GCM-SHA384\" THEN {\n    // The connection is using a strong cipher.\n} ELSE {\n    // The connection is not using the preferred strong cipher.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING cipher = MWG.SSLServerCipher()\n// The SSL server cipher is: \" + cipher\n\nIF cipher == \"ECDHE-RSA-AES256-GCM-SHA384\" THEN {\n    // The connection is using a strong cipher.\n} ELSE {\n    // The connection is not using the preferred strong cipher.\n}"}, {"name": "MWG.SSLServerProtocol ()", "return_type": "STRING", "return_desc": "Returns the SSL server protocol.", "parameter_desc": "None", "description": "Returns the SSL server protocol", "example_code": "STRING sslProtocol = MWG.SSLServerProtocol()\n\nIF sslProtocol == \"TLSv1.2\" THEN {\n    // The SSL server protocol is TLSv1.2\n} ELSE {\n    // The SSL server protocol is not TLSv1.2, it is: \" + sslProtocol\n    MWG.Block(\"Unsupported SSL protocol: \" + sslProtocol)\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING sslProtocol = MWG.SSLServerProtocol()\n\nIF sslProtocol == \"TLSv1.2\" THEN {\n    // The SSL server protocol is TLSv1.2\n} ELSE {\n    // The SSL server protocol is not TLSv1.2, it is: \" + sslProtocol\n    MWG.Block(\"Unsupported SSL protocol: \" + sslProtocol)\n}"}, {"name": "MWG.StatusCode (MWG.RequestResponse)", "return_type": "NUMBER", "return_desc": "Returns the HTTP status code associated with the given request or response.", "parameter_desc": "MWG.RequestResponse: The input representing either the request or response whose HTTP status code is to be returned.", "description": "Returns the HTTP status code of a request or response", "example_code": "NUMBER customStatusCode = 404\nMWG.SetHTTPStatusCode(customStatusCode)\n// Custom status code set to 404", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER customStatusCode = 404\nMWG.SetHTTPStatusCode(customStatusCode)\n// Custom status code set to 404"}, {"name": "MWG.StreamProbability ()", "return_type": "NUMBER", "return_desc": "Returns the probability of the body being an audio or video stream.", "parameter_desc": "None", "description": "Returns the probability of the body being an audio or video stream", "example_code": "NUMBER probability = MWG.StreamProbability()\n\nIF probability > 0.5 THEN {\n    // High probability detected: \" + probability\n    MWG.Block(\"High probability of unwanted content\")\n} ELSE {\n    // Low probability detected: \" + probability\n    MWG.Allow(\"Low probability, allowing request\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER probability = MWG.StreamProbability()\n\nIF probability > 0.5 THEN {\n    // High probability detected: \" + probability\n    MWG.Block(\"High probability of unwanted content\")\n} ELSE {\n    // Low probability detected: \" + probability\n    MWG.Allow(\"Low probability, allowing request\")\n}"}, {"name": "MWG.STRINGListByID (STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector corresponding to the provided string ID.", "parameter_desc": "STRING: the ID used to retrieve the VECTOR.", "description": "Retrieves a VECTOR by ID", "example_code": "// Define the ID of the string list you want to retrieve\nSTRING listID = \"example_list_id\"\n\n// Retrieve the VECTOR<STRING> using the MWG.StringListByID function\nVECTOR<STRING> urlList = MWG.StringListByID(listID)\n\n// Get the current URL\nMWG.URL currentURL = MWG.Url()\n\n// Check if the current URL is in the retrieved list\nIF currentURL.ToString() IN urlList THEN {\n    // Block the connection if the URL is in the list\n    MWG.Block(\"Access to this URL is blocked as it is in the restricted list.\")\n} ELSE {\n    // Allow the connection if the URL is not in the list\n    MWG.Allow(\"URL is not in the restricted list.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the ID of the string list you want to retrieve\nSTRING listID = \"example_list_id\"\n\n// Retrieve the VECTOR<STRING> using the MWG.StringListByID function\nVECTOR<STRING> urlList = MWG.StringListByID(listID)\n\n// Get the current URL\nMWG.URL currentURL = MWG.Url()\n\n// Check if the current URL is in the retrieved list\nIF currentURL.ToString() IN urlList THEN {\n    // Block the connection if the URL is in the list\n    MWG.Block(\"Access to this URL is blocked as it is in the restricted list.\")\n} ELSE {\n    // Allow the connection if the URL is not in the list\n    MWG.Allow(\"URL is not in the restricted list.\")\n}"}, {"name": "MWG.STRINGListByName (STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector corresponding to the specified list name.", "parameter_desc": "STRING: The name of the list to retrieve.", "description": "Retrieves a VECTOR by list name", "example_code": "// Retrieve the list of strings by name\nVECTOR<STRING> myList = MWG.StringListByName(\"example_list_name\")\n\n// Iterate through the list and print each string\nFOR EACH STRING item IN myList {\n    // item\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the list of strings by name\nVECTOR<STRING> myList = MWG.StringListByName(\"example_list_name\")\n\n// Iterate through the list and print each string\nFOR EACH STRING item IN myList {\n    // item\n}"}, {"name": "MWG.STRINGListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns true if Vector<String> list with the name exists.", "parameter_desc": "STRING: the name of the list to check for.", "description": "Returns TRUE if VECTOR<STRING> list with the name exists", "example_code": "STRING listName = \"example_list\"\n\nIF MWG.StringListByNameExists(listName) THEN {\n    // The list \" + listName + \" exists.\n} ELSE {\n    // The list \" + listName + \" does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING listName = \"example_list\"\n\nIF MWG.StringListByNameExists(listName) THEN {\n    // The list \" + listName + \" exists.\n} ELSE {\n    // The list \" + listName + \" does not exist.\n}"}, {"name": "MWG.TIEFileReputation (MWG.TIEFileReputationSetting)", "return_type": "NUMBER", "return_desc": "Returns a numerical rating of the file's reputation from the TIE server for the current body.", "parameter_desc": "MWG.TIEFileReputationSetting: the configuration settings for retrieving the file reputation rating from the TIE server for the current body.", "description": "file reputation from TIE server rating for current body", "example_code": "MWG.TIEFileReputationSetting reputationSetting\n\n// Assuming there's a function to get the file reputation setting\nreputationSetting = MWG.GetFileReputationSetting()\n\nIF reputationSetting.IsMalicious THEN {\n    MWG.Block(\"File is malicious\")\n} ELSE {\n    MWG.Allow(\"File is safe\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.TIEFileReputationSetting reputationSetting\n\n// Assuming there's a function to get the file reputation setting\nreputationSetting = MWG.GetFileReputationSetting()\n\nIF reputationSetting.IsMalicious THEN {\n    MWG.Block(\"File is malicious\")\n} ELSE {\n    MWG.Allow(\"File is safe\")\n}"}, {"name": "MWG.TimeForExternals ()", "return_type": "NUMBER", "return_desc": "Returns the total amount of time waited for a transaction.", "parameter_desc": "None", "description": "Returns the total amount of time waited for a transaction", "example_code": "// Get the total amount of time waited for a transaction\nNUMBER externalTime = MWG.TimeForExternals()\n\n// Total time waited for externals: \" + externalTime\n\n// If the external time exceeds a certain threshold, block the request\nIF externalTime > 5000 THEN {\n    MWG.Block(\"Request blocked due to excessive external wait time\")\n} ELSE {\n    MWG.Allow(\"Request allowed with acceptable external wait time\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the total amount of time waited for a transaction\nNUMBER externalTime = MWG.TimeForExternals()\n\n// Total time waited for externals: \" + externalTime\n\n// If the external time exceeds a certain threshold, block the request\nIF externalTime > 5000 THEN {\n    MWG.Block(\"Request blocked due to excessive external wait time\")\n} ELSE {\n    MWG.Allow(\"Request allowed with acceptable external wait time\")\n}"}, {"name": "MWG.TimeForTransaction ()", "return_type": "NUMBER", "return_desc": "Returns the total duration of the transaction.", "parameter_desc": "None", "description": "Returns the total duration of transaction", "example_code": "NUMBER transactionTime = MWG.TimeForTransaction()\n// Total transaction time: transactionTime milliseconds", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER transactionTime = MWG.TimeForTransaction()\n// Total transaction time: transactionTime milliseconds"}, {"name": "MWG.ToMWGSetting (MWG.AntimalwareSetting)", "return_type": "MWG.InternalSetting", "return_desc": "Returns the `MWG.InternalSetting equivalent`.", "parameter_desc": "MWG.AntimalwareSetting: the setting to convert.", "description": "Casts an MWG.AntimalwareSetting to a more general MWG.InternalSetting.", "example_code": "// Create an instance of MWG.AntimalwareSetting\nMWG.AntimalwareSetting antimalwareSetting = MWG.ToMWGSetting(MWG.AntimalwareSetting)\n\n// Configure the antimalware setting as needed\nantimalwareSetting.enable = TRUE\nantimalwareSetting.scanLevel = \"High\"\nantimalwareSetting.actionOnDetection = \"Block\"\n\n// Apply the antimalware setting\nMWG.SetAntimalwareSetting(antimalwareSetting)\n\n// Antimalware setting applied with high scan level and block action.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of MWG.AntimalwareSetting\nMWG.AntimalwareSetting antimalwareSetting = MWG.ToMWGSetting(MWG.AntimalwareSetting)\n\n// Configure the antimalware setting as needed\nantimalwareSetting.enable = TRUE\nantimalwareSetting.scanLevel = \"High\"\nantimalwareSetting.actionOnDetection = \"Block\"\n\n// Apply the antimalware setting\nMWG.SetAntimalwareSetting(antimalwareSetting)\n\n// Antimalware setting applied with high scan level and block action."}, {"name": "MWG.ToMWGSetting (MWG.CloudStorageEncryptionSetting)", "return_type": "MWG.InternalSetting", "return_desc": "Returns the `MWG.InternalSetting equivalent`.", "parameter_desc": "MWG.CloudStorageEncryptionSetting: the setting to convert.", "description": "Casts an MWG.CloudStorageEncryptionSetting to a more general MWG.InternalSetting.", "example_code": "// Create an instance of MWG.CloudStorageEncryptionSupportSetting\nMWG.CloudStorageEncryptionSupportSetting encryptionSetting = MWG.CloudStorageEncryptionSupportSetting()\n\n// Convert the MWG.CloudStorageEncryptionSupportSetting to a more general MWG.InternalSetting\nMWG.InternalSetting internalSetting = MWG.ToMWGSetting(encryptionSetting)\n\n// Use the internalSetting for further processing\n// Converted setting: \" + internalSetting", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of MWG.CloudStorageEncryptionSupportSetting\nMWG.CloudStorageEncryptionSupportSetting encryptionSetting = MWG.CloudStorageEncryptionSupportSetting()\n\n// Convert the MWG.CloudStorageEncryptionSupportSetting to a more general MWG.InternalSetting\nMWG.InternalSetting internalSetting = MWG.ToMWGSetting(encryptionSetting)\n\n// Use the internalSetting for further processing\n// Converted setting: \" + internalSetting"}, {"name": "MWG.ToMWGSetting (MWG.CloudStorageEncryptionSupportSetting)", "return_type": "MWG.InternalSetting", "return_desc": "Returns the `MWG.InternalSetting equivalent`.", "parameter_desc": "MWG.CloudStorageEncryptionSupportSetting: the setting to convert.", "description": "Casts an MWG.CloudStorageEncryptionSupportSetting to a more general MWG.InternalSetting.", "example_code": "MWG.CloudStorageEncryptionSupportSetting encryptionSetting\n// Configure the encryptionSetting as needed\n// For example, you might set some properties on the encryptionSetting object here\n\n// Enable cloud storage encryption with the configured setting\nMWG.EnableCloudStorageEncryption(encryptionSetting)\n\n// Cloud storage encryption has been enabled.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.CloudStorageEncryptionSupportSetting encryptionSetting\n// Configure the encryptionSetting as needed\n// For example, you might set some properties on the encryptionSetting object here\n\n// Enable cloud storage encryption with the configured setting\nMWG.EnableCloudStorageEncryption(encryptionSetting)\n\n// Cloud storage encryption has been enabled."}, {"name": "MWG.ToMWGSetting (MWG.MATDSetting)", "return_type": "MWG.InternalSetting", "return_desc": "Returns the `MWG.InternalSetting equivalent`.", "parameter_desc": "MWG.MATDSetting: the setting to convert.", "description": "Casts an MWG.MATDSetting to a more general MWG.InternalSetting.", "example_code": "// Create an instance of MWG.MATDSetting\nMWG.MATDSetting matdSetting\n\n// Configure the MATD setting (this is just an example, actual configuration may vary)\nmatdSetting.someProperty = \"someValue\"\n\n// Convert the MATD setting to a generic MWG setting\nMWG.InternalSetting genericSetting = MWG.ToMWGSetting(matdSetting)\n\n// Use the generic setting in some way\nMWG.ExecuteEvent(genericSetting, \"SomeEvent\", MWG.InternalParameterList())\n\n// Allow the connection\nMWG.Allow(\"configureMATD completed\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of MWG.MATDSetting\nMWG.MATDSetting matdSetting\n\n// Configure the MATD setting (this is just an example, actual configuration may vary)\nmatdSetting.someProperty = \"someValue\"\n\n// Convert the MATD setting to a generic MWG setting\nMWG.InternalSetting genericSetting = MWG.ToMWGSetting(matdSetting)\n\n// Use the generic setting in some way\nMWG.ExecuteEvent(genericSetting, \"SomeEvent\", MWG.InternalParameterList())\n\n// Allow the connection\nMWG.Allow(\"configureMATD completed\")"}, {"name": "MWG.ToSTRING (MWG.URL)", "return_type": "STRING", "return_desc": "Returns the URL converted to a string.", "parameter_desc": "MWG.URL: The URL object to be converted to a STRING.", "description": "Return a URL as a STRING", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = MWG.ToString(currentUrl)\n// Current URL: \" + urlString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = MWG.ToString(currentUrl)\n// Current URL: \" + urlString"}, {"name": "MWG.TracingInformation ()", "return_type": "JSON", "return_desc": "Returns the header from the tracing file as a JSON object.", "parameter_desc": "None", "description": "Get the tracing file header information.", "example_code": "// Retrieve tracing information\nSTRING traceInfo = MWG.TracingInformation()\n\n// The following line would print the tracing information to the console for debugging\n// traceInfo", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve tracing information\nSTRING traceInfo = MWG.TracingInformation()\n\n// The following line would print the tracing information to the console for debugging\n// traceInfo"}, {"name": "MWG.Url ()", "return_type": "MWG.URL", "return_desc": "Returns the URL of the current trigger.", "parameter_desc": "None", "description": "Returns the URL of a request", "example_code": "MWG.URL currentUrl = MWG.Url()\n// The current URL is: + currentUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\n// The current URL is: + currentUrl"}, {"name": "MWG.UrlCategories (MWG.InternalSetting)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns a vector of GTI categories associated with the URL.", "parameter_desc": "MWG.InternalSetting: the configuration settings for the URL categorization process.", "description": "Logging: Return GTI categories of the URL", "example_code": "MWG.UrlCategorizationSetting urlCategorization = MWG.UrlCategories()\nVECTOR<MWG.UrlCategory> categories = urlCategorization.GetCategories(MWG.Url())\n\nIF \"Malicious Sites\" IN categories THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorization = MWG.UrlCategories()\nVECTOR<MWG.UrlCategory> categories = urlCategorization.GetCategories(MWG.Url())\n\nIF \"Malicious Sites\" IN categories THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}"}, {"name": "MWG.UrlCategories (MWG.UrlCategorizationSetting)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns a vector containing the GTI categories for the given URL.", "parameter_desc": "MWG.UrlCategorizationSetting: Configuration settings for URL categorization.", "description": "Return GTI categories of the URL", "example_code": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategories()\nVECTOR<MWG.UrlCategory> categories = urlCategorizationSetting.GetCategories(MWG.Url())\n\n// Check if the URL is categorized as \"Malicious Sites\"\nFOR EACH category IN categories {\n    IF category.GetName() == \"Malicious Sites\" THEN {\n        MWG.Block(\"Access to malicious sites is blocked.\")\n    }\n}\n\n// If no malicious category is found, allow the request\nMWG.Allow(\"URL is safe.\")", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategories()\nVECTOR<MWG.UrlCategory> categories = urlCategorizationSetting.GetCategories(MWG.Url())\n\n// Check if the URL is categorized as \"Malicious Sites\"\nFOR EACH category IN categories {\n    IF category.GetName() == \"Malicious Sites\" THEN {\n        MWG.Block(\"Access to malicious sites is blocked.\")\n    }\n}\n\n// If no malicious category is found, allow the request\nMWG.Allow(\"URL is safe.\")"}, {"name": "MWG.UrlCategories (MWG.UrlCategorizationSetting, STRING)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns a vector containing the GTI categories of the specified URL.", "parameter_desc": "MWG.UrlCategorizationSetting: configuration settings; STRING: the URL.", "description": "Returns the GTI categories of the URL", "example_code": "// Initialize the URL categorization setting\nMWG.UrlCategorizationSetting categorizationSetting = [\"DefaultCategorization\"]\n\n// Get the current URL as a STRING\nSTRING url = MWG.Url().ToString()\n\n// Hypothetical function call to get URL categories\nVECTOR<MWG.UrlCategory> categories = MWG.UrlCategories(categorizationSetting, url)\n\n// URL: \" + url\n// Categories: \" + categories.ToString()\n\n// Check if the URL is categorized as \"Malicious\" and block it if it is\nIF \"Malicious\" IN categories THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize the URL categorization setting\nMWG.UrlCategorizationSetting categorizationSetting = [\"DefaultCategorization\"]\n\n// Get the current URL as a STRING\nSTRING url = MWG.Url().ToString()\n\n// Hypothetical function call to get URL categories\nVECTOR<MWG.UrlCategory> categories = MWG.UrlCategories(categorizationSetting, url)\n\n// URL: \" + url\n// Categories: \" + categories.ToString()\n\n// Check if the URL is categorized as \"Malicious\" and block it if it is\nIF \"Malicious\" IN categories THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is allowed.\")\n}"}, {"name": "MWG.UrlCategorizationCloudLookupDone (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the last URL categorization request was sent to the cloud, and`FALSE`otherwise.", "parameter_desc": "MWG.InternalSetting: the configuration settings;", "description": "Logging: Tells if the last request was sent to the cloud or not", "example_code": "MWG.Url currentUrl = MWG.Url()\nMWG.UrlCategorizationSetting urlCategorizationSetting\n\n// Perform the URL categorization cloud lookup\nMWG.UrlCategorizationCloudLookupDone(urlCategorizationSetting)\n\n// Check the categorization result and take action\nIF urlCategorizationSetting.IsCategorized THEN {\n    // URL has been categorized.\n    // Additional logic based on the categorization\n} ELSE {\n    // URL categorization failed or is not categorized.\n    // Handle the case where categorization is not done\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.Url currentUrl = MWG.Url()\nMWG.UrlCategorizationSetting urlCategorizationSetting\n\n// Perform the URL categorization cloud lookup\nMWG.UrlCategorizationCloudLookupDone(urlCategorizationSetting)\n\n// Check the categorization result and take action\nIF urlCategorizationSetting.IsCategorized THEN {\n    // URL has been categorized.\n    // Additional logic based on the categorization\n} ELSE {\n    // URL categorization failed or is not categorized.\n    // Handle the case where categorization is not done\n}"}, {"name": "MWG.UrlCategorizationCloudLookupDone (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the last request was sent to the cloud, otherwise`FALSE`", "parameter_desc": "MWG.UrlCategorizationSetting specifies the settings used to categorize URLs in the custom programming language.", "description": "Tells if the last request was sent to the cloud or not", "example_code": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\n\n// Perform the URL categorization cloud lookup\nMWG.UrlCategorizationCloudLookupDone(urlCategorizationSetting)\n\n// Check the result of the URL categorization\nIF urlCategorizationSetting.IsCategorized THEN {\n    VECTOR<MWG.UrlCategory> categories = urlCategorizationSetting.GetCategories()\n    \n    // Iterate through the categories and perform actions based on the category\n    FOR EACH category IN categories {\n        // Category: \" + category.GetName()\n        \n        // Example action: Block if the category is \"Malicious\"\n        IF category.GetName() == \"Malicious\" THEN {\n            MWG.Block(\"Access to malicious sites is blocked.\")\n        }\n    }\n} ELSE {\n    // URL categorization failed or no categories found.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\n\n// Perform the URL categorization cloud lookup\nMWG.UrlCategorizationCloudLookupDone(urlCategorizationSetting)\n\n// Check the result of the URL categorization\nIF urlCategorizationSetting.IsCategorized THEN {\n    VECTOR<MWG.UrlCategory> categories = urlCategorizationSetting.GetCategories()\n    \n    // Iterate through the categories and perform actions based on the category\n    FOR EACH category IN categories {\n        // Category: \" + category.GetName()\n        \n        // Example action: Block if the category is \"Malicious\"\n        IF category.GetName() == \"Malicious\" THEN {\n            MWG.Block(\"Access to malicious sites is blocked.\")\n        }\n    }\n} ELSE {\n    // URL categorization failed or no categories found.\n}"}, {"name": "MWG.UrlCategorizedByCloundLookup (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a GTI cloud lookup determines the rating result of the URL, otherwise`FALSE`", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Tells if a GTI cloud lookup has led to the rating result of the URL", "example_code": "// Create an internal setting for URL categorization by cloud lookup\nMWG.InternalSetting urlCategorizationSetting = MWG.UrlCategorizedByCloudLookup()\n\n// Execute the URL categorization\nMWG.ExecuteEvent(urlCategorizationSetting, \"CategorizeURL\")\n\n// Retrieve the URL object\nMWG.URL currentUrl = MWG.Url()\n\n// Check the category of the URL\nSTRING urlCategory = currentUrl.Category\n\n// URL Category: \" + urlCategory\n// Block or allow based on the category\nIF urlCategory == \"Malicious\" THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an internal setting for URL categorization by cloud lookup\nMWG.InternalSetting urlCategorizationSetting = MWG.UrlCategorizedByCloudLookup()\n\n// Execute the URL categorization\nMWG.ExecuteEvent(urlCategorizationSetting, \"CategorizeURL\")\n\n// Retrieve the URL object\nMWG.URL currentUrl = MWG.Url()\n\n// Check the category of the URL\nSTRING urlCategory = currentUrl.Category\n\n// URL Category: \" + urlCategory\n// Block or allow based on the category\nIF urlCategory == \"Malicious\" THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}"}, {"name": "MWG.UrlCategorizedByCloundLookup (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the URL's rating result was determined by a GTI cloud lookup, otherwise`FALSE`", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for the categorization.", "description": "Tells if a GTI cloud lookup has led to the rating result of the URL", "example_code": "MWG.UrlCategorizationSetting urlCategorizationSetting = // Initialize with appropriate settings\n\nIF MWG.UrlCategorizationCloudLookupDone(urlCategorizationSetting) THEN {\n    // URL categorization was done by cloud lookup.\n} ELSE {\n    // URL categorization was not done by cloud lookup.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorizationSetting = // Initialize with appropriate settings\n\nIF MWG.UrlCategorizationCloudLookupDone(urlCategorizationSetting) THEN {\n    // URL categorization was done by cloud lookup.\n} ELSE {\n    // URL categorization was not done by cloud lookup.\n}"}, {"name": "MWG.UrlCategorizedByDCC (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns a`BOOLEAN`indicating whether the value of GTI.UrlCategories was determined by the Dynamic Content Classifier.", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Tells if value of GTI.UrlCategories was computed by the Dynamic Content Classifier", "example_code": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizedByDCC()\n\nIF urlCategorizationSetting THEN {\n    // URL is categorized by DCC\n    MWG.Allow(\"URL categorized by DCC\")\n} ELSE {\n    // URL is not categorized by DCC\n    MWG.Block(\"URL not categorized by DCC\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizedByDCC()\n\nIF urlCategorizationSetting THEN {\n    // URL is categorized by DCC\n    MWG.Allow(\"URL categorized by DCC\")\n} ELSE {\n    // URL is not categorized by DCC\n    MWG.Block(\"URL not categorized by DCC\")\n}"}, {"name": "MWG.UrlCategorizedByDCC (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the GTI.UrlCategories value is computed by the Dynamic Content Classifier.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization.", "description": "Tells if value of GTI.UrlCategories was computed by the Dynamic Content Classifier", "example_code": "MWG.UrlCategorizationSetting settings = MWG.UrlCategorizationSetting()\n// Configure the settings object as needed\nsettings.someProperty = someValue\n\n// Apply the settings\nMWG.SetInternalGTISettings(settings)\n\n// GTI settings have been applied.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting settings = MWG.UrlCategorizationSetting()\n// Configure the settings object as needed\nsettings.someProperty = someValue\n\n// Apply the settings\nMWG.SetInternalGTISettings(settings)\n\n// GTI settings have been applied."}, {"name": "MWG.UrlCategorizedByForwardDNS (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a forward DNS lookup influences the rating result of the URL; otherwise, it returns`FALSE`", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Tells if a forward DNS lookup has led to the rating result of the URL", "example_code": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Create an instance of MWG.UrlCategorizationSetting\nMWG.UrlCategorizationSetting urlCategorizationSetting\n\n// Set the necessary properties for the URL categorization setting\n// (Assuming there are properties to set, this is just a placeholder)\n// urlCategorizationSetting.someProperty = someValue\n\n// Use the MWG.UrlCategorizedByForwardDNS function\nMWG.InternalSetting dnsCategorization = MWG.UrlCategorizedByForwardDNS(urlCategorizationSetting)\n\n// Check the result of the DNS categorization\nIF dnsCategorization THEN {\n    // URL categorized by forward DNS: \" + currentUrl\n    // Allow the connection\n    MWG.Allow(\"DNS Categorization Successful\")\n} ELSE {\n    // URL not categorized by forward DNS: \" + currentUrl\n    // Block the connection\n    MWG.Block(\"DNS Categorization Failed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Create an instance of MWG.UrlCategorizationSetting\nMWG.UrlCategorizationSetting urlCategorizationSetting\n\n// Set the necessary properties for the URL categorization setting\n// (Assuming there are properties to set, this is just a placeholder)\n// urlCategorizationSetting.someProperty = someValue\n\n// Use the MWG.UrlCategorizedByForwardDNS function\nMWG.InternalSetting dnsCategorization = MWG.UrlCategorizedByForwardDNS(urlCategorizationSetting)\n\n// Check the result of the DNS categorization\nIF dnsCategorization THEN {\n    // URL categorized by forward DNS: \" + currentUrl\n    // Allow the connection\n    MWG.Allow(\"DNS Categorization Successful\")\n} ELSE {\n    // URL not categorized by forward DNS: \" + currentUrl\n    // Block the connection\n    MWG.Block(\"DNS Categorization Failed\")\n}"}, {"name": "MWG.UrlCategorizedByForwardDNS (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the URL's rating result was determined by a forward DNS lookup.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization.", "description": "Tells if a forward DNS lookup has led to the rating result of the URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nMWG.UrlCategorizationSetting categorizationSetting = [\"default_categorization_setting\"]\n\n// Assuming there's a function to categorize the URL\nVECTOR<MWG.UrlCategory> categories = MWG.CategorizeUrl(currentUrl, categorizationSetting)\n\n// Check if the URL falls under a specific category\nIF \"Malicious\" IN categories THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nMWG.UrlCategorizationSetting categorizationSetting = [\"default_categorization_setting\"]\n\n// Assuming there's a function to categorize the URL\nVECTOR<MWG.UrlCategory> categories = MWG.CategorizeUrl(currentUrl, categorizationSetting)\n\n// Check if the URL falls under a specific category\nIF \"Malicious\" IN categories THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}"}, {"name": "MWG.UrlCategorizedByReverseDNS (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a reverse DNS lookup determines the rating of the URL, otherwise`FALSE`", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Tells if a reverse DNS lookup has led to the rating result of the URL", "example_code": "// Create an instance of the internal setting for URL categorization by reverse DNS\nMWG.InternalSetting reverseDNSSetting = MWG.UrlCategorizedByReverseDNS\n\n// Execute the internal setting\nMWG.ExecuteEvent(reverseDNSSetting)\n\n// Retrieve the categorized URL\nMWG.URL categorizedUrl = MWG.Url()\n\n// Check if the URL has been categorized by reverse DNS\nIF (categorizedUrl.IsCategorizedByReverseDNS()) THEN {\n    // Perform actions based on the URL categorization result\n    // URL categorized by reverse DNS: \" + categorizedUrl.ToString()\n    MWG.Allow(\"URLCategorizedByReverseDNS\")\n} ELSE {\n    // Perform alternative actions if the URL is not categorized by reverse DNS\n    // URL not categorized by reverse DNS: \" + categorizedUrl.ToString()\n    MWG.Block(\"URLNotCategorizedByReverseDNS\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of the internal setting for URL categorization by reverse DNS\nMWG.InternalSetting reverseDNSSetting = MWG.UrlCategorizedByReverseDNS\n\n// Execute the internal setting\nMWG.ExecuteEvent(reverseDNSSetting)\n\n// Retrieve the categorized URL\nMWG.URL categorizedUrl = MWG.Url()\n\n// Check if the URL has been categorized by reverse DNS\nIF (categorizedUrl.IsCategorizedByReverseDNS()) THEN {\n    // Perform actions based on the URL categorization result\n    // URL categorized by reverse DNS: \" + categorizedUrl.ToString()\n    MWG.Allow(\"URLCategorizedByReverseDNS\")\n} ELSE {\n    // Perform alternative actions if the URL is not categorized by reverse DNS\n    // URL not categorized by reverse DNS: \" + categorizedUrl.ToString()\n    MWG.Block(\"URLNotCategorizedByReverseDNS\")\n}"}, {"name": "MWG.UrlCategorizedByReverseDNS (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a reverse DNS lookup determines the URL's categorization rating.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization.", "description": "Tells if a reverse DNS lookup has led to the rating result of the URL", "example_code": "MWG.UrlCategorizationSetting urlCategorization = MWG.UrlCategorizationSetting()\nMWG.URL currentUrl = MWG.Url()\n\nIF urlCategorization.GetCategory(currentUrl) == \"Social Media\" THEN {\n    // Blocking access to social media sites\n    MWG.Block(\"Access to social media sites is not allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorization = MWG.UrlCategorizationSetting()\nMWG.URL currentUrl = MWG.Url()\n\nIF urlCategorization.GetCategory(currentUrl) == \"Social Media\" THEN {\n    // Blocking access to social media sites\n    MWG.Block(\"Access to social media sites is not allowed.\")\n}"}, {"name": "MWG.UrlGeolocation ()", "return_type": "STRING", "return_desc": "Returns the geolocation string of the URL.", "parameter_desc": "None", "description": "Returns the Geolocation STRING of the URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING geolocation = MWG.UrlGeolocation(currentUrl)\n// Geolocation of the URL: \" + geolocation", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING geolocation = MWG.UrlGeolocation(currentUrl)\n// Geolocation of the URL: \" + geolocation"}, {"name": "MWG.UrlGeolocation (MWG.InternalSetting)", "return_type": "STRING", "return_desc": "Returns the geolocation string associated with the URL.", "parameter_desc": "MWG.InternalSetting: Configuration or settings object required to obtain the geolocation of the URL.", "description": "Logging: Returns the Geolocation STRING of the URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\n// Assuming there is a function to get geolocation information\n// This is a placeholder as the actual function is not provided\n// MAP<STRING><STRING> geolocationInfo = MWG.GetUrlGeolocation(urlString)\n\n// Example of how you might use the geolocation information\n// IF geolocationInfo[\"country\"] == \"US\" THEN {\n//     // Accessing a URL from the United States: \" + urlString\n// } ELSE {\n//     // Accessing a URL from outside the United States: \" + urlString\n// }", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\n// Assuming there is a function to get geolocation information\n// This is a placeholder as the actual function is not provided\n// MAP<STRING><STRING> geolocationInfo = MWG.GetUrlGeolocation(urlString)\n\n// Example of how you might use the geolocation information\n// IF geolocationInfo[\"country\"] == \"US\" THEN {\n//     // Accessing a URL from the United States: \" + urlString\n// } ELSE {\n//     // Accessing a URL from outside the United States: \" + urlString\n// }"}, {"name": "MWG.UrlGeolocation (MWG.UrlCategorizationSetting, STRING)", "return_type": "STRING", "return_desc": "Returns the geolocation string of the given URL.", "parameter_desc": "MWG.UrlCategorizationSetting: Configuration settings for URL categorization; STRING: the url.", "description": "Get Geolocation of given URL.", "example_code": "// Create a URL categorization setting object\nMWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\n\n// Get the current URL as a string\nSTRING url = MWG.Url().ToString()\n\n// Get the geolocation of the URL\nSTRING geolocation = MWG.UrlGeolocation(urlCategorizationSetting, url)\n\n// Geolocation of the URL: \" + geolocation\n\n// Example condition based on geolocation\nIF geolocation == \"US\" THEN {\n    // Accessing a US-based URL\n    MWG.Allow(\"US-based URL allowed\")\n} ELSE {\n    // Accessing a non-US-based URL\n    MWG.Block(\"Non-US-based URL blocked\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a URL categorization setting object\nMWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\n\n// Get the current URL as a string\nSTRING url = MWG.Url().ToString()\n\n// Get the geolocation of the URL\nSTRING geolocation = MWG.UrlGeolocation(urlCategorizationSetting, url)\n\n// Geolocation of the URL: \" + geolocation\n\n// Example condition based on geolocation\nIF geolocation == \"US\" THEN {\n    // Accessing a US-based URL\n    MWG.Allow(\"US-based URL allowed\")\n} ELSE {\n    // Accessing a non-US-based URL\n    MWG.Block(\"Non-US-based URL blocked\")\n}"}, {"name": "MWG.UrlGeolocation (STRING)", "return_type": "STRING", "return_desc": "Returns the geographic location associated with the given URL as a string.", "parameter_desc": "STRING: the URL.", "description": "Geolocation STRING for the given URL", "example_code": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Get the geolocation of the current URL\nSTRING geolocation = MWG.UrlGeolocation(currentUrl)\n\n// Geolocation: \" + geolocation\n// Check if the geolocation is from a restricted country\nIF geolocation == \"restricted_country\" THEN {\n    // Block access if the geolocation is from a restricted country\n    MWG.Block(\"Access from this country is restricted.\")\n} ELSE {\n    // Allow access if the geolocation check passes\n    MWG.Allow(\"Geolocation check passed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Get the geolocation of the current URL\nSTRING geolocation = MWG.UrlGeolocation(currentUrl)\n\n// Geolocation: \" + geolocation\n// Check if the geolocation is from a restricted country\nIF geolocation == \"restricted_country\" THEN {\n    // Block access if the geolocation is from a restricted country\n    MWG.Block(\"Access from this country is restricted.\")\n} ELSE {\n    // Allow access if the geolocation check passes\n    MWG.Allow(\"Geolocation check passed.\")\n}"}, {"name": "MWG.UrlHasHighRisk (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the URL is determined to be of high risk according to internal settings.", "parameter_desc": "MWG.InternalSetting: Configuration parameter indicating internal settings for URL risk assessment.", "description": "Logging: Returns 'TRUE' if the URL yields high risk", "example_code": "MWG.InternalSetting internalSetting = // Initialize with appropriate internal settings\n\nIF MWG.UrlHasHighRisk(internalSetting) THEN {\n    MWG.Block(\"Access to this URL is blocked due to high risk.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting internalSetting = // Initialize with appropriate internal settings\n\nIF MWG.UrlHasHighRisk(internalSetting) THEN {\n    MWG.Block(\"Access to this URL is blocked due to high risk.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}"}, {"name": "MWG.UrlHasHighRisk (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the URL is determined to be of high risk based on the given categorization settings.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization.", "description": "Returns 'TRUE' if the URL yields high risk", "example_code": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\n\nIF MWG.UrlHasHighRisk(urlCategorizationSetting) THEN {\n    MWG.Block(\"Access to high-risk URLs is not allowed.\")\n} ELSE {\n    MWG.Allow(\"URL is not high-risk.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\n\nIF MWG.UrlHasHighRisk(urlCategorizationSetting) THEN {\n    MWG.Block(\"Access to high-risk URLs is not allowed.\")\n} ELSE {\n    MWG.Allow(\"URL is not high-risk.\")\n}"}, {"name": "MWG.UrlHasMediumRisk (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the URL is classified as posing a medium risk.", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Returns 'TRUE' if the URL yields medium risk", "example_code": "MWG.InternalSetting settings = // Initialize or obtain the settings as needed\n\nIF MWG.UrlHasMediumRisk(settings) THEN {\n    // The URL is classified as medium risk.\n    MWG.Block(\"Access blocked due to medium risk classification.\")\n} ELSE {\n    // The URL is not classified as medium risk.\n    MWG.Allow(\"URL passed medium risk check.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting settings = // Initialize or obtain the settings as needed\n\nIF MWG.UrlHasMediumRisk(settings) THEN {\n    // The URL is classified as medium risk.\n    MWG.Block(\"Access blocked due to medium risk classification.\")\n} ELSE {\n    // The URL is not classified as medium risk.\n    MWG.Allow(\"URL passed medium risk check.\")\n}"}, {"name": "MWG.UrlHasMediumRisk (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the categorized URL is determined to have a medium level of risk.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization.", "description": "Returns 'TRUE' if the URL yields medium risk", "example_code": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize with appropriate settings\n\nIF MWG.UrlHasMediumRisk(categorizationSetting) THEN {\n    // The URL has a medium level of risk.\n    MWG.Block(\"Access to this URL is blocked due to medium risk categorization.\")\n} ELSE {\n    // The URL does not have a medium level of risk.\n    MWG.Allow(\"URL is safe to access.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize with appropriate settings\n\nIF MWG.UrlHasMediumRisk(categorizationSetting) THEN {\n    // The URL has a medium level of risk.\n    MWG.Block(\"Access to this URL is blocked due to medium risk categorization.\")\n} ELSE {\n    // The URL does not have a medium level of risk.\n    MWG.Allow(\"URL is safe to access.\")\n}"}, {"name": "MWG.UrlHasMinimalRisk (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the analyzed URL poses minimal security risk.", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Returns 'TRUE' if the URL yields minimal risk", "example_code": "MWG.InternalSetting settings = // Initialize or obtain the settings as needed\n\nIF MWG.UrlHasMinimalRisk(settings) THEN {\n    // The URL poses minimal security risk.\n    MWG.Allow(\"MinimalRiskRule\")\n} ELSE {\n    // The URL poses a potential security risk.\n    MWG.Block(\"HighRiskURL\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting settings = // Initialize or obtain the settings as needed\n\nIF MWG.UrlHasMinimalRisk(settings) THEN {\n    // The URL poses minimal security risk.\n    MWG.Allow(\"MinimalRiskRule\")\n} ELSE {\n    // The URL poses a potential security risk.\n    MWG.Block(\"HighRiskURL\")\n}"}, {"name": "MWG.UrlHasMinimalRisk (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the URL is categorized as minimal risk.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization of URLs.", "description": "Returns 'TRUE' if the URL yields minimal risk", "example_code": "// Obtain the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Initialize or obtain the URL categorization settings\nMWG.UrlCategorizationSetting categorizationSetting = // Your categorization settings here\n\n// Check if the URL has minimal risk\nIF MWG.UrlHasMinimalRisk(categorizationSetting) THEN {\n    // URL has minimal risk\n    MWG.Allow(\"MinimalRiskCheck\")\n} ELSE {\n    // URL does not have minimal risk\n    MWG.Block(\"HighRiskURL\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Obtain the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Initialize or obtain the URL categorization settings\nMWG.UrlCategorizationSetting categorizationSetting = // Your categorization settings here\n\n// Check if the URL has minimal risk\nIF MWG.UrlHasMinimalRisk(categorizationSetting) THEN {\n    // URL has minimal risk\n    MWG.Allow(\"MinimalRiskCheck\")\n} ELSE {\n    // URL does not have minimal risk\n    MWG.Block(\"HighRiskURL\")\n}"}, {"name": "MWG.UrlHasUnverifiedRisk (MWG.InternalSetting)", "return_type": "BOOLEAN", "return_desc": "Returns `TRUE` if the URL is considered to have an unverified risk.", "parameter_desc": "MWG.InternalSetting: Configuration parameter used within the function.", "description": "Logging: Returns 'TRUE' if the URL yields unverified risk", "example_code": "MWG.InternalSetting riskSetting = // Initialize or obtain the appropriate MWG.InternalSetting\n\nIF MWG.UrlHasUnverifiedRisk(riskSetting) THEN {\n    // The URL has an unverified risk.\n    MWG.Block(\"Access to this URL is blocked due to unverified risk.\")\n} ELSE {\n    // The URL does not have an unverified risk.\n    MWG.Allow(\"URL is safe\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalSetting riskSetting = // Initialize or obtain the appropriate MWG.InternalSetting\n\nIF MWG.UrlHasUnverifiedRisk(riskSetting) THEN {\n    // The URL has an unverified risk.\n    MWG.Block(\"Access to this URL is blocked due to unverified risk.\")\n} ELSE {\n    // The URL does not have an unverified risk.\n    MWG.Allow(\"URL is safe\")\n}"}, {"name": "MWG.UrlHasUnverifiedRisk (MWG.UrlCategorizationSetting)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the URL has an unverified risk according to the given categorization setting.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization.", "description": "Returns TRUE if the URL yields unverified risk", "example_code": "// Obtain the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Initialize the URL categorization setting\nMWG.UrlCategorizationSetting categorizationSetting = // Initialize or obtain the categorization setting\n\n// Check if the URL has an unverified risk\nBOOLEAN hasUnverifiedRisk = MWG.UrlHasUnverifiedRisk(categorizationSetting)\n\n// Take action based on the risk status\nIF hasUnverifiedRisk THEN {\n    // The URL has unverified risk.\n    MWG.Block(\"Access to this URL is blocked due to unverified risk.\")\n} ELSE {\n    // The URL is safe.\n    MWG.Allow(\"URL is safe\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Obtain the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Initialize the URL categorization setting\nMWG.UrlCategorizationSetting categorizationSetting = // Initialize or obtain the categorization setting\n\n// Check if the URL has an unverified risk\nBOOLEAN hasUnverifiedRisk = MWG.UrlHasUnverifiedRisk(categorizationSetting)\n\n// Take action based on the risk status\nIF hasUnverifiedRisk THEN {\n    // The URL has unverified risk.\n    MWG.Block(\"Access to this URL is blocked due to unverified risk.\")\n} ELSE {\n    // The URL is safe.\n    MWG.Allow(\"URL is safe\")\n}"}, {"name": "MWG.URLReputation (MWG.InternalSetting)", "return_type": "NUMBER", "return_desc": "Returns the GTI reputation score of the given URL as a numerical value.", "parameter_desc": "MWG.InternalSetting: A configuration parameter used to customize the behavior of the URL reputation check.", "description": "Logging: Return GTI reputation of the URL", "example_code": "MWG.URL currentUrl = MWG.Url()\nMWG.UrlCategorizationSetting urlCategory = currentUrl.GetCategorization()\n\nIF urlCategory.IsMalicious() THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nMWG.UrlCategorizationSetting urlCategory = currentUrl.GetCategorization()\n\nIF urlCategory.IsMalicious() THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}"}, {"name": "MWG.URLReputation (MWG.UrlCategorizationSetting)", "return_type": "NUMBER", "return_desc": "Returns a numerical score representing the GTI reputation of the given URL.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization.", "description": "Return GTI reputation of the URL", "example_code": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize your categorization settings here\nMWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nNUMBER reputationScore = MWG.URLReputation(categorizationSetting, urlString)\n\nIF reputationScore > 50 THEN {\n    MWG.Block(\"URL has a high risk reputation\")\n} ELSE {\n    MWG.Allow(\"URL is safe\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting categorizationSetting = // Initialize your categorization settings here\nMWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nNUMBER reputationScore = MWG.URLReputation(categorizationSetting, urlString)\n\nIF reputationScore > 50 THEN {\n    MWG.Block(\"URL has a high risk reputation\")\n} ELSE {\n    MWG.Allow(\"URL is safe\")\n}"}, {"name": "MWG.URLReputation (MWG.UrlCategorizationSetting, STRING)", "return_type": "NUMBER", "return_desc": "Returns a numeric value indicating the risk level of a given URL, ranging from -127 (Minimal Risk) to 127 (High Risk).", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization; STRING: the URL whose reputation is being checked.", "description": "Returns the reputation value for the given URL. Range is from -127 to 127, where -127 means 'Minimal Risk' and 127 means 'High Risk'", "example_code": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\nMWG.URL currentUrl = MWG.Url()\nSTRING urlCategory = urlCategorizationSetting.GetCategory(currentUrl)\n\nIF urlCategory == \"Malicious\" THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting urlCategorizationSetting = MWG.UrlCategorizationSetting()\nMWG.URL currentUrl = MWG.Url()\nSTRING urlCategory = urlCategorizationSetting.GetCategory(currentUrl)\n\nIF urlCategory == \"Malicious\" THEN {\n    MWG.Block(\"Access to malicious sites is blocked.\")\n} ELSE {\n    MWG.Allow(\"URL is safe.\")\n}"}, {"name": "MWG.URLReputationSTRING (MWG.InternalSetting)", "return_type": "STRING", "return_desc": "Returns the GTI reputation of the URL in string format.", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Return GTI reputation of the URL as STRING", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlReputation = currentUrl.ReputationString()\n\nIF urlReputation == \"Malicious\" THEN {\n    MWG.Block(\"Access to malicious site blocked\")\n} ELSE {\n    MWG.Allow(\"URL is safe\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlReputation = currentUrl.ReputationString()\n\nIF urlReputation == \"Malicious\" THEN {\n    MWG.Block(\"Access to malicious site blocked\")\n} ELSE {\n    MWG.Allow(\"URL is safe\")\n}"}, {"name": "MWG.URLReputationSTRING (MWG.UrlCategorizationSetting)", "return_type": "STRING", "return_desc": "Returns the GTI reputation score of the specified URL as a string.", "parameter_desc": "MWG.UrlCategorizationSetting: The settings that define how the URL categorization should be evaluated.", "description": "Return GTI reputation of the URL as STRING", "example_code": "MWG.UrlCategorizationSetting categorizationSetting = MWG.UrlCategorizationSetting()\nMWG.URL currentUrl = MWG.Url()\nSTRING urlReputation = MWG.URLReputationString(categorizationSetting, currentUrl)\n\nIF urlReputation == \"High Risk\" THEN {\n    MWG.Block(\"Access to this URL is blocked due to high risk reputation.\")\n} ELSE {\n    MWG.Allow(\"URL reputation is acceptable.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.UrlCategorizationSetting categorizationSetting = MWG.UrlCategorizationSetting()\nMWG.URL currentUrl = MWG.Url()\nSTRING urlReputation = MWG.URLReputationString(categorizationSetting, currentUrl)\n\nIF urlReputation == \"High Risk\" THEN {\n    MWG.Block(\"Access to this URL is blocked due to high risk reputation.\")\n} ELSE {\n    MWG.Allow(\"URL reputation is acceptable.\")\n}"}, {"name": "MWG.URLReputationSTRING (MWG.UrlCategorizationSetting, STRING)", "return_type": "STRING", "return_desc": "Returns the GTI reputation of the specified URL as a string, indicating either 'Minimal Risk', 'Unverified', 'Medium Risk', or 'High Risk'.", "parameter_desc": "MWG.UrlCategorizationSetting: the configuration settings for categorization; STRING: the URL to be evaluated for reputation.", "description": "Return GTI reputation for the given URL as STRING. Result is 'Minimal Risk', 'Unverified', 'Medium Risk', or 'High Risk'", "example_code": "// Assume we have a URL categorization setting object\nMWG.UrlCategorizationSetting urlCategorizationSetting = ... // Initialize this with the appropriate setting\n\n// The URL to check\nSTRING urlToCheck = MWG.Url().ToString()\n\n// Get the URL reputation string\nSTRING reputation = MWG.URLReputationString(urlCategorizationSetting, urlToCheck)\n\n// URL Reputation: reputation\n\n// Take action based on the reputation\nIF reputation == \"High Risk\" THEN {\n    MWG.Block(\"Access to this URL is blocked due to high risk reputation.\")\n} ELSE {\n    MWG.Allow(\"URL reputation check passed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a URL categorization setting object\nMWG.UrlCategorizationSetting urlCategorizationSetting = ... // Initialize this with the appropriate setting\n\n// The URL to check\nSTRING urlToCheck = MWG.Url().ToString()\n\n// Get the URL reputation string\nSTRING reputation = MWG.URLReputationString(urlCategorizationSetting, urlToCheck)\n\n// URL Reputation: reputation\n\n// Take action based on the reputation\nIF reputation == \"High Risk\" THEN {\n    MWG.Block(\"Access to this URL is blocked due to high risk reputation.\")\n} ELSE {\n    MWG.Allow(\"URL reputation check passed.\")\n}"}, {"name": "MWG.UserDefinedInitDone ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the user-defined initialization is done.", "parameter_desc": "None", "description": "Check if user-defined initialization is done.", "example_code": "// Initialize some user-defined settings\nVECTOR<STRING> userSettings = \"setting1\", \"setting2\", \"setting3\"\n\n// Perform some operations with the settings\nFOR EACH setting IN userSettings {\n    // Initializing: \" + setting\n    // Add your initialization logic here\n}\n\n// Mark the user-defined initialization as done\nMWG.SetUserDefinedInitDone()\n\n// User-defined initialization completed.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize some user-defined settings\nVECTOR<STRING> userSettings = \"setting1\", \"setting2\", \"setting3\"\n\n// Perform some operations with the settings\nFOR EACH setting IN userSettings {\n    // Initializing: \" + setting\n    // Add your initialization logic here\n}\n\n// Mark the user-defined initialization as done\nMWG.SetUserDefinedInitDone()\n\n// User-defined initialization completed."}, {"name": "MWG.UserDefinedVar (STRING)", "return_type": "MWG.InternalVariant", "return_desc": "Returns the value of a user-defined variable as an internal variant type.", "parameter_desc": "STRING: the name of the user-defined variable to retrieve.", "description": "Get a user defined variable", "example_code": "STRING variableName = \"exampleVar\"\nSTRING variableValue = \"exampleValue\"\n\nMWG.SetUserDefinedVar(variableName, variableValue)\n\n// User-defined variable set: exampleVar = exampleValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING variableName = \"exampleVar\"\nSTRING variableValue = \"exampleValue\"\n\nMWG.SetUserDefinedVar(variableName, variableValue)\n\n// User-defined variable set: exampleVar = exampleValue"}, {"name": "MWG.UserGroups ()", "return_type": "VECTOR<STRING>", "return_desc": "Returns authentication user groups.", "parameter_desc": "None", "description": "Returns authentication user groups", "example_code": "VECTOR<STRING> userGroups = MWG.UserGroups()\n\nIF \"admin\" IN userGroups THEN {\n    // User is in the admin group\n    MWG.Allow(\"User is admin\")\n} ELSE {\n    // User is not in the admin group\n    MWG.Block(\"Access denied: User is not an admin\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> userGroups = MWG.UserGroups()\n\nIF \"admin\" IN userGroups THEN {\n    // User is in the admin group\n    MWG.Allow(\"User is admin\")\n} ELSE {\n    // User is not in the admin group\n    MWG.Block(\"Access denied: User is not an admin\")\n}"}, {"name": "MWG.Username ()", "return_type": "STRING", "return_desc": "Returns the name of the authenticated user.", "parameter_desc": "None", "description": "Returns the name of authenticated user", "example_code": "STRING username = MWG.Username()\n// Authenticated user: \" + username", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING username = MWG.Username()\n// Authenticated user: \" + username"}, {"name": "MWG.UUID ()", "return_type": "STRING", "return_desc": "Returns UUID.", "parameter_desc": "None", "description": "Returns UUID", "example_code": "STRING uuid = MWG.UUID()\n// Generated UUID: + uuid", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING uuid = MWG.UUID()\n// Generated UUID: + uuid"}, {"name": "MWG.VirusNames (MWG.AntimalwareSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector of names of detected viruses.", "parameter_desc": "MWG.AntimalwareSetting: the antimalware configuration settings used to scan and identify viruses.", "description": "Returns names of found viruses (via GAM)", "example_code": "MWG.AntimalwareSetting antimalwareSetting = ... // Assume this is initialized with your antimalware settings\nVECTOR<STRING> virusNames = MWG.VirusNames(antimalwareSetting)\n\nIF virusNames.SIZE() > 0 THEN {\n    // Detected Viruses:\n    FOR STRING virusName IN virusNames {\n        // virusName\n    }\n    MWG.Block(\"Virus detected: \" + virusNames[0])\n} ELSE {\n    MWG.Allow(\"No viruses detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.AntimalwareSetting antimalwareSetting = ... // Assume this is initialized with your antimalware settings\nVECTOR<STRING> virusNames = MWG.VirusNames(antimalwareSetting)\n\nIF virusNames.SIZE() > 0 THEN {\n    // Detected Viruses:\n    FOR STRING virusName IN virusNames {\n        // virusName\n    }\n    MWG.Block(\"Virus detected: \" + virusNames[0])\n} ELSE {\n    MWG.Allow(\"No viruses detected\")\n}"}, {"name": "MWG.VirusNames (MWG.InternalSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing the names of detected viruses as per the internal settings.", "parameter_desc": "MWG.InternalSetting: the configuration settings.", "description": "Logging: Returns names of found viruses", "example_code": "VECTOR<STRING> virusNames = MWG.VirusNames()\n\nIF virusNames.SIZE() > 0 THEN {\n    // Viruses detected: \" + virusNames.TO_STRING()\n    MWG.Block(\"Access blocked due to detected viruses: \" + virusNames.TO_STRING())\n} ELSE {\n    // No viruses detected.\n    MWG.Allow(\"No viruses found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> virusNames = MWG.VirusNames()\n\nIF virusNames.SIZE() > 0 THEN {\n    // Viruses detected: \" + virusNames.TO_STRING()\n    MWG.Block(\"Access blocked due to detected viruses: \" + virusNames.TO_STRING())\n} ELSE {\n    // No viruses detected.\n    MWG.Allow(\"No viruses found\")\n}"}, {"name": "MWG.VirusNames (MWG.MATDSetting)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing the names of viruses detected by ATD.", "parameter_desc": "MWG.MATDSetting: Settings object for configuring the virus detection parameters.", "description": "Returns names of found viruses (via ATD)", "example_code": "// Assume we have a pre-configured MWG.MATDSetting object\nMWG.MATDSetting matdSetting = [YourMATDSetting]\n\n// Retrieve the names of detected viruses\nVECTOR<STRING> virusNames = MWG.VirusNames(matdSetting)\n\n// Check if any viruses were detected\nIF virusNames.SIZE() > 0 THEN {\n    // Detected Viruses: \n    // DEBUG(\"Detected Viruses: \" + virusNames.TO_STRING())\n    \n    // Optionally, block the connection\n    MWG.Block(\"Connection blocked due to detected viruses: \" + virusNames.TO_STRING())\n} ELSE {\n    // Allow the connection if no viruses were detected\n    MWG.Allow(\"No viruses detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a pre-configured MWG.MATDSetting object\nMWG.MATDSetting matdSetting = [YourMATDSetting]\n\n// Retrieve the names of detected viruses\nVECTOR<STRING> virusNames = MWG.VirusNames(matdSetting)\n\n// Check if any viruses were detected\nIF virusNames.SIZE() > 0 THEN {\n    // Detected Viruses: \n    // DEBUG(\"Detected Viruses: \" + virusNames.TO_STRING())\n    \n    // Optionally, block the connection\n    MWG.Block(\"Connection blocked due to detected viruses: \" + virusNames.TO_STRING())\n} ELSE {\n    // Allow the connection if no viruses were detected\n    MWG.Allow(\"No viruses detected\")\n}"}, {"name": "MWG.WebUrlCategoryListByName (STRING)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns the specified GTICategory list.", "parameter_desc": "STRING: name of list to retrieve", "description": "Retrieves a GTICategory list by name", "example_code": "// Define the category name to look up\nSTRING categoryName = \"Social Media\"\n\n// Get the list of URL categories for the given name\nVECTOR<MWG.UrlCategory> urlCategories = MWG.WebUrlCategoryListByName(categoryName)\n\n// Set a user-defined variable with the retrieved URL categories\nMWG.SetUserDefinedVar(\"UserDefinedUrlCategories\", urlCategories)\n\n// Retrieved URL Categories: \" + urlCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the category name to look up\nSTRING categoryName = \"Social Media\"\n\n// Get the list of URL categories for the given name\nVECTOR<MWG.UrlCategory> urlCategories = MWG.WebUrlCategoryListByName(categoryName)\n\n// Set a user-defined variable with the retrieved URL categories\nMWG.SetUserDefinedVar(\"UserDefinedUrlCategories\", urlCategories)\n\n// Retrieved URL Categories: \" + urlCategories"}, {"name": "MWG.WebUrlCategoryListByNameExists (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the list exists.", "parameter_desc": "STRING: name of list to check for.", "description": "Returns TRUE if GTICategory list with the name exists", "example_code": "STRING listName = \"example_list\"\n\nIF MWG.StringListByNameExists(listName) THEN {\n    // The list \"example_list\" exists.\n} ELSE {\n    // The list \"example_list\" does not exist.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING listName = \"example_list\"\n\nIF MWG.StringListByNameExists(listName) THEN {\n    // The list \"example_list\" exists.\n} ELSE {\n    // The list \"example_list\" does not exist.\n}"}, {"name": "MWG.X509CommonNamesToRegExList (VECTOR<STRING>)", "return_type": "RegExJSi.List", "return_desc": "Returns a list of regular expressions corresponding to the CN wildcard strings provided in the input vector.", "parameter_desc": "VECTOR: A collection of STRINGs in CN wildcard format.", "description": "Converts a VECTOR of STRINGs in CN wildcard format to a regex VECTOR", "example_code": "// Define a VECTOR of common names\nVECTOR<STRING> commonNames = \"example.com\", \"test.com\", \"sample.org\"\n\n// Convert the common names to a list of regular expressions\nRegExJSi.List regexList = MWG.X509CommonNamesToRegExList(commonNames)\n\n// Converted Regular Expressions: regexList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of common names\nVECTOR<STRING> commonNames = \"example.com\", \"test.com\", \"sample.org\"\n\n// Convert the common names to a list of regular expressions\nRegExJSi.List regexList = MWG.X509CommonNamesToRegExList(commonNames)\n\n// Converted Regular Expressions: regexList"}, {"name": "MWG.X509CommonNameToRegEx (STRING)", "return_type": "RegExJSi", "return_desc": "Returns a regular expression equivalent of a given wildcard-formatted common name (CN).", "parameter_desc": "STRING: the common name in wildcard format that will be converted to a regular expression.", "description": "Converts CN wildcard format to a regular expression", "example_code": "STRING commonName = \"example.com\"\nSTRING regex = MWG.X509CommonNameToRegEx(commonName)\n\n// Converted regex: \" + regex", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING commonName = \"example.com\"\nSTRING regex = MWG.X509CommonNameToRegEx(commonName)\n\n// Converted regex: \" + regex"}, {"name": "Net.Begin (Net.IPRange)", "return_type": "STRING", "return_desc": "Returns the first IP address in the given IP range as a string.", "parameter_desc": "Net.IPRange: The range of IP addresses from which the function will return the first IP as a STRING.", "description": "Return first IP of an IP range as STRING", "example_code": "Net.IPRange ipRange = \"192.168.1.0/24\"\nSTRING firstIP = Net.Begin(ipRange)\n// The first IP in the range is: firstIP", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IPRange ipRange = \"192.168.1.0/24\"\nSTRING firstIP = Net.Begin(ipRange)\n// The first IP in the range is: firstIP"}, {"name": "Net.End (Net.IPRange)", "return_type": "STRING", "return_desc": "Returns the final IP address in the specified IP range as a string.", "parameter_desc": "Net.IPRange: the range of IP address from which the last IP is to be returned as a STRING.", "description": "Return last IP of an IP range as STRING", "example_code": "// Define an IP range\nNet.IPRange ipRange = \"192.168.1.0/24\"\n\n// Get the last IP in the range\nSTRING lastIP = Net.End(ipRange)\n\n// The last IP in the range is: \" + lastIP", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define an IP range\nNet.IPRange ipRange = \"192.168.1.0/24\"\n\n// Get the last IP in the range\nSTRING lastIP = Net.End(ipRange)\n\n// The last IP in the range is: \" + lastIP"}, {"name": "Net.Get (VECTOR<Net.IP>, NUMBER, NUMBER)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns a specified range of IP addresses from a given IP list.", "parameter_desc": "VECTOR: the original IP list; NUMBER: the starting index for the subset; NUMBER: the NUMBER of IP addresses to include in the subset.", "description": "Return a subset of an IP list", "example_code": "VECTOR<Net.IP> ipList = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\", \"192.168.1.4\", \"192.168.1.5\"\nNUMBER startIndex = 1\nNUMBER count = 3\n\nVECTOR<Net.IP> subset = Net.Get(ipList, startIndex, count)\n\n// Subset of IP addresses: \" + subset", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> ipList = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\", \"192.168.1.4\", \"192.168.1.5\"\nNUMBER startIndex = 1\nNUMBER count = 3\n\nVECTOR<Net.IP> subset = Net.Get(ipList, startIndex, count)\n\n// Subset of IP addresses: \" + subset"}, {"name": "Net.Get (VECTOR<Net.IPRange>, NUMBER, NUMBER)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns a subset of the IP range list based on the given vector and numbers.", "parameter_desc": "VECTOR: the list of IP ranges; NUMBER: the starting index of the subset; NUMBER: the NUMBER of IP ranges to include in the subset.", "description": "Return a subset of an IP range list", "example_code": "// Define a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = [\"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"]\n\n// Define the starting index and the number of IP ranges to include in the subset\nNUMBER startIndex = 1\nNUMBER count = 2\n\n// Get the subset of the IP range list\nVECTOR<Net.IPRange> subset = Net.Get(ipRanges, startIndex, count)\n\n// Subset of IP ranges: \n// DEBUG(\"Subset of IP ranges: \" + subset)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = [\"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"]\n\n// Define the starting index and the number of IP ranges to include in the subset\nNUMBER startIndex = 1\nNUMBER count = 2\n\n// Get the subset of the IP range list\nVECTOR<Net.IPRange> subset = Net.Get(ipRanges, startIndex, count)\n\n// Subset of IP ranges: \n// DEBUG(\"Subset of IP ranges: \" + subset)"}, {"name": "Net.Insert (VECTOR<Net.IP>, Net.IP, NUMBER)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns the vector with the IP inserted at the specified position.", "parameter_desc": "VECTOR: The list of IPs, Net.IP: The IP to be inserted, NUMBER: The position in the list where the IP should be inserted.", "description": "Insert an IP into an IP list", "example_code": "// Initialize a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\n\n// Define the IP to be inserted\nNet.IP newIP = Net.IP(\"192.168.1.4\")\n\n// Define the position where the new IP should be inserted\nNUMBER position = 2\n\n// Insert the new IP into the VECTOR at the specified position\nNet.Insert(ipList, newIP, position)\n\n// Updated IP List: \" + ipList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\n\n// Define the IP to be inserted\nNet.IP newIP = Net.IP(\"192.168.1.4\")\n\n// Define the position where the new IP should be inserted\nNUMBER position = 2\n\n// Insert the new IP into the VECTOR at the specified position\nNet.Insert(ipList, newIP, position)\n\n// Updated IP List: \" + ipList"}, {"name": "Net.Insert (VECTOR<Net.IPRange>, Net.IPRange, NUMBER)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns a vector that includes the IP range inserted into the original IP range list.", "parameter_desc": "VECTOR: The list of IP ranges, Net.IPRange: The IP range to insert, NUMBER: The position to insert the IP range.", "description": "Insert an IP range into an IP range list", "example_code": "// Define a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\")\n\n// Define the IP range to insert\nNet.IPRange newRange = Net.IPRange(\"172.16.0.0/12\")\n\n// Insert the new IP range at position 1 (second position in the VECTOR)\nNet.Insert(ipRanges, newRange, 1)\n\n// Previously: Print the updated VECTOR to the console for debugging\n// DEBUG(ipRanges)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\")\n\n// Define the IP range to insert\nNet.IPRange newRange = Net.IPRange(\"172.16.0.0/12\")\n\n// Insert the new IP range at position 1 (second position in the VECTOR)\nNet.Insert(ipRanges, newRange, 1)\n\n// Previously: Print the updated VECTOR to the console for debugging\n// DEBUG(ipRanges)"}, {"name": "Net.IsEqual (Net.IP, Net.IP)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two IP addresses are identical, otherwise`FALSE`", "parameter_desc": "The parameters are two IP addresses to be compared for equality.", "description": "Check if two IP addresses are identical", "example_code": "Net.IP ip1 = Net.IP(\"192.168.1.1\")\nNet.IP ip2 = Net.IP(\"192.168.1.1\")\nNet.IP ip3 = Net.IP(\"10.0.0.1\")\n\nIF Net.IsEqual(ip1, ip2) THEN {\n    // ip1 is equal to ip2\n} ELSE {\n    // ip1 is not equal to ip2\n}\n\nIF Net.IsEqual(ip1, ip3) THEN {\n    // ip1 is equal to ip3\n} ELSE {\n    // ip1 is not equal to ip3\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP ip1 = Net.IP(\"192.168.1.1\")\nNet.IP ip2 = Net.IP(\"192.168.1.1\")\nNet.IP ip3 = Net.IP(\"10.0.0.1\")\n\nIF Net.IsEqual(ip1, ip2) THEN {\n    // ip1 is equal to ip2\n} ELSE {\n    // ip1 is not equal to ip2\n}\n\nIF Net.IsEqual(ip1, ip3) THEN {\n    // ip1 is equal to ip3\n} ELSE {\n    // ip1 is not equal to ip3\n}"}, {"name": "Net.IsInRange (Net.IP, Net.IPRange)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the IP address is within the specified range, otherwise`FALSE`", "parameter_desc": "Net.IP: the IP address to check; Net.IPRange: the range within which to check.", "description": "Check if an IP address is in a given range", "example_code": "Net.IP clientIP = \"192.168.1.10\"\nNet.IPRange allowedRange = \"192.168.1.0/24\"\n\nIF Net.IsInRange(clientIP, allowedRange) THEN {\n    // Client IP is within the allowed range.\n    MWG.Allow(\"IP in allowed range\")\n} ELSE {\n    // Client IP is not within the allowed range.\n    MWG.Block(\"IP not in allowed range\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP clientIP = \"192.168.1.10\"\nNet.IPRange allowedRange = \"192.168.1.0/24\"\n\nIF Net.IsInRange(clientIP, allowedRange) THEN {\n    // Client IP is within the allowed range.\n    MWG.Allow(\"IP in allowed range\")\n} ELSE {\n    // Client IP is not within the allowed range.\n    MWG.Block(\"IP not in allowed range\")\n}"}, {"name": "Net.IsInRangeList (Net.IP, VECTOR<Net.IPRange>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the given IP address falls within any of the specified IP ranges in the list, otherwise`FALSE`", "parameter_desc": "Net.IP: the IP address to be checked; VECTOR: a list of ip address ranges.", "description": "Check if an IP address is in at least one range of a list of ranges", "example_code": "// Define the IP address to check\nNet.IP clientIP = Web.Request.Client.IP\n\n// Define a list of IP ranges\nVECTOR<Net.IPRange> ipRanges = \"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"\n\n// Check if the client IP is within any of the specified ranges\nIF Net.IsInRangeList(clientIP, ipRanges) THEN {\n    // Allow the connection if the IP is within the range\n    MWG.Allow(\"IP is within the allowed range\")\n} ELSE {\n    // Block the connection if the IP is not within the range\n    MWG.Block(\"IP is not within the allowed range\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the IP address to check\nNet.IP clientIP = Web.Request.Client.IP\n\n// Define a list of IP ranges\nVECTOR<Net.IPRange> ipRanges = \"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"\n\n// Check if the client IP is within any of the specified ranges\nIF Net.IsInRangeList(clientIP, ipRanges) THEN {\n    // Allow the connection if the IP is within the range\n    MWG.Allow(\"IP is within the allowed range\")\n} ELSE {\n    // Block the connection if the IP is not within the range\n    MWG.Block(\"IP is not within the allowed range\")\n}"}, {"name": "Net.IsIPv4 (Net.IP)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the given IP address is an IPv4 address, otherwise`FALSE`", "parameter_desc": "Net.IP: An IP address to be checked if it's IPv4.", "description": "Check if IP address is IP version 4", "example_code": "STRING ipString = \"192.168.1.1\"\nNet.IP ipAddress = Net.ToIP(ipString)\n\nIF Net.IsIPv4(ipAddress) THEN {\n    // The IP address 192.168.1.1 is an IPv4 address.\n} ELSE {\n    // The IP address 192.168.1.1 is not an IPv4 address.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING ipString = \"192.168.1.1\"\nNet.IP ipAddress = Net.ToIP(ipString)\n\nIF Net.IsIPv4(ipAddress) THEN {\n    // The IP address 192.168.1.1 is an IPv4 address.\n} ELSE {\n    // The IP address 192.168.1.1 is not an IPv4 address.\n}"}, {"name": "Net.IsIPv6 (Net.IP)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the given IP address is IPv6, otherwise`FALSE`", "parameter_desc": "Net.IP: The IP address to check.", "description": "Check if IP address is IP version 6", "example_code": "Net.IP clientIP = MWG.Client.IP()\n\nIF Net.IsIPv6(clientIP) THEN {\n    // The client IP is an IPv6 address.\n} ELSE {\n    // The client IP is not an IPv6 address.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP clientIP = MWG.Client.IP()\n\nIF Net.IsIPv6(clientIP) THEN {\n    // The client IP is an IPv6 address.\n} ELSE {\n    // The client IP is not an IPv6 address.\n}"}, {"name": "Net.Overlaps (Net.IPRange, Net.IPRange)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the two IP ranges overlap, otherwise`FALSE`", "parameter_desc": "Net.IPRange parameters represent the two IP ranges to check for overlaps.", "description": "Check if two IP ranges overlap", "example_code": "VECTOR<Net.IPRange> list1 = \"192.168.1.0/24\", \"10.0.0.0/8\"\nVECTOR<Net.IPRange> list2 = \"192.168.1.128/25\", \"172.16.0.0/12\"\n\nBOOLEAN overlap = Overlaps(list1, list2)\n\nIF overlap THEN {\n    // The IP ranges overlap.\n} ELSE {\n    // The IP ranges do not overlap.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> list1 = \"192.168.1.0/24\", \"10.0.0.0/8\"\nVECTOR<Net.IPRange> list2 = \"192.168.1.128/25\", \"172.16.0.0/12\"\n\nBOOLEAN overlap = Overlaps(list1, list2)\n\nIF overlap THEN {\n    // The IP ranges overlap.\n} ELSE {\n    // The IP ranges do not overlap.\n}"}, {"name": "Net.ToIP (STRING)", "return_type": "Net.IP", "return_desc": "Returns an IP address representation of the given string.", "parameter_desc": "STRING: the IP address to be converted.", "description": "Convert a STRING to an IP address. This function is synonymous with Net.ToIPAddress().", "example_code": "STRING ipString = \"192.168.1.1\"\nNet.IP ipAddress = Net.ToIP(ipString)\n// Converted IP Address: + ipAddress", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING ipString = \"192.168.1.1\"\nNet.IP ipAddress = Net.ToIP(ipString)\n// Converted IP Address: + ipAddress"}, {"name": "Net.ToIPList (VECTOR<STRING>)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns a vector where each string in the input list is converted to an IP address.", "parameter_desc": "VECTOR: a list of STRINGs to be converted to an IP list", "description": "Convert a STRING list to an IP list", "example_code": "// Define a vector of strings representing IP addresses\nVECTOR<STRING> ipStrings = \"192.168.1.1\", \"10.0.0.1\", \"172.16.0.1\"\n\n// Convert the vector of strings to a list of Net.IP objects\nVECTOR<Net.IP> ipList = Net.ToIPList(ipStrings)\n\n// Converted IP List: \n// ipList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a vector of strings representing IP addresses\nVECTOR<STRING> ipStrings = \"192.168.1.1\", \"10.0.0.1\", \"172.16.0.1\"\n\n// Convert the vector of strings to a list of Net.IP objects\nVECTOR<Net.IP> ipList = Net.ToIPList(ipStrings)\n\n// Converted IP List: \n// ipList"}, {"name": "Net.ToIPRange (STRING)", "return_type": "Net.IPRange", "return_desc": "Returns an IP range parsed from the provided string.", "parameter_desc": "STRING: an IP address or range that will be converted to an IP range object.", "description": "Convert a STRING to an IP range", "example_code": "STRING ipRangeString = \"192.168.1.0/24\"\nNet.IPRange ipRange = Net.ToIPRange(ipRangeString)\n\n// Assuming we have a function to get the client's IP address\nNet.IP clientIP = GetClientIP()\n\nIF clientIP IN ipRange THEN {\n    // Client IP is within the specified range.\n    MWG.Allow(\"IP within range\")\n} ELSE {\n    // Client IP is not within the specified range.\n    MWG.Block(\"IP not within range\")\n}\n\n// Dummy function to simulate getting the client's IP address\nFUNCTION GetClientIP() RETURNS Net.IP {\n    // This would normally be replaced with actual logic to get the client's IP\n    RETURN Net.ToIP(\"192.168.1.5\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING ipRangeString = \"192.168.1.0/24\"\nNet.IPRange ipRange = Net.ToIPRange(ipRangeString)\n\n// Assuming we have a function to get the client's IP address\nNet.IP clientIP = GetClientIP()\n\nIF clientIP IN ipRange THEN {\n    // Client IP is within the specified range.\n    MWG.Allow(\"IP within range\")\n} ELSE {\n    // Client IP is not within the specified range.\n    MWG.Block(\"IP not within range\")\n}\n\n// Dummy function to simulate getting the client's IP address\nFUNCTION GetClientIP() RETURNS Net.IP {\n    // This would normally be replaced with actual logic to get the client's IP\n    RETURN Net.ToIP(\"192.168.1.5\")\n}"}, {"name": "Net.ToIPRange (VECTOR<STRING>)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns a vector of IP ranges converted from a vector of strings.", "parameter_desc": "VECTOR: A list of STRING representations of IP addresses to be converted into a range of IP addresses.", "description": "Convert STRING list to an IP range list", "example_code": "// Define a VECTOR of STRINGs representing IP addresses or ranges\nVECTOR<STRING> ipStrings = \"192.168.1.0/24\", \"10.0.0.1\", \"172.16.0.0/16\"\n\n// Convert the VECTOR of STRINGs to a VECTOR<Net.IPRange> object\nVECTOR<Net.IPRange> ipRanges = Net.ToIPRange(ipStrings)\n\n// Use the ipRanges object for further processing\nNet.IP testIP = Net.IP(\"192.168.1.5\")\nBOOLEAN isInRange = FALSE\n\n// Check if the testIP is within any of the defined ranges\nFOR EACH range IN ipRanges {\n    IF range.Contains(testIP) THEN {\n        isInRange = TRUE\n        BREAK\n    }\n}\n\n// Print the result\nIF isInRange THEN {\n    // IP is within the range\n} ELSE {\n    // IP is not within the range\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of STRINGs representing IP addresses or ranges\nVECTOR<STRING> ipStrings = \"192.168.1.0/24\", \"10.0.0.1\", \"172.16.0.0/16\"\n\n// Convert the VECTOR of STRINGs to a VECTOR<Net.IPRange> object\nVECTOR<Net.IPRange> ipRanges = Net.ToIPRange(ipStrings)\n\n// Use the ipRanges object for further processing\nNet.IP testIP = Net.IP(\"192.168.1.5\")\nBOOLEAN isInRange = FALSE\n\n// Check if the testIP is within any of the defined ranges\nFOR EACH range IN ipRanges {\n    IF range.Contains(testIP) THEN {\n        isInRange = TRUE\n        BREAK\n    }\n}\n\n// Print the result\nIF isInRange THEN {\n    // IP is within the range\n} ELSE {\n    // IP is not within the range\n}"}, {"name": "Net.ToSTRING (Net.IP)", "return_type": "STRING", "return_desc": "Returns the IP address as a string.", "parameter_desc": "Net.IP: the IP address to convert", "description": "Convert an IP to a STRING", "example_code": "Net.IP ipAddress = Net.IP(\"192.168.1.1\")\nSTRING ipString = Net.ToString(ipAddress)\n// The IP address as a string is: \" + ipString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "Net.IP ipAddress = Net.IP(\"192.168.1.1\")\nSTRING ipString = Net.ToString(ipAddress)\n// The IP address as a string is: \" + ipString"}, {"name": "Net.ToSTRING (Net.IPRange)", "return_type": "STRING", "return_desc": "Returns the IP address range as a string.", "parameter_desc": "Net.IPRange: the IP address range to convert", "description": "Convert an IP range to a STRING", "example_code": "// Define an IP range\nNet.IPRange ipRange = Net.IPRange(\"192.168.1.0\", \"192.168.1.255\")\n\n// Convert the IP range to a string\nSTRING ipRangeString = Net.ToString(ipRange)\n\n// The IP range is: \n// ipRangeString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define an IP range\nNet.IPRange ipRange = Net.IPRange(\"192.168.1.0\", \"192.168.1.255\")\n\n// Convert the IP range to a string\nSTRING ipRangeString = Net.ToString(ipRange)\n\n// The IP range is: \n// ipRangeString"}, {"name": "Net.ToSTRING (VECTOR<Net.IP>)", "return_type": "STRING", "return_desc": "Returns the string representation of the IP list.", "parameter_desc": "VECTOR: the list of IP address to convert", "description": "Convert an IP list to a STRING", "example_code": "// Define a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"10.0.0.1\"), Net.IP(\"172.16.0.1\");\n\n// Convert the VECTOR of Net.IP to a STRING\nSTRING ipString = Net.ToString(ipList);\n\n// Print the resulting STRING to the console was previously done here\n// ipString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"10.0.0.1\"), Net.IP(\"172.16.0.1\");\n\n// Convert the VECTOR of Net.IP to a STRING\nSTRING ipString = Net.ToString(ipList);\n\n// Print the resulting STRING to the console was previously done here\n// ipString"}, {"name": "Net.ToSTRING (VECTOR<Net.IPRange>)", "return_type": "STRING", "return_desc": "Returns a string representation of the provided IP range list.", "parameter_desc": "VECTOR: The list of IP ranges to be converted into a STRING.", "description": "Convert an IP range list to a STRING", "example_code": "// Define a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\");\n\n// Convert the VECTOR of Net.IPRange to a STRING\nSTRING ipRangesString = Net.ToString(ipRanges);\n\n// Print the resulting STRING to the console\n// DEBUG(ipRangesString)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\");\n\n// Convert the VECTOR of Net.IPRange to a STRING\nSTRING ipRangesString = Net.ToString(ipRanges);\n\n// Print the resulting STRING to the console\n// DEBUG(ipRangesString)"}, {"name": "Overlaps (RegExJSi.List, RegExJSi.List)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "RegExJSi.List list1 = [\"example_list1\"]\nRegExJSi.List list2 = [\"example_list2\"]\n\nIF Overlaps(list1, list2) THEN {\n    // The lists have overlapping elements.\n} ELSE {\n    // The lists do not have overlapping elements.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "RegExJSi.List list1 = [\"example_list1\"]\nRegExJSi.List list2 = [\"example_list2\"]\n\nIF Overlaps(list1, list2) THEN {\n    // The lists have overlapping elements.\n} ELSE {\n    // The lists do not have overlapping elements.\n}"}, {"name": "Overlaps (VECTOR<MediaType>, VECTOR<MediaType>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "VECTOR<MediaType> allowedMediaTypes = [\"image/jpeg\", \"image/png\", \"application/pdf\"]\nVECTOR<MediaType> requestMediaTypes = [\"image/gif\", \"image/jpeg\"]\n\nIF Overlaps(allowedMediaTypes, requestMediaTypes) THEN {\n    // There is an overlap in media types.\n    MWG.Allow(\"MediaTypeOverlap\")\n} ELSE {\n    // No overlap in media types.\n    MWG.Block(\"NoMediaTypeOverlap\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MediaType> allowedMediaTypes = [\"image/jpeg\", \"image/png\", \"application/pdf\"]\nVECTOR<MediaType> requestMediaTypes = [\"image/gif\", \"image/jpeg\"]\n\nIF Overlaps(allowedMediaTypes, requestMediaTypes) THEN {\n    // There is an overlap in media types.\n    MWG.Allow(\"MediaTypeOverlap\")\n} ELSE {\n    // No overlap in media types.\n    MWG.Block(\"NoMediaTypeOverlap\")\n}"}, {"name": "Overlaps (VECTOR<MWG.HostAndCertificate>, VECTOR<MWG.HostAndCertificate>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "VECTOR<MWG.HostAndCertificate> list1 = [\"host_cert_list1\"]\nVECTOR<MWG.HostAndCertificate> list2 = [\"host_cert_list2\"]\n\nIF Overlaps(list1, list2) THEN {\n    // The lists have overlapping elements.\n    MWG.Block(\"Access blocked due to overlapping host and certificate.\")\n} ELSE {\n    // The lists do not have overlapping elements.\n    MWG.Allow(\"No overlap detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.HostAndCertificate> list1 = [\"host_cert_list1\"]\nVECTOR<MWG.HostAndCertificate> list2 = [\"host_cert_list2\"]\n\nIF Overlaps(list1, list2) THEN {\n    // The lists have overlapping elements.\n    MWG.Block(\"Access blocked due to overlapping host and certificate.\")\n} ELSE {\n    // The lists do not have overlapping elements.\n    MWG.Allow(\"No overlap detected.\")\n}"}, {"name": "Overlaps (VECTOR<MWG.UrlCategory>, VECTOR<MWG.UrlCategory>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "VECTOR<MWG.UrlCategory> allowedCategories = [\"allowed_categories_list\"]\nVECTOR<MWG.UrlCategory> currentCategories = MWG.Url().Categories\n\nIF Overlaps(allowedCategories, currentCategories) THEN {\n    // Category allowed\n    MWG.Allow(\"Category allowed\")\n} ELSE {\n    // Category not allowed\n    MWG.Block(\"Category not allowed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.UrlCategory> allowedCategories = [\"allowed_categories_list\"]\nVECTOR<MWG.UrlCategory> currentCategories = MWG.Url().Categories\n\nIF Overlaps(allowedCategories, currentCategories) THEN {\n    // Category allowed\n    MWG.Allow(\"Category allowed\")\n} ELSE {\n    // Category not allowed\n    MWG.Block(\"Category not allowed\")\n}"}, {"name": "Overlaps (VECTOR<Net.IP>, VECTOR<Net.IP>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "VECTOR<Net.IP> list1 = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\nVECTOR<Net.IP> list2 = Net.IP(\"192.168.1.3\"), Net.IP(\"192.168.1.4\"), Net.IP(\"192.168.1.5\")\n\nIF Overlaps(list1, list2) THEN {\n    // IP lists overlap\n    MWG.Block(\"IP overlap detected\")\n} ELSE {\n    // No IP overlap\n    MWG.Allow(\"No IP overlap detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> list1 = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\nVECTOR<Net.IP> list2 = Net.IP(\"192.168.1.3\"), Net.IP(\"192.168.1.4\"), Net.IP(\"192.168.1.5\")\n\nIF Overlaps(list1, list2) THEN {\n    // IP lists overlap\n    MWG.Block(\"IP overlap detected\")\n} ELSE {\n    // No IP overlap\n    MWG.Allow(\"No IP overlap detected\")\n}"}, {"name": "Overlaps (VECTOR<Net.IPRange>, VECTOR<Net.IPRange>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "VECTOR<Net.IPRange> list1 = [\"IPRangeList1\"]\nVECTOR<Net.IPRange> list2 = [\"IPRangeList2\"]\n\nIF Overlaps(list1, list2) THEN {\n    // The IP ranges overlap.\n    MWG.Block(\"Access blocked due to overlapping IP ranges.\")\n} ELSE {\n    // The IP ranges do not overlap.\n    MWG.Allow(\"No overlap detected.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> list1 = [\"IPRangeList1\"]\nVECTOR<Net.IPRange> list2 = [\"IPRangeList2\"]\n\nIF Overlaps(list1, list2) THEN {\n    // The IP ranges overlap.\n    MWG.Block(\"Access blocked due to overlapping IP ranges.\")\n} ELSE {\n    // The IP ranges do not overlap.\n    MWG.Allow(\"No overlap detected.\")\n}"}, {"name": "Overlaps (VECTOR<NUMBER>, VECTOR<NUMBER>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "VECTOR<NUMBER> vector1 = 1, 2, 3, 4, 5\nVECTOR<NUMBER> vector2 = 4, 5, 6, 7, 8\n\nIF Overlaps(vector1, vector2) THEN {\n    // The vectors overlap.\n} ELSE {\n    // The vectors do not overlap.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> vector1 = 1, 2, 3, 4, 5\nVECTOR<NUMBER> vector2 = 4, 5, 6, 7, 8\n\nIF Overlaps(vector1, vector2) THEN {\n    // The vectors overlap.\n} ELSE {\n    // The vectors do not overlap.\n}"}, {"name": "Overlaps (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any of the elements in one list can be found in the other.", "parameter_desc": "Two lists for comparison.", "description": "Check if the two lists have any overlapping elements.", "example_code": "VECTOR<STRING> list1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> list2 = \"banana\", \"date\", \"fig\"\n\nIF Overlaps(list1, list2) THEN {\n    // The lists have common elements.\n} ELSE {\n    // The lists do not have common elements.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> list1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> list2 = \"banana\", \"date\", \"fig\"\n\nIF Overlaps(list1, list2) THEN {\n    // The lists have common elements.\n} ELSE {\n    // The lists do not have common elements.\n}"}, {"name": "OverlapsCaseInsensitive (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "BOOLEAN", "return_desc": "Returns true if there is any overlap (case-insensitive) between the two vectors.", "parameter_desc": "Two VECTORs for comparison.", "description": "Check if the two lists have any overlapping elements ignoring capitalization.", "example_code": "VECTOR<STRING> list1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> list2 = \"Banana\", \"date\", \"elderberry\"\n\nIF OverlapsCaseInsensitive(list1, list2) THEN {\n    // There is an overlap between the two lists.\n} ELSE {\n    // There is no overlap between the two lists.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> list1 = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> list2 = \"Banana\", \"date\", \"elderberry\"\n\nIF OverlapsCaseInsensitive(list1, list2) THEN {\n    // There is an overlap between the two lists.\n} ELSE {\n    // There is no overlap between the two lists.\n}"}, {"name": "RBI.GetIsolateAllSeatInfo ()", "return_type": "JSON", "return_desc": "Returns the number of seats currently taken in the RBI IsolateAll license.", "parameter_desc": "None", "description": "Returns the NUMBER of seats currently taken in the RBI IsolateAll license", "example_code": "JSON seatInfo = RBI.GetIsolateAllSeatInfo()\n// Current RBI IsolateAll seats taken: \" + seatInfo", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "JSON seatInfo = RBI.GetIsolateAllSeatInfo()\n// Current RBI IsolateAll seats taken: \" + seatInfo"}, {"name": "RBI.GetRequestID ()", "return_type": "STRING", "return_desc": "Returns the RBI request ID.", "parameter_desc": "None", "description": "Return the RBI request ID", "example_code": "STRING requestID = RBI.GetRequestID()\n// RBI Request ID:  + requestID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING requestID = RBI.GetRequestID()\n// RBI Request ID:  + requestID"}, {"name": "RBI.GetSessionID ()", "return_type": "STRING", "return_desc": "Returns the RBI session ID.", "parameter_desc": "None", "description": "Return the RBI session ID", "example_code": "STRING sessionID = RBI.GetSessionID()\n// RBI Session ID: + sessionID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING sessionID = RBI.GetSessionID()\n// RBI Session ID: + sessionID"}, {"name": "RBI.GetTabID ()", "return_type": "STRING", "return_desc": "Returns the RBI tab ID.", "parameter_desc": "None", "description": "Return the RBI tab ID", "example_code": "// Call the RBI.GetTabID() function and store the result in a variable\nSTRING tabID = RBI.GetTabID()\n\n// The RBI Tab ID is: \" + tabID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Call the RBI.GetTabID() function and store the result in a variable\nSTRING tabID = RBI.GetTabID()\n\n// The RBI Tab ID is: \" + tabID"}, {"name": "RBI.HasUserIsolateAllSeat ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a seat is available for the current user on the RBI IsolateAll license.", "parameter_desc": "None", "description": "Returns TRUE if a seat is available for the current user on the RBI IsolateAll license", "example_code": "IF RBI.HasUserIsolateAllSeat() THEN {\n    // A seat is available for the current user on the RBI IsolateAll license.\n    // Additional actions can be taken here if a seat is available\n} ELSE {\n    // No seat is available for the current user on the RBI IsolateAll license.\n    // Additional actions can be taken here if no seat is available\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF RBI.HasUserIsolateAllSeat() THEN {\n    // A seat is available for the current user on the RBI IsolateAll license.\n    // Additional actions can be taken here if a seat is available\n} ELSE {\n    // No seat is available for the current user on the RBI IsolateAll license.\n    // Additional actions can be taken here if no seat is available\n}"}, {"name": "RBI.InSessionCreation ()", "return_type": "BOOLEAN", "return_desc": "Returns if current request is part of session establishment.", "parameter_desc": "None", "description": "returns if current request is part of session establishment", "example_code": "IF RBI.InSessionCreation() THEN {\n    // The current request is part of session establishment.\n} ELSE {\n    // The current request is not part of session establishment.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF RBI.InSessionCreation() THEN {\n    // The current request is part of session establishment.\n} ELSE {\n    // The current request is not part of session establishment.\n}"}, {"name": "RBI.IsFullIsolationSession ()", "return_type": "BOOLEAN", "return_desc": "Returns if the current request is isolated (full isolation).", "parameter_desc": "None", "description": "returns if current request is isolated (full isolation)", "example_code": "IF RBI.IsFullIsolationSession() THEN {\n    // This is a full isolation session.\n    // Additional logic for full isolation sessions\n} ELSE {\n    // This is not a full isolation session.\n    // Additional logic for non-full isolation sessions\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF RBI.IsFullIsolationSession() THEN {\n    // This is a full isolation session.\n    // Additional logic for full isolation sessions\n} ELSE {\n    // This is not a full isolation session.\n    // Additional logic for non-full isolation sessions\n}"}, {"name": "RBI.IsInIsolation ()", "return_type": "BOOLEAN", "return_desc": "Returns if the current request is isolated.", "parameter_desc": "None", "description": "returns if current request is isolated", "example_code": "IF RBI.IsInIsolation() THEN {\n    // The current request is isolated.\n    // Additional actions can be taken here if the request is isolated\n} ELSE {\n    // The current request is not isolated.\n    // Additional actions can be taken here if the request is not isolated\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF RBI.IsInIsolation() THEN {\n    // The current request is isolated.\n    // Additional actions can be taken here if the request is isolated\n} ELSE {\n    // The current request is not isolated.\n    // Additional actions can be taken here if the request is not isolated\n}"}, {"name": "RBI.IsRiskyWebSession ()", "return_type": "BOOLEAN", "return_desc": "Returns if the current request is isolated (risky web).", "parameter_desc": "None", "description": "returns if current request is isolated (risky web)", "example_code": "IF RBI.IsRiskyWebSession() THEN {\n    // This is a risky web session.\n    MWG.Block(\"Access blocked due to risky web session.\")\n} ELSE {\n    // This is not a risky web session.\n    MWG.Allow(\"Safe web session.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF RBI.IsRiskyWebSession() THEN {\n    // This is a risky web session.\n    MWG.Block(\"Access blocked due to risky web session.\")\n} ELSE {\n    // This is not a risky web session.\n    MWG.Allow(\"Safe web session.\")\n}"}, {"name": "RBI.LicensedFullIsolationSeats ()", "return_type": "NUMBER", "return_desc": "Returns the number of licensed seats for full isolation.", "parameter_desc": "None", "description": "Returns the NUMBER of licensed seats for full isolation", "example_code": "NUMBER seats = RBI.LicensedFullIsolationSeats()\n// Number of licensed full isolation seats: \" + seats", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER seats = RBI.LicensedFullIsolationSeats()\n// Number of licensed full isolation seats: \" + seats"}, {"name": "RBI.MustBeIsolated ()", "return_type": "BOOLEAN", "return_desc": "Returns if the current request should have been isolated, but isolation was not possible.", "parameter_desc": "None", "description": "Returns if the current request should have been isolated, but isolation was not possible", "example_code": "IF RBI.MustBeIsolated() THEN {\n    // The current request should have been isolated, but isolation was not possible.\n    MWG.Block(\"Isolation required but not possible\")\n} ELSE {\n    // The current request does not require isolation or isolation was successful.\n    MWG.Allow(\"Isolation check passed\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF RBI.MustBeIsolated() THEN {\n    // The current request should have been isolated, but isolation was not possible.\n    MWG.Block(\"Isolation required but not possible\")\n} ELSE {\n    // The current request does not require isolation or isolation was successful.\n    MWG.Allow(\"Isolation check passed\")\n}"}, {"name": "RegExJSi.Append (RegExJSi.List, STRING)", "return_type": "RegExJSi.List", "return_desc": "Returns the regular expression list with the given regular expression appended to the end.", "parameter_desc": "RegExJSi.List: list to append to; STRING: regular expression to append.", "description": "Adds the input STRING as regular expression and returns the updated list", "example_code": "// Initialize a RegExJSi.List\nRegExJSi.List regexList\n\n// Define a regular expression string\nSTRING regexPattern = \"^https?://.*\"\n\n// Add the regular expression to the list\nRegExJSi.Add(regexList, regexPattern)\n\n// Regular expression added to the list.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a RegExJSi.List\nRegExJSi.List regexList\n\n// Define a regular expression string\nSTRING regexPattern = \"^https?://.*\"\n\n// Add the regular expression to the list\nRegExJSi.Add(regexList, regexPattern)\n\n// Regular expression added to the list."}, {"name": "RegExJSi.FindAll (RegExJSi, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing all matches or captured groups from the given string.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches.", "description": "Returns list of matches or captures in case of capture groups.", "example_code": "// Define the input string\nSTRING inputString = \"Contact us at support@example.com or sales@example.com for more information.\"\n\n// Define the regular expression pattern to match email addresses\nRegExJSi emailPattern = RegExJSi(\"[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\\\.[a-zA-Z]{2,}\")\n\n// Use the RegExJSi.FindAll function to find all matches\nVECTOR<STRING> emailMatches = RegExJSi.FindAll(emailPattern, inputString)\n\n// Found email addresses: \n// emailMatches", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the input string\nSTRING inputString = \"Contact us at support@example.com or sales@example.com for more information.\"\n\n// Define the regular expression pattern to match email addresses\nRegExJSi emailPattern = RegExJSi(\"[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}\")\n\n// Use the RegExJSi.FindAll function to find all matches\nVECTOR<STRING> emailMatches = RegExJSi.FindAll(emailPattern, inputString)\n\n// Found email addresses: \n// emailMatches"}, {"name": "RegExJSi.Matches (RegExJSi, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the regular expression matches the provided `STRING`.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches.", "description": "Returns TRUE if the regular expression matches the second argument", "example_code": "// Define the regular expression pattern\nRegExJSi pattern = RegExJSi(\".*example.*\")\n\n// Get the current URL as a string\nSTRING currentUrl = MWG.Url().ToString()\n\n// Check if the URL matches the pattern\nIF RegExJSi.Matches(pattern, currentUrl) THEN {\n    // Block the request if the pattern matches\n    MWG.Block(\"Access to URLs containing 'example' is not allowed.\")\n} ELSE {\n    // Allow the request if the pattern does not match\n    MWG.Allow(\"URL does not contain the forbidden pattern.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the regular expression pattern\nRegExJSi pattern = RegExJSi(\".*example.*\")\n\n// Get the current URL as a string\nSTRING currentUrl = MWG.Url().ToString()\n\n// Check if the URL matches the pattern\nIF RegExJSi.Matches(pattern, currentUrl) THEN {\n    // Block the request if the pattern matches\n    MWG.Block(\"Access to URLs containing 'example' is not allowed.\")\n} ELSE {\n    // Allow the request if the pattern does not match\n    MWG.Allow(\"URL does not contain the forbidden pattern.\")\n}"}, {"name": "RegExJSi.Matches (RegExJSi.List, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if any regular expression in the list matches the given `STRING`.", "parameter_desc": "RegExJSi.List: list of regular expressions to use for matching; STRING: input to check for matches.", "description": "Check if a STRING matches any regular expression in a list.", "example_code": "// Define a list of regular expressions\nRegExJSi.List regexList = [\"example_regex_list\"]\n\n// Get the current URL as a string\nSTRING currentURL = MWG.Url().ToString()\n\n// Check if the current URL matches any regular expression in the list\nIF RegExJSi.Matches(regexList, currentURL) THEN {\n    // Block the request if a match is found\n    MWG.Block(\"Blocked due to matching regex\")\n} ELSE {\n    // Allow the request if no match is found\n    MWG.Allow(\"No matching regex found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a list of regular expressions\nRegExJSi.List regexList = [\"example_regex_list\"]\n\n// Get the current URL as a string\nSTRING currentURL = MWG.Url().ToString()\n\n// Check if the current URL matches any regular expression in the list\nIF RegExJSi.Matches(regexList, currentURL) THEN {\n    // Block the request if a match is found\n    MWG.Block(\"Blocked due to matching regex\")\n} ELSE {\n    // Allow the request if no match is found\n    MWG.Allow(\"No matching regex found\")\n}"}, {"name": "RegExJSi.Matches (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the regular expression defined in the first `STRING` matches the entirety of the second `STRING`.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches.", "description": "Returns TRUE if the first argument as regular expression matches the second argument", "example_code": "STRING url = MWG.Url().ToString()\nRegExJSi pattern = \".*example\\\\.com.*\"\n\n// Checking if the URL matches the pattern\nIF RegExJSi.Matches(pattern, url) THEN {\n    // Blocking access if the URL matches the pattern\n    MWG.Block(\"Access to example.com is not allowed\")\n} ELSE {\n    // Allowing access if the URL does not match the pattern\n    MWG.Allow(\"URL does not match the blocked pattern\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING url = MWG.Url().ToString()\nRegExJSi pattern = \".*example\\.com.*\"\n\n// Checking if the URL matches the pattern\nIF RegExJSi.Matches(pattern, url) THEN {\n    // Blocking access if the URL matches the pattern\n    MWG.Block(\"Access to example.com is not allowed\")\n} ELSE {\n    // Allowing access if the URL does not match the pattern\n    MWG.Allow(\"URL does not match the blocked pattern\")\n}"}, {"name": "RegExJSi.ReplaceAllMatches (RegExJSi, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns a new string where all occurrences matching the regular expression in the input string are replaced by the specified replacement string.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches; STRING: the replacement STRING.", "description": "Returns a copy of given STRING, where all occurrences of regular expression are replaced by given third parameter. For example STRING \"pre:abc# pre:cde#\", regular expression \"reg(pre:(.*?)#)\" and replace STRING \"\\1\" will result in \"abc pre:cde#\" (note that ? after * in regular expression results in a non greedy match!)", "example_code": "// Define the input string\nSTRING inputString = \"The quick brown fox jumps over the lazy dog. The quick brown fox is fast.\"\n\n// Define the regular expression pattern to match \"quick brown fox\"\nRegExJSi regexPattern = \"quick brown fox\"\n\n// Define the replacement string\nSTRING replacementString = \"swift red fox\"\n\n// Use the ReplaceAllMatches function to replace all occurrences of the pattern\nSTRING resultString = RegExJSi.ReplaceAllMatches(regexPattern, inputString, replacementString)\n\n// The result was: \"The swift red fox jumps over the lazy dog. The swift red fox is fast.\"\n\nIn this example:\n- The `inputString` contains the text where we want to perform the replacements.\n- The `regexPattern` is the regular expression pattern that matches \"quick brown fox\".\n- The `replacementString` is the string that will replace each occurrence of the pattern.\n- The `RegExJSi.ReplaceAllMatches` function is called with the pattern, input string, and replacement string, and the result is stored in `resultString`.\n- Finally, the result was: \"The swift red fox jumps over the lazy dog. The swift red fox is fast.\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the input string\nSTRING inputString = \"The quick brown fox jumps over the lazy dog. The quick brown fox is fast.\"\n\n// Define the regular expression pattern to match \"quick brown fox\"\nRegExJSi regexPattern = \"quick brown fox\"\n\n// Define the replacement string\nSTRING replacementString = \"swift red fox\"\n\n// Use the ReplaceAllMatches function to replace all occurrences of the pattern\nSTRING resultString = RegExJSi.ReplaceAllMatches(regexPattern, inputString, replacementString)\n\n// The result was: \"The swift red fox jumps over the lazy dog. The swift red fox is fast.\"\n\nIn this example:\n- The `inputString` contains the text where we want to perform the replacements.\n- The `regexPattern` is the regular expression pattern that matches \"quick brown fox\".\n- The `replacementString` is the string that will replace each occurrence of the pattern.\n- The `RegExJSi.ReplaceAllMatches` function is called with the pattern, input string, and replacement string, and the result is stored in `resultString`.\n- Finally, the result was: \"The swift red fox jumps over the lazy dog. The swift red fox is fast.\""}, {"name": "RegExJSi.ReplaceAllMatches (STRING, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns a copy of the given string where all occurrences matching the regular expression are replaced by the specified replacement string.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches; STRING: the replacement STRING.", "description": "Returns a copy of given STRING, where all occurrences of regular expression (1st parameter) are replaced by given third parameter.For example STRING \"pre:abc# pre:cde#\", regular expression \"reg(pre:(.*?)#)\" and replace STRING \"\\1\" will result in \"abc pre:cde#\" (note that ? after * in regular expression results in a non greedy match!)", "example_code": "STRING inputString = \"pre:abc# pre:cde# pre:efg#\"\nSTRING pattern = \"reg(pre:(.*?)#)\"\nSTRING replacement = \"\\1\"\n\nSTRING result = RegExJSi.ReplaceAllMatches(pattern, inputString, replacement)\n\n// This will output: \"abc pre:cde# pre:efg#\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"pre:abc# pre:cde# pre:efg#\"\nSTRING pattern = \"reg(pre:(.*?)#)\"\nSTRING replacement = \"\u0001\"\n\nSTRING result = RegExJSi.ReplaceAllMatches(pattern, inputString, replacement)\n\n// This will output: \"abc pre:cde# pre:efg#\""}, {"name": "RegExJSi.ReplaceFirstMatch (RegExJSi, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns a new string with the first match of the regular expression in the input string replaced by the specified replacement string.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches; STRING: the replacement STRING.", "description": "Returns a copy of given STRING, where the first occurrence of regular expression is replaced by given third parameter. For example STRING \"pre:abc# pre:cde#\", regular expression \"reg(pre:(.*?)#)\" and replace STRING \"\\1\" will result in \"abc pre:cde#\" (note that ? after * in regular expression results in a non greedy match!)", "example_code": "// Define the input string\nSTRING inputString = \"pre:abc# pre:cde#\"\n\n// Define the regular expression pattern\nRegExJSi regexPattern = \"reg(pre:(.*?)#)\"\n\n// Define the replacement string\nSTRING replacementString = \"\\1\"\n\n// Use the ReplaceFirstMatch function to replace the first match\nSTRING resultString = RegExJSi.ReplaceFirstMatch(regexPattern, inputString, replacementString)\n\n// Print the result to the console\n// resultString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the input string\nSTRING inputString = \"pre:abc# pre:cde#\"\n\n// Define the regular expression pattern\nRegExJSi regexPattern = \"reg(pre:(.*?)#)\"\n\n// Define the replacement string\nSTRING replacementString = \"\u0001\"\n\n// Use the ReplaceFirstMatch function to replace the first match\nSTRING resultString = RegExJSi.ReplaceFirstMatch(regexPattern, inputString, replacementString)\n\n// Print the result to the console\n// resultString"}, {"name": "RegExJSi.ReplaceFirstMatch (STRING, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns a string where the first occurrence matching the given regular expression is replaced by the specified replacement string.", "parameter_desc": "STRING: the regular expression to match; STRING: the input STRING to search within; STRING: the replacement STRING.", "description": "Returns a copy of given STRING, where the first occurrence of regular expression (1st parameter) is replaced by given third parameter.For example STRING \"pre:abc# pre:cde#\", regular expression \"reg(pre:(.*?)#)\" and replace STRING \"\\1\" will result in \"abc pre:cde#\" (note that ? after * in regular expression results in a non greedy match!)", "example_code": "STRING inputString = \"The quick brown fox jumps over the lazy dog\";\nSTRING pattern = \"quick (.*?) fox\";\nSTRING replacement = \"slow \\1 cat\";\n\nSTRING result = RegExJSi.ReplaceFirstMatch(pattern, inputString, replacement);\n\n// Output: \"The slow brown cat jumps over the lazy dog\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"The quick brown fox jumps over the lazy dog\";\nSTRING pattern = \"quick (.*?) fox\";\nSTRING replacement = \"slow \u0001 cat\";\n\nSTRING result = RegExJSi.ReplaceFirstMatch(pattern, inputString, replacement);\n\n// Output: \"The slow brown cat jumps over the lazy dog\""}, {"name": "RegExJSi.Search (RegExJSi, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns true if the given string contains at least one match or capture group based on the specified regular expression.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches.", "description": "Returns TRUE if at least one match or capture(in case of capture groups).", "example_code": "// Define the regular expression pattern\nRegExJSi pattern = RegExJSi(\"example-pattern\")\n\n// Get the current URL as a string\nSTRING currentURL = MWG.Url().ToString()\n\n// Check if the URL matches the pattern\nIF RegExJSi.Search(pattern, currentURL) THEN {\n    // Block the request if the pattern is found\n    MWG.Block(\"Blocked due to matching pattern\")\n} ELSE {\n    // Allow the request if the pattern is not found\n    MWG.Allow(\"Pattern not found\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the regular expression pattern\nRegExJSi pattern = RegExJSi(\"example-pattern\")\n\n// Get the current URL as a string\nSTRING currentURL = MWG.Url().ToString()\n\n// Check if the URL matches the pattern\nIF RegExJSi.Search(pattern, currentURL) THEN {\n    // Block the request if the pattern is found\n    MWG.Block(\"Blocked due to matching pattern\")\n} ELSE {\n    // Allow the request if the pattern is not found\n    MWG.Allow(\"Pattern not found\")\n}"}, {"name": "RegExJSi.SearchAllMatches (RegExJSi, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing all substrings of the input string that match the given regular expression.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches.", "description": "Returns list of matched regex input (for e.g: STRING: 'a1b2c3d4e5', Regex: '\\d' the result would be : '1', ' 2', '3', '4', '5').", "example_code": "// Define the input string\nSTRING inputString = \"a1b2c3d4e5\";\n\n// Define the regular expression pattern to match digits\nRegExJSi regexPattern = \"\\d\";\n\n// Use the RegExJSi.SearchAllMatches function to find all matches\nVECTOR<STRING> matches = RegExJSi.SearchAllMatches(regexPattern, inputString);\n\n// Matches found: \" + matches\n// In this example:\n// - The `inputString` is \"a1b2c3d4e5\".\n// - The `regexPattern` is defined as `\"\\d\"`, which matches any digit.\n// - The `RegExJSi.SearchAllMatches` function is called with the `regexPattern` and `inputString` as arguments, and it returns a `VECTOR<STRING>` containing all the matched digit sequences.\n// - The matches are then printed to the console using the `DEBUG` function.\n// When this routine is executed, it will output:\n// Matches found: 1, 2, 3, 4, 5", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the input string\nSTRING inputString = \"a1b2c3d4e5\";\n\n// Define the regular expression pattern to match digits\nRegExJSi regexPattern = \"\\d\";\n\n// Use the RegExJSi.SearchAllMatches function to find all matches\nVECTOR<STRING> matches = RegExJSi.SearchAllMatches(regexPattern, inputString);\n\n// Matches found: \" + matches\n// In this example:\n// - The `inputString` is \"a1b2c3d4e5\".\n// - The `regexPattern` is defined as `\"\\d\"`, which matches any digit.\n// - The `RegExJSi.SearchAllMatches` function is called with the `regexPattern` and `inputString` as arguments, and it returns a `VECTOR<STRING>` containing all the matched digit sequences.\n// - The matches are then printed to the console using the `DEBUG` function.\n// When this routine is executed, it will output:\n// Matches found: 1, 2, 3, 4, 5"}, {"name": "RegExJSi.ToSTRING (RegExJSi)", "return_type": "STRING", "return_desc": "Returns the regular expression in string format.", "parameter_desc": "RegExJSi: the regular expression object to be converted to a STRING.", "description": "return the regular expression as a STRING", "example_code": "// Create a RegExJSi object\nRegExJSi myRegex = RegExJSi(\"^[a-zA-Z0-9]+$\")\n\n// Convert the RegExJSi object to a STRING\nSTRING regexString = RegExJSi.ToString(myRegex)\n\n// The regular expression is: \n// regexString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a RegExJSi object\nRegExJSi myRegex = RegExJSi(\"^[a-zA-Z0-9]+$\")\n\n// Convert the RegExJSi object to a STRING\nSTRING regexString = RegExJSi.ToString(myRegex)\n\n// The regular expression is: \n// regexString"}, {"name": "RegExJSi.WildcardMatch (RegExJSi, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing the substrings of the input string that match the groups within the specified regular expression.", "parameter_desc": "RegExJSi: the regular expression pattern to match agains; STRING: the input STRING in which to search for matches.", "description": "Returns a list with matched expressions of a given STRING, for example property with STRING \"http://www.google.de\" and regular expression \"/(ftp|http|https):\\/\\/(\\w+)*\\.(\\w+\\.)*(\\w+)*/\" will return a list with the elements 'http', 'www', 'google.', 'de'", "example_code": "// Define the wildcard pattern and the string to match\nRegExJSi pattern = \"example*pattern\"\nSTRING inputString = \"example123pattern\"\n\n// Use the WildcardMatch function to check if the input string matches the pattern\nBOOLEAN isMatch = RegExJSi.WildcardMatch(pattern, inputString)\n\n// Print the result to the console\nIF isMatch THEN {\n    // The input string matches the wildcard pattern.\n} ELSE {\n    // The input string does not match the wildcard pattern.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the wildcard pattern and the string to match\nRegExJSi pattern = \"example*pattern\"\nSTRING inputString = \"example123pattern\"\n\n// Use the WildcardMatch function to check if the input string matches the pattern\nBOOLEAN isMatch = RegExJSi.WildcardMatch(pattern, inputString)\n\n// Print the result to the console\nIF isMatch THEN {\n    // The input string matches the wildcard pattern.\n} ELSE {\n    // The input string does not match the wildcard pattern.\n}"}, {"name": "RegExJSiList.ToSTRING (RegExJSi.List, STRING)", "return_type": "STRING", "return_desc": "Returns the regular expression list as a delimited (default \", \") string.", "parameter_desc": "RegExJSi.List: list to convert to STRING; STRING: delimiter to use.", "description": "return the regular expression list as a delimited (default \", \") STRING", "example_code": "// Assume we have a RegExJSi.List object named regexList\nRegExJSi.List regexList = [\"example_regex_list\"]\n\n// Convert the RegExJSi.List to a STRING with a specified delimiter\nSTRING delimiter = \",\"\nSTRING regexListString = RegExJSiList.ToString(regexList, delimiter)\n\n// Print the resulting STRING to the console\n// DEBUG(regexListString)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a RegExJSi.List object named regexList\nRegExJSi.List regexList = [\"example_regex_list\"]\n\n// Convert the RegExJSi.List to a STRING with a specified delimiter\nSTRING delimiter = \",\"\nSTRING regexListString = RegExJSiList.ToString(regexList, delimiter)\n\n// Print the resulting STRING to the console\n// DEBUG(regexListString)"}, {"name": "RegExJSiListPtr.ToSTRING (RegExJSi.List, STRING)", "return_type": "STRING", "return_desc": "Returns the regular expression list formatted as a string, with items separated by a specified delimiter. Default is \", \".", "parameter_desc": "RegExJSi.List: the list of regular expressions; STRING: the delimiter used to join them.", "description": "return the regular expression list as a delimited (default \", \") STRING", "example_code": "// Create a new RegExJSi.List\nRegExJSi.List regexList = RegExJSi.List()\n\n// Add a regular expression to the list\nRegExJSi.Add(regexList, \"^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\\\.[a-zA-Z]{2,}$\")\n\n// Add another regular expression to the list\nRegExJSi.Add(regexList, \"^https?://[a-zA-Z0-9.-]+\\\\.[a-zA-Z]{2,}(/.*)?$\")\n\n// Regular expressions added to the list.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a new RegExJSi.List\nRegExJSi.List regexList = RegExJSi.List()\n\n// Add a regular expression to the list\nRegExJSi.Add(regexList, \"^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$\")\n\n// Add another regular expression to the list\nRegExJSi.Add(regexList, \"^https?://[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}(/.*)?$\")\n\n// Regular expressions added to the list."}, {"name": "Remove (MAP<STRING, STRING>, STRING)", "return_type": "MAP<STRING,STRING>", "return_desc": "Returns the updated map.", "parameter_desc": "MAP<STRING, STRING>: map to remove from; STRING: key to remove from map.", "description": "Fuctions: Returns the map without the given key", "example_code": "// Initialize a map with some key-value pairs\nMAP<STRING, STRING> exampleMap = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Original Map: exampleMap\n\n// Remove a key from the map\nexampleMap = Remove(exampleMap, \"key2\")\n\n// Updated Map: exampleMap", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a map with some key-value pairs\nMAP<STRING, STRING> exampleMap = {\n    \"key1\": \"value1\",\n    \"key2\": \"value2\",\n    \"key3\": \"value3\"\n}\n\n// Original Map: exampleMap\n\n// Remove a key from the map\nexampleMap = Remove(exampleMap, \"key2\")\n\n// Updated Map: exampleMap"}, {"name": "Remove (RegExJSi.List, NUMBER)", "return_type": "RegExJSi.List", "return_desc": "Returns a new `RegExJSi`.List with the specified entry removed.", "parameter_desc": "RegExJSi.List: the list to remove from; NUMBER: the zero-based index of the entry to remove.", "description": "Remove a list entry", "example_code": "// Initialize a RegExJSi.List with some example regular expressions\nRegExJSi.List regexList = [\"^abc\", \"def$\", \"ghi.*\"]\n\n// Specify the index of the entry to remove\nNUMBER indexToRemove = 1\n\n// Remove the entry at the specified index\nRegExJSi.List updatedList = Remove(regexList, indexToRemove)\n\n// Print the updated list to the console for debugging\n// updatedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a RegExJSi.List with some example regular expressions\nRegExJSi.List regexList = [\"^abc\", \"def$\", \"ghi.*\"]\n\n// Specify the index of the entry to remove\nNUMBER indexToRemove = 1\n\n// Remove the entry at the specified index\nRegExJSi.List updatedList = Remove(regexList, indexToRemove)\n\n// Print the updated list to the console for debugging\n// updatedList"}, {"name": "Remove (RegExJSi.List, NUMBER, NUMBER)", "return_type": "RegExJSi.List", "return_desc": "Returns a list with entries removed between the specified start and end indices.", "parameter_desc": "RegExJSi.List: the list to remove from; NUMBER: the starting index; NUMBER: the ending index.", "description": "Remove list entries between the given indices", "example_code": "// Assume we have a RegExJSi.List object named regexList\nRegExJSi.List regexList = [\"example_list\"]\n\n// Define the index of the element to remove\nNUMBER indexToRemove = 1\n\n// Remove the element at the specified index\nregexList = Remove(regexList, indexToRemove)\n\n// Updated regexList: \" + regexList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a RegExJSi.List object named regexList\nRegExJSi.List regexList = [\"example_list\"]\n\n// Define the index of the element to remove\nNUMBER indexToRemove = 1\n\n// Remove the element at the specified index\nregexList = Remove(regexList, indexToRemove)\n\n// Updated regexList: \" + regexList"}, {"name": "Remove (RegExJSi.List, RegExJSi.List)", "return_type": "RegExJSi.List", "return_desc": "Returns the updated list.", "parameter_desc": "RegExJSi.List: list to remove from; RegExJSi.List: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "// Initialize two RegExJSi.List objects with some example regular expressions\nRegExJSi.List list1 = \"regex1\", \"regex2\", \"regex3\", \"regex4\"\nRegExJSi.List list2 = \"regex2\", \"regex4\"\n\n// Remove elements from list1 that are present in list2\nRegExJSi.List updatedList = Remove(list1, list2)\n\n// Debug output to verify the operation was replaced with this comment\n// Updated list1: + updatedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize two RegExJSi.List objects with some example regular expressions\nRegExJSi.List list1 = \"regex1\", \"regex2\", \"regex3\", \"regex4\"\nRegExJSi.List list2 = \"regex2\", \"regex4\"\n\n// Remove elements from list1 that are present in list2\nRegExJSi.List updatedList = Remove(list1, list2)\n\n// Debug output to verify the operation was replaced with this comment\n// Updated list1: + updatedList"}, {"name": "Remove (VECTOR<MediaType>, NUMBER, NUMBER)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MediaType>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR<MediaType> with some example media types\nVECTOR<MediaType> mediaTypes = MediaType(\"image/jpeg\"), MediaType(\"video/mp4\"), MediaType(\"application/pdf\"), MediaType(\"text/html\")\n\n// Original media types: \" + mediaTypes\n\n// Remove elements from index 1 to 2 (inclusive)\nRemove(mediaTypes, 1, 2)\n\n// Modified media types: \" + mediaTypes", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR<MediaType> with some example media types\nVECTOR<MediaType> mediaTypes = MediaType(\"image/jpeg\"), MediaType(\"video/mp4\"), MediaType(\"application/pdf\"), MediaType(\"text/html\")\n\n// Original media types: \" + mediaTypes\n\n// Remove elements from index 1 to 2 (inclusive)\nRemove(mediaTypes, 1, 2)\n\n// Modified media types: \" + mediaTypes"}, {"name": "Remove (VECTOR<MediaType>, VECTOR<MediaType>)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MediaType>: list to remove from; VECTOR<MediaType>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "// Define a VECTOR of MediaType with some initial values\nVECTOR<MediaType> mediaList = MediaType(\"image/jpeg\"), MediaType(\"video/mp4\"), MediaType(\"application/pdf\"), MediaType(\"image/png\")\n\n// Define a VECTOR of MediaType with elements to remove\nVECTOR<MediaType> removeList = MediaType(\"image/jpeg\"), MediaType(\"application/pdf\")\n\n// Use the Remove function to remove elements from mediaList that are in removeList\nVECTOR<MediaType> updatedMediaList = Remove(mediaList, removeList)\n\n// Updated Media List: \" + updatedMediaList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of MediaType with some initial values\nVECTOR<MediaType> mediaList = MediaType(\"image/jpeg\"), MediaType(\"video/mp4\"), MediaType(\"application/pdf\"), MediaType(\"image/png\")\n\n// Define a VECTOR of MediaType with elements to remove\nVECTOR<MediaType> removeList = MediaType(\"image/jpeg\"), MediaType(\"application/pdf\")\n\n// Use the Remove function to remove elements from mediaList that are in removeList\nVECTOR<MediaType> updatedMediaList = Remove(mediaList, removeList)\n\n// Updated Media List: \" + updatedMediaList"}, {"name": "Remove (VECTOR<MWG.ApplicationCategoryType>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.ApplicationCategoryType>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.ApplicationCategoryType>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"Social Media\", \"Streaming Media\", \"File Sharing\", \"Gaming\", \"News\"]\n\n// Define the start and end indices for removal\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Remove elements from the VECTOR\nappCategories = Remove(appCategories, startIndex, endIndex)\n\n// Debug the result to see the remaining elements\n// DEBUG(appCategories) was replaced with this comment to explain the code. The line originally output the value of appCategories to the console.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"Social Media\", \"Streaming Media\", \"File Sharing\", \"Gaming\", \"News\"]\n\n// Define the start and end indices for removal\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Remove elements from the VECTOR\nappCategories = Remove(appCategories, startIndex, endIndex)\n\n// Debug the result to see the remaining elements\n// DEBUG(appCategories) was replaced with this comment to explain the code. The line originally output the value of appCategories to the console."}, {"name": "Remove (VECTOR<MWG.ApplicationCategoryType>, VECTOR<MWG.ApplicationCategoryType>)", "return_type": "VECTOR<MWG.ApplicationCategoryType>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.ApplicationCategoryType>: list to remove from; VECTOR<MWG.ApplicationCategoryType>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "// Define two vectors of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> allCategories = [\"Social Media\", \"Streaming Media\", \"Shopping\", \"News\"]\nVECTOR<MWG.ApplicationCategoryType> categoriesToRemove = [\"Shopping\", \"News\"]\n\n// Remove categoriesToRemove from allCategories\nVECTOR<MWG.ApplicationCategoryType> updatedCategories = Remove(allCategories, categoriesToRemove)\n\n// Updated Categories: \" + updatedCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two vectors of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> allCategories = [\"Social Media\", \"Streaming Media\", \"Shopping\", \"News\"]\nVECTOR<MWG.ApplicationCategoryType> categoriesToRemove = [\"Shopping\", \"News\"]\n\n// Remove categoriesToRemove from allCategories\nVECTOR<MWG.ApplicationCategoryType> updatedCategories = Remove(allCategories, categoriesToRemove)\n\n// Updated Categories: \" + updatedCategories"}, {"name": "Remove (VECTOR<MWG.ApplicationType>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.ApplicationType>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.ApplicationType>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appTypes = [\"AppType1\", \"AppType2\", \"AppType3\", \"AppType4\", \"AppType5\"]\n\n// Define the start and end indices for removal\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Remove elements from the VECTOR\nappTypes.Remove(startIndex, endIndex)\n\n// The resulting VECTOR after removal\n// appTypes", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appTypes = [\"AppType1\", \"AppType2\", \"AppType3\", \"AppType4\", \"AppType5\"]\n\n// Define the start and end indices for removal\nNUMBER startIndex = 1\nNUMBER endIndex = 3\n\n// Remove elements from the VECTOR\nappTypes.Remove(startIndex, endIndex)\n\n// The resulting VECTOR after removal\n// appTypes"}, {"name": "Remove (VECTOR<MWG.ApplicationType>, VECTOR<MWG.ApplicationType>)", "return_type": "VECTOR<MWG.ApplicationType>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.ApplicationType>: list to remove from; VECTOR<MWG.ApplicationType>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "// Define a vector of MWG.ApplicationType to represent the current applications\nVECTOR<MWG.ApplicationType> currentApplications = [\"App1\", \"App2\", \"App3\", \"App4\"]\n\n// Define a vector of MWG.ApplicationType to represent the applications to be removed\nVECTOR<MWG.ApplicationType> applicationsToRemove = [\"App2\", \"App4\"]\n\n// Call the Remove function to remove the specified applications from the current applications\nVECTOR<MWG.ApplicationType> updatedApplications = Remove(currentApplications, applicationsToRemove)\n\n// Updated Applications: \" + updatedApplications", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a vector of MWG.ApplicationType to represent the current applications\nVECTOR<MWG.ApplicationType> currentApplications = [\"App1\", \"App2\", \"App3\", \"App4\"]\n\n// Define a vector of MWG.ApplicationType to represent the applications to be removed\nVECTOR<MWG.ApplicationType> applicationsToRemove = [\"App2\", \"App4\"]\n\n// Call the Remove function to remove the specified applications from the current applications\nVECTOR<MWG.ApplicationType> updatedApplications = Remove(currentApplications, applicationsToRemove)\n\n// Updated Applications: \" + updatedApplications"}, {"name": "Remove (VECTOR<MWG.HostAndCertificate>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.HostAndCertificate>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.HostAndCertificate>: list  to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "VECTOR<MWG.HostAndCertificate> originalList = [\"original_list\"]\nVECTOR<MWG.HostAndCertificate> elementsToRemove = [\"elements_to_remove\"]\n\nVECTOR<MWG.HostAndCertificate> updatedList = Remove(originalList, elementsToRemove)\n\n// \"Updated List: \" + updatedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.HostAndCertificate> originalList = [\"original_list\"]\nVECTOR<MWG.HostAndCertificate> elementsToRemove = [\"elements_to_remove\"]\n\nVECTOR<MWG.HostAndCertificate> updatedList = Remove(originalList, elementsToRemove)\n\n// \"Updated List: \" + updatedList"}, {"name": "Remove (VECTOR<MWG.HostAndCertificate>, VECTOR<MWG.HostAndCertificate>)", "return_type": "VECTOR<MWG.HostAndCertificate>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.HostAndCertificate>: list to remove from; VECTOR<MWG.HostAndCertificate>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "// Define the initial list of MWG.HostAndCertificate objects\nVECTOR<MWG.HostAndCertificate> initialList = [ \"initial_list\" ]\n\n// Define the list of MWG.HostAndCertificate objects to be removed\nVECTOR<MWG.HostAndCertificate> removeList = [ \"remove_list\" ]\n\n// Call the Remove function to remove items in removeList from initialList\nVECTOR<MWG.HostAndCertificate> updatedList = Remove(initialList, removeList)\n\n// Optionally, set the updated list to a property or use it further in the code\nMWG.SetPropertyValue(\"UpdatedHostAndCertificateList\", updatedList)\n\n// Debug output to verify the result\n// Updated list after removal: \" + updatedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define the initial list of MWG.HostAndCertificate objects\nVECTOR<MWG.HostAndCertificate> initialList = [ \"initial_list\" ]\n\n// Define the list of MWG.HostAndCertificate objects to be removed\nVECTOR<MWG.HostAndCertificate> removeList = [ \"remove_list\" ]\n\n// Call the Remove function to remove items in removeList from initialList\nVECTOR<MWG.HostAndCertificate> updatedList = Remove(initialList, removeList)\n\n// Optionally, set the updated list to a property or use it further in the code\nMWG.SetPropertyValue(\"UpdatedHostAndCertificateList\", updatedList)\n\n// Debug output to verify the result\n// Updated list after removal: \" + updatedList"}, {"name": "Remove (VECTOR<MWG.UrlCategory>, NUMBER, NUMBER)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.UrlCategory>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"SocialMedia\", \"News\", \"Shopping\", \"Entertainment\", \"Education\"]\n\n// Original VECTOR: \" + urlCategories\n\n// Remove 2 elements starting from index 1 (i.e., \"News\" and \"Shopping\")\nurlCategories = Remove(urlCategories, 1, 2)\n\n// Modified VECTOR: \" + urlCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"SocialMedia\", \"News\", \"Shopping\", \"Entertainment\", \"Education\"]\n\n// Original VECTOR: \" + urlCategories\n\n// Remove 2 elements starting from index 1 (i.e., \"News\" and \"Shopping\")\nurlCategories = Remove(urlCategories, 1, 2)\n\n// Modified VECTOR: \" + urlCategories"}, {"name": "Remove (VECTOR<MWG.UrlCategory>, VECTOR<MWG.UrlCategory>)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<MWG.UrlCategory>: list to remove from; VECTOR<MWG.UrlCategory>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "// Define two vectors of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> allCategories = [\"all_categories_list\"]\nVECTOR<MWG.UrlCategory> categoriesToRemove = [\"remove_categories_list\"]\n\n// Remove categoriesToRemove from allCategories\nVECTOR<MWG.UrlCategory> updatedCategories = Remove(allCategories, categoriesToRemove)\n\n// Set the updated categories to a user-defined variable\nMWG.SetUserDefinedVar(\"UpdatedCategories\", updatedCategories)\n\n// Updated Categories: \" + updatedCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define two vectors of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> allCategories = [\"all_categories_list\"]\nVECTOR<MWG.UrlCategory> categoriesToRemove = [\"remove_categories_list\"]\n\n// Remove categoriesToRemove from allCategories\nVECTOR<MWG.UrlCategory> updatedCategories = Remove(allCategories, categoriesToRemove)\n\n// Set the updated categories to a user-defined variable\nMWG.SetUserDefinedVar(\"UpdatedCategories\", updatedCategories)\n\n// Updated Categories: \" + updatedCategories"}, {"name": "Remove (VECTOR<Net.IP>, NUMBER, NUMBER)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<Net.IP>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\", \"192.168.1.4\", \"192.168.1.5\"\n\n// Original IP List: \n// DEBUG(\"Original IP List: \" + ipList)\n\n// Remove 2 elements starting from index 1\nRemove(ipList, 1, 2)\n\n// Modified IP List: \n// DEBUG(\"Modified IP List: \" + ipList)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of Net.IP\nVECTOR<Net.IP> ipList = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\", \"192.168.1.4\", \"192.168.1.5\"\n\n// Original IP List: \n// DEBUG(\"Original IP List: \" + ipList)\n\n// Remove 2 elements starting from index 1\nRemove(ipList, 1, 2)\n\n// Modified IP List: \n// DEBUG(\"Modified IP List: \" + ipList)"}, {"name": "Remove (VECTOR<Net.IP>, VECTOR<Net.IP>)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<Net.IP>: list to remove from; VECTOR<Net.IP>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "VECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\nVECTOR<Net.IP> ipsToRemove = Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\n\nipList = Remove(ipList, ipsToRemove)\n\n// Updated IP List: \" + ipList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\nVECTOR<Net.IP> ipsToRemove = Net.IP(\"192.168.1.2\"), Net.IP(\"192.168.1.3\")\n\nipList = Remove(ipList, ipsToRemove)\n\n// Updated IP List: \" + ipList"}, {"name": "Remove (VECTOR<Net.IPRange>, NUMBER, NUMBER)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<Net.IPRange>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\"), Net.IPRange(\"172.16.0.0/12\")\n\n// Define the start and end indices for removal\nNUMBER startIndex = 1\nNUMBER endIndex = 2\n\n// Create a new VECTOR to store the updated list\nVECTOR<Net.IPRange> updatedIpRanges\n\n// Loop through the original VECTOR and add elements that are not in the removal range\nFOR NUMBER i = 0 TO SIZE(ipRanges) - 1 {\n    IF i < startIndex OR i > endIndex THEN {\n        updatedIpRanges = updatedIpRanges + ipRanges[i]\n    }\n}\n\n// Assign the updated VECTOR back to the original variable\nipRanges = updatedIpRanges\n\n// Commented out debug output to verify the removal\n// \"Updated IP Ranges: \" + ipRanges", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRanges = Net.IPRange(\"192.168.1.0/24\"), Net.IPRange(\"10.0.0.0/8\"), Net.IPRange(\"172.16.0.0/12\")\n\n// Define the start and end indices for removal\nNUMBER startIndex = 1\nNUMBER endIndex = 2\n\n// Create a new VECTOR to store the updated list\nVECTOR<Net.IPRange> updatedIpRanges\n\n// Loop through the original VECTOR and add elements that are not in the removal range\nFOR NUMBER i = 0 TO SIZE(ipRanges) - 1 {\n    IF i < startIndex OR i > endIndex THEN {\n        updatedIpRanges = updatedIpRanges + ipRanges[i]\n    }\n}\n\n// Assign the updated VECTOR back to the original variable\nipRanges = updatedIpRanges\n\n// Commented out debug output to verify the removal\n// \"Updated IP Ranges: \" + ipRanges"}, {"name": "Remove (VECTOR<Net.IPRange>, VECTOR<Net.IPRange>)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<Net.IPRange>: list to remove from; VECTOR<Net.IPRange>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "VECTOR<Net.IPRange> ipList = \"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"\nVECTOR<Net.IPRange> ipToRemove = \"10.0.0.0/8\"\n\nVECTOR<Net.IPRange> updatedList = Remove(ipList, ipToRemove)\n\n// Updated IP List: \" + updatedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> ipList = \"192.168.1.0/24\", \"10.0.0.0/8\", \"172.16.0.0/12\"\nVECTOR<Net.IPRange> ipToRemove = \"10.0.0.0/8\"\n\nVECTOR<Net.IPRange> updatedList = Remove(ipList, ipToRemove)\n\n// Updated IP List: \" + updatedList"}, {"name": "Remove (VECTOR<NUMBER>, NUMBER, NUMBER)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<NUMBER>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR of NUMBERs\nVECTOR<NUMBER> numbers = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10\n\n// Original VECTOR: \n// numbers\n\n// Remove elements from index 3 to 5 (inclusive)\nnumbers = Remove(numbers, 3, 5)\n\n// Updated VECTOR: \n// numbers", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of NUMBERs\nVECTOR<NUMBER> numbers = 1, 2, 3, 4, 5, 6, 7, 8, 9, 10\n\n// Original VECTOR: \n// numbers\n\n// Remove elements from index 3 to 5 (inclusive)\nnumbers = Remove(numbers, 3, 5)\n\n// Updated VECTOR: \n// numbers"}, {"name": "Remove (VECTOR<NUMBER>, VECTOR<NUMBER>)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<NUMBER>: list to remove from; VECTOR<NUMBER>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "VECTOR<STRING> exampleList = \"one\", \"two\", \"three\", \"four\", \"five\"\n// Original List: \" + exampleList\n\n// Remove elements from index 1 to 3 (inclusive)\nexampleList = Remove(exampleList, 1, 3)\n// Updated List: \" + exampleList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> exampleList = \"one\", \"two\", \"three\", \"four\", \"five\"\n// Original List: \" + exampleList\n\n// Remove elements from index 1 to 3 (inclusive)\nexampleList = Remove(exampleList, 1, 3)\n// Updated List: \" + exampleList"}, {"name": "Remove (VECTOR<STRING>, NUMBER, NUMBER)", "return_type": "VECTOR<STRING>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<STRING>: list to remove from; NUMBER: starting index; NUMBER: ending index.", "description": "Remove list entries between given indices", "example_code": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> myList = \"apple\", \"banana\", \"cherry\", \"date\", \"elderberry\"\n\n// Original list: \" + myList\n// Remove elements from index 1 to 3 (inclusive)\nmyList = Remove(myList, 1, 3)\n\n// Updated list: \" + myList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of STRINGs\nVECTOR<STRING> myList = \"apple\", \"banana\", \"cherry\", \"date\", \"elderberry\"\n\n// Original list: \" + myList\n// Remove elements from index 1 to 3 (inclusive)\nmyList = Remove(myList, 1, 3)\n\n// Updated list: \" + myList"}, {"name": "Remove (VECTOR<STRING>, VECTOR<STRING>)", "return_type": "VECTOR<STRING>", "return_desc": "Returns the updated list.", "parameter_desc": "VECTOR<STRING>: list to remove from; VECTOR<STRING>: elements to remove.", "description": "Remove all elements from the first list that match an element in the second list.", "example_code": "VECTOR<STRING> originalList = \"apple\", \"banana\", \"cherry\", \"date\", \"fig\"\nVECTOR<STRING> itemsToRemove = \"banana\", \"fig\"\n\n// Using the Remove function to remove items from originalList that are present in itemsToRemove\nVECTOR<STRING> updatedList = Remove(originalList, itemsToRemove)\n\n// Original List: \" + originalList\n// Items to Remove: \" + itemsToRemove\n// Updated List: \" + updatedList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> originalList = \"apple\", \"banana\", \"cherry\", \"date\", \"fig\"\nVECTOR<STRING> itemsToRemove = \"banana\", \"fig\"\n\n// Using the Remove function to remove items from originalList that are present in itemsToRemove\nVECTOR<STRING> updatedList = Remove(originalList, itemsToRemove)\n\n// Original List: \" + originalList\n// Items to Remove: \" + itemsToRemove\n// Updated List: \" + updatedList"}, {"name": "Replace (STRING, NUMBER, NUMBER, STRING)", "return_type": "STRING", "return_desc": "Returns a string with the specified character range replaced by the second string argument.", "parameter_desc": "STRING: the original STRING; NUMBER: start position; NUMBER: length of the range; STRING: the replacement STRING.", "description": "Replaces character range by second STRING argument and returns the resulting STRING", "example_code": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\nNUMBER lengthToReplace = 5\nSTRING replacementString = \"MOWGLI\"\n\nSTRING resultString = Replace(originalString, startPosition, lengthToReplace, replacementString)\n// Original String: Hello, World!\n// Modified String: Hello, MOWGLI!", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\nNUMBER lengthToReplace = 5\nSTRING replacementString = \"MOWGLI\"\n\nSTRING resultString = Replace(originalString, startPosition, lengthToReplace, replacementString)\n// Original String: Hello, World!\n// Modified String: Hello, MOWGLI!"}, {"name": "Replace (STRING, NUMBER, STRING)", "return_type": "STRING", "return_desc": "Returns the modified string after replacing characters in the first string, starting at the given position, with the second string.", "parameter_desc": "STRING: the original STRING; NUMBER: the starting position; STRING: the STRING to insert.", "description": "Replaces characters of 1st STRING starting at given postion by the second STRING and returns the result", "example_code": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\nSTRING replacementString = \"MOWGLI\"\n\nSTRING resultString = Replace(originalString, startPosition, replacementString)\n\n// This will print \"Hello, MOWGLI!\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\nSTRING replacementString = \"MOWGLI\"\n\nSTRING resultString = Replace(originalString, startPosition, replacementString)\n\n// This will print \"Hello, MOWGLI!\""}, {"name": "ReplaceAll (STRING, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns a new string with all instances of the specified substring replaced by the given replacement string.", "parameter_desc": "STRING: the original text; STRING: the subSTRING to be replaced; STRING: the replacement text.", "description": "Replaces all occurences of the given subSTRING with the replacement STRING", "example_code": "STRING originalString = \"The quick brown fox jumps over the lazy dog\"\nSTRING targetSubstring = \"o\"\nSTRING replacementSubstring = \"0\"\n\nSTRING resultString = ReplaceAll(originalString, targetSubstring, replacementSubstring)\n\n// This will print: \"The quick br0wn f0x jumps 0ver the lazy d0g\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"The quick brown fox jumps over the lazy dog\"\nSTRING targetSubstring = \"o\"\nSTRING replacementSubstring = \"0\"\n\nSTRING resultString = ReplaceAll(originalString, targetSubstring, replacementSubstring)\n\n// This will print: \"The quick br0wn f0x jumps 0ver the lazy d0g\""}, {"name": "ReplaceFirst (STRING, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the new string with the replacement made.", "parameter_desc": "STRING: source to search in; STRING: what to search for; STRING: what to replace with.", "description": "Replaces the first occurrence of the search STRING(second parameter) in the source(first parameter) with the third parameter", "example_code": "STRING sourceString = \"Hello world, welcome to the world of MOWGLI\"\nSTRING targetString = \"world\"\nSTRING replacementString = \"universe\"\n\nSTRING resultString = ReplaceFirst(targetString, replacementString, sourceString)\n\n// Output: \"Hello universe, welcome to the world of MOWGLI\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING sourceString = \"Hello world, welcome to the world of MOWGLI\"\nSTRING targetString = \"world\"\nSTRING replacementString = \"universe\"\n\nSTRING resultString = ReplaceFirst(targetString, replacementString, sourceString)\n\n// Output: \"Hello universe, welcome to the world of MOWGLI\""}, {"name": "ReplaceIfEmpty (MWG.InternalVariant, STRING)", "return_type": "STRING", "return_desc": "Returns the given string if the internal variant string is empty. Otherwise, it returns the internal variant string.", "parameter_desc": "MWG.InternalVariant: the original STRING to check; STRING: the replacement STRING to use if the original is empty.", "description": "replace a STRING if it is empty", "example_code": "MWG.InternalVariant myVariant\nSTRING defaultValue = \"Default Value\"\n\n// Assume myVariant is empty at this point\nmyVariant = ReplaceIfEmpty(myVariant, defaultValue)\n\n// The value of myVariant is: \" + myVariant", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalVariant myVariant\nSTRING defaultValue = \"Default Value\"\n\n// Assume myVariant is empty at this point\nmyVariant = ReplaceIfEmpty(myVariant, defaultValue)\n\n// The value of myVariant is: \" + myVariant"}, {"name": "ReplaceIfEmpty (STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the second string if the first string is empty. Otherwise, it returns the first string.", "parameter_desc": "STRING: the target STRING to check; STRING: the replacement STRING.", "description": "replace a STRING if it is empty", "example_code": "STRING originalString = \"\"\nSTRING replacementString = \"Default Value\"\n\nSTRING resultString = ReplaceIfEmpty(originalString, replacementString)\n\n// \"Resulting String: \" + resultString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"\"\nSTRING replacementString = \"Default Value\"\n\nSTRING resultString = ReplaceIfEmpty(originalString, replacementString)\n\n// \"Resulting String: \" + resultString"}, {"name": "ReplaceIfEquals (MWG.InternalVariant, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the third string if the first and second strings are equal; otherwise, it returns the first string.", "parameter_desc": "MWG.InternalVariant: original STRING; the STRING to compare against, and the replacement STRING.", "description": "compare and replace a STRING", "example_code": "MWG.InternalVariant myVariant = \"oldValue\"\nSTRING targetValue = \"oldValue\"\nSTRING newValue = \"newValue\"\n\n// Replace the value of myVariant if it equals targetValue\nReplaceIfEquals(myVariant, targetValue, newValue)\n\n// The value of myVariant is now: \" + myVariant", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalVariant myVariant = \"oldValue\"\nSTRING targetValue = \"oldValue\"\nSTRING newValue = \"newValue\"\n\n// Replace the value of myVariant if it equals targetValue\nReplaceIfEquals(myVariant, targetValue, newValue)\n\n// The value of myVariant is now: \" + myVariant"}, {"name": "ReplaceIfEquals (STRING, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the third string if the first and second strings are equal; otherwise, it returns the first string.", "parameter_desc": "STRING: the original STRING; STRING: the text to compare against; STRING: the replacement text.", "description": "compare and replace a STRING", "example_code": "STRING originalString = \"hello\"\nSTRING targetString = \"hello\"\nSTRING replacementString = \"world\"\n\nSTRING resultString = ReplaceIfEquals(originalString, targetString, replacementString)\n\n// Original String: \" + originalString\n// Target String: \" + targetString\n// Replacement String: \" + replacementString\n// Result String: \" + resultString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"hello\"\nSTRING targetString = \"hello\"\nSTRING replacementString = \"world\"\n\nSTRING resultString = ReplaceIfEquals(originalString, targetString, replacementString)\n\n// Original String: \" + originalString\n// Target String: \" + targetString\n// Replacement String: \" + replacementString\n// Result String: \" + resultString"}, {"name": "Reverse (RegExJSi.List)", "return_type": "RegExJSi.List", "return_desc": "Returns a list where the elements are in the opposite order from the original list.", "parameter_desc": "RegExJSi.List: the list that you want to reverse.", "description": "Return a reversed version of a list", "example_code": "// Create a RegExJSi.List with some regular expressions\nRegExJSi.List regexList = \"reg1\", \"reg2\", \"reg3\"\n\n// Reverse the list\nRegExJSi.List reversedList = regexList.Reverse()\n\n// Reversed List: \" + reversedList was originally printed to the console here.", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a RegExJSi.List with some regular expressions\nRegExJSi.List regexList = \"reg1\", \"reg2\", \"reg3\"\n\n// Reverse the list\nRegExJSi.List reversedList = regexList.Reverse()\n\n// Reversed List: \" + reversedList was originally printed to the console here."}, {"name": "Reverse (VECTOR<MediaType>)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: The list to be reversed.", "description": "Return a reversed list", "example_code": "VECTOR<MediaType> originalVector = [\"example_media_list\"]\nVECTOR<MediaType> reversedVector\n\nNUMBER length = originalVector.Size()\nNUMBER i = length - 1\n\nWHILE i >= 0 DO {\n    reversedVector.PushBack(originalVector[i])\n    i = i - 1\n}\n\n// Optionally, set the reversed vector to a user-defined variable\nMWG.SetUserDefinedVar(\"ReversedMediaTypes\", reversedVector)\n\n// Original Vector: \" + originalVector\n// Reversed Vector: \" + reversedVector", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MediaType> originalVector = [\"example_media_list\"]\nVECTOR<MediaType> reversedVector\n\nNUMBER length = originalVector.Size()\nNUMBER i = length - 1\n\nWHILE i >= 0 DO {\n    reversedVector.PushBack(originalVector[i])\n    i = i - 1\n}\n\n// Optionally, set the reversed vector to a user-defined variable\nMWG.SetUserDefinedVar(\"ReversedMediaTypes\", reversedVector)\n\n// Original Vector: \" + originalVector\n// Reversed Vector: \" + reversedVector"}, {"name": "Reverse (VECTOR<MWG.ApplicationCategoryType>)", "return_type": "VECTOR<MWG.ApplicationCategoryType>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: the list to be reversed.", "description": "Return a reversed list", "example_code": "// Initialize a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"Social Media\", \"Streaming Media\", \"File Sharing\"]\n\n// Reverse the VECTOR\nVECTOR<MWG.ApplicationCategoryType> reversedCategories = Reverse(appCategories)\n\n// Reversed Application Categories: \" + reversedCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.ApplicationCategoryType\nVECTOR<MWG.ApplicationCategoryType> appCategories = [\"Social Media\", \"Streaming Media\", \"File Sharing\"]\n\n// Reverse the VECTOR\nVECTOR<MWG.ApplicationCategoryType> reversedCategories = Reverse(appCategories)\n\n// Reversed Application Categories: \" + reversedCategories"}, {"name": "Reverse (VECTOR<MWG.ApplicationType>)", "return_type": "VECTOR<MWG.ApplicationType>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: The list to be reversed.", "description": "Return a reversed list", "example_code": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appTypes = MWG.ApplicationType(\"App1\"), MWG.ApplicationType(\"App2\"), MWG.ApplicationType(\"App3\")\n\n// Reverse the VECTOR\nVECTOR<MWG.ApplicationType> reversedAppTypes = Reverse(appTypes)\n\n// Reversed Application Types: \" + reversedAppTypes", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.ApplicationType\nVECTOR<MWG.ApplicationType> appTypes = MWG.ApplicationType(\"App1\"), MWG.ApplicationType(\"App2\"), MWG.ApplicationType(\"App3\")\n\n// Reverse the VECTOR\nVECTOR<MWG.ApplicationType> reversedAppTypes = Reverse(appTypes)\n\n// Reversed Application Types: \" + reversedAppTypes"}, {"name": "Reverse (VECTOR<MWG.HostAndCertificate>)", "return_type": "VECTOR<MWG.HostAndCertificate>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: The input list to be reversed.", "description": "Return a reversed list", "example_code": "VECTOR<MWG.HostAndCertificate> originalVector = [\"example_list\"]\nVECTOR<MWG.HostAndCertificate> reversedVector = []\n\nNUMBER length = SIZE(originalVector)\nNUMBER i = length - 1\n\nWHILE i >= 0 DO {\n    reversedVector = Insert(reversedVector, originalVector[i], length - i - 1)\n    i = i - 1\n}\n\n// Original Vector: \" + originalVector\n// Reversed Vector: \" + reversedVector", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.HostAndCertificate> originalVector = [\"example_list\"]\nVECTOR<MWG.HostAndCertificate> reversedVector = []\n\nNUMBER length = SIZE(originalVector)\nNUMBER i = length - 1\n\nWHILE i >= 0 DO {\n    reversedVector = Insert(reversedVector, originalVector[i], length - i - 1)\n    i = i - 1\n}\n\n// Original Vector: \" + originalVector\n// Reversed Vector: \" + reversedVector"}, {"name": "Reverse (VECTOR<MWG.UrlCategory>)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: The list to be reversed.", "description": "Return a reversed list", "example_code": "// Initialize a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"example_url_category_list\"]\n\n// Original list: \n// urlCategories\n\n// Reverse the list using the Reverse function\nVECTOR<MWG.UrlCategory> reversedCategories = Reverse(urlCategories)\n\n// Reversed list: \n// reversedCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"example_url_category_list\"]\n\n// Original list: \n// urlCategories\n\n// Reverse the list using the Reverse function\nVECTOR<MWG.UrlCategory> reversedCategories = Reverse(urlCategories)\n\n// Reversed list: \n// reversedCategories"}, {"name": "Reverse (VECTOR<Net.IP>)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: The input list to be reversed.", "description": "Return a reversed list", "example_code": "// Define a VECTOR of Net.IP\nVECTOR<Net.IP> ipAddresses = \"192.168.1.1\", \"10.0.0.1\", \"172.16.0.1\"\n\n// Reverse the VECTOR of Net.IP\nVECTOR<Net.IP> reversedIPAddresses = Reverse(ipAddresses)\n\n// Original IP Addresses: \" + ipAddresses\n// Reversed IP Addresses: \" + reversedIPAddresses", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of Net.IP\nVECTOR<Net.IP> ipAddresses = \"192.168.1.1\", \"10.0.0.1\", \"172.16.0.1\"\n\n// Reverse the VECTOR of Net.IP\nVECTOR<Net.IP> reversedIPAddresses = Reverse(ipAddresses)\n\n// Original IP Addresses: \" + ipAddresses\n// Reversed IP Addresses: \" + reversedIPAddresses"}, {"name": "Reverse (VECTOR<Net.IPRange>)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: The list to be reversed.", "description": "Return a reversed list", "example_code": "VECTOR<Net.IPRange> ipRanges = [\"example_ip_range_list\"]\nVECTOR<Net.IPRange> reversedIPRanges = Reverse(ipRanges)\n\n// Original IP Ranges: \" + ipRanges\n// Reversed IP Ranges: \" + reversedIPRanges", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> ipRanges = [\"example_ip_range_list\"]\nVECTOR<Net.IPRange> reversedIPRanges = Reverse(ipRanges)\n\n// Original IP Ranges: \" + ipRanges\n// Reversed IP Ranges: \" + reversedIPRanges"}, {"name": "Reverse (VECTOR<NUMBER>)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: The list to be reversed.", "description": "Return a reversed list", "example_code": "VECTOR<NUMBER> originalNumbers = 1, 2, 3, 4, 5\nVECTOR<NUMBER> reversedNumbers = Reverse(originalNumbers)\n// Original Numbers: \" + originalNumbers\n// Reversed Numbers: \" + reversedNumbers", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<NUMBER> originalNumbers = 1, 2, 3, 4, 5\nVECTOR<NUMBER> reversedNumbers = Reverse(originalNumbers)\n// Original Numbers: \" + originalNumbers\n// Reversed Numbers: \" + reversedNumbers"}, {"name": "Reverse (VECTOR<STRING>)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a reversed list.", "parameter_desc": "VECTOR: the list to be reversed.", "description": "Return a reversed list", "example_code": "VECTOR<STRING> originalVector = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> reversedVector = Reverse(originalVector)\n\n// Original Vector: apple, banana, cherry\n// Reversed Vector: cherry, banana, apple", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> originalVector = \"apple\", \"banana\", \"cherry\"\nVECTOR<STRING> reversedVector = Reverse(originalVector)\n\n// Original Vector: apple, banana, cherry\n// Reversed Vector: cherry, banana, apple"}, {"name": "ReverseFind (STRING, NUMBER, STRING)", "return_type": "NUMBER", "return_desc": "Returns the position (or -1) of the second string within the first string, starting the search from a specified position.", "parameter_desc": "STRING: The main STRING to search within;  NUMBER: The starting position for the search;  STRING: The subSTRING to find in the main STRING.", "description": "Returns the position of the second STRING in the first one starting at given position (or -1)", "example_code": "STRING mainString = \"Hello, world! Welcome to the world of MOWGLI.\"\nSTRING searchString = \"world\"\nNUMBER startPosition = 30\nNUMBER position = ReverseFind(mainString, startPosition, searchString)\n\n// The position of 'searchString' in 'mainString' starting from position startPosition is: position", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mainString = \"Hello, world! Welcome to the world of MOWGLI.\"\nSTRING searchString = \"world\"\nNUMBER startPosition = 30\nNUMBER position = ReverseFind(mainString, startPosition, searchString)\n\n// The position of 'searchString' in 'mainString' starting from position startPosition is: position"}, {"name": "ReverseFind (STRING, STRING)", "return_type": "NUMBER", "return_desc": "Returns the position of the second string within the first string, or -1 if it is not found.", "parameter_desc": "STRING: the STRING to search within; STRING: the STRING to find.", "description": "Returns the position of the second STRING in the first one (or -1)", "example_code": "STRING mainString = \"Hello, world! Welcome to the world of MOWGLI.\"\nSTRING searchString = \"world\"\n\nNUMBER position = ReverseFind(mainString, searchString)\n\nIF position != -1 THEN {\n    // The last occurrence of 'searchString' is at position: position\n} ELSE {\n    // The string 'searchString' was not found in the main string.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mainString = \"Hello, world! Welcome to the world of MOWGLI.\"\nSTRING searchString = \"world\"\n\nNUMBER position = ReverseFind(mainString, searchString)\n\nIF position != -1 THEN {\n    // The last occurrence of 'searchString' is at position: position\n} ELSE {\n    // The string 'searchString' was not found in the main string.\n}"}, {"name": "RoutineName ()", "return_type": "STRING", "return_desc": "Returns the name of the currently executing routine as a string.", "parameter_desc": "None", "description": "Returns the name of the current routine", "example_code": "// RoutineName has been triggered\n// Add your code here", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// RoutineName has been triggered\n// Add your code here"}, {"name": "Set (MAP<STRING, STRING>, STRING, STRING)", "return_type": "MAP<STRING,STRING>", "return_desc": "Returns the modified map.", "parameter_desc": "MAP<STRING, STRING>: map to modify; STRING: key to modify; STRING: value to set.", "description": "Add a value-key pair to the map", "example_code": "// Initialize a MAP<STRING,STRING>\nMAP<STRING,STRING> exampleMap\n\n// Set a key-value pair in the map\nSet(exampleMap, \"username\", \"john_doe\")\n\n// Set another key-value pair in the map\nSet(exampleMap, \"email\", \"john_doe@example.com\")\n\n// Map contents: \" + exampleMap", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a MAP<STRING,STRING>\nMAP<STRING,STRING> exampleMap\n\n// Set a key-value pair in the map\nSet(exampleMap, \"username\", \"john_doe\")\n\n// Set another key-value pair in the map\nSet(exampleMap, \"email\", \"john_doe@example.com\")\n\n// Map contents: \" + exampleMap"}, {"name": "Set (RegExJSi.List, NUMBER, RegExJSi)", "return_type": "RegExJSi.List", "return_desc": "Returns the modified list with the new element inserted at the specified position.", "parameter_desc": "RegExJSi.List: the list where an element will be inserted; NUMBER: the position at which the element will be inserted; RegExJSi: the element to be inserted into the list.", "description": "Insert a list element at the given position", "example_code": "// Create a new RegExJSi object\nRegExJSi regex1 = RegExJSi(\"examplePattern1\")\nRegExJSi regex2 = RegExJSi(\"examplePattern2\")\n\n// Create a new RegExJSi.List object\nRegExJSi.List regexList = RegExJSi.List()\n\n// Add the first regex to the list\nregexList.Add(regex1)\n\n// Hypothetical Set function to replace the first regex with the second one\nSet(regexList, 0, regex2)\n\n// First pattern in list: \" + regexList.Get(0).Pattern()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a new RegExJSi object\nRegExJSi regex1 = RegExJSi(\"examplePattern1\")\nRegExJSi regex2 = RegExJSi(\"examplePattern2\")\n\n// Create a new RegExJSi.List object\nRegExJSi.List regexList = RegExJSi.List()\n\n// Add the first regex to the list\nregexList.Add(regex1)\n\n// Hypothetical Set function to replace the first regex with the second one\nSet(regexList, 0, regex2)\n\n// First pattern in list: \" + regexList.Get(0).Pattern()"}, {"name": "Size (MAP<STRING, STRING>)", "return_type": "NUMBER", "return_desc": "Returns the number of keys in the map.", "parameter_desc": "MAP<STRING, STRING>: map to count elements.", "description": "Functions: Returns the NUMBER of map keys", "example_code": "// Create an empty map\nMAP<STRING, STRING> myMap = CreateMapStringToString()\n\n// Add some key-value pairs to the map\nmyMap = Set(myMap, \"key1\", \"value1\")\nmyMap = Set(myMap, \"key2\", \"value2\")\nmyMap = Set(myMap, \"key3\", \"value3\")\n\n// Get the size of the map\nNUMBER mapSize = Size(myMap)\n\n// The size of the map is: mapSize", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an empty map\nMAP<STRING, STRING> myMap = CreateMapStringToString()\n\n// Add some key-value pairs to the map\nmyMap = Set(myMap, \"key1\", \"value1\")\nmyMap = Set(myMap, \"key2\", \"value2\")\nmyMap = Set(myMap, \"key3\", \"value3\")\n\n// Get the size of the map\nNUMBER mapSize = Size(myMap)\n\n// The size of the map is: mapSize"}, {"name": "Size (MWG.CertificateAuthorityList)", "return_type": "NUMBER", "return_desc": "Returns the number of elements in the given list.", "parameter_desc": "MWG.CertificateAuthorityList: list to count elements.", "description": "Return a count of list elements", "example_code": "// Retrieve the certificate authority list by name\nMWG.CertificateAuthorityList caList = MWG.CAListByName(\"ExampleCAList\")\n\n// Get the size of the certificate authority list\nNUMBER caListSize = Size(caList)\n\n// The size of the certificate authority list is: \n// caListSize", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Retrieve the certificate authority list by name\nMWG.CertificateAuthorityList caList = MWG.CAListByName(\"ExampleCAList\")\n\n// Get the size of the certificate authority list\nNUMBER caListSize = Size(caList)\n\n// The size of the certificate authority list is: \n// caListSize"}, {"name": "Size (RegExJSi.List)", "return_type": "NUMBER", "return_desc": "Returns the number of elements in the given list.", "parameter_desc": "RegExJSi.List: the list to be counted.", "description": "Return a count of list elements", "example_code": "// Initialize a RegExJSi.List\nRegExJSi.List myRegExList = RegExJSi.List()\n\n// Add some regular expressions to the list\nmyRegExList.Add(RegExJSi(\"regex1\"))\nmyRegExList.Add(RegExJSi(\"regex2\"))\nmyRegExList.Add(RegExJSi(\"regex3\"))\n\n// Get the size of the list\nNUMBER listSize = Size(myRegExList)\n\n// The size of the RegEx list is: listSize", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a RegExJSi.List\nRegExJSi.List myRegExList = RegExJSi.List()\n\n// Add some regular expressions to the list\nmyRegExList.Add(RegExJSi(\"regex1\"))\nmyRegExList.Add(RegExJSi(\"regex2\"))\nmyRegExList.Add(RegExJSi(\"regex3\"))\n\n// Get the size of the list\nNUMBER listSize = Size(myRegExList)\n\n// The size of the RegEx list is: listSize"}, {"name": "Slice (STRING, NUMBER)", "return_type": "STRING", "return_desc": "Returns a substring of the given string starting from the specified position.", "parameter_desc": "STRING: the input STRING to slice; NUMBER: the starting position.", "description": "Returns part of the STRING starting at the given position", "example_code": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\n\n// Use the Slice function to get a substring starting from the specified position\nSTRING result = Slice(originalString, startPosition)\n\n// Print the result to the console\n// result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!\"\nNUMBER startPosition = 7\n\n// Use the Slice function to get a substring starting from the specified position\nSTRING result = Slice(originalString, startPosition)\n\n// Print the result to the console\n// result"}, {"name": "Slice (STRING, NUMBER, NUMBER)", "return_type": "STRING", "return_desc": "Returns a substring that begins at the specified starting position and has the specified length.", "parameter_desc": "STRING: the STRING to extract from; NUMBER: the starting position; NUMBER: the length of the subSTRING.", "description": "Returns part of the STRING starting at the given position with given length", "example_code": "STRING originalString = \"Hello, MOWGLI!\"\nNUMBER startPosition = 7\nNUMBER length = 6\n\nSTRING slicedString = Slice(originalString, startPosition, length)\n// This will print \"MOWGLI\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, MOWGLI!\"\nNUMBER startPosition = 7\nNUMBER length = 6\n\nSTRING slicedString = Slice(originalString, startPosition, length)\n// This will print \"MOWGLI\""}, {"name": "Split (STRING, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing substrings of the original string, divided by the specified delimiter.", "parameter_desc": "STRING: the input STRING to be split; STRING: the delimiter.", "description": "Split a STRING by given delimiter into a STRING list", "example_code": "STRING inputString = \"apple,banana,cherry\"\nSTRING delimiter = \",\"\n\nVECTOR<STRING> result = Split(inputString, delimiter)\n\n// The split result is: + result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"apple,banana,cherry\"\nSTRING delimiter = \",\"\n\nVECTOR<STRING> result = Split(inputString, delimiter)\n\n// The split result is: + result"}, {"name": "Split (STRING, STRING, BOOLEAN)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector of substrings split by the specified delimiter from the input string, with the boolean indicating delimiter type.", "parameter_desc": "STRING: The input STRING to split.STRING: The delimiter used for splitting.BOOLEAN: Specifies if the delimiter is a single character (TRUE) or a STRING (FALSE).", "description": "Split a STRING by given delimiter into a STRING list. The BOOLEAN determines if delimiter contains single char delimiters or a STRING", "example_code": "STRING inputString = \"apple,banana,orange,grape\"\nSTRING delimiter = \",\"\nBOOLEAN isSingleCharDelimiter = TRUE\n\nVECTOR<STRING> result = Split(inputString, delimiter, isSingleCharDelimiter)\n\n// Split result: \" + result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"apple,banana,orange,grape\"\nSTRING delimiter = \",\"\nBOOLEAN isSingleCharDelimiter = TRUE\n\nVECTOR<STRING> result = Split(inputString, delimiter, isSingleCharDelimiter)\n\n// Split result: \" + result"}, {"name": "Split (STRING, STRING, STRING)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector of substrings obtained by splitting the input string and trimming specified characters.", "parameter_desc": "STRING: the input STRING to be split; STRING: the delimiter used to split the input; STRING: the characters to trim from the resulting subSTRINGs.", "description": "Split a STRING into a STRING list and trim characters defined by the last argument", "example_code": "STRING inputString = \"apple, banana, cherry, date\"\nSTRING delimiter = \",\"\nSTRING trimChars = \" \"\n\nVECTOR<STRING> result = Split(inputString, delimiter, trimChars)\n\n// \"Split result: \" + result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"apple, banana, cherry, date\"\nSTRING delimiter = \",\"\nSTRING trimChars = \" \"\n\nVECTOR<STRING> result = Split(inputString, delimiter, trimChars)\n\n// \"Split result: \" + result"}, {"name": "StartsWith (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the first `STRING` begins with the second `STRING`.", "parameter_desc": "STRING: the main STRING to check; STRING: the subSTRING to check for.", "description": "Returns TRUE if the STRING starts with the other STRING", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF StartsWith(urlString, \"https://\") THEN {\n    // The URL starts with 'https://'\n} ELSE {\n    // The URL does not start with 'https://'\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF StartsWith(urlString, \"https://\") THEN {\n    // The URL starts with 'https://'\n} ELSE {\n    // The URL does not start with 'https://'\n}"}, {"name": "StartsWithCaseInsensitive (STRING, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns true if the first string starts with the second string, ignoring case.", "parameter_desc": "STRING: the main STRING to be checked; STRING: the prefix STRING to check against.", "description": "Returns TRUE if the STRING starts (case insensitive) with the other STRING", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF StartsWithCaseInsensitive(urlString, \"https://example.com\") THEN {\n    // The URL starts with 'https://example.com' (case insensitive).\n    MWG.Allow(\"URL starts with example.com\")\n} ELSE {\n    // The URL does not start with 'https://example.com'.\n    MWG.Block(\"URL does not start with example.com\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\nIF StartsWithCaseInsensitive(urlString, \"https://example.com\") THEN {\n    // The URL starts with 'https://example.com' (case insensitive).\n    MWG.Allow(\"URL starts with example.com\")\n} ELSE {\n    // The URL does not start with 'https://example.com'.\n    MWG.Block(\"URL does not start with example.com\")\n}"}, {"name": "StopWatch.GetMS (STRING)", "return_type": "NUMBER", "return_desc": "Returns the elapsed time in milliseconds as a number from the stopwatch.", "parameter_desc": "STRING: The identifier of the stopwatch from which to get the milliseconds.", "description": "Get milliseconds from the stop watch", "example_code": "// Start the stopwatch with an identifier \"exampleWatch\"\nStopWatch.Start(\"exampleWatch\")\n\n// Perform some operations\n// For demonstration, we'll just use a DEBUG statement\n// Performing some operations...\n\n// Get the elapsed time in milliseconds from the stopwatch\nNUMBER elapsedTime = StopWatch.GetMS(\"exampleWatch\")\n\n// Print the elapsed time to the console\n// Elapsed time in milliseconds: \" + elapsedTime", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Start the stopwatch with an identifier \"exampleWatch\"\nStopWatch.Start(\"exampleWatch\")\n\n// Perform some operations\n// For demonstration, we'll just use a DEBUG statement\n// Performing some operations...\n\n// Get the elapsed time in milliseconds from the stopwatch\nNUMBER elapsedTime = StopWatch.GetMS(\"exampleWatch\")\n\n// Print the elapsed time to the console\n// Elapsed time in milliseconds: \" + elapsedTime"}, {"name": "StopWatch.GetUS (STRING)", "return_type": "NUMBER", "return_desc": "Returns the elapsed time in microseconds from the stopwatch.", "parameter_desc": "STRING: The identifier of the stopwatch instance.", "description": "Get microseconds from the stop watch", "example_code": "// Start the stopwatch with an identifier \"myStopwatch\"\nStopWatch.Start(\"myStopwatch\")\n\n// Perform some operations here\n// For demonstration, we'll just use a DEBUG statement\n// Performing some operations...\n\n// Get the elapsed time in microseconds\nNUMBER elapsedTime = StopWatch.GetUS(\"myStopwatch\")\n\n// Print the elapsed time to the console\n// Elapsed time in microseconds: \" + elapsedTime", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Start the stopwatch with an identifier \"myStopwatch\"\nStopWatch.Start(\"myStopwatch\")\n\n// Perform some operations here\n// For demonstration, we'll just use a DEBUG statement\n// Performing some operations...\n\n// Get the elapsed time in microseconds\nNUMBER elapsedTime = StopWatch.GetUS(\"myStopwatch\")\n\n// Print the elapsed time to the console\n// Elapsed time in microseconds: \" + elapsedTime"}, {"name": "SubSTRINGBetween (STRING, STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the substring that is found between the two specified strings in the given input string.", "parameter_desc": "STRING: the input STRING; STRING: the starting delimiter; STRING: the ending delimiter.", "description": "extract a sub-STRING between two STRINGs", "example_code": "STRING inputString = \"Hello [World]!\"\nSTRING startDelimiter = \"[\"\nSTRING endDelimiter = \"]\"\n\nSTRING result = SubstringBetween(inputString, startDelimiter, endDelimiter)\n\n// This will print \"World\" to the console", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING inputString = \"Hello [World]!\"\nSTRING startDelimiter = \"[\"\nSTRING endDelimiter = \"]\"\n\nSTRING result = SubstringBetween(inputString, startDelimiter, endDelimiter)\n\n// This will print \"World\" to the console"}, {"name": "TextLanguage (STRING)", "return_type": "STRING", "return_desc": "Returns the input text language (ISO 639-1 code).", "parameter_desc": "STRING: input text.", "description": "Returns the input text language (ISO 639-1 code)", "example_code": "STRING text = \"Hello, how are you?\"\nSTRING languageCode = TextLanguage(text)\n// Detected language code: \" + languageCode", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING text = \"Hello, how are you?\"\nSTRING languageCode = TextLanguage(text)\n// Detected language code: \" + languageCode"}, {"name": "ToBoolean (MWG.InternalVariant)", "return_type": "BOOLEAN", "return_desc": "Returns the Boolean representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert to BOOLEAN.", "description": "Convert an internal variant to a BOOLEAN.", "example_code": "MWG.InternalVariant internalValue = MWG.GetSomeInternalValue()  // Assume this function gets an internal variant value\nBOOLEAN booleanValue = ToBoolean(internalValue)\n\nIF booleanValue THEN {\n    // The internal value is TRUE\n} ELSE {\n    // The internal value is FALSE\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalVariant internalValue = MWG.GetSomeInternalValue()  // Assume this function gets an internal variant value\nBOOLEAN booleanValue = ToBoolean(internalValue)\n\nIF booleanValue THEN {\n    // The internal value is TRUE\n} ELSE {\n    // The internal value is FALSE\n}"}, {"name": "ToBoolVector (MWG.InternalVariant)", "return_type": "VECTOR<BOOLEAN>", "return_desc": "Returns the Boolean vector representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert to VECTOR of BOOLEANs.", "description": "Convert an internal variant to a VECTOR of BOOLEANs.", "example_code": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant internalVar = GetSomeInternalVariant()\n\n// Convert the internal variant to a VECTOR<BOOLEAN>\nVECTOR<BOOLEAN> boolVector = internalVar.ToBoolVector()\n\n// Use the boolean vector for some logic\nIF boolVector[0] THEN {\n    // The first element in the boolean vector is TRUE\n} ELSE {\n    // The first element in the boolean vector is FALSE\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant internalVar = GetSomeInternalVariant()\n\n// Convert the internal variant to a VECTOR<BOOLEAN>\nVECTOR<BOOLEAN> boolVector = internalVar.ToBoolVector()\n\n// Use the boolean vector for some logic\nIF boolVector[0] THEN {\n    // The first element in the boolean vector is TRUE\n} ELSE {\n    // The first element in the boolean vector is FALSE\n}"}, {"name": "ToDataRef (STRING)", "return_type": "DATAREF", "return_desc": "Returns the `DATAREF` representation of the `STRING`.", "parameter_desc": "STRING: input to convert.", "description": "Convert a STRING to a DATAREF", "example_code": "STRING exampleString = \"This is a test string\"\nDATAREF exampleDataRef = ToDataRef(exampleString)\n\n// Original STRING: This is a test string\n// Converted DATAREF: This is a test string converted to DATAREF", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING exampleString = \"This is a test string\"\nDATAREF exampleDataRef = ToDataRef(exampleString)\n\n// Original STRING: This is a test string\n// Converted DATAREF: This is a test string converted to DATAREF"}, {"name": "ToDLPClassification (STRING)", "return_type": "DLP.Classification", "return_desc": "Returns a DLP.Classification object corresponding to a given classification ID.", "parameter_desc": "STRING: the classification ID to be converted.", "description": "convert classifiation id to classifiation", "example_code": "STRING classificationID = \"12345\"\nDLP.Classification classification = ToDLPClassification(classificationID)\n\n// The classification object for ID 12345 is: classification", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING classificationID = \"12345\"\nDLP.Classification classification = ToDLPClassification(classificationID)\n\n// The classification object for ID 12345 is: classification"}, {"name": "ToHostAndCertificate (MWG.InternalVariant)", "return_type": "MWG.HostAndCertificate", "return_desc": "Returns the`MWG.HostAndCertificate`representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a MWG.HostAndCertificate.", "example_code": "// Assume we have an internal variant value\nMWG.InternalVariant internalVariantValue = ... // some internal variant value\n\n// Convert the internal variant to a HostAndCertificate object\nMWG.HostAndCertificate hostAndCert = ToHostAndCertificate(internalVariantValue)\n\n// Use the hostAndCert object for further processing\n// Host: \" + hostAndCert.Host\n// Certificate: \" + hostAndCert.Certificate", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an internal variant value\nMWG.InternalVariant internalVariantValue = ... // some internal variant value\n\n// Convert the internal variant to a HostAndCertificate object\nMWG.HostAndCertificate hostAndCert = ToHostAndCertificate(internalVariantValue)\n\n// Use the hostAndCert object for further processing\n// Host: \" + hostAndCert.Host\n// Certificate: \" + hostAndCert.Certificate"}, {"name": "ToIDSTRING (MWG.UrlCategory)", "return_type": "STRING", "return_desc": "Returns the unique identifier string of a GTI category based on the given URL category.", "parameter_desc": "MWG.UrlCategory: the URL category object to get the ID of.", "description": "Returns the ID of a GTI category", "example_code": "// Assume we have an MWG.UrlCategory object named urlCategory\nMWG.UrlCategory urlCategory = MWG.Url().GetCategory()\n\n// Use the ToIDString function to get the unique identifier string of the URL category\nSTRING categoryID = ToIDString(urlCategory)\n\n// The category ID is: \" + categoryID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.UrlCategory object named urlCategory\nMWG.UrlCategory urlCategory = MWG.Url().GetCategory()\n\n// Use the ToIDString function to get the unique identifier string of the URL category\nSTRING categoryID = ToIDString(urlCategory)\n\n// The category ID is: \" + categoryID"}, {"name": "ToIPAddress (MWG.InternalVariant)", "return_type": "Net.IP", "return_desc": "Returns the IP address representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a Net.IP.", "example_code": "MWG.InternalVariant variantIP = \"192.168.1.1\"\nNet.IP ipAddress = variantIP.ToIPAddress()\n\n// Converted IP Address: + ipAddress", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalVariant variantIP = \"192.168.1.1\"\nNet.IP ipAddress = variantIP.ToIPAddress()\n\n// Converted IP Address: + ipAddress"}, {"name": "ToIPRange (MWG.InternalVariant)", "return_type": "Net.IPRange", "return_desc": "Returns the IP address range representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a Net.IPRange.", "example_code": "// Assume we have an internal variant value\nMWG.InternalVariant internalValue = GetInternalVariantValue()\n\n// Convert the internal variant to an IP range\nNet.IPRange ipRange = ToIPRange(internalValue)\n\n// Perform some action with the IP range\n// Converted IP Range: \" + ipRange.ToString()\n\n// Example condition to block a specific IP range\nIF ipRange.Contains(\"192.168.1.1\") THEN {\n    MWG.Block(\"Access from this IP is not allowed\")\n} ELSE {\n    MWG.Allow(\"IP is allowed\")\n}\n\n// Dummy function to simulate getting an internal variant value\nFUNCTION GetInternalVariantValue() RETURNS MWG.InternalVariant {\n    // This is just a placeholder. Replace with actual logic to get the internal variant.\n    MWG.InternalVariant variant\n    // Set the variant value here\n    RETURN variant\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an internal variant value\nMWG.InternalVariant internalValue = GetInternalVariantValue()\n\n// Convert the internal variant to an IP range\nNet.IPRange ipRange = ToIPRange(internalValue)\n\n// Perform some action with the IP range\n// Converted IP Range: \" + ipRange.ToString()\n\n// Example condition to block a specific IP range\nIF ipRange.Contains(\"192.168.1.1\") THEN {\n    MWG.Block(\"Access from this IP is not allowed\")\n} ELSE {\n    MWG.Allow(\"IP is allowed\")\n}\n\n// Dummy function to simulate getting an internal variant value\nFUNCTION GetInternalVariantValue() RETURNS MWG.InternalVariant {\n    // This is just a placeholder. Replace with actual logic to get the internal variant.\n    MWG.InternalVariant variant\n    // Set the variant value here\n    RETURN variant\n}"}, {"name": "ToIPRangeVector (MWG.InternalVariant)", "return_type": "VECTOR<Net.IPRange>", "return_desc": "Returns the IP address range vector representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a VECTOR of Net.IPRange", "example_code": "// Assume internalVariant is an MWG.InternalVariant object\nMWG.InternalVariant internalVariant = ... // Initialize this with your specific internal variant\n\n// Convert the internal variant to a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRangeVector = ToIPRangeVector(internalVariant)\n\n// Converted IP Ranges: \" + ipRangeVector", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume internalVariant is an MWG.InternalVariant object\nMWG.InternalVariant internalVariant = ... // Initialize this with your specific internal variant\n\n// Convert the internal variant to a VECTOR of Net.IPRange\nVECTOR<Net.IPRange> ipRangeVector = ToIPRangeVector(internalVariant)\n\n// Converted IP Ranges: \" + ipRangeVector"}, {"name": "ToIPVector (MWG.InternalVariant)", "return_type": "VECTOR<Net.IP>", "return_desc": "Returns the IP address vector representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a VECTOR of Net.IP", "example_code": "// Assume internalVariant is an MWG.InternalVariant object obtained from some context\nMWG.InternalVariant internalVariant = ... // Obtain the internal variant from context\n\n// Convert the internal variant to a VECTOR of Net.IP\nVECTOR<Net.IP> ipVector = ToIPVector(internalVariant)\n\n// Iterate over the VECTOR and print each IP address\nFOR EACH ip IN ipVector {\n    // IP Address: \" + ip\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume internalVariant is an MWG.InternalVariant object obtained from some context\nMWG.InternalVariant internalVariant = ... // Obtain the internal variant from context\n\n// Convert the internal variant to a VECTOR of Net.IP\nVECTOR<Net.IP> ipVector = ToIPVector(internalVariant)\n\n// Iterate over the VECTOR and print each IP address\nFOR EACH ip IN ipVector {\n    // IP Address: \" + ip\n}"}, {"name": "ToJSON (MWG.InternalVariant)", "return_type": "JSON", "return_desc": "Returns the JSON object representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a JSON object.", "example_code": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant myVariant\n\n// Populate the MWG.InternalVariant object with some data\nmyVariant[\"key1\"] = \"value1\"\nmyVariant[\"key2\"] = 12345\nmyVariant[\"key3\"] = TRUE\n\n// Convert the MWG.InternalVariant object to a JSON string\nSTRING jsonString = myVariant.ToJSON()\n\n// Converted JSON: \" + jsonString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant myVariant\n\n// Populate the MWG.InternalVariant object with some data\nmyVariant[\"key1\"] = \"value1\"\nmyVariant[\"key2\"] = 12345\nmyVariant[\"key3\"] = TRUE\n\n// Convert the MWG.InternalVariant object to a JSON string\nSTRING jsonString = myVariant.ToJSON()\n\n// Converted JSON: \" + jsonString"}, {"name": "ToLower (STRING)", "return_type": "STRING", "return_desc": "Returns the input string converted to all lower case characters.", "parameter_desc": "STRING: The input STRING to be converted to lower case.", "description": "Returns the input STRING with upper case characters replaced by lower case", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING lowerCaseUrl = ToLower(currentUrl)\n// lowerCaseUrl", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING lowerCaseUrl = ToLower(currentUrl)\n// lowerCaseUrl"}, {"name": "ToMap (MWG.InternalVariant)", "return_type": "MAP<STRING,MWG.InternalVariant>", "return_desc": "Returns the map representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a map.", "example_code": "// Assume we have an MWG.InternalVariant object named internalVariant\nMWG.InternalVariant internalVariant = ... // some initialization or assignment\n\n// Convert the internal variant to a map\nMAP<STRING, MWG.InternalVariant> variantMap = ToMap(internalVariant)\n\n// Iterate over the map and print each key-value pair\nFOR EACH key IN variantMap {\n    MWG.InternalVariant value = variantMap[key]\n    // Key: key, Value: value\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant object named internalVariant\nMWG.InternalVariant internalVariant = ... // some initialization or assignment\n\n// Convert the internal variant to a map\nMAP<STRING, MWG.InternalVariant> variantMap = ToMap(internalVariant)\n\n// Iterate over the map and print each key-value pair\nFOR EACH key IN variantMap {\n    MWG.InternalVariant value = variantMap[key]\n    // Key: key, Value: value\n}"}, {"name": "ToMediaType (MWG.InternalVariant)", "return_type": "MediaType", "return_desc": "Returns the `MediaType` representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a MediaType.", "example_code": "// Assume we have an internal variant value\nMWG.InternalVariant internalValue = GetInternalVariantValue()\n\n// Convert the internal variant to a MediaType\nMediaType mediaType = ToMediaType(internalValue)\n\n// Perform some action based on the MediaType\nIF mediaType == \"application/pdf\" THEN {\n    // The media type is PDF.\n} ELSE {\n    // The media type is not PDF.\n}\n\n// Dummy function to simulate getting an internal variant value\nFUNCTION GetInternalVariantValue() RETURNS MWG.InternalVariant {\n    // This is just a placeholder. Replace with actual logic to get the internal variant.\n    MWG.InternalVariant dummyValue = \"application/pdf\"\n    RETURN dummyValue\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an internal variant value\nMWG.InternalVariant internalValue = GetInternalVariantValue()\n\n// Convert the internal variant to a MediaType\nMediaType mediaType = ToMediaType(internalValue)\n\n// Perform some action based on the MediaType\nIF mediaType == \"application/pdf\" THEN {\n    // The media type is PDF.\n} ELSE {\n    // The media type is not PDF.\n}\n\n// Dummy function to simulate getting an internal variant value\nFUNCTION GetInternalVariantValue() RETURNS MWG.InternalVariant {\n    // This is just a placeholder. Replace with actual logic to get the internal variant.\n    MWG.InternalVariant dummyValue = \"application/pdf\"\n    RETURN dummyValue\n}"}, {"name": "ToMediaType (STRING)", "return_type": "MediaType", "return_desc": "Returns the `MediaType` representation of the string.", "parameter_desc": "STRING: value to convert.", "description": "Convert a STRING to a MediaType.", "example_code": "STRING mediaTypeString = \"application/json\"\nMediaType mediaTypeObject = ToMediaType(mediaTypeString)\n\n// Converted media type: + mediaTypeObject", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING mediaTypeString = \"application/json\"\nMediaType mediaTypeObject = ToMediaType(mediaTypeString)\n\n// Converted media type: + mediaTypeObject"}, {"name": "ToMediaTypeVector (MWG.InternalVariant)", "return_type": "VECTOR<MediaType>", "return_desc": "Returns the `MediaType` `VECTOR`representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a VECTOR of MediaTypes", "example_code": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant internalVariant = ... // some initialization\n\n// Convert the MWG.InternalVariant to a VECTOR<MediaType>\nVECTOR<MediaType> mediaTypeVector = internalVariant.ToMediaTypeVector()\n\n// Set a user-defined variable with the converted VECTOR<MediaType>\nMWG.SetUserDefinedVar(\"exampleMediaTypeVector\", mediaTypeVector)\n\n// Converted MediaTypeVector: \" + mediaTypeVector", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant internalVariant = ... // some initialization\n\n// Convert the MWG.InternalVariant to a VECTOR<MediaType>\nVECTOR<MediaType> mediaTypeVector = internalVariant.ToMediaTypeVector()\n\n// Set a user-defined variable with the converted VECTOR<MediaType>\nMWG.SetUserDefinedVar(\"exampleMediaTypeVector\", mediaTypeVector)\n\n// Converted MediaTypeVector: \" + mediaTypeVector"}, {"name": "ToNumber (MWG.InternalVariant)", "return_type": "NUMBER", "return_desc": "Returns the number representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a NUMBER.", "example_code": "// Define a string variable\nSTRING strNumber = \"12345\"\n\n// Convert the string to a number using ToNumber\nNUMBER num = ToNumber(strNumber)\n\n// Perform an arithmetic operation\nNUMBER result = num + 10\n\n// The result is: \" + ToString(result)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a string variable\nSTRING strNumber = \"12345\"\n\n// Convert the string to a number using ToNumber\nNUMBER num = ToNumber(strNumber)\n\n// Perform an arithmetic operation\nNUMBER result = num + 10\n\n// The result is: \" + ToString(result)"}, {"name": "ToNumber (STRING)", "return_type": "NUMBER", "return_desc": "Returns the numerical representation of the input string.", "parameter_desc": "STRING: The STRING that you want to convert to a NUMBER.", "description": "Convert a STRING to a NUMBER", "example_code": "STRING strValue = \"12345\"\nNUMBER numValue = ToNumber(strValue)\n// The numeric value is: numValue", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING strValue = \"12345\"\nNUMBER numValue = ToNumber(strValue)\n// The numeric value is: numValue"}, {"name": "ToNumberVector (MWG.InternalVariant)", "return_type": "VECTOR<NUMBER>", "return_desc": "Returns the number vector representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a VECTOR of NUMBERs.", "example_code": "// Assume we have an MWG.InternalVariant value\nMWG.InternalVariant internalVariantValue = ... // some internal variant value\n\n// Convert the internal variant to a VECTOR<NUMBER>\nVECTOR<NUMBER> numberVector = ToNumberVector(internalVariantValue)\n\n// Converted VECTOR<NUMBER>: \" + numberVector", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant value\nMWG.InternalVariant internalVariantValue = ... // some internal variant value\n\n// Convert the internal variant to a VECTOR<NUMBER>\nVECTOR<NUMBER> numberVector = ToNumberVector(internalVariantValue)\n\n// Converted VECTOR<NUMBER>: \" + numberVector"}, {"name": "ToRegExJSi (MWG.InternalVariant)", "return_type": "RegExJSi", "return_desc": "Returns the regular expression representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a regular expression.", "example_code": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\n// Define the regular expression pattern\nSTRING pattern = \".*example\\\\.com.*\"\n\n// Convert the pattern to a RegExJSi object\nRegExJSi regex = ToRegExJSi(pattern)\n\n// Check if the URL matches the pattern\nIF regex.Match(urlString) THEN {\n    // URL matches the pattern\n    MWG.Allow(\"URL matches the pattern\")\n} ELSE {\n    // URL does not match the pattern\n    MWG.Block(\"URL does not match the pattern\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nSTRING urlString = currentUrl.ToString()\n\n// Define the regular expression pattern\nSTRING pattern = \".*example\\.com.*\"\n\n// Convert the pattern to a RegExJSi object\nRegExJSi regex = ToRegExJSi(pattern)\n\n// Check if the URL matches the pattern\nIF regex.Match(urlString) THEN {\n    // URL matches the pattern\n    MWG.Allow(\"URL matches the pattern\")\n} ELSE {\n    // URL does not match the pattern\n    MWG.Block(\"URL does not match the pattern\")\n}"}, {"name": "ToRegExJSi (STRING)", "return_type": "RegExJSi", "return_desc": "Returns a regular expression object constructed from the input string.", "parameter_desc": "STRING: the input text to parse a regular expression from.", "description": "Construct a regular expression from a STRING", "example_code": "STRING pattern = \"example.*\"\nRegExJSi regex = ToRegExJSi(pattern)\n\nSTRING testString = \"exampleString\"\n\nIF regex.Matches(testString) THEN {\n    // The string matches the pattern.\n} ELSE {\n    // The string does not match the pattern.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING pattern = \"example.*\"\nRegExJSi regex = ToRegExJSi(pattern)\n\nSTRING testString = \"exampleString\"\n\nIF regex.Matches(testString) THEN {\n    // The string matches the pattern.\n} ELSE {\n    // The string does not match the pattern.\n}"}, {"name": "ToRegExJSiList (MWG.InternalVariant)", "return_type": "RegExJSi.List", "return_desc": "Returns the regular expression list representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a list of regular expressions.", "example_code": "// Assume we have an internal variant\nMWG.InternalVariant internalVariant = GetInternalVariant()\n\n// Convert the internal variant to a list of regular expressions\nRegExJSi.List regexList = ToRegExJSiList(internalVariant)\n\n// Converted RegEx List: \n// regexList.ToString()\n\n// Dummy function to simulate getting an internal variant\nFUNCTION GetInternalVariant() RETURNS MWG.InternalVariant {\n    // Create and return a dummy internal variant\n    MWG.InternalVariant variant\n    // Populate the variant with some data (this is just an example)\n    variant.SetValue(\"exampleKey\", \"exampleValue\")\n    RETURN variant\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an internal variant\nMWG.InternalVariant internalVariant = GetInternalVariant()\n\n// Convert the internal variant to a list of regular expressions\nRegExJSi.List regexList = ToRegExJSiList(internalVariant)\n\n// Converted RegEx List: \n// regexList.ToString()\n\n// Dummy function to simulate getting an internal variant\nFUNCTION GetInternalVariant() RETURNS MWG.InternalVariant {\n    // Create and return a dummy internal variant\n    MWG.InternalVariant variant\n    // Populate the variant with some data (this is just an example)\n    variant.SetValue(\"exampleKey\", \"exampleValue\")\n    RETURN variant\n}"}, {"name": "ToRegExJSiList (VECTOR<STRING>)", "return_type": "RegExJSi.List", "return_desc": "Returns a list of regular expressions created from a given vector of strings.", "parameter_desc": "VECTOR: A collection of STRINGs to be converted into a regular expression list.", "description": "Create a regular expression list from a STRING VECTOR", "example_code": "// Define a VECTOR of STRINGs containing regular expression patterns\nVECTOR<STRING> patterns = \"pattern1\", \"pattern2\", \"pattern3\"\n\n// Convert the VECTOR of STRINGs into a RegExJSi.List\nRegExJSi.List regexList = ToRegExJSiList(patterns)\n\n// Converted RegExJSi.List: regexList", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of STRINGs containing regular expression patterns\nVECTOR<STRING> patterns = \"pattern1\", \"pattern2\", \"pattern3\"\n\n// Convert the VECTOR of STRINGs into a RegExJSi.List\nRegExJSi.List regexList = ToRegExJSiList(patterns)\n\n// Converted RegExJSi.List: regexList"}, {"name": "ToShortSTRING (VECTOR<MWG.UrlCategory>)", "return_type": "STRING", "return_desc": "Returns GTI category list as short name string.", "parameter_desc": "VECTOR<MWG.UrlCategory>: list to convert to short STRING.", "description": "Returns GTI category list as short name STRING", "example_code": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Get the categories of the current URL\nVECTOR<MWG.UrlCategory> urlCategories = currentUrl.GetCategories()\n\n// Convert the categories to a short string\nSTRING shortCategories = ToShortString(urlCategories)\n\n// Short Categories: \" + shortCategories\n// was previously printed to the console here", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the current URL\nMWG.URL currentUrl = MWG.Url()\n\n// Get the categories of the current URL\nVECTOR<MWG.UrlCategory> urlCategories = currentUrl.GetCategories()\n\n// Convert the categories to a short string\nSTRING shortCategories = ToShortString(urlCategories)\n\n// Short Categories: \" + shortCategories\n// was previously printed to the console here"}, {"name": "ToSTRING (BOOLEAN)", "return_type": "STRING", "return_desc": "Returns the string representation of a boolean value.", "parameter_desc": "BOOLEAN: The BOOLEAN value to be converted to a STRING.", "description": "Convert a BOOLEAN to a STRING", "example_code": "BOOLEAN isAllowed = TRUE\nSTRING isAllowedStr = ToString(isAllowed)\n// The value of isAllowed is: \" + isAllowedStr", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "BOOLEAN isAllowed = TRUE\nSTRING isAllowedStr = ToString(isAllowed)\n// The value of isAllowed is: \" + isAllowedStr"}, {"name": "ToSTRING (DATAREF)", "return_type": "STRING", "return_desc": "Returns the data referenced by the `DATAREF` as a string.", "parameter_desc": "DATAREF: The data reference to be converted to a STRING.", "description": "Returns data as STRING", "example_code": "NUMBER myNumber = 42\nBOOLEAN myBoolean = TRUE\n\nSTRING numberAsString = ToString(myNumber)\nSTRING booleanAsString = ToString(myBoolean)\n\n// The number as a string is: 42\n// The boolean as a string is: TRUE", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER myNumber = 42\nBOOLEAN myBoolean = TRUE\n\nSTRING numberAsString = ToString(myNumber)\nSTRING booleanAsString = ToString(myBoolean)\n\n// The number as a string is: 42\n// The boolean as a string is: TRUE"}, {"name": "ToSTRING (JSON)", "return_type": "STRING", "return_desc": "Returns the string representation of the given JSON object.", "parameter_desc": "JSON: the JSON object to be converted to a STRING.", "description": "Convert a JSON object to a STRING", "example_code": "// Create a JSON object\nJSON jsonObject = JSON()\n\n// Add some key-value pairs to the JSON object\njsonObject[\"name\"] = \"John Doe\"\njsonObject[\"age\"] = 30\njsonObject[\"isEmployee\"] = TRUE\n\n// Convert the JSON object to a string\nSTRING jsonString = jsonObject.ToString()\n\n// The following line would print the JSON string to the console\n// jsonString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a JSON object\nJSON jsonObject = JSON()\n\n// Add some key-value pairs to the JSON object\njsonObject[\"name\"] = \"John Doe\"\njsonObject[\"age\"] = 30\njsonObject[\"isEmployee\"] = TRUE\n\n// Convert the JSON object to a string\nSTRING jsonString = jsonObject.ToString()\n\n// The following line would print the JSON string to the console\n// jsonString"}, {"name": "ToSTRING (MAP<STRING, STRING>)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "MAP<STRING, STRING>: map to convert to STRING.", "description": "Convert a STRING to STRING map to a STRING", "example_code": "// Initialize a MAP<STRING,STRING>\nMAP<STRING,STRING> exampleMap\nexampleMap[\"key1\"] = \"value1\"\nexampleMap[\"key2\"] = \"value2\"\nexampleMap[\"key3\"] = \"value3\"\n\n// Convert the map to a string\nSTRING mapAsString = ToString(exampleMap)\n\n// Print the string representation of the map to the console\n// mapAsString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a MAP<STRING,STRING>\nMAP<STRING,STRING> exampleMap\nexampleMap[\"key1\"] = \"value1\"\nexampleMap[\"key2\"] = \"value2\"\nexampleMap[\"key3\"] = \"value3\"\n\n// Convert the map to a string\nSTRING mapAsString = ToString(exampleMap)\n\n// Print the string representation of the map to the console\n// mapAsString"}, {"name": "ToSTRING (MediaType)", "return_type": "STRING", "return_desc": "Returns the string representation of the specified media type.", "parameter_desc": "MediaType: the media type to be converted to a STRING.", "description": "Convert a media type to a STRING", "example_code": "// Assume mediaType is a MediaType object obtained from some previous operation\nMediaType mediaType = GetMediaTypeFromSomewhere()\n\n// Convert the MediaType to a STRING\nSTRING mediaTypeString = ToString(mediaType)\n\n// The media type as a string is: \" + mediaTypeString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume mediaType is a MediaType object obtained from some previous operation\nMediaType mediaType = GetMediaTypeFromSomewhere()\n\n// Convert the MediaType to a STRING\nSTRING mediaTypeString = ToString(mediaType)\n\n// The media type as a string is: \" + mediaTypeString"}, {"name": "ToSTRING (MWG.ApplicationCategoryType)", "return_type": "STRING", "return_desc": "Returns application category type as a string.", "parameter_desc": "MWG.ApplicationCategoryType: to be converted to STRING", "description": "Convert application category type to a STRING", "example_code": "// Assume we have an MWG.ApplicationCategoryType object\nMWG.ApplicationCategoryType appCategory = GetApplicationCategory()\n\n// Convert the application category to a string\nSTRING appCategoryString = appCategory.ToString()\n\n// Application Category: appCategoryString\n\n// Dummy function to simulate getting an application category\nFUNCTION GetApplicationCategory() RETURNS MWG.ApplicationCategoryType {\n    // This function would normally retrieve the application category\n    // For this example, we'll just return a placeholder value\n    RETURN MWG.ApplicationCategoryType(\"ExampleCategory\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.ApplicationCategoryType object\nMWG.ApplicationCategoryType appCategory = GetApplicationCategory()\n\n// Convert the application category to a string\nSTRING appCategoryString = appCategory.ToString()\n\n// Application Category: appCategoryString\n\n// Dummy function to simulate getting an application category\nFUNCTION GetApplicationCategory() RETURNS MWG.ApplicationCategoryType {\n    // This function would normally retrieve the application category\n    // For this example, we'll just return a placeholder value\n    RETURN MWG.ApplicationCategoryType(\"ExampleCategory\")\n}"}, {"name": "ToSTRING (MWG.ApplicationSubCategoryType)", "return_type": "STRING", "return_desc": "Returns application subcategory type as a string.", "parameter_desc": "MWG.ApplicationSubCategoryType: to be converted to STRING", "description": "Convert application subcategory type to a STRING", "example_code": "// Assume we have an MWG.ApplicationSubCategoryType object\nMWG.ApplicationSubCategoryType appSubCategory = GetApplicationSubCategory()\n\n// Convert the MWG.ApplicationSubCategoryType object to a string\nSTRING appSubCategoryString = appSubCategory.ToString()\n\n// Print the string representation to the console\n// appSubCategoryString\n\n// Dummy function to simulate obtaining an MWG.ApplicationSubCategoryType object\nFUNCTION MWG.ApplicationSubCategoryType GetApplicationSubCategory() {\n    // Implementation to get the MWG.ApplicationSubCategoryType object\n    // This is just a placeholder for the actual implementation\n    RETURN someAppSubCategoryObject\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.ApplicationSubCategoryType object\nMWG.ApplicationSubCategoryType appSubCategory = GetApplicationSubCategory()\n\n// Convert the MWG.ApplicationSubCategoryType object to a string\nSTRING appSubCategoryString = appSubCategory.ToString()\n\n// Print the string representation to the console\n// appSubCategoryString\n\n// Dummy function to simulate obtaining an MWG.ApplicationSubCategoryType object\nFUNCTION MWG.ApplicationSubCategoryType GetApplicationSubCategory() {\n    // Implementation to get the MWG.ApplicationSubCategoryType object\n    // This is just a placeholder for the actual implementation\n    RETURN someAppSubCategoryObject\n}"}, {"name": "ToSTRING (MWG.ApplicationType)", "return_type": "STRING", "return_desc": "Returns the application's ID as a string.", "parameter_desc": "MWG.ApplicationType: the type of application for which the ID is to be returned as a STRING.", "description": "Returns the id of an application", "example_code": "// Assume we have an MWG.ApplicationType object\nMWG.ApplicationType appType = GetApplicationType() // This is a placeholder for however you obtain the application type\n\n// Convert the MWG.ApplicationType object to a STRING\nSTRING appTypeString = appType.ToString()\n\n// Print the string representation to the console\n// Application Type: \" + appTypeString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.ApplicationType object\nMWG.ApplicationType appType = GetApplicationType() // This is a placeholder for however you obtain the application type\n\n// Convert the MWG.ApplicationType object to a STRING\nSTRING appTypeString = appType.ToString()\n\n// Print the string representation to the console\n// Application Type: \" + appTypeString"}, {"name": "ToSTRING (MWG.InternalVariant)", "return_type": "STRING", "return_desc": "Returns an internal variant as a string.", "parameter_desc": "MWG.InternalVariant: to be converted to STRING", "description": "Converts internal variant to STRING", "example_code": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant variant = GetSomeInternalVariant()\n\n// Convert the InternalVariant to a string\nSTRING variantString = variant.ToString()\n\n// Print the string representation to the console\n// variantString\n\n// Dummy function to simulate obtaining an MWG.InternalVariant object\nFUNCTION GetSomeInternalVariant() RETURNS MWG.InternalVariant {\n    // Implementation to get an MWG.InternalVariant object\n    // This is just a placeholder for the actual implementation\n    MWG.InternalVariant exampleVariant\n    // Set some value to the exampleVariant\n    return exampleVariant\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant variant = GetSomeInternalVariant()\n\n// Convert the InternalVariant to a string\nSTRING variantString = variant.ToString()\n\n// Print the string representation to the console\n// variantString\n\n// Dummy function to simulate obtaining an MWG.InternalVariant object\nFUNCTION GetSomeInternalVariant() RETURNS MWG.InternalVariant {\n    // Implementation to get an MWG.InternalVariant object\n    // This is just a placeholder for the actual implementation\n    MWG.InternalVariant exampleVariant\n    // Set some value to the exampleVariant\n    return exampleVariant\n}"}, {"name": "ToSTRING (MWG.UrlCategory)", "return_type": "STRING", "return_desc": "Returns the GTI category as a string.", "parameter_desc": "MWG.UrlCategory: the URL category from which the function will generate a GTI category STRING.", "description": "Returns GTI category STRING", "example_code": "MWG.URL currentUrl = MWG.Url()\nMWG.UrlCategory urlCategory = currentUrl.Category()\nSTRING categoryString = ToString(urlCategory)\n\n// The URL category is: categoryString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.URL currentUrl = MWG.Url()\nMWG.UrlCategory urlCategory = currentUrl.Category()\nSTRING categoryString = ToString(urlCategory)\n\n// The URL category is: categoryString"}, {"name": "ToSTRING (Net.IP)", "return_type": "STRING", "return_desc": "Returns the string representation of the given IP address.", "parameter_desc": "Net.IP: The IP address to be converted to a STRING.", "description": "Convert an IP address to a STRING", "example_code": "// Assume we have an IP address object\nNet.IP ipAddress = \"192.168.1.1\"\n\n// Convert the IP address to a string\nSTRING ipString = Net.ToString(ipAddress)\n\n// The IP address as a string is: \" + ipString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an IP address object\nNet.IP ipAddress = \"192.168.1.1\"\n\n// Convert the IP address to a string\nSTRING ipString = Net.ToString(ipAddress)\n\n// The IP address as a string is: \" + ipString"}, {"name": "ToSTRING (Net.IPRange)", "return_type": "STRING", "return_desc": "Returns a string representation of the given IP range.", "parameter_desc": "Net.IPRange: the IP range object to be converted to a STRING.", "description": "Convert IP range to a STRING", "example_code": "// Define an IP range\nNet.IPRange ipRange = Net.IPRange(\"192.168.1.0\", \"192.168.1.255\")\n\n// Convert the IP range to a string\nSTRING ipRangeString = ToString(ipRange)\n\n// The IP range is: \n// ipRangeString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define an IP range\nNet.IPRange ipRange = Net.IPRange(\"192.168.1.0\", \"192.168.1.255\")\n\n// Convert the IP range to a string\nSTRING ipRangeString = ToString(ipRange)\n\n// The IP range is: \n// ipRangeString"}, {"name": "ToSTRING (NUMBER)", "return_type": "STRING", "return_desc": "Returns the string representation of the given number.", "parameter_desc": "NUMBER: the numeric value to be converted to a STRING.", "description": "Convert a NUMBER to a STRING", "example_code": "NUMBER myNumber = 123.45\nSTRING myString = ToString(myNumber)\n// Outputting myString to the console", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER myNumber = 123.45\nSTRING myString = ToString(myNumber)\n// Outputting myString to the console"}, {"name": "ToSTRING (NUMBER, NUMBER)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "NUMBER: input to convert to STRING; NUMBER: desired amount of decimal places.", "description": "Returns the input decimal NUMBER as STRING with the input decimal places(e.g. 10.1234, 2 will return 10.12)", "example_code": "NUMBER value = 123.456\nSTRING stringValue = ToString(value)\n// Outputting the stringValue to the console", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER value = 123.456\nSTRING stringValue = ToString(value)\n// Outputting the stringValue to the console"}, {"name": "ToSTRING (VECTOR<MediaType>)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<MediaType>: list to convert to STRING.", "description": "Convert a media type list to a STRING. Elements are separated by ', '", "example_code": "// Initialize a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = MediaType(\"image/jpeg\"), MediaType(\"application/pdf\"), MediaType(\"text/html\");\n\n// Convert the VECTOR<MediaType> to a STRING\nSTRING mediaTypesString = ToString(mediaTypes);\n\n// Print the resulting STRING to the console\n// mediaTypesString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = MediaType(\"image/jpeg\"), MediaType(\"application/pdf\"), MediaType(\"text/html\");\n\n// Convert the VECTOR<MediaType> to a STRING\nSTRING mediaTypesString = ToString(mediaTypes);\n\n// Print the resulting STRING to the console\n// mediaTypesString"}, {"name": "ToSTRING (VECTOR<MediaType>, STRING)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<MediaType>: list to convert to STRING; STRING: separator to put between elements.", "description": "Convert a media type list to a STRING. Elements are separated by given separator", "example_code": "// Initialize a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = MediaType(\"image/jpeg\"), MediaType(\"application/pdf\"), MediaType(\"text/html\");\n\n// Convert the VECTOR to a STRING\nSTRING mediaTypesString = ToString(mediaTypes);\n\n// Print the STRING representation to the console\n// mediaTypesString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of MediaType\nVECTOR<MediaType> mediaTypes = MediaType(\"image/jpeg\"), MediaType(\"application/pdf\"), MediaType(\"text/html\");\n\n// Convert the VECTOR to a STRING\nSTRING mediaTypesString = ToString(mediaTypes);\n\n// Print the STRING representation to the console\n// mediaTypesString"}, {"name": "ToSTRING (VECTOR<MWG.UrlCategory>)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<MWG.UrlCategory>: list to convert to STRING.", "description": "Convert a url category list to a STRING.", "example_code": "// Assume we have a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"example_url_category_list\"]\n\n// Convert the VECTOR<MWG.UrlCategory> to a STRING\nSTRING urlCategoriesString = ToString(urlCategories)\n\n// This line would print the STRING representation to the console\n// urlCategoriesString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a VECTOR of MWG.UrlCategory\nVECTOR<MWG.UrlCategory> urlCategories = [\"example_url_category_list\"]\n\n// Convert the VECTOR<MWG.UrlCategory> to a STRING\nSTRING urlCategoriesString = ToString(urlCategories)\n\n// This line would print the STRING representation to the console\n// urlCategoriesString"}, {"name": "ToSTRING (VECTOR<Net.IP>)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<Net.IP>: list to convert to STRING.", "description": "Return an IP list as a STRING", "example_code": "VECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"10.0.0.1\"), Net.IP(\"172.16.0.1\")\nSTRING ipString = Net.ToString(ipList)\n// Output the IP string to the console\n// ipString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"10.0.0.1\"), Net.IP(\"172.16.0.1\")\nSTRING ipString = Net.ToString(ipList)\n// Output the IP string to the console\n// ipString"}, {"name": "ToSTRING (VECTOR<Net.IP>, STRING)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<Net.IP>: list to convert to STRING; STRING: separator to put between elements.", "description": "Returns list of IP addresses as a STRING with the input delimiter (uses \",\" if delimiter is empty)", "example_code": "VECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"10.0.0.1\"), Net.IP(\"172.16.0.1\")\nSTRING ipString = Net.ToString(ipList)\n// Output the string representation of the IP list to the console\n// ipString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> ipList = Net.IP(\"192.168.1.1\"), Net.IP(\"10.0.0.1\"), Net.IP(\"172.16.0.1\")\nSTRING ipString = Net.ToString(ipList)\n// Output the string representation of the IP list to the console\n// ipString"}, {"name": "ToSTRING (VECTOR<Net.IPRange>, STRING)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<Net.IPRange>: list to convert to STRING; STRING: separator to put between elements.", "description": "Returns list of IP address ranges as a STRING with the input delimiter (uses \",\" if delimiter is empty)", "example_code": "VECTOR<Net.IPRange> ipRanges = [\"example_ip_range_list\"]\nSTRING ipRangesString = Net.ToString(ipRanges)\n// Outputting the ipRangesString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IPRange> ipRanges = [\"example_ip_range_list\"]\nSTRING ipRangesString = Net.ToString(ipRanges)\n// Outputting the ipRangesString"}, {"name": "ToSTRING (VECTOR<NUMBER>, STRING)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<NUMBER>: list to convert to STRING; STRING: separator to put between elements.", "description": "Returns list of NUMBERs as a STRING with the input delimiter (uses \",\" if delimiter is empty)", "example_code": "// Initialize a VECTOR of NUMBERs\nVECTOR<NUMBER> numbers = 1, 2, 3, 4, 5\n\n// Convert the VECTOR to a STRING with a hyphen as the separator\nSTRING result = ToString(numbers, \"-\")\n\n// Print the result to the console\n// DEBUG(result)", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Initialize a VECTOR of NUMBERs\nVECTOR<NUMBER> numbers = 1, 2, 3, 4, 5\n\n// Convert the VECTOR to a STRING with a hyphen as the separator\nSTRING result = ToString(numbers, \"-\")\n\n// Print the result to the console\n// DEBUG(result)"}, {"name": "ToSTRING (VECTOR<STRING>)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<STRING>: list to convert to STRING.", "description": "Convert a STRING VECTOR to a single STRING", "example_code": "VECTOR<STRING> exampleList = \"apple\", \"banana\", \"cherry\"\nSTRING result = ToString(exampleList)\n// Output result to the console\n// result", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> exampleList = \"apple\", \"banana\", \"cherry\"\nSTRING result = ToString(exampleList)\n// Output result to the console\n// result"}, {"name": "ToSTRING (VECTOR<STRING>, STRING)", "return_type": "STRING", "return_desc": "Returns the string representation of the given parameter.", "parameter_desc": "VECTOR<STRING>: list to convert to STRING; STRING: separator to put between elements.", "description": "Convert a STRING VECTOR with given delimiter to a single STRING", "example_code": "VECTOR<STRING> words = \"Hello\", \"world\", \"this\", \"is\", \"MOWGLI\"\nSTRING delimiter = \" \"\nSTRING result = Join(words, delimiter)\n// This will print \"Hello world this is MOWGLI\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<STRING> words = \"Hello\", \"world\", \"this\", \"is\", \"MOWGLI\"\nSTRING delimiter = \" \"\nSTRING result = Join(words, delimiter)\n// This will print \"Hello world this is MOWGLI\""}, {"name": "ToSTRING (YouTubeVideoCategory)", "return_type": "STRING", "return_desc": "Returns the name of the YouTube video category as a string.", "parameter_desc": "YouTubeVideoCategory: The category of the YouTube video to be converted to a STRING.", "description": "Returns the YouTubeVideo category name", "example_code": "// Assume we have a YouTubeVideoCategory object\nYouTubeVideoCategory category = GetYouTubeVideoCategory() // This is a placeholder for however you obtain the category\n\n// Convert the YouTubeVideoCategory to a STRING\nSTRING categoryName = ToString(category)\n\n// The YouTube video category is: \" + categoryName", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a YouTubeVideoCategory object\nYouTubeVideoCategory category = GetYouTubeVideoCategory() // This is a placeholder for however you obtain the category\n\n// Convert the YouTubeVideoCategory to a STRING\nSTRING categoryName = ToString(category)\n\n// The YouTube video category is: \" + categoryName"}, {"name": "ToSTRINGToSTRINGMap (MWG.InternalVariant)", "return_type": "MAP<STRING,STRING>", "return_desc": "Returns the string to string map representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a STRING to STRING map.", "example_code": "// Create a MAP<STRING><STRING>\nMAP<STRING><STRING> stringMap\n\n// Populate the map with some key-value pairs\nstringMap[\"key1\"] = \"value1\"\nstringMap[\"key2\"] = \"value2\"\nstringMap[\"key3\"] = \"value3\"\n\n// Assuming there is a function to convert MAP<STRING><STRING> to MWG.InternalVariant\nMWG.InternalVariant variant = ConvertMapToVariant(stringMap)\n\n// Use the variant in some way\n// Converted variant: \" + variant.ToString()\n\n// Placeholder function for converting MAP<STRING><STRING> to MWG.InternalVariant\nMWG.InternalVariant ConvertMapToVariant(MAP<STRING><STRING> map) {\n    // Implementation would go here\n    // This is just a placeholder as the actual function is not specified\n    MWG.InternalVariant variant\n    // Conversion logic\n    return variant\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create a MAP<STRING><STRING>\nMAP<STRING><STRING> stringMap\n\n// Populate the map with some key-value pairs\nstringMap[\"key1\"] = \"value1\"\nstringMap[\"key2\"] = \"value2\"\nstringMap[\"key3\"] = \"value3\"\n\n// Assuming there is a function to convert MAP<STRING><STRING> to MWG.InternalVariant\nMWG.InternalVariant variant = ConvertMapToVariant(stringMap)\n\n// Use the variant in some way\n// Converted variant: \" + variant.ToString()\n\n// Placeholder function for converting MAP<STRING><STRING> to MWG.InternalVariant\nMWG.InternalVariant ConvertMapToVariant(MAP<STRING><STRING> map) {\n    // Implementation would go here\n    // This is just a placeholder as the actual function is not specified\n    MWG.InternalVariant variant\n    // Conversion logic\n    return variant\n}"}, {"name": "ToSTRINGVector (MWG.InternalVariant)", "return_type": "VECTOR<STRING>", "return_desc": "Returns the string vector representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a STRING VECTOR.", "example_code": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant variantObject = GetSomeInternalVariant()\n\n// Convert the MWG.InternalVariant object to a VECTOR<STRING>\nVECTOR<STRING> stringVector = variantObject.ToStringVector()\n\n// Print the contents of the VECTOR<STRING> to the console\nFOR STRING item IN stringVector {\n    // item\n}\n\n// Dummy function to simulate obtaining an MWG.InternalVariant object\nFUNCTION GetSomeInternalVariant() RETURNS MWG.InternalVariant {\n    // Implementation to get an MWG.InternalVariant object\n    // This is just a placeholder for the actual implementation\n    MWG.InternalVariant variant\n    // Populate the variant with some data\n    RETURN variant\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an MWG.InternalVariant object\nMWG.InternalVariant variantObject = GetSomeInternalVariant()\n\n// Convert the MWG.InternalVariant object to a VECTOR<STRING>\nVECTOR<STRING> stringVector = variantObject.ToStringVector()\n\n// Print the contents of the VECTOR<STRING> to the console\nFOR STRING item IN stringVector {\n    // item\n}\n\n// Dummy function to simulate obtaining an MWG.InternalVariant object\nFUNCTION GetSomeInternalVariant() RETURNS MWG.InternalVariant {\n    // Implementation to get an MWG.InternalVariant object\n    // This is just a placeholder for the actual implementation\n    MWG.InternalVariant variant\n    // Populate the variant with some data\n    RETURN variant\n}"}, {"name": "ToUpper (STRING)", "return_type": "STRING", "return_desc": "Returns a string where all lowercase characters are converted to uppercase.", "parameter_desc": "STRING: the input text to be converted to upper case.", "description": "Returns the input STRING with lower case characters replaced by upper case", "example_code": "STRING originalString = \"hello, world\"\nSTRING upperString = ToUpper(originalString)\n// Display the converted string\n// upperString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"hello, world\"\nSTRING upperString = ToUpper(originalString)\n// Display the converted string\n// upperString"}, {"name": "ToVolumeSTRING (NUMBER)", "return_type": "STRING", "return_desc": "Returns the input number converted to a volume string, rounded to the appropriate unit (e.g., 1 GB or 3 MB).", "parameter_desc": "NUMBER: input to convert to volume STRING.", "description": "Returns the input NUMBER converted to a volume STRING, rounded to the appropriate unit(e.g. 1 GB or 3 MB)", "example_code": "NUMBER sizeInBytes = 1048576\nSTRING volumeString = ToVolumeString(sizeInBytes)\n// The volume is: \" + volumeString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER sizeInBytes = 1048576\nSTRING volumeString = ToVolumeString(sizeInBytes)\n// The volume is: \" + volumeString"}, {"name": "ToWebUrlCategory (MWG.InternalVariant)", "return_type": "MWG.UrlCategory", "return_desc": "Returns the URL category representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a url category.", "example_code": "MWG.InternalVariant internalVariant = MWG.Url()\nMWG.UrlCategory urlCategory = ToWebUrlCategory(internalVariant)\n\nIF urlCategory == \"Social Media\" THEN {\n    MWG.Block(\"Access to social media sites is not allowed.\")\n} ELSE {\n    MWG.Allow(\"URL category is allowed.\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "MWG.InternalVariant internalVariant = MWG.Url()\nMWG.UrlCategory urlCategory = ToWebUrlCategory(internalVariant)\n\nIF urlCategory == \"Social Media\" THEN {\n    MWG.Block(\"Access to social media sites is not allowed.\")\n} ELSE {\n    MWG.Allow(\"URL category is allowed.\")\n}"}, {"name": "ToWebUrlCategory (NUMBER)", "return_type": "MWG.UrlCategory", "return_desc": "Returns the GTI category corresponding to the given numerical input.", "parameter_desc": "NUMBER: the identifier of the GTI category to be converted.", "description": "Convert a NUMBER to a GTI category", "example_code": "// Define a NUMBER variable\nNUMBER categoryNumber = 5\n\n// Convert the NUMBER to a GTI category using ToWebUrlCategory\nMWG.UrlCategory urlCategory = ToWebUrlCategory(categoryNumber)\n\n// The GTI category for number 5 is urlCategory", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a NUMBER variable\nNUMBER categoryNumber = 5\n\n// Convert the NUMBER to a GTI category using ToWebUrlCategory\nMWG.UrlCategory urlCategory = ToWebUrlCategory(categoryNumber)\n\n// The GTI category for number 5 is urlCategory"}, {"name": "ToWebUrlCategoryList (MWG.InternalVariant)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns the URL category list representation of the internal variant.", "parameter_desc": "MWG.InternalVariant: value to convert.", "description": "Convert an internal variant to a url category list.", "example_code": "// Assume we have an internal variant value\nMWG.InternalVariant internalVariant = GetInternalVariantSomehow()\n\n// Convert the internal variant to a URL category list\nVECTOR<MWG.UrlCategory> urlCategories = ToWebUrlCategoryList(internalVariant)\n\n// Iterate through the URL categories and print them\nFOR EACH category IN urlCategories {\n    // URL Category: \" + category\n}\n\n// This is a placeholder function to simulate obtaining an internal variant\nFUNCTION GetInternalVariantSomehow() RETURNS MWG.InternalVariant {\n    // Implementation to get an internal variant\n    // This is just a placeholder and would be replaced with actual logic\n    MWG.InternalVariant variant\n    // Populate the variant with some data\n    RETURN variant\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an internal variant value\nMWG.InternalVariant internalVariant = GetInternalVariantSomehow()\n\n// Convert the internal variant to a URL category list\nVECTOR<MWG.UrlCategory> urlCategories = ToWebUrlCategoryList(internalVariant)\n\n// Iterate through the URL categories and print them\nFOR EACH category IN urlCategories {\n    // URL Category: \" + category\n}\n\n// This is a placeholder function to simulate obtaining an internal variant\nFUNCTION GetInternalVariantSomehow() RETURNS MWG.InternalVariant {\n    // Implementation to get an internal variant\n    // This is just a placeholder and would be replaced with actual logic\n    MWG.InternalVariant variant\n    // Populate the variant with some data\n    RETURN variant\n}"}, {"name": "ToWebUrlCategoryList (VECTOR<NUMBER>)", "return_type": "VECTOR<MWG.UrlCategory>", "return_desc": "Returns the GTI category list corresponding to the given number list.", "parameter_desc": "VECTOR: list of NUMBERs to convert to GTI categories.", "description": "Convert a NUMBER list to a GTI category list.", "example_code": "// Define a VECTOR of NUMBERs representing category IDs\nVECTOR<NUMBER> categoryNumbers = 1, 2, 3, 4, 5\n\n// Convert the category numbers to GTI categories\nVECTOR<MWG.UrlCategory> gtiCategories = ToWebUrlCategoryList(categoryNumbers)\n\n// GTI Categories: \" + gtiCategories", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a VECTOR of NUMBERs representing category IDs\nVECTOR<NUMBER> categoryNumbers = 1, 2, 3, 4, 5\n\n// Convert the category numbers to GTI categories\nVECTOR<MWG.UrlCategory> gtiCategories = ToWebUrlCategoryList(categoryNumbers)\n\n// GTI Categories: \" + gtiCategories"}, {"name": "ToYouTubeVideoCategory (STRING)", "return_type": "YouTubeVideoCategory", "return_desc": "Returns a YouTubeVideoCategory object corresponding to the given category ID.", "parameter_desc": "STRING: the ID of the desired youtube video category.", "description": "Create a YouTube Video category by ID", "example_code": "STRING categoryName = \"Education\"\nYouTubeVideoCategory category = ToYouTubeVideoCategory(categoryName)\n\n// The YouTube video category is: \" + category", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING categoryName = \"Education\"\nYouTubeVideoCategory category = ToYouTubeVideoCategory(categoryName)\n\n// The YouTube video category is: \" + category"}, {"name": "Trigger ()", "return_type": "STRING", "return_desc": "Returns a string representing the currently active trigger.", "parameter_desc": "None", "description": "Returns the current Trigger", "example_code": "// This routine is triggered on both Web.Request and Web.Response events\n// Add your code here", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// This routine is triggered on both Web.Request and Web.Response events\n// Add your code here"}, {"name": "Trim (STRING)", "return_type": "STRING", "return_desc": "Returns the input string with whitespace removed from both the beginning and end.", "parameter_desc": "STRING: the input text to remove leading and trailing whitespace from.", "description": "Trims STRING by removing whitespaces from both ends", "example_code": "STRING originalString = \"   Hello, World!   \"\nSTRING trimmedString = Trim(originalString)\n// Original String: '   Hello, World!   '\n// Trimmed String: 'Hello, World!'", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"   Hello, World!   \"\nSTRING trimmedString = Trim(originalString)\n// Original String: '   Hello, World!   '\n// Trimmed String: 'Hello, World!'"}, {"name": "Trim (STRING, STRING)", "return_type": "STRING", "return_desc": "Returns a string with the specified characters removed from both its start and end.", "parameter_desc": "STRING: the input to be trimmed; STRING: the set of characters to remove from both ends.", "description": "Trims STRING by removing given characters from both ends", "example_code": "STRING originalString = \"   Hello, World!   \"\nSTRING trimmedString = Trim(originalString, \" \")\n// Original String: \"   Hello, World!   \"\n// Trimmed String: \"Hello, World!\"", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"   Hello, World!   \"\nSTRING trimmedString = Trim(originalString, \" \")\n// Original String: \"   Hello, World!   \"\n// Trimmed String: \"Hello, World!\""}, {"name": "TrimLeft (STRING)", "return_type": "STRING", "return_desc": "Returns the input string with all leading whitespaces removed.", "parameter_desc": "STRING: The input STRING from which leading whitespaces will be removed.", "description": "Trims STRING by removing whitespaces from the beginning", "example_code": "STRING originalString = \"   Hello, World!\"\nSTRING trimmedString = TrimLeft(originalString)\n// Original String: '   Hello, World!'\n// Trimmed String: 'Hello, World!'", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"   Hello, World!\"\nSTRING trimmedString = TrimLeft(originalString)\n// Original String: '   Hello, World!'\n// Trimmed String: 'Hello, World!'"}, {"name": "TrimLeft (STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the input string with the specified characters removed from the start.", "parameter_desc": "STRING: the input text to trim; STRING: the characters to remove from the beginning.", "description": "Trims STRING by removing given characters from the beginning", "example_code": "STRING originalString = \"###HelloWorld\"\nSTRING charactersToTrim = \"#\"\nSTRING trimmedString = TrimLeft(originalString, charactersToTrim)\n\n// Original String: ###HelloWorld\n// Trimmed String: HelloWorld", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"###HelloWorld\"\nSTRING charactersToTrim = \"#\"\nSTRING trimmedString = TrimLeft(originalString, charactersToTrim)\n\n// Original String: ###HelloWorld\n// Trimmed String: HelloWorld"}, {"name": "TrimRight (STRING)", "return_type": "STRING", "return_desc": "Returns the input string with all trailing whitespaces removed.", "parameter_desc": "STRING: The input STRING from which trailing whitespace will be removed.", "description": "Trims STRING by removing whitespaces from the end", "example_code": "STRING originalString = \"Hello, World!   \"\nSTRING trimmedString = TrimRight(originalString)\n// Original String: 'Hello, World!   '\n// Trimmed String: 'Hello, World!'", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!   \"\nSTRING trimmedString = TrimRight(originalString)\n// Original String: 'Hello, World!   '\n// Trimmed String: 'Hello, World!'"}, {"name": "TrimRight (STRING, STRING)", "return_type": "STRING", "return_desc": "Returns the input string with specified characters removed from its end.", "parameter_desc": "STRING: the input text to be trimmed; STRING: the characters to remove from the end.", "description": "Trims STRING by removing given characters from the end", "example_code": "STRING originalString = \"Hello, World!!!\"\nSTRING charactersToRemove = \"!\"\nSTRING trimmedString = TrimRight(originalString, charactersToRemove)\n\n// Original String: \" + originalString\n// Trimmed String: \" + trimmedString", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING originalString = \"Hello, World!!!\"\nSTRING charactersToRemove = \"!\"\nSTRING trimmedString = TrimRight(originalString, charactersToRemove)\n\n// Original String: \" + originalString\n// Trimmed String: \" + trimmedString"}, {"name": "UCE.AppGroups (UCE.PrivateApp)", "return_type": "VECTOR<STRING>", "return_desc": "Returns a vector containing the configured application groups for the given private app.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns the configured application groups", "example_code": "VECTOR<UCE.PrivateApp> privateApps = [\"PrivateAppList\"]\n\nUCE.PrivateApp targetApp = \"ExampleApp\"\n\nIF targetApp IN privateApps THEN {\n    // Target application is in the list of private apps.\n    MWG.Allow(\"PrivateAppAllowed\")\n} ELSE {\n    // Target application is not in the list of private apps.\n    MWG.Block(\"PrivateAppBlocked\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<UCE.PrivateApp> privateApps = [\"PrivateAppList\"]\n\nUCE.PrivateApp targetApp = \"ExampleApp\"\n\nIF targetApp IN privateApps THEN {\n    // Target application is in the list of private apps.\n    MWG.Allow(\"PrivateAppAllowed\")\n} ELSE {\n    // Target application is not in the list of private apps.\n    MWG.Block(\"PrivateAppBlocked\")\n}"}, {"name": "UCE.ContainsProfile (VECTOR<UCE.DeviceProfile>, STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the `VECTOR`contains a profile with the specified `STRING` name, otherwise`FALSE`", "parameter_desc": "VECTOR: The collection of profiles to search within; STRING: The name of the profile to find.", "description": "Returns if the profiles contain a profile with the given name", "example_code": "VECTOR<UCE.DeviceProfile> deviceProfiles = [\"allowed_profiles\"]\nSTRING profileToCheck = \"example_profile\"\n\nIF UCE.ContainsProfile(deviceProfiles, profileToCheck) THEN {\n    // Profile is allowed\n    MWG.Allow(\"ProfileCheck\")\n} ELSE {\n    // Profile is not allowed\n    MWG.Block(\"ProfileCheck\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<UCE.DeviceProfile> deviceProfiles = [\"allowed_profiles\"]\nSTRING profileToCheck = \"example_profile\"\n\nIF UCE.ContainsProfile(deviceProfiles, profileToCheck) THEN {\n    // Profile is allowed\n    MWG.Allow(\"ProfileCheck\")\n} ELSE {\n    // Profile is not allowed\n    MWG.Block(\"ProfileCheck\")\n}"}, {"name": "UCE.CustomEgressAvailable (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the Egress IP was found in the customer resource.", "parameter_desc": "STRING: input egress ID.", "description": "Returns a bool if the Egress IP was found in the customer resource.", "example_code": "STRING egressID = \"custom_egress_id\"\n\n// Apply the custom egress IP\nUCE.ApplyCustomEgress(egressID)\n\n// Applied custom egress with ID: \" + egressID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING egressID = \"custom_egress_id\"\n\n// Apply the custom egress IP\nUCE.ApplyCustomEgress(egressID)\n\n// Applied custom egress with ID: \" + egressID"}, {"name": "UCE.DoubleEncrypt (UCE.PrivateApp)", "return_type": "BOOLEAN", "return_desc": "Returns a boolean indicating whether the private app requires double encryption.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns if the private app should be encrypted twice", "example_code": "UCE.PrivateApp privateAppInstance\nBOOLEAN requiresDoubleEncryption = UCE.DoubleEncrypt(privateAppInstance)\n\nIF requiresDoubleEncryption THEN {\n    // The private app requires double encryption.\n} ELSE {\n    // The private app does not require double encryption.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "UCE.PrivateApp privateAppInstance\nBOOLEAN requiresDoubleEncryption = UCE.DoubleEncrypt(privateAppInstance)\n\nIF requiresDoubleEncryption THEN {\n    // The private app requires double encryption.\n} ELSE {\n    // The private app does not require double encryption.\n}"}, {"name": "UCE.GetBrowserAccess (UCE.PrivateApp)", "return_type": "BOOLEAN", "return_desc": "Returns a boolean indicating whether the private application is accessible through a browser.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns if the private app can be accessed via browser", "example_code": "// Create an instance of UCE.PrivateApp\nUCE.PrivateApp privateAppInstance = ... // Initialize this with the appropriate private app instance\n\n// Check if the private application is accessible through a browser\nBOOLEAN isAccessible = UCE.GetBrowserAccess(privateAppInstance)\n\n// Perform actions based on the accessibility\nIF isAccessible THEN {\n    // The private application is accessible through a browser.\n    // Additional logic for accessible private app\n} ELSE {\n    // The private application is not accessible through a browser.\n    // Additional logic for non-accessible private app\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Create an instance of UCE.PrivateApp\nUCE.PrivateApp privateAppInstance = ... // Initialize this with the appropriate private app instance\n\n// Check if the private application is accessible through a browser\nBOOLEAN isAccessible = UCE.GetBrowserAccess(privateAppInstance)\n\n// Perform actions based on the accessibility\nIF isAccessible THEN {\n    // The private application is accessible through a browser.\n    // Additional logic for accessible private app\n} ELSE {\n    // The private application is not accessible through a browser.\n    // Additional logic for non-accessible private app\n}"}, {"name": "UCE.GetCertConfig (UCE.PrivateApp)", "return_type": "STRING", "return_desc": "Returns the ID of the `MWG.ClientContextRevProxySetting configuration `as a string.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns the ID of the MWG.ClientContextRevProxySetting configuration", "example_code": "// Define a variable to hold the private app configuration\nUCE.PrivateApp privateAppConfig\n\n// Call the UCE.GetCertConfig function to retrieve the certificate configuration\nprivateAppConfig = UCE.GetCertConfig()\n\n// Check if the configuration was successfully retrieved\nIF privateAppConfig != NULL THEN {\n    // Certificate Configuration Retrieved: \n    // privateAppConfig\n} ELSE {\n    // Failed to retrieve certificate configuration.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Define a variable to hold the private app configuration\nUCE.PrivateApp privateAppConfig\n\n// Call the UCE.GetCertConfig function to retrieve the certificate configuration\nprivateAppConfig = UCE.GetCertConfig()\n\n// Check if the configuration was successfully retrieved\nIF privateAppConfig != NULL THEN {\n    // Certificate Configuration Retrieved: \n    // privateAppConfig\n} ELSE {\n    // Failed to retrieve certificate configuration.\n}"}, {"name": "UCE.GetClientDeviceProfiles ()", "return_type": "VECTOR<UCE.DeviceProfile>", "return_desc": "Returns the device profiles of the client (MCP).", "parameter_desc": "None", "description": "Returns the device profiles of the client (MCP)", "example_code": "VECTOR<UCE.DeviceProfile> deviceProfiles = UCE.GetClientDeviceProfiles()\n\n// Iterate through the device profiles and print each one\nFOR EACH profile IN deviceProfiles {\n    // Device Profile: \" + profile\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<UCE.DeviceProfile> deviceProfiles = UCE.GetClientDeviceProfiles()\n\n// Iterate through the device profiles and print each one\nFOR EACH profile IN deviceProfiles {\n    // Device Profile: \" + profile\n}"}, {"name": "UCE.GetOutboundConnectionInfo (STRING)", "return_type": "JSON", "return_desc": "Returns a JSON object containing details about the outbound connection.", "parameter_desc": "STRING: The destination or connection identifier to get outbound connection details for.", "description": "Determines outbound connection details", "example_code": "STRING destination = \"example.com\"\nJSON connectionInfo = UCE.GetOutboundConnectionInfo(destination)\n// Outbound Connection Info: \" + connectionInfo.toString()", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING destination = \"example.com\"\nJSON connectionInfo = UCE.GetOutboundConnectionInfo(destination)\n// Outbound Connection Info: \" + connectionInfo.toString()"}, {"name": "UCE.GetPrivateApp ()", "return_type": "UCE.PrivateApp", "return_desc": "Returns the detected private app.", "parameter_desc": "None", "description": "Returns the detected private app", "example_code": "UCE.PrivateApp privateApp = UCE.GetPrivateApp()\n\nIF privateApp != NULL THEN {\n    // Private App detected: \" + privateApp\n    // Additional logic for handling the private app can be added here\n} ELSE {\n    // No Private App detected.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "UCE.PrivateApp privateApp = UCE.GetPrivateApp()\n\nIF privateApp != NULL THEN {\n    // Private App detected: \" + privateApp\n    // Additional logic for handling the private app can be added here\n} ELSE {\n    // No Private App detected.\n}"}, {"name": "UCE.GetProtocol (UCE.PrivateApp)", "return_type": "STRING", "return_desc": "Returns the protocol configuration of the specified private application.", "parameter_desc": "UCE.PrivateApp: the private application whose protocol you want to retrieve.", "description": "Returns the configured protocol of the private app", "example_code": "// Assume we have a UCE.PrivateApp object named privateApp\nUCE.PrivateApp privateApp = ... // Initialize or obtain the privateApp object\n\n// Retrieve the protocol configuration of the private app\nSTRING protocol = UCE.GetProtocol(privateApp)\n\n// The protocol configuration of the private app is: \" + protocol\n// was printed to the console for debugging purposes", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a UCE.PrivateApp object named privateApp\nUCE.PrivateApp privateApp = ... // Initialize or obtain the privateApp object\n\n// Retrieve the protocol configuration of the private app\nSTRING protocol = UCE.GetProtocol(privateApp)\n\n// The protocol configuration of the private app is: \" + protocol\n// was printed to the console for debugging purposes"}, {"name": "UCE.ID (UCE.PrivateApp)", "return_type": "STRING", "return_desc": "Returns a string representing the unique identifier of the private app.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns the ID of the private app", "example_code": "// Assume we have a UCE.PrivateApp instance named privateAppInstance\nUCE.PrivateApp privateAppInstance = ... // Initialize or obtain the private app instance\n\n// Get the ID of the private app\nSTRING privateAppID = UCE.ID(privateAppInstance)\n\n// The ID of the private app is: \" + privateAppID", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have a UCE.PrivateApp instance named privateAppInstance\nUCE.PrivateApp privateAppInstance = ... // Initialize or obtain the private app instance\n\n// Get the ID of the private app\nSTRING privateAppID = UCE.ID(privateAppInstance)\n\n// The ID of the private app is: \" + privateAppID"}, {"name": "UCE.IngressCountry ()", "return_type": "STRING", "return_desc": "Returns a string of 2 characters identifying the country code of the Ingress POP.", "parameter_desc": "None", "description": "Returns a STRING of 2 characters identifying the country code of the Ingress POP.", "example_code": "STRING countryCode = UCE.IngressCountry()\n\nIF countryCode == \"US\" THEN {\n    // Ingress country is the United States.\n    MWG.Allow(\"Ingress from US\")\n} ELSE {\n    // Ingress country is not the United States.\n    MWG.Block(\"Access blocked for non-US ingress\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING countryCode = UCE.IngressCountry()\n\nIF countryCode == \"US\" THEN {\n    // Ingress country is the United States.\n    MWG.Allow(\"Ingress from US\")\n} ELSE {\n    // Ingress country is not the United States.\n    MWG.Block(\"Access blocked for non-US ingress\")\n}"}, {"name": "UCE.IsCoachingSessionActive (STRING)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a coaching session with the given ID is currently active.", "parameter_desc": "STRING: the ID of the coaching session.", "description": "returns TRUE if a coaching session with given ID is active", "example_code": "STRING sessionID = \"12345\"\nBOOLEAN isActive = UCE.IsCoachingSessionActive(sessionID)\n\nIF isActive THEN {\n    // \"Coaching session with ID \" + sessionID + \" is currently active.\"\n} ELSE {\n    // \"Coaching session with ID \" + sessionID + \" is not active.\"\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "STRING sessionID = \"12345\"\nBOOLEAN isActive = UCE.IsCoachingSessionActive(sessionID)\n\nIF isActive THEN {\n    // \"Coaching session with ID \" + sessionID + \" is currently active.\"\n} ELSE {\n    // \"Coaching session with ID \" + sessionID + \" is not active.\"\n}"}, {"name": "UCE.IsMarkedForRBI (UCE.PrivateApp)", "return_type": "BOOLEAN", "return_desc": "Returns whether the connection to a private application is marked for isolation.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Functions: Returns if this connection to a private application will be sent to isolation", "example_code": "// Assume privateApp is obtained from some context or initialization\nUCE.PrivateApp privateApp = // Initialization or context-specific code to get the private app\n\n// Check if the private app is marked for RBI\nIF UCE.IsMarkedForRBI(privateApp) THEN {\n    // The private app is marked for RBI.\n    // Additional logic for handling RBI-marked private apps\n} ELSE {\n    // The private app is not marked for RBI.\n    // Additional logic for handling non-RBI-marked private apps\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume privateApp is obtained from some context or initialization\nUCE.PrivateApp privateApp = // Initialization or context-specific code to get the private app\n\n// Check if the private app is marked for RBI\nIF UCE.IsMarkedForRBI(privateApp) THEN {\n    // The private app is marked for RBI.\n    // Additional logic for handling RBI-marked private apps\n} ELSE {\n    // The private app is not marked for RBI.\n    // Additional logic for handling non-RBI-marked private apps\n}"}, {"name": "UCE.IsPrivateApp (UCE.PrivateApp)", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if a private app is detected.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns if a private app was detected", "example_code": "// Get the detected private app\nUCE.PrivateApp privateApp = UCE.GetPrivateApp()\n\n// Check if the detected app is a private app\nIF UCE.IsPrivateApp(privateApp) THEN {\n    // Perform actions if it is a private app\n    // Detected a private app: \" + privateApp\n    MWG.Block(\"Access to private apps is not allowed\")\n} ELSE {\n    // Allow the connection if it is not a private app\n    MWG.Allow(\"No private app detected\")\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Get the detected private app\nUCE.PrivateApp privateApp = UCE.GetPrivateApp()\n\n// Check if the detected app is a private app\nIF UCE.IsPrivateApp(privateApp) THEN {\n    // Perform actions if it is a private app\n    // Detected a private app: \" + privateApp\n    MWG.Block(\"Access to private apps is not allowed\")\n} ELSE {\n    // Allow the connection if it is not a private app\n    MWG.Allow(\"No private app detected\")\n}"}, {"name": "UCE.LicensedSeats ()", "return_type": "NUMBER", "return_desc": "Returns the count of licensed seats as a number.", "parameter_desc": "None", "description": "Returns the NUMBER of licensed seats", "example_code": "NUMBER licensedSeats = UCE.LicensedSeats()\n// The number of licensed seats is: \" + licensedSeats\n\nIF licensedSeats < 10 THEN {\n    // Warning: The number of licensed seats is below the threshold.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "NUMBER licensedSeats = UCE.LicensedSeats()\n// The number of licensed seats is: \" + licensedSeats\n\nIF licensedSeats < 10 THEN {\n    // Warning: The number of licensed seats is below the threshold.\n}"}, {"name": "UCE.Name (UCE.PrivateApp)", "return_type": "STRING", "return_desc": "Returns the name of the specified private app as a string.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns the name of the private app", "example_code": "// Assume we have an instance of UCE.PrivateApp\nUCE.PrivateApp privateAppInstance = ... // Initialize or obtain the private app instance\n\n// Get the name of the private app\nSTRING appName = UCE.Name(privateAppInstance)\n\n// The name of the private app is: \" + appName", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an instance of UCE.PrivateApp\nUCE.PrivateApp privateAppInstance = ... // Initialize or obtain the private app instance\n\n// Get the name of the private app\nSTRING appName = UCE.Name(privateAppInstance)\n\n// The name of the private app is: \" + appName"}, {"name": "UCE.UsedConnector (UCE.PrivateApp)", "return_type": "STRING", "return_desc": "Returns the instance name of the connector currently in use within the specified private app.", "parameter_desc": "UCE.PrivateApp: An instance of the private application.", "description": "Returns the used connector instance", "example_code": "// Assume we have an instance of UCE.PrivateApp\nUCE.PrivateApp myPrivateApp = GetPrivateAppInstance()\n\n// Retrieve the name of the used connector\nSTRING connectorName = UCE.UsedConnector(myPrivateApp)\n\n// The used connector is: connectorName\n\n// Dummy function to simulate getting a private app instance\nUCE.PrivateApp GetPrivateAppInstance() {\n    // Implementation to get the private app instance\n    // This is just a placeholder for the actual logic\n    UCE.PrivateApp appInstance\n    // ... populate appInstance ...\n    return appInstance\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "// Assume we have an instance of UCE.PrivateApp\nUCE.PrivateApp myPrivateApp = GetPrivateAppInstance()\n\n// Retrieve the name of the used connector\nSTRING connectorName = UCE.UsedConnector(myPrivateApp)\n\n// The used connector is: connectorName\n\n// Dummy function to simulate getting a private app instance\nUCE.PrivateApp GetPrivateAppInstance() {\n    // Implementation to get the private app instance\n    // This is just a placeholder for the actual logic\n    UCE.PrivateApp appInstance\n    // ... populate appInstance ...\n    return appInstance\n}"}, {"name": "Utils.IsInPreRun ()", "return_type": "BOOLEAN", "return_desc": "Returns`TRUE`if the current state is policy prerun, otherwise`FALSE`", "parameter_desc": "None", "description": "test if we are in policy prerun", "example_code": "IF Utils.IsInPreRun() THEN {\n    // The current state is policy prerun.\n} ELSE {\n    // The current state is not policy prerun.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "IF Utils.IsInPreRun() THEN {\n    // The current state is policy prerun.\n} ELSE {\n    // The current state is not policy prerun.\n}"}, {"name": "VectorUtils.EqualsIgnoreOrder (VECTOR<MediaType>, VECTOR<MediaType>)", "return_type": "BOOLEAN", "return_desc": "Returns true if all elements of one vector are in the other and vice versa.", "parameter_desc": "Two VECTORs to compare.", "description": "TRUE if all elements of one VECTOR are in the other and vice versa", "example_code": "VECTOR<MediaType> mediaTypes1 = \"image/jpeg\", \"image/png\", \"application/pdf\"\nVECTOR<MediaType> mediaTypes2 = \"application/pdf\", \"image/png\", \"image/jpeg\"\n\nBOOLEAN areEqual = VectorUtils.EqualsIgnoreOrder(mediaTypes1, mediaTypes2)\n\nIF areEqual THEN {\n    // The media types are equal.\n} ELSE {\n    // The media types are not equal.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MediaType> mediaTypes1 = \"image/jpeg\", \"image/png\", \"application/pdf\"\nVECTOR<MediaType> mediaTypes2 = \"application/pdf\", \"image/png\", \"image/jpeg\"\n\nBOOLEAN areEqual = VectorUtils.EqualsIgnoreOrder(mediaTypes1, mediaTypes2)\n\nIF areEqual THEN {\n    // The media types are equal.\n} ELSE {\n    // The media types are not equal.\n}"}, {"name": "VectorUtils.EqualsIgnoreOrder (VECTOR<MWG.UrlCategory>, VECTOR<MWG.UrlCategory>)", "return_type": "BOOLEAN", "return_desc": "Returns true if all elements of one vector are in the other and vice versa.", "parameter_desc": "Two VECTORs to compare.", "description": "TRUE if all elements of one VECTOR are in the other and vice versa", "example_code": "VECTOR<MWG.UrlCategory> categoryList1 = [\"CategoryList1\"]\nVECTOR<MWG.UrlCategory> categoryList2 = [\"CategoryList2\"]\n\nIF VectorUtils.EqualsIgnoreOrder(categoryList1, categoryList2) THEN {\n    // The URL categories in both lists are the same, ignoring order.\n} ELSE {\n    // The URL categories in the lists are different.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<MWG.UrlCategory> categoryList1 = [\"CategoryList1\"]\nVECTOR<MWG.UrlCategory> categoryList2 = [\"CategoryList2\"]\n\nIF VectorUtils.EqualsIgnoreOrder(categoryList1, categoryList2) THEN {\n    // The URL categories in both lists are the same, ignoring order.\n} ELSE {\n    // The URL categories in the lists are different.\n}"}, {"name": "VectorUtils.EqualsIgnoreOrder (VECTOR<Net.IP>, VECTOR<Net.IP>)", "return_type": "BOOLEAN", "return_desc": "Returns true if all elements of one vector are in the other and vice versa.", "parameter_desc": "Two VECTORs to compare.", "description": "TRUE if all elements of one VECTOR are in the other and vice versa", "example_code": "VECTOR<Net.IP> vector1 = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"\nVECTOR<Net.IP> vector2 = \"192.168.1.3\", \"192.168.1.1\", \"192.168.1.2\"\n\nBOOLEAN areEqual = VectorUtils.EqualsIgnoreOrder(vector1, vector2)\n\nIF areEqual THEN {\n    // The IP vectors are equal, ignoring order.\n} ELSE {\n    // The IP vectors are not equal.\n}", "reviewed": "FALSE", "need_info": "FALSE", "code_example": "VECTOR<Net.IP> vector1 = \"192.168.1.1\", \"192.168.1.2\", \"192.168.1.3\"\nVECTOR<Net.IP> vector2 = \"192.168.1.3\", \"192.168.1.1\", \"192.168.1.2\"\n\nBOOLEAN areEqual = VectorUtils.EqualsIgnoreOrder(vector1, vector2)\n\nIF areEqual THEN {\n    // The IP vectors are equal, ignoring order.\n} ELSE {\n    // The IP vectors are not equal.\n}"}]