Open
Conversation
kcorbett-hdx
commented
Jan 24, 2026
- updates the Akamai DS2 Default to be used with the v0.9 SIEM dashboards (found here https://dashboards.trafficpeak.live/dashboards/f/bf17xxzu1h5ogb/security)
- SIEM specific transform update
mcalcaterra
reviewed
Jan 26, 2026
| "sql_transform": "SELECT datediff('s', reqTimeSec, now64(3)) as hdx_source_latency,\ndecodeURLComponent(assumeNotNull(UA)) as UA,\ndecodeURLComponent(assumeNotNull(referer)) as referer,\ndecodeURLComponent(assumeNotNull(queryStr)) as queryStr,\nextract(decodeURLComponent(assumeNotNull(breadcrumbs)), '\\/\\/BC\\/(\\S*)') as breadcrumbs,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'a=([^,\\]]+)') as Edge_IP,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'b=([^,\\]]+)') as Edge_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'k=([^,\\]]+)') as Edge_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'l=([^,\\]]+)') as Edge_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'm=([^,\\]]+)') as Edge_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'n=([^,\\]]+)') as Edge_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'o=([^,\\]]+)') as Edge_ASN,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'a=([^,\\]]+)') as Origin_IP,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'b=([^,\\]]+)') as Origin_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'k=([^,\\]]+)') as Origin_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'l=([^,\\]]+)') as Origin_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'm=([^,\\]]+)') as Origin_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'n=([^,\\]]+)') as Origin_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'o=([^,\\]]+)') as Origin_ASN,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'a=([^,\\]]+)') as Peer_IP,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'b=([^,\\]]+)') as Peer_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'k=([^,\\]]+)') as Peer_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'l=([^,\\]]+)') as Peer_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'm=([^,\\]]+)') as Peer_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'n=([^,\\]]+)') as Peer_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'o=([^,\\]]+)') as Peer_ASN,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'a=([^,\\]]+)') as Parent_IP,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'b=([^,\\]]+)') as Parent_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'k=([^,\\]]+)') as Parent_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'l=([^,\\]]+)') as Parent_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'm=([^,\\]]+)') as Parent_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'n=([^,\\]]+)') as Parent_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'o=([^,\\]]+)') as Parent_ASN,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'a=([^,\\]]+)') as CloudWrapper_IP,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'b=([^,\\]]+)') as CloudWrapper_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'k=([^,\\]]+)') as CloudWrapper_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'l=([^,\\]]+)') as CloudWrapper_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'm=([^,\\]]+)') as CloudWrapper_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'n=([^,\\]]+)') as CloudWrapper_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'o=([^,\\]]+)') as CloudWrapper_ASN,\nassumeNotNull(decodeURLComponent(cmcd)) as url_cmcd,\nconcat('/', assumeNotNull(reqPath)) as reqPath,\nif(startsWith(url_cmcd, '//x.x@U/'), substring(url_cmcd, 9), url_cmcd) as url,\nflatten(extractAllGroupsVertical(assumeNotNull(url), '([^=,\"]+)=\"?([^,=\"]+)\"? ?')) as groups,\nakamai_cmcd_query_param('bl', groups) as cmcd_buffer_length,\nakamai_cmcd_query_param('br', groups) as cmcd_encoded_bitrate,\nurl LIKE '%,bs,%' ? 1 : 0 as cmcd_buffer_starvation,\nakamai_cmcd_query_param('cid', groups) as cmcd_content_id,\nakamai_cmcd_query_param('d', groups) as cmcd_object_duration,\nakamai_cmcd_query_param('dl', groups) as cmcd_deadline,\nakamai_cmcd_query_param('mtp', groups) as cmcd_measured_throughput,\nakamai_cmcd_query_param('nor', groups) as cmcd_next_object_requests,\nakamai_cmcd_query_param('nrr', groups) as cmcd_next_range_request,\nakamai_cmcd_object_type(akamai_cmcd_query_param('ot', groups)) as cmcd_object_type,\nakamai_cmcd_query_param('pr', groups) as cmcd_playback_rate,\nakamai_cmcd_query_param('rtp', groups) as cmcd_requested_max_throughput,\nakamai_cmcd_streaming_format(akamai_cmcd_query_param('sf', groups)) as cmcd_streaming_format,\nakamai_cmcd_query_param('sid', groups) as cmcd_session_id,\nakamai_cmcd_stream_type(akamai_cmcd_query_param('st', groups)) as cmcd_stream_type,\nurl LIKE '%,su,%' ? 1 : 0 as cmcd_startup,\nakamai_cmcd_query_param('tb', groups) as cmcd_top_bitrate,\nakamai_cmcd_query_param('v', groups) as cmcd_version,\nakamai_cmcd_query_param('d', groups) as cmcd_playback_duration,\nsplitByChar(':', lower(assumeNotNull(reqHost)))[1] as reqHost,\nposition(assumeNotNull(contentProtectionInfo), 'epd') >= 1 as epd_Match,\nsplitByString('/', assumeNotNull(contentProtectionInfo))[5] as epd_Code,\nsplitByString('/', assumeNotNull(contentProtectionInfo))[6] as epd_ActionCode,\nmultiIf(epd_Code='av', 'Anonymous VPN',\n epd_Code='pp','Public Proxy',\n epd_Code='hp','Hosting Provder',\n epd_Code='tr','TOR Exit Node',\n epd_Code='dp','Smart DNS Proxy',\n epd_Code='rp','Residential Proxy',\n epd_Code='vc','VPN Data Centre','')\nas epd_Category,\nmultiIf(epd_ActionCode='0', 'Request Denied',\n epd_ActionCode='1', 'Request Allowed(override)',\n epd_ActionCode='2', 'Request Redirected', '')\nas epd_ActionName,\nsplitByChar('|',assumeNotNull(securityRules))[1] as policy,\nsplitByChar('|',assumeNotNull(securityRules))[3] as denyRule,\nif(empty(splitByChar('|',assumeNotNull(securityRules))[3]),0,1) as denied,\nmultiIf(denyRule like '%REP%','Reputation', \n\tdenyRule like '3%' or denyRule like 'BOT-%', 'BOT',\n\tdenyRule like 'IP%' or denyRule like 'URL-%', 'DOS',\n\tdenyRule like 'XSS%' or denyRule like 'WAT-%' or denyRule like 'RFI-ANOMALY%' or denyRule like 'PLATFORM-ANOMALY' or denyRule like 'SQL%' or denyRule like 'LFI%' or denyRule like 'CMD-INJECTION%' or denyRule like 'PROTOCOL-ANOMALY%' or denyRule like 'ADAPTIVE_UA_IP_BLOCK%' or denyRule like '6%', 'WAF Rule',\n\t''\n\t) as denyGroup,\nsplitByChar('|',assumeNotNull(earlyHints))[1] as userHints,\nsplitByChar('|',assumeNotNull(earlyHints))[2] as userHintsBytes,\nsplitByChar('|',assumeNotNull(earlyHints))[3] as akamaiHints,\nsplitByChar('|',assumeNotNull(earlyHints))[4] as akamaiHintsBytes,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[1] as ew_stageInformation,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[2] as ew_ID,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[3] as ew_processTime,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[4] as ew_totalTime,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[5] as ew_totalStageTime,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[6] as ew_usedMemory,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[7] as ew_edgeServerFlow,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[8] as ew_errorCode,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[9] as ew_httpStatus,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[10] as ew_cpuFlits,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[11] as ew_tierID,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[1] as ew_uID,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[2] as ew_version,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[3] as ew_eventHandler,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[4] as ew_offReason,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[5] as ew_logicExecuted,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[6] as ew_status,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[7] as ew_revisionID,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[8] as ew_metrics,\nsplitByChar(':',splitByChar('|',coalesce(assumeNotNull(securityRules),'||'))[2]) as rulesTriggered,\nconcat(reqHost, reqPath) as URL,\nmultiIf(\ncacheStatus=1,1,\nbreadcrumbs IS NULL OR empty(breadcrumbs),0,\nOrigin_IP IS NULL OR empty(Origin_IP) OR Origin_IP = '127.0.0.1',1,0\n) as cacheStatus,\n*\nFROM {STREAM}", | ||
| "rate_limit": null, | ||
| "sql_transform": "SELECT \ntoUnixTimestamp(toDateTime (toStartOfSecond (reqTimeSec)))::UInt32 as ts_sec_idx,\ndatediff('s', reqTimeSec, now64(3)) as hdx_source_latency,\ndecodeURLComponent(assumeNotNull(UA)) as UA,\ndecodeURLComponent(assumeNotNull(referer)) as referer,\ndecodeURLComponent(assumeNotNull(queryStr)) as queryStr,\nextract(decodeURLComponent(assumeNotNull(breadcrumbs)), '\\/\\/BC\\/(\\S*)') as breadcrumbs,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'a=([^,\\]]+)') as Edge_IP,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'b=([^,\\]]+)') as Edge_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'k=([^,\\]]+)') as Edge_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'l=([^,\\]]+)') as Edge_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'm=([^,\\]]+)') as Edge_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'n=([^,\\]]+)') as Edge_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=g[^]]*\\])', 'o=([^,\\]]+)') as Edge_ASN,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'a=([^,\\]]+)') as Origin_IP,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'b=([^,\\]]+)') as Origin_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'k=([^,\\]]+)') as Origin_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'l=([^,\\]]+)') as Origin_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'm=([^,\\]]+)') as Origin_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'n=([^,\\]]+)') as Origin_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(\\[[^[]*c=o[^]]*\\])', 'o=([^,\\]]+)') as Origin_ASN,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'a=([^,\\]]+)') as Peer_IP,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'b=([^,\\]]+)') as Peer_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'k=([^,\\]]+)') as Peer_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'l=([^,\\]]+)') as Peer_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'm=([^,\\]]+)') as Peer_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'n=([^,\\]]+)') as Peer_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=p[^]]*\\])', 'o=([^,\\]]+)') as Peer_ASN,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'a=([^,\\]]+)') as Parent_IP,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'b=([^,\\]]+)') as Parent_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'k=([^,\\]]+)') as Parent_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'l=([^,\\]]+)') as Parent_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'm=([^,\\]]+)') as Parent_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'n=([^,\\]]+)') as Parent_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=c[^]]*\\])', 'o=([^,\\]]+)') as Parent_ASN,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'a=([^,\\]]+)') as CloudWrapper_IP,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'b=([^,\\]]+)') as CloudWrapper_RequestID,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'k=([^,\\]]+)') as CloudWrapper_RequestEndTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'l=([^,\\]]+)') as CloudWrapper_TurnAroundTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'm=([^,\\]]+)') as CloudWrapper_DNSLookupTime,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'n=([^,\\]]+)') as CloudWrapper_GeoInfo,\nakamai_breadcrumbs(breadcrumbs, '(,\\[[^[]*c=w[^]]*\\])', 'o=([^,\\]]+)') as CloudWrapper_ASN,\nassumeNotNull(decodeURLComponent(cmcd)) as url_cmcd,\nconcat('/', assumeNotNull(reqPath)) as reqPath,\nif(startsWith(url_cmcd, '//x.x@U/'), substring(url_cmcd, 9), url_cmcd) as url,\nflatten(extractAllGroupsVertical(assumeNotNull(url), '([^=,\"]+)=\"?([^,=\"]+)\"? ?')) as groups,\nakamai_cmcd_query_param('bl', groups) as cmcd_buffer_length,\nakamai_cmcd_query_param('br', groups) as cmcd_encoded_bitrate,\nurl LIKE '%,bs,%' ? 1 : 0 as cmcd_buffer_starvation,\nakamai_cmcd_query_param('cid', groups) as cmcd_content_id,\nakamai_cmcd_query_param('d', groups) as cmcd_object_duration,\nakamai_cmcd_query_param('dl', groups) as cmcd_deadline,\nakamai_cmcd_query_param('mtp', groups) as cmcd_measured_throughput,\nakamai_cmcd_query_param('nor', groups) as cmcd_next_object_requests,\nakamai_cmcd_query_param('nrr', groups) as cmcd_next_range_request,\nakamai_cmcd_object_type(akamai_cmcd_query_param('ot', groups)) as cmcd_object_type,\nakamai_cmcd_query_param('pr', groups) as cmcd_playback_rate,\nakamai_cmcd_query_param('rtp', groups) as cmcd_requested_max_throughput,\nakamai_cmcd_streaming_format(akamai_cmcd_query_param('sf', groups)) as cmcd_streaming_format,\nakamai_cmcd_query_param('sid', groups) as cmcd_session_id,\nakamai_cmcd_stream_type(akamai_cmcd_query_param('st', groups)) as cmcd_stream_type,\nurl LIKE '%,su,%' ? 1 : 0 as cmcd_startup,\nakamai_cmcd_query_param('tb', groups) as cmcd_top_bitrate,\nakamai_cmcd_query_param('v', groups) as cmcd_version,\nakamai_cmcd_query_param('d', groups) as cmcd_playback_duration,\nsplitByChar(':', lower(assumeNotNull(reqHost)))[1] as reqHost,\nposition(assumeNotNull(contentProtectionInfo), 'epd') >= 1 as epd_Match,\nsplitByString('/', assumeNotNull(contentProtectionInfo))[5] as epd_Code,\nsplitByString('/', assumeNotNull(contentProtectionInfo))[6] as epd_ActionCode,\nmultiIf(epd_Code='av', 'Anonymous VPN',\n epd_Code='pp','Public Proxy',\n epd_Code='hp','Hosting Provder',\n epd_Code='tr','TOR Exit Node',\n epd_Code='dp','Smart DNS Proxy',\n epd_Code='rp','Residential Proxy',\n epd_Code='vc','VPN Data Centre','')\nas epd_Category,\nmultiIf(epd_ActionCode='0', 'Request Denied',\n epd_ActionCode='1', 'Request Allowed(override)',\n epd_ActionCode='2', 'Request Redirected', '')\nas epd_ActionName,\nsplitByChar('|',assumeNotNull(securityRules))[1] as policy,\nsplitByChar('|',assumeNotNull(securityRules))[3] as denyRule,\nif(empty(splitByChar('|',assumeNotNull(securityRules))[3]),0,1) as denied,\nmultiIf(denyRule like '%REP%','Reputation', \n\tdenyRule like '3%' or denyRule like 'BOT-%', 'BOT',\n\tdenyRule like 'IP%', 'DOS',\n\tdenyRule like 'XSS%' or denyRule like 'WAT-%' or denyRule like 'RFI-ANOMALY%' or denyRule like 'PLATFORM-ANOMALY' or denyRule like 'SQL%' or denyRule like 'LFI%' or denyRule like 'CMD-INJECTION%' or denyRule like 'PROTOCOL-ANOMALY%' or denyRule like 'ADAPTIVE_UA_IP_BLOCK%' or denyRule like '6%', 'WAF Rule',\n\t''\n\t) as denyGroup,\nsplitByChar('|',assumeNotNull(earlyHints))[1] as userHints,\nsplitByChar('|',assumeNotNull(earlyHints))[2] as userHintsBytes,\nsplitByChar('|',assumeNotNull(earlyHints))[3] as akamaiHints,\nsplitByChar('|',assumeNotNull(earlyHints))[4] as akamaiHintsBytes,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[1] as ew_stageInformation,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[2] as ew_ID,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[3] as ew_processTime,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[4] as ew_totalTime,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[5] as ew_totalStageTime,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[6] as ew_usedMemory,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[7] as ew_edgeServerFlow,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[8] as ew_errorCode,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[9] as ew_httpStatus,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[10] as ew_cpuFlits,\nakamai_edge_worker_execution(assumeNotNull(ewExecutionInfo))[11] as ew_tierID,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[1] as ew_uID,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[2] as ew_version,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[3] as ew_eventHandler,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[4] as ew_offReason,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[5] as ew_logicExecuted,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[6] as ew_status,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[7] as ew_revisionID,\nakamai_edge_worker(assumeNotNull(ewUsageInfo))[8] as ew_metrics,\nsplitByChar(':',splitByChar('|',coalesce(assumeNotNull(securityRules),'||'))[2]) as rulesTriggered,\nconcat(reqHost, reqPath) as URL,\nmultiIf(\ncacheStatus=1,1,\nbreadcrumbs IS NULL OR empty(breadcrumbs),0,\nOrigin_IP IS NULL OR empty(Origin_IP),1,0\n) as cacheStatus,\n*\nFROM {STREAM}", | ||
| "null_values": [ |
Collaborator
There was a problem hiding this comment.
You've reverted cache status to the older version where we did not account for the Origin_IP being the loopback IP
multiIf(\ncacheStatus=1,1,\nbreadcrumbs IS NULL OR empty(breadcrumbs),0,\nOrigin_IP IS NULL OR empty(Origin_IP) OR Origin_IP = '127.0.0.1',1,0\n) as cacheStatus
mcalcaterra
reviewed
Jan 26, 2026
| } | ||
| }, | ||
| { | ||
| "name": "ts_sec_idx", |
Collaborator
There was a problem hiding this comment.
What's the idea here? Isn't this just the same value as the reqTimeSec?
mcalcaterra
reviewed
Jan 26, 2026
| "settings": { | ||
| "is_default": true, | ||
| "rate_limit": null, | ||
| "sql_transform": "SELECT\ndecodeURLComponent(requestHeadersStr) as requestHeadersStr, \ndecodeURLComponent(responseHeadersStr) as responseHeadersStr, \nakamai_siem_extract(rulesStr) as rules,\nakamai_siem_extract(ruleTagsStr) as ruleTags,\narrayResize(akamai_siem_extract(ruleDataStr), length(ruleTags), '') as ruleData, \nakamai_siem_extract(ruleActionsStr) as ruleActions,\nakamai_siem_extract(ruleMessagesStr) as ruleMessages,\nakamai_siem_extract(ruleVersionsStr) as ruleVersions,\narrayResize(akamai_siem_extract(ruleSelectorsStr), length(ruleTags), '') as ruleSelectors, \nakamai_extract_key_pair(requestHeadersStr,'\\r\\n', ':') as requestHeaders,\nakamai_extract_key_pair(responseHeadersStr,'\\r\\n', ':') as responseHeaders,\narrayExists(x -> multiSearchAny(x, ['AKAMAI/BOT/','BOT/','CUSTOM/BOT/','MBS_CL']), ruleTags) as attack_bot, \narrayExists(x -> multiSearchAny(x, ['ASE/','AKAMAI/POLICY/','OWASP_CRS/','AKAMAI/WAF','AKAMAI/WEB_ATTACK/']), ruleTags) as attack_waf,\narrayExists(x -> x = 'REPUTATION', ruleTags) as attack_reputation,\narrayExists(x -> startsWith(x, 'AKAMAI/CUSTOM'), ruleTags) as attack_custom,\narrayExists(x -> position(x, 'IPBLOCK') !=0, ruleTags) as attack_dos,\nmultiIf(\n arrayExists(x -> startsWith(x, 'Web Scrapers'), ruleMessages), 'Web Scrapers', \n arrayExists(x -> startsWith(x, 'Scanning Tools'), ruleMessages), 'Scanning Tools', \n arrayExists(x -> startsWith(x, 'Web Attackers'), ruleMessages), 'Web Attackers', \n arrayExists(x -> startsWith(x, 'DOS Attacker'), ruleMessages), 'DOS Attacker', \n Null) as ruleMessage,\n arrayFilter((x, y) -> y = 1, ['Bot','WAF', 'Reputation','Custom','DoS'], [attack_bot, attack_waf,attack_reputation,attack_custom,attack_dos]) AS attackTypes,\n arrayDistinct(arrayFilter(x -> multiSearchAny(x, ['AKAMAI/BOT/','BOT/','CUSTOM/BOT/','MBS_CL',':']), ruleTags)) as ruleTagsBot,\narrayDistinct(arrayFilter(x -> multiSearchAny(x, ['ASE/','AKAMAI/POLICY/','OWASP_CRS/','AKAMAI/WAF','AKAMAI/WEB_ATTACK/',':']), ruleTags)) as ruleTagsWAF,\narrayDistinct(arrayFilter(x -> multiSearchAny(x, ['IPBLOCK',':']), ruleTags)) as ruleTagsDOS,\nrequestHeaders['Sec-CH-UA'] AS CH_UA,\nrequestHeaders['User-Agent'] AS UA,\nnotEmpty(CH_UA) as has_CH_UA,\n regexpExtract(requestHeadersStr, 'Referer:\\\\s*(\\\\S+)', 1) AS referer,\nmultiIf(\n arrayExists(x -> multiSearchAny(x, ['AKAMAI/BOT/AKAMAI_CATEGORIZED']), ruleTags), 'Akamai', \n arrayExists(x -> multiSearchAny(x, ['AKAMAI/BOT/CUST_DEFINED_BOTS']), ruleTags), 'Customer', \n arrayExists(x -> multiSearchAny(x, ['AKAMAI/BOT/UNKNOWN_BOT']), ruleTags), 'Unknown', \n '') as bot_type,\nmultiIf( bot_type = 'Akamai', arrayFilter(x -> multiSearchAny(x, ['3991']), rules),\n bot_type = 'Customer', arrayFilter(x -> multiSearchAny(x, ['BOT-6']), rules),\n bot_type = 'Unknown', arrayFilter(x -> multiSearchAny(x, ['3900', '3903', '3910', '3912','3990' ]), rules), ['']) as BotCategoryAkamai,\narrayMap(x -> (indexOf(rules, x)), BotCategoryAkamai) as arrayMapIndex,\narrayStringConcat(arrayMap(x -> (ruleData[x] ), arrayMapIndex)) as botnet_id,\narrayStringConcat(arrayMap(x -> (ruleMessages[x] ), arrayMapIndex)) as bot_category, \n*\nFROM\n{STREAM}", |
Collaborator
There was a problem hiding this comment.
There seems to be some differences here like hdx_source_latency was removed, this does not seem like something we want to remove, can you please review the changes being made here?
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.