@datadog/esbuild-plugin 3.1.8-dev.0 → 3.1.8-dev.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/index.d.ts +5302 -288
- package/dist/src/index.js +1 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/index.mjs +1 -1
- package/dist/src/index.mjs.map +1 -1
- package/package.json +2 -2
package/dist/src/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createUnplugin as e}from"unplugin";import t from"chalk";import n from"async-retry";import{File as o}from"buffer";import r,{mkdtemp as i}from"fs/promises";import s from"fs";import{JsonStreamStringify as a}from"json-stream-stringify";import u from"path";import{Readable as d}from"stream";import{createHash as c,randomUUID as p}from"crypto";import l,{tmpdir as f}from"os";import*as m from"eslint-scope";import g from"jszip";import{glob as h}from"glob";import y from"pretty-bytes";import b from"p-queue";import w from"@jridgewell/remapping";import{performance as v}from"perf_hooks";import{instrument as $}from"@datadog/js-instrumentation-wasm";import{simpleGit as k}from"simple-git";import x from"esbuild";import E from"node:url";import S from"node:path";import I from"node:module";const D=E.fileURLToPath(import.meta.url),j=S.dirname(D),P=I.createRequire(import.meta.url),A="__datadog-helper-file",M=new RegExp(A),C=["development","production","test"],N=["datadoghq.com","us3.datadoghq.com","us5.datadoghq.com","datadoghq.eu","ddog-gov.com","us2.ddog-gov.com","ap1.datadoghq.com","ap2.datadoghq.com","datad0g.com"],O=N[0],R="datadog-build-plugins",T=t.bold.green,_=t.bold.yellow,F=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],L=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],z=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},B=(e,t,n)=>{if(void 0!==e)return(e=>N.some((t=>t===e)))(e)?e:void n.push(`${t} "${e}" is not a supported Datadog site. See the site parameters in https://docs.datadoghq.com/getting_started/site/.`)},K=e=>{if(null===e||"object"!=typeof e)return"";const t="title"in e&&"string"==typeof e.title?e.title:void 0,n="detail"in e&&"string"==typeof e.detail?e.detail:void 0;return t&&n?`${t}: ${n}`:t||(n?`detail: ${n}`:"")},U=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),V=async e=>{const{getForm:t,defaultHeaders:n={},zip:o=!0}=e,r=await t(),i=new Request("fake://url",{method:"POST",body:r});return{data:o?i.body.pipeThrough(new CompressionStream("gzip")):i.body,headers:{"Content-Encoding":o?"gzip":"multipart/form-data",...n,...Object.fromEntries(i.headers.entries())}}},q=[400,401,403,404,405,409,413],H=e=>{const{auth:t,url:o,method:r="GET",getData:i,type:s="text"}=e,a={retries:0===e.retries?0:e.retries||5,onRetry:e.onRetry,maxTimeout:e.maxTimeout,minTimeout:e.minTimeout};return n((async(e,n)=>{let a;try{const e={method:r,duplex:"half"};let n={"X-Datadog-Origin":"build-plugins"};if(t?.apiKey&&(n["DD-API-KEY"]=t.apiKey),t?.appKey&&(n["DD-APPLICATION-KEY"]=t.appKey),"function"==typeof i){const{data:t,headers:o}=await i();e.body=t,n={...n,...o}}a=await fetch(o,{...e,headers:n})}catch(t){return e(t),{}}if(!a.ok){let t=`HTTP ${a.status} ${a.statusText}`;try{const e=(e=>{try{const t=JSON.parse(e);if(null!==t&&"object"==typeof t)if("errors"in t&&Array.isArray(t.errors)){const e=t.errors.map(K).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=K(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(q.includes(a.status))return e(new Error(t)),{};throw new Error(t)}try{let e;return e="json"===s?await a.json():await a.text(),e}catch(t){return e(t),{}}}),a)},W=e=>({message:t,context:n})=>H({retries:2,minTimeout:100,url:"https://browser-http-intake.logs.datadoghq.com/v1/input/pub44d5f4eb86e1392037b7501f7adc540e",method:"POST",type:"json",getData:async()=>{const o={ddsource:e.packageName||R,message:t,service:"build-plugins",team:"language-foundations",env:e.env,version:e.version,bundler:{name:e.bundler.name,version:e.bundler.version},metadata:e.metadata,...n};return{data:JSON.stringify(o),headers:{"Content-Type":"application/json"}}}}),J=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),G=e=>e.includes(A),Y=e=>{const t={bundler:e.bundler,errors:e.errors,metadata:e.metadata,warnings:e.warnings,logs:e.logs,timings:e.timings,start:e.start,end:e.end,duration:e.duration,writeDuration:e.writeDuration,entries:[],inputs:[],outputs:[]};for(const n of e.entries||[]){const e={...n,inputs:[],outputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),n.outputs&&(e.outputs=n.outputs.map((e=>e.filepath))),t.entries.push(e)}for(const n of e.inputs||[]){const e={...n,dependencies:[],dependents:[]};if(n.dependencies)for(const t of n.dependencies)e.dependencies.push(t.filepath);if(n.dependents)for(const t of n.dependents)e.dependents.push(t.filepath);t.inputs.push(e)}for(const n of e.outputs||[]){const e={...n,inputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),t.outputs.push(e)}return t},Q=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},X=e=>{const t=Math.floor(e/1e3/60/60/24),n=new Date(e-24*t*60*60*1e3),o=n.getUTCHours(),r=n.getUTCMinutes(),i=n.getUTCSeconds(),s=n.getUTCMilliseconds(),a=`${t?`${t}d `:""}${o?`${o}h `:""}${r?`${r}m `:""}${i?`${i}s`:""}`.trim();return`${a}${!a||s?` ${s}ms`:""}`.trim()},Z=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),r=Math.min(10,Math.floor(o/2)),i=o-r;return`${e.slice(0,r)}${n}${e.slice(-i)}`},ee=(e="")=>{try{if(!e||e.startsWith("git@"))return e;const t=new URL(e),n="/"===t.pathname?"":t.pathname;return`${t.protocol?`${t.protocol}//`:""}${t.host}${n}`}catch{return e}},te=e=>Object.entries(e).map((([e,n])=>` - ${e}: ${t.bold.green((e=>{if(void 0===e)return"undefined";if(null===e)return"null";if(Array.isArray(e))return e.join(", ");if("object"==typeof e)try{return JSON.stringify(e,null,2)}catch{return String(e)}return e?.toString()??""})(n))}`)).join("\n");let ne=0;const oe={debug:0,info:1,warn:2,error:3,none:4},re=e=>e.split(">").map(J).join(">"),ie=(e,n,o,r)=>{const i=re(e);return(s,a="debug",{forward:u,context:d}={})=>{let c=t.dim,p=console.log;"error"===a?(c=t.red,p=console.error):"warn"===a?(c=t.yellow,p=console.warn):"info"===a&&(c=t.cyan,p=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=W(n);await t({message:f,context:{plugin:e,status:a,...d}})}catch(t){ie(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}oe[a]>=oe[r]&&p(`${c(l)} ${f}`)}},se=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:d=[]}=i,c={pluginName:e,label:r,spans:[],tags:[...d,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(c);const p=()=>c.spans.filter((e=>!e.end)),l=n=>{p().length||(!c.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),c.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=p();if(i?.length){i.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of i)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),l(e)}return{timer:c,resume:l,end:e=>{f(e,!1);const n=c.spans.reduce(((e,t)=>e+(t.end-t.start)),0);c.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(X(n))}`,s)},pause:f,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=p();for(const n of t)n.tags.push(...e)}else c.tags.push(...e)}}},ae=(e,t,n="warn")=>o=>{const r=ie(o,e,t,n);return{getLogger:r=>ae(e,t,n)(`${re(o)}>${r}`),time:se(o,t.timings,r),error:(e,t)=>r(e,"error",t),warn:(e,t)=>r(e,"warn",t),info:(e,t)=>r(e,"info",t),debug:(e,t)=>r(e,"debug",t)}},ue=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],de=(e,t,n,o)=>{const r=n=>function(...r){const i=o.time(`${e} | ${t}`,{log:!1,tags:["type:hook",`hook:${t}`]}),s=n.apply(this,r);return s instanceof Promise?s.finally((()=>{i.end()})):(i.end(),s)};return"object"==typeof n&&null!==n&&"handler"in n?{...n,handler:r(n.handler)}:r(n)},ce=(e,t,n)=>{const o=e.getLogger(R);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=J(e.name);for(const r of ue){const i=e[r];i&&(n[r]=de(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},pe="apps",le="datadog-apps-plugin",fe="api/unstable/app-builder-code/apps",me="datadog-apps-assets.zip",ge=/\.backend\.(ts|tsx|js|jsx)$/,he=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],ye=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),be=async e=>r.mkdir(e,{recursive:!0}),we=(e,t)=>{var n;n=u.dirname(e),s.mkdirSync(n,{recursive:!0}),s.writeFileSync(e,t,{encoding:"utf-8"})},ve=e=>s.readFileSync(e,{encoding:"utf-8"}),$e=e=>{try{return s.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},ke=async(e,t)=>{if("function"==typeof s.openAsBlob){const n=await s.openAsBlob(e,{type:t.contentType});return new o([n],t.filename)}{const n=d.toWeb(s.createReadStream(e)),r=await new Response(n).blob();return new o([r],t.filename,{type:t.contentType})}},xe=async e=>{const t={empty:!1,exists:!0};try{const{size:n}=await r.stat(e);0===n&&(t.empty=!0)}catch(e){if("ENOENT"!==e.code)throw e;t.exists=!1}return t};var Ee=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(Ee||{});function Se(e,t){if(!function(e){return"Program"===e.type}(e))throw new Error(`Expected a Program node from this.parse() for ${t}, got ${e.type}`);return e}function Ie(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function De(e){return"type"===e.importKind||"type"===e.exportKind}function je(e,t){return function(e,t){const n=Se(e,t),o=function(e){const t=new Map;for(const n of e.body)if("FunctionDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"function"});else if("ClassDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"class"});else if("VariableDeclaration"===n.type)for(const e of n.declarations)"Identifier"===e.id.type&&t.set(e.id.name,{kind:"variable",init:e.init});else if("ImportDeclaration"===n.type)for(const e of n.specifiers)t.set(e.local.name,{kind:"import"});return t}(n),r=[];for(const e of n.body){if("ExportDefaultDeclaration"===e.type)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);if("ExportAllDeclaration"===e.type)throw new Error(`"export *" is not supported in .backend.ts files. Use explicit named exports instead: ${t}`);if("ExportNamedDeclaration"!==e.type)continue;e.declaration&&r.push(...Me(e.declaration,t).map((e=>({kind:"local",name:e,localName:e}))));const n="string"==typeof e.source?.value?e.source.value:null;for(const i of e.specifiers){if("Identifier"!==i.exported.type)continue;if("default"===i.exported.name)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);const e="Identifier"===i.local.type?i.local.name:"string"==typeof i.local.value?i.local.value:null;e&&(n?r.push({kind:"re-export",name:i.exported.name,localName:e,source:n}):("Identifier"===i.local.type&&Ce(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const Pe=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function Ae(e){return null==e||Pe.has(e.type)}function Me(e,t){if("FunctionDeclaration"===e.type&&e.id)return[e.id.name];if("ClassDeclaration"===e.type)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${t}`);if("VariableDeclaration"===e.type)return e.declarations.flatMap((e=>{if("Identifier"!==e.id.type)throw new Error(`Destructured exports are not supported in backend files. Use individual named exports instead: ${t}`);if(Ae(e.init))throw new Error(`Non-function export "${e.id.name}" in backend file ${t}. Only function exports are supported — use "export function ${e.id.name}(…) { }" instead.`);return[e.id.name]}));throw new Error(`Unsupported export declaration type "${e.type}" in backend file ${t}. Only function and variable exports are allowed.`)}function Ce(e,t,n){const o=t.get(e);if(o){if("class"===o.kind)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${n}`);if("variable"===o.kind&&Ae(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function Ne(e){const t=e.relativePath.split(u.sep).join("/");return`${c("sha256").update(t).digest("hex")}.${e.name}`}function Oe(e){const t=[];for(const{exportName:n,queryName:o}of e)t.push(`export async function ${n}(...args) {`),t.push(` return globalThis.DD_APPS_RUNTIME.executeBackendFunction(${JSON.stringify(o)}, args);`),t.push("}"),t.push("");return t.join("\n")}function Re(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return P.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}(n)&&o.push("import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';"),o.push(""),o.push('/** @param {import("./context.types").Context} $ */'),o.push("export async function main($) {"),o.push(" globalThis.$ = $;"),o.push(""),o.push(" // Register the $.Actions-based implementation for executeAction"),o.push(" if (typeof setExecuteActionImplementation === 'function') {\n setExecuteActionImplementation(async (actionId, request) => {\n const actionPath = actionId.replace(/^com\\.datadoghq\\./, '');\n const pathParts = actionPath.split('.');\n let actionFn = $.Actions;\n for (const part of pathParts) {\n if (!actionFn) throw new Error('Action not found: ' + actionId);\n actionFn = actionFn[part];\n }\n if (typeof actionFn !== 'function') throw new Error('Action is not a function: ' + actionId);\n return actionFn(request);\n });\n }"),o.push(""),o.push(" const args = $.backendFunctionArgs ?? [];"),o.push(` const result = await ${e}(...args);`),o.push(" return result;"),o.push("}"),o.join("\n")}function Te(e,t,n){const o={state:t},r=e=>{n._?.(e,o),function(e,t){return t[e.type]}(e,n)?.(e,o);for(const t of Object.keys(e))"type"!==t&&i(e[t])},i=e=>{if(Array.isArray(e))for(const t of e)_e(t)&&r(t);else _e(e)&&r(e)};r(e)}function _e(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function Fe(e){Te(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=m.analyze(e,{ecmaVersion:2022,ignoreEval:!0,sourceType:"module"}),n=new Map;for(const e of t.scopes)for(const t of e.references)n.set(t.identifier,t);return{scopeManager:t,referencesByIdentifier:n,moduleScope:Ke(t)}}function Le(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function ze(e){return e.defs.some((e=>"ImportBinding"===e.type))}function Be(e,t){return t.moduleScope.set.get(e)}function Ke(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function Ue(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:Ve(e,t)},r=[];return Te(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(Je(o,t.unsupportedAliases,t.scopeAnalysis))throw Xe(n,"action-catalog call aliases");if(Je(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw Xe(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!qe(o,t.scopeAnalysis))return!1;if(e.optional||We(o))throw Xe(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function Ve(e,t){const n=new Set;return Te(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&Je(e.init,t.actionFunctions,t))return Ye(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&qe(e.init,t))return Ye(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!Je(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Qe(e.value))).map((e=>e.name));return Ye(e,t,n)}(e,t))n.add(o)},AssignmentExpression(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.left.type&&"Identifier"===e.right.type&&Je(e.right,t.actionFunctions,t))return Ge([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&qe(e.right,t))return Ge([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!Je(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Qe(e.value)));return Ge(n,t)}(e,t))n.add(o)}}),n}function qe(e,t){const n=He(e);return!!n&&Je(n,t.actionNamespaces,t)}function He(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?He(e.object):void 0}function We(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&We(e.object)}function Je(e,t,n){return function(e,t,n){const o=Le(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function Ge(e,t){return e.flatMap((e=>{const n=Le(e,t.moduleScope);return n?[n]:[]}))}function Ye(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function Qe(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?Qe(e.argument):Qe(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?Qe(e):[]));case"RestElement":return Qe(e.argument);case"AssignmentPattern":return Qe(e.left);case"MemberExpression":return[]}}function Xe(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const Ze="@datadog/action-catalog";function et(e,t,n){const o=e.get(t);if(!o)return at(t,[],n.name);const r=Le(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?ut(t,[],n.name):ot({modules:e,visitedExports:new Set},t,r,[]):ut(t,[],n.name)}function tt(e,t,n,o){const r=e.modules.get(t);if(!r)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"export",exportName:n,message:`Module '${e}' was not collected while resolving export '${n}'.`,hops:t}}(t,o,n);if("default"===n)return it(t,o,n);const i=`${t}\0${n}`;if(e.visitedExports.has(i))return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"cycle",exportName:n,message:`Resolving export '${n}' from module '${e}' would cycle through the module graph.`,hops:t}}(t,o,n);e.visitedExports.add(i);try{const t=r.exportsByName.get(n);return t?function(e,t,n,o,r){if("unsupported"===o.kind)return function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-export",exportName:n,exportReason:o,message:`Export '${n}' from module '${e}' is unsupported: ${o}.`,hops:t}}(t.id,r,n,o.reason);if("re-export"===o.kind)return"default"===o.importedName?it(t.id,r,n):tt(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return ot(e,t.id,o.variable,[...r,{kind:"local-export",moduleId:t.id,exportName:n,localName:o.variable.name}])}(e,r,n,t,o):function(e,t,n,o){let r;for(const i of t.starExports){const s=tt(e,i.resolvedId,n,[...o,{kind:"star-export",moduleId:t.id,exportName:n,sourceModuleId:i.resolvedId}]);if("unsupported"===s.kind){if("missing-export"===s.reason)continue;return s}if(!r||!nt(r,s)){if(r)return rt(t.id,o,n);r=s}}return r??function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-export",exportName:n,message:`Module '${e}' does not expose export '${n}'.`,hops:t}}(t.id,o,n)}(e,r,n,o)}finally{e.visitedExports.delete(i)}}function nt(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function ot(e,t,n,o){const r=e.modules.get(t);if(!r)return at(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return st(t,r,n);if("namespace"===o.kind)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"namespace-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported namespace import.`,hops:t}}(t,r,n);if("default"===o.importedName)return st(t,r,n);return tt(e,o.resolvedId,o.importedName,[...r,{kind:"import",moduleId:t,localName:n,exportName:o.importedName,sourceModuleId:o.resolvedId}])}(e,r.id,n.name,i,o);const s=r.topLevelBindingsByVariable.get(n);return s?"const"===s.kind?{kind:"local",moduleId:r.id,variable:n,binding:s,hops:o}:"mutable"===s.kind?function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"mutable-binding",variableName:n,declarationKind:o,message:`Variable '${n}' in module '${e}' is declared with mutable '${o}'.`,hops:t}}(r.id,o,n.name,s.declarationKind):function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-binding",variableName:n,bindingReason:o,message:`Variable '${n}' in module '${e}' has unsupported binding: ${o}.`,hops:t}}(r.id,o,n.name,s.reason):function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-static-binding",variableName:n,message:`Variable '${n}' in module '${e}' does not have a recorded top-level static binding.`,hops:t}}(r.id,o,n.name)}function rt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"ambiguous-star-export",exportName:n,message:`Module '${e}' exposes ambiguous star exports for '${n}'.`,hops:t}}function it(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-export",exportName:n,message:`Export '${n}' from module '${e}' resolves through an unsupported default export.`,hops:t}}function st(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported default import.`,hops:t}}function at(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"variable",variableName:n,message:`Module '${e}' was not collected while resolving variable '${n}'.`,hops:t}}function ut(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unresolved-identifier",variableName:n,message:`Identifier '${n}' in module '${e}' is not a resolvable reference.`,hops:t}}function dt(e,t,n){const o=vt(n);switch(o.type){case"Literal":return function(e,t){if("string"==typeof t.value)return{kind:"resolved",moduleId:e,value:t.value};return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-string-literal",valueType:t,message:`Literal value type '${t}' in module '${e}' is not a string.`}}(e,typeof t.value)}(t,o);case"TemplateLiteral":return function(e,t){if(t.expressions.length>0)return function(e){return{kind:"unsupported",moduleId:e,reason:"dynamic-template-literal",message:`Dynamic template literals in module '${e}' cannot be resolved to static strings.`}}(e);return{kind:"resolved",moduleId:e,value:t.quasis.map((e=>e.value.cooked??e.value.raw)).join("")}}(t,o);case"Identifier":return function(e,t,n){const o=et(e.modules,t,n);if("unsupported"===o.kind)return Pt(o,n.name);if(!o.binding.expression)return At(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return Et(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return dt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=ct(e,t,n);if("unsupported"===o.kind)return o;return dt(e,o.moduleId,o.expression)}(e,t,o);default:return function(e,t){return{kind:"unsupported",moduleId:e,reason:"unsupported-expression",expressionType:t,message:`Expression type '${t}' in module '${e}' cannot be resolved to a static string.`}}(t,o.type)}}function ct(e,t,n){if(n.optional)return function(e){return{kind:"unsupported",moduleId:e,reason:"optional-member-expression",message:`Optional member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if(n.computed)return function(e){return{kind:"unsupported",moduleId:e,reason:"computed-member-expression",message:`Computed member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if("Identifier"!==n.property.type)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-static-member-property",propertyType:t,message:`Member property type '${t}' in module '${e}' is not statically named.`}}(t,n.property.type);const o=pt(e,t,n.object);return"unsupported"===o.kind?o:function(e,t,n){let o;for(const r of t.properties){if("SpreadElement"===r.type)return jt(e);if(r.computed)return xt(e);if(wt(r)===n){if(o)return St(e,n);if("init"!==r.kind)return kt(e,n);if(!lt(r))return Dt(e,n,r.value.type);o=r}}if(!o)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"missing-object-property",propertyName:t,message:`Static object in module '${e}' does not have property '${t}'.`}}(e,n);return{kind:"resolved",moduleId:e,expression:o.value}}(o.moduleId,o.expression,n.property.name)}function pt(e,t,n){if("Super"===n.type)return It(t,n.type);const o=vt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=ct(e,t,o);return"unsupported"===n.kind?n:pt(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return It(t,o.type);const r=et(e.modules,t,o);if("unsupported"===r.kind)return Pt(r,o.name);if(!r.binding.expression)return At(r.moduleId,r.variable.name);if(e.mutatedImportedObjectVariables.has(r.variable))return function(e,t){return{kind:"unsupported",moduleId:e,reason:"imported-object-mutation",variableName:t,message:`Imported object '${t}' from module '${e}' is mutated in the module graph.`}}(r.moduleId,r.variable.name);if(e.seenVariables.has(r.variable))return Et(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return pt(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function lt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function ft(e){const t=new Set;for(const n of e.values())Te(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){gt(e.left,t)},UpdateExpression(e,{state:t}){gt(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&>(e.argument,t)},ForInStatement(e,{state:t}){mt(e.left,t)},ForOfStatement(e,{state:t}){mt(e.left,t)}});return t}function mt(e,t){"VariableDeclaration"!==e.type&>(e,t)}function gt(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&>(e.left,t):gt(e.argument,t);else for(const n of e.elements)n&>(n,t);else for(const n of e.properties)gt("RestElement"===n.type?n.argument:n.value,t);else{const n=bt(e);n&&ht(n,t)}else ht(e,t)}function ht(e,t){const n=yt(t,e,new Set);n&&t.mutatedVariables.add(n)}function yt(e,t,n){const o=Le(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),ze(o)){const n=et(e.modules,e.record.id,t);return"local"===n.kind?n.variable:void 0}const r=function(e){for(const t of e.defs){const e=t.node;if("VariableDeclarator"===e.type&&e.init)return e.init}return}(o);if(!r)return;const i=function(e){const t=vt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return bt(t);return}(r);return i?yt(e,i,n):void 0}function bt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?bt(e.object):void 0}function wt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function vt(e){let t=e;for(;$t(t);)t=t.expression;return t}function $t(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function kt(e,t){return{kind:"unsupported",moduleId:e,reason:"accessor-object-property",propertyName:t,message:`Static object property '${t}' in module '${e}' is an accessor.`}}function xt(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function Et(e,t){return{kind:"unsupported",moduleId:e,reason:"cycle",variableName:t,message:`Resolving variable '${t}' in module '${e}' would cycle through static string values.`}}function St(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function It(e,t){return{kind:"unsupported",moduleId:e,reason:"non-object-member-value",expressionType:t,message:`Expression type '${t}' in module '${e}' is not a static object value.`}}function Dt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unsupported-object-property-value",propertyName:t,valueType:n,message:`Static object property '${t}' in module '${e}' has unsupported value type '${n}'.`}}function jt(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function Pt(e,t){return{kind:"unsupported",moduleId:e.moduleId,reason:"static-definition-unsupported",variableName:t,definition:e,message:`Variable '${t}' could not be resolved to a static definition: ${e.message}`}}function At(e,t){return{kind:"unsupported",moduleId:e,reason:"uninitialized-const",variableName:t,message:`Const variable '${t}' in module '${e}' does not have an initializer.`}}const Mt=new Set(["node_modules",".yarn"]);function Ct(e,t,n,o=[]){if(!Yt(e,t))return null;const r=Se(n,e),i=Fe(r),s=function(e,t){const n=function(e){return e.body.flatMap((e=>("ImportDeclaration"===e.type||"ExportNamedDeclaration"===e.type||"ExportAllDeclaration"===e.type)&&e.source&&Ie(e.source)?[e.source.value]:[]))}(e);return t.map(((e,t)=>({source:n[t]??e,resolvedId:e})))}(r,o);return{id:e,ast:r,scopeAnalysis:i,staticDependencies:s,unsupportedDependencies:Jt(r),importsByVariable:Nt(r,i,s),exportsByName:Ot(r,i,s),starExports:_t(r,s),topLevelBindingsByVariable:Ft(r,i)}}function Nt(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!Ie(r.source))continue;const e=Wt(n,r.source.value);for(const n of r.specifiers){const[r]=t.scopeManager.getDeclaredVariables(n);r&&("ImportSpecifier"!==n.type?o.set(r,{kind:"ImportDefaultSpecifier"===n.type?"default":"namespace",resolvedId:e}):o.set(r,{kind:"named",importedName:qt(n.imported),resolvedId:e}))}}return o}function Ot(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&Tt(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):Rt(r,t,n,o);return o}function Rt(e,t,n,o){if(e.declaration)!function(e,t,n){if(!e)return;if("VariableDeclaration"===e.type){for(const o of e.declarations){const e=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const t of e)n.set(t.name,{kind:"unsupported",reason:"binding pattern export"});continue}const[r]=e;r&&n.set(o.id.name,{kind:"local",variable:r})}return}if(("FunctionDeclaration"===e.type||"ClassDeclaration"===e.type)&&e.id){const[o]=t.scopeManager.getDeclaredVariables(e);o&&n.set(e.id.name,{kind:"local",variable:o})}}(e.declaration,t,o);else if(e.source&&Ie(e.source)){const t=Wt(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=qt(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:qt(n.local),resolvedId:t}):o.set(e,{kind:"unsupported",reason:"default re-export",resolvedId:t})}}else for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=qt(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=Be(qt(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function Tt(e,t,n){const o=Ht(e);o&&Ie(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Wt(t,e.source.value)})}function _t(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||Ht(e)||!Ie(e.source)?[]:[{resolvedId:Wt(t,e.source.value)}]))}function Ft(e,t){const n=new Map;for(const o of e.body)Lt(o,t,n);return function(e,t,n){Te(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){Kt(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){Kt(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Kt(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){Bt(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){Bt(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function Lt(e,t,n){if("VariableDeclaration"===e.type)return void zt(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void zt(e.declaration,t,n);const o="ExportNamedDeclaration"===e.type||"ExportDefaultDeclaration"===e.type?e.declaration:e;if(o&&("FunctionDeclaration"===o.type||"ClassDeclaration"===o.type)&&o.id){const[e]=t.scopeManager.getDeclaredVariables(o);e&&n.set(e,{kind:"unsupported",reason:`${o.type} binding`})}}function zt(e,t,n){for(const o of e.declarations){const r=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const e of r)n.set(e,{kind:"unsupported",reason:"binding pattern"});continue}const[i]=r;i&&("const"===e.kind?n.set(i,{kind:"const",expression:o.init??null}):n.set(i,{kind:"mutable",declarationKind:e.kind}))}}function Bt(e,t,n){"VariableDeclaration"!==e.type&&Kt(e,t,n)}function Kt(e,t,n){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&Kt(e.left,t,n):Kt(e.argument,t,n);else for(const o of e.elements)o&&Kt(o,t,n);else for(const o of e.properties)Kt("RestElement"===o.type?o.argument:o.value,t,n);else{const o=Vt(e);o&&Ut(o,t,n,"mutated object binding")}else Ut(e,t,n,"reassigned binding")}function Ut(e,t,n,o){const r=Le(e,t);if(!r||ze(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function Vt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?Vt(e.object):void 0}function qt(e){return"Identifier"===e.type?e.name:String(e.value)}function Ht(e){const t=e.exported;return t?qt(t):void 0}function Wt(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function Jt(e){const t=[];return Te(e,t,{ImportExpression(e,{state:t}){const n=function(e){return Xt(e.source,"non-literal dynamic import")}(e);Gt(n)&&t.push({specifier:n,kind:"dynamic-import"})},CallExpression(e,{state:t}){if(function(e){return"Import"===e.callee.type}(e)){const n=function(e){return Xt(e.arguments[0],"non-literal dynamic import")}(e);Gt(n)&&t.push({specifier:n,kind:"dynamic-import"})}else(function(e){if("Identifier"!==e.callee.type||"require"!==e.callee.name)return!1;const[t]=e.arguments;return!t||!Ie(t)||Zt(t.value)})(e)&&t.push({specifier:Qt(e),kind:"require"})}}),t}function Gt(e){return"non-literal dynamic import"===e||Zt(e)}function Yt(e,t){if(!he.some((t=>e.endsWith(t))))return!1;const n=u.relative(u.resolve(t),e);return!n.startsWith("..")&&!u.isAbsolute(n)&&!n.split(u.sep).some((e=>Mt.has(e)))}function Qt(e){return Xt(e.arguments[0],"local require")}function Xt(e,t){return Ie(e)?e.value:t}function Zt(e){return e.startsWith(".")||e.startsWith("/")}function en(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function tn(e,t,n){const o=new Set;return function(e,t,n,o){const r=[e],i=new Set;for(;r.length>0;){const s=r.shift();if(i.has(s))continue;i.add(s);const a=t.get(s);if(!a)throw en(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw en(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Yt(i,n)){if(!t.has(i))throw en(e,`uncollected local import ${i} from ${a.id}`);r.push(i)}}}}(e,t,n,(({record:e})=>{const n=function(e){const t=new Set,n=new Set;for(const r of e.body)if("ImportDeclaration"===r.type&&"string"==typeof(o=r.source.value)&&(o===Ze||o.startsWith(`${Ze}/`))&&!De(r))for(const e of r.specifiers)De(e)||("ImportNamespaceSpecifier"===e.type?n.add(e.local.name):t.add(e.local.name));var o;return{functions:t,namespaces:n}}(e.ast),r=function(e,t){const n=new Set,o=new Set;for(const r of e.scopeManager.scopes)for(const e of r.variables)ze(e)&&(t.functions.has(e.name)&&n.add(e),t.namespaces.has(e.name)&&o.add(e));return{moduleScope:e,actionFunctions:n,actionNamespaces:o}}(e.scopeAnalysis,n);for(const n of Ue(e.ast,r,e.id)){const r=nn(n,t,e);r&&o.add(r)}})),[...o].sort()}function nn(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw sn(n.id,"non-object action-catalog call arguments");const r=function(e,t){let n;for(const o of e.properties){if("SpreadElement"===o.type)throw sn(t,"spread object arguments");if(o.computed)throw sn(t,"computed object property keys");if(rn(o)){if(n)throw sn(t,"multiple connectionId properties");if("init"!==o.kind)throw sn(t,"accessor connectionId properties");if(!on(o))throw sn(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return dt({modules:e,mutatedImportedObjectVariables:ft(e),seenVariables:new Set},t,n)}(t,n.id,r.value);if("resolved"===i.kind)return i.value;throw s=n.id,a=`static string resolution ${function(e){return"static-definition-unsupported"===e.reason?`${e.reason}/${e.definition.reason}`:e.reason}(i)}: ${i.message}`,new Error(`Unsupported action-catalog connectionId in ${s}: ${a}.`);var s,a}function on(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function rn(e){return"connectionId"===function(e){if("Identifier"===e.key.type)return e.key.name;if("Literal"===e.key.type&&"string"==typeof e.key.value)return e.key.value;return}(e)}function sn(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const an=/^(?:\0|virtual:)/;function un(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=dn(n.id);if(r=o,an.test(r))return;var r;const i=Ct(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(dn));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function dn(e){return e.split("?")[0]}function cn(e,t){const n=un(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>tn(e,n.getModuleRecords(),t)}}function pn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function ln(e,t,n=[]){return{configFile:!1,root:e,logLevel:"silent",build:{minify:!1,target:"esnext",rollupOptions:{output:{format:"es",exports:"named",inlineDynamicImports:!0},preserveEntrySignatures:"exports-only",treeshake:!1,onwarn(e,t){"MODULE_LEVEL_DIRECTIVE"!==e.code&&t(e)}}},resolve:{extensions:[...he,".json"]},plugins:[pn("dd-backend-resolve",t),...n]}}function fn(e){return`${e.relativePath}/${e.name}`}async function mn(e,t,n,o){const r=fn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return Re(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=cn(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=ln(n,{[i]:s},[a.plugin]),d=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),c=Array.isArray(d)?d[0]:d;if(!("output"in c))throw new Error(`Unexpected vite.build result for "${r}"`);const p="chunk"===c.output[0].type?c.output[0].code:"",l={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${p.length} bytes)`),{func:l,code:p}}async function gn(e,t,n,o,r){const i=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,s=fn(t);r.debug(`Calling Datadog API: ${i}`);const a=JSON.stringify({data:{type:"queries",attributes:{query:{id:p(),name:s,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e,allowedConnectionIds:t.allowedConnectionIds,context:{backendFunctionArgs:n}}},onlyTriggerManually:!0}},template_params:{}}}}),u=await H({url:i,auth:o,method:"POST",type:"json",getData:()=>({data:a,headers:{"Content-Type":"application/json"}})}),d=u.data?.id;if(!d)throw new Error("No receipt ID returned from Datadog API");return r.debug(`Query execution started with receipt: ${d}`),async function(e,t,n){const o=`https://api.${t.site}/api/v2/app-builder/queries/execution-long-polling/${e}`,r=10;for(let e=0;e<r;e++){n.debug(`Long-poll attempt ${e+1}/${r}...`);const i=await H({url:o,auth:t,type:"json"});if(i.errors?.length){const e=i.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const s=i.data?.attributes;if(n.debug(`Long-poll response, done: ${s?.done}`),s?.done){if(!s.outputs)throw new Error("Query execution completed without outputs");return s.outputs}}throw new Error("Query execution timed out")}(d,o,r)}function hn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class yn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function bn(e,t,n){const{functionName:o,args:r=[]}=await function(e){return new Promise(((t,n)=>{let o="";e.on("data",(e=>{o+=e.toString()})),e.on("end",(()=>{try{t(JSON.parse(o))}catch{n(new Error("Invalid JSON body"))}})),e.on("error",n)}))}(e);if(!o||"string"!=typeof o)throw new yn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new yn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function wn(e,t,n,o,r){const i=t=>mn(e,t,o,r),s=t();s.length>0&&r.info(`Dev server middleware active for ${s.length} backend function(s): ${s.map((e=>e.name)).join(", ")}`);const a=n.apiKey&&n.appKey?{apiKey:n.apiKey,appKey:n.appKey,site:n.site}:void 0;return a||r.warn("Auth credentials not configured. The /__dd/executeAction endpoint will be unavailable. Set DD_API_KEY and DD_APP_KEY to enable remote execution."),(e,n,o)=>{if("POST"!==e.method)return void o();const s=(u=t(),new Map(u.map((e=>[Ne(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await bn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){hn(t,e instanceof yn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,n,s,i).catch((()=>{hn(n,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void hn(n,403,"Auth credentials not configured. Set DD_API_KEY and DD_APP_KEY to enable remote execution.");(async function(e,t,n,o,r,i){try{const{func:s,code:a,args:u}=await bn(e,n,o),d=fn(s);i.debug(`Executing action: ${d} with args`);const c=await gn(a,s,u,r,i);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:c}))}catch(e){const n=e instanceof yn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";i.debug(`Error handling executeAction: ${o}`),hn(t,n,o)}})(e,n,s,i,a,r).catch((()=>{hn(n,500,"Unexpected error")}))}else o()}}const vn=async(e,t)=>{const n=(await Promise.all(e.map((e=>h(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>u.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(u.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(u.sep);if(!e.every((e=>e.startsWith(`${r}${u.sep}`))))break;n=r}return n})(o),i=o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o.split(u.sep).join("/")}}));return i},$n=(e,t)=>G(t)?A:t.startsWith(e)||u.isAbsolute(t)?t:u.resolve(e,t),kn=(e,t)=>{let n,o=$n(process.cwd(),e);for(;!n;){const e=u.resolve(o,t);if($e(e)&&(n=e),o=o.split(u.sep).slice(0,-1).join(u.sep),[u.sep,""].includes(o))break}return n},xn=(e,t)=>{const n=[...e].map((e=>$n(t||process.cwd(),e).split(u.sep))),o=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<o;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(u.sep)||u.sep},En=t.bold.red,Sn=t.bold.yellow,In=e=>{const t=kn(e,"package.json");if(t)try{const e=ve(t);return JSON.parse(e)}catch(e){return}},Dn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=In(e);o||t.warn(Sn("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(En("Unable to determine the app name to compute the app identifier."));const i=((e,t)=>{const n=e||(e=>{if(e&&e.repository)return"string"==typeof e.repository?e.repository:"url"in e.repository?e.repository.url:void 0})(t);if(!n)return;const o=ee(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(En("Unable to determine the git remote to compute the app identifier."));const s=n?.identifier||((e,t)=>{if(!e||!t)return;const n=`${e}:${t}`;return c("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(En("Unable to compute the app identifier.")),{identifier:s,name:r}},jn=t.green.bold,Pn=t.yellow.bold,An=t.cyan.bold,Mn=t.bold,Cn=(e,t={},n)=>async()=>{const o=await ke(e,{contentType:"application/zip",filename:me});return V({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,me);const t=L("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},Nn=async(e,t,n)=>{const o=[],r=[];if(!t.apiKey||!t.appKey)return o.push(new Error("Missing authentication token, need both app and api keys.")),{errors:o,warnings:r};if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:r};const i=(s=t.site,a=t.identifier,L("APPS_INTAKE_URL")||`https://api.${s}/${fe}/${a}/upload`);var s,a;const u=U({bundler:t.bundlerName,plugin:"apps",version:t.version}),c=te({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(u,null,2)}`}),p=`an archive of:\n - ${jn(e.assets.length.toString())} files\n - ${jn(y(e.size))}\n\nWith the configuration:\n${c}`;if(t.dryRun)return n.error(`\n${An("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:Cn(e.archivePath,u,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Pn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}});if(n.debug(`Uploaded ${p}\n`),o.app_builder_id){const e=`https://app.${t.site}/app-builder/apps/${o.app_builder_id}`;n.info(`Your application is available at:\n ${An(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${fe}/${t}/release/live`)(t.site,t.identifier);await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:e,method:"PUT",type:"json",getData:async()=>({data:d.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...u}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${Pn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${Mn(o.version_id)} to live.`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));o.push(t)}return{errors:o,warnings:r}},On=t.yellow.bold,Rn=t.red.bold,Tn="manifest.json";async function _n(e){const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-manifest-")),n=u.join(t,Tn);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[Ne(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await ye(t),e}return{manifestAsset:{absolutePath:n,relativePath:Tn},cleanup:()=>ye(t)}}const Fn=async({backendOutputs:e,backendFunctions:t,context:n,options:o})=>{const i=n.getLogger(le),{auth:a,buildRoot:d,bundler:{name:c,outDir:p},git:f,version:m}=n,h=i.time("handle assets");let y,b,w;try{const n=i.time("resolve identifier"),{name:h,identifier:w}=Dn(d,i,{url:f?.remote,name:o.name,identifier:o.identifier});if(!w||!h)throw new Error("Missing apps identification.\nEither:\n - pass an 'options.apps.identifier' and 'options.apps.name' to your plugin's configuration.\n - have a 'name' and a 'repository' in your 'package.json'.\n - have a valid remote url on your git project.\n");n.end();const v=u.relative(d,p),$=[...o.include,`${v}/**/*`],k=await vn($,d);if(!k.length)return void i.debug("No assets to upload.");const x=new Set(e.values()),E=k.filter((e=>!x.has(e.absolutePath))).map((e=>({...e,relativePath:`frontend/${e.relativePath}`})));for(const[t,n]of e)E.push({absolutePath:n,relativePath:`backend/${t}.js`});const{manifestAsset:S,cleanup:I}=await _n(t);b=I,E.push(S);const D=i.time("archive assets"),j=await(async e=>{const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-")),n=u.join(t,me),o=new g;for(const t of e)o.file(t.relativePath,s.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=s.createWriteStream(n),i=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});i.on("error",t),r.on("error",t),r.on("close",e),i.pipe(r)}));const{size:i}=await r.stat(n);return{archivePath:n,size:i,assets:e}})(E);D.end(),y=u.dirname(j.archivePath);const P=i.time("upload assets"),{errors:A,warnings:M}=await Nn(j,{apiKey:a.apiKey,appKey:a.appKey,bundlerName:c,dryRun:o.dryRun,identifier:w,name:h,site:a.site,version:m},i);if(P.end(),M.length>0&&i.warn(`${On("Warnings while uploading assets:")}\n - ${M.join("\n - ")}`),A.length>0){const e=A.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){w=e,i.error(`${Rn("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await ye(y),b&&await b(),h.end(),w)throw w};const Ln=u.join(j,"./apps-runtime.mjs"),zn=({bundler:e,context:t,options:n})=>{const o=t.getLogger(le),{auth:r,buildRoot:s}=t;t.inject({type:"file",position:Ee.MIDDLE,value:Ln});const{setBackendFunctions:a,getBackendFunctions:d}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[ge],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=je(this.parse(e),t);if(0===n.length)return o.warn(`Backend file ${t} has no exported functions. Did you forget to add a named export?`),a(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=u.relative(n,t).replace(ge,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:Ne(e)})}return{functions:r,proxyCode:Oe(i)}}(n,t,s);return a(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let r,a=new Map,c=d();if(c.length>0){const t=await async function(e,t,n,o){const r=await i(u.join(f(),"dd-apps-backend-")),s=new Map,a=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const i of t){const t=Ne(i),d=`\0dd-backend:${t}`,c=Re(i.name,i.absolutePath,n),p=cn(i.absolutePath,n),l=ln(n,{[d]:c},[p.plugin]),f=await e({...l,build:{...l.build,write:!0,outDir:r,emptyOutDir:!1,rollupOptions:{...l.build.rollupOptions,input:{[t]:d},output:{...l.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=u.resolve(r,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}a.set(i.absolutePath,p.getAllowedConnectionIds())}return{outDir:r,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:a.get(e.absolutePath)})))}}(e.build,c,s,o);r=t.outDir,a=t.outputs,c=t.functions}try{await Fn({backendOutputs:a,backendFunctions:c,context:t,options:n})}finally{r&&await ye(r)}},configureServer(t){t.middlewares.use(wn(e.build,d,r,s,o))}}},Bn=({options:e,context:t,bundler:n})=>{const o=t.getLogger(le),r=(e=>{const t=e[pe]||{};return{enable:t.enable??!!e[pe],include:t.include||[],dryRun:t.dryRun??!L("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim()}})(e);return r.enable?"vite"!==t.bundler.name?(o.warn(`The apps plugin only supports Vite; skipping under '${t.bundler.name}'.`),[]):[{name:le,enforce:"post",vite:zn({bundler:n,context:t,options:r})}]:[]},Kn="errorTracking",Un="datadog-error-tracking-plugin",Vn=(e,n,o)=>{if(".map"!==u.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=u.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return u.join(e,t);try{const n=e.replace(/\/*$/,"/"),o=new URL(n),r=t.replace(/^[\\/]*/,"");return new URL(r,o).href}catch{return`${e}${t}`}})(e,i);return{minifiedFilePath:r,minifiedUrl:s,relativePath:i}},qn=/[/]+|[\\]+/g,Hn=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Wn=(e,t)=>{const n=e.replace(Hn,"").split(qn),o=t.replace(Hn,"").split(qn),r=n.join("/");let i="";for(let e=0;e<o.length;e+=1){const t=o.slice(-e).join("/");r.startsWith(t)&&(i=t)}return i},Jn=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([xe(e.minifiedFilePath),xe(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Wn(e.relativePath,t)}})(e,n),i=[],s=[],a=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(o)try{a.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${u.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:o.hash,repository_url:o.remote}],version:1})})}catch(t){s.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&s.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:a,errors:i,warnings:s}},Gn=t.green.bold,Yn=t.yellow.bold,Qn=t.red.bold,Xn=(e,t={})=>async()=>V({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await ke(o.path,o.options):new Blob([o.value],{type:o.options.contentType});t.append(n,e,o.options.filename)}return t},defaultHeaders:t,zip:!0}),Zn=async(e,t,n,o)=>{const r=[],i=[];if(!n.apiKey)return r.push({error:new Error("No authentication token provided")}),{errors:r,warnings:i};if(0===e.length)return i.push("No sourcemaps to upload"),{errors:r,warnings:i};const s=o.time("Queue uploads"),a=new(b.default?b.default:b)({concurrency:t.maxConcurrency}),u=(d=n.site,L("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${d}/api/v2/srcmap`);var d;const c=U({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=te({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),l=`\nUploading ${Gn(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(l);const f=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};f.push(a.add((async()=>{try{await H({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:Xn(s,c),onRetry:(t,n)=>{const r=`Failed to upload ${Yn(e.sourcemap)} | ${Yn(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}return s.end(),o.debug(`Queued ${Gn(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:i,errors:r}},eo=async(e,t,n)=>{const o=n.time("get sourcemaps files"),r=((e,t)=>{if(!t.outputs||0===t.outputs.length)throw new Error("No output files found.");return t.outputs.filter((e=>e.filepath.endsWith(".map"))).map((e=>e.filepath)).map((n=>({...Vn(e.minifiedPathPrefix,t.outDir,n),sourcemapFilePath:n,minifiedPathPrefix:e.minifiedPathPrefix})))})(e.sourcemaps,{outDir:t.outDir,outputs:t.outputs});o.end();const i=n.time("send sourcemaps");await(async(e,t,n,o)=>{const r=Date.now(),i=t.minifiedPathPrefix,s={git_repository_url:n.git?.remote,git_commit_sha:n.git?.hash,plugin_version:n.version,project_path:n.outDir,service:t.service,type:"js_sourcemap",version:t.releaseVersion},a=o.time("Compute payloads"),u=await Promise.all(e.map((e=>Jn(e,s,i,n.git))));a.end();const d=u.map((e=>e.errors)).flat(),c=u.map((e=>e.warnings)).flat();if(c.length>0&&o.warn(`Warnings while preparing payloads:\n - ${c.join("\n - ")}`),d.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${d.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const p=o.time("Upload sourcemaps"),{errors:l,warnings:f}=await Zn(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site},o);if(p.end(),o.debug(`Done uploading ${Gn(`${e.length-l.length}/${e.length}`)} sourcemaps in ${Gn(X(Date.now()-r))}.`),l.length>0){const e=`Failed to upload some sourcemaps:\n - ${l.map((({metadata:e,error:t})=>{const n=t.cause||t.stack||t.message;return e?`${Qn(e.file)} | ${Qn(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,site:t.site,version:t.version},n),i.end()},to=e=>{const n=t.bold.red,o=e[Kn]||{},r={errors:[]};if(o.sourcemaps){const t=o.sourcemaps,i=t.releaseVersion||e.metadata?.version;i||r.errors.push(`${n("sourcemaps.releaseVersion")} is required (set it directly or via ${n("metadata.version")}).`),t.releaseVersion&&e.metadata?.version&&t.releaseVersion!==e.metadata.version&&r.errors.push(`${n("sourcemaps.releaseVersion")} must match ${n("metadata.version")} when both are configured.`),t.service||r.errors.push(`${n("sourcemaps.service")} is required.`),t.minifiedPathPrefix||r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} is required.`),t.minifiedPathPrefix&&!(e=>{let t;try{t=new URL(e).host}catch{}return!(!t&&!e.startsWith("/"))})(t.minifiedPathPrefix)&&r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} must be a valid URL or start with '/'.`),i&&(r.config={bailOnError:!1,dryRun:!1,maxConcurrency:20,...t,releaseVersion:i})}return r},no=({options:e,context:t})=>{const n=t.getLogger(Un),o=n.time("validate options"),r=((e,t)=>{const n=[],o=to(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Un}.`);const r={enable:!!e[Kn],...e[Kn],sourcemaps:void 0};return o.config&&(r.sourcemaps=o.config),r})(e,n);if(o.end(),!r.enable)return[];let i,s,a=!1;const u=async()=>{if(!r.sourcemaps||a)return;a=!0;const e=n.time("sourcemaps process");await eo(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:i,outDir:t.bundler.outDir,outputs:s?.outputs||[],site:t.auth.site,version:t.version},n),e.end()};return[{name:Un,enforce:"post",async git(e){i=e,s&&await u()},async buildReport(t){s=t,!i&&Q(e)||await u()},async asyncTrueEnd(){a||await u()}}]},oo="liveDebugger",ro="datadog-live-debugger-plugin",io="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",so="__DD_LIVE_DEBUGGER_BUILD__",ao=e=>void 0===e?io:`${io};if(typeof globalThis.${so}==='undefined'){globalThis.${so}={version:${JSON.stringify(e)}}}`;function uo(e){return"function"==typeof e?e:e.default}function co(e,t,n,o,r){const i=u.relative(t,e).replace(/\\/g,"/"),s=po(n,r);if(s)return`${i};${s}`;const a=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${a}:${o}`}function po(e,t){const n=e.node,o=e.parent;return"id"in n&&t.isIdentifier(n.id)?n.id.name:t.isObjectMethod(n)||t.isClassMethod(n)||t.isClassPrivateMethod(n)?mo(n.key,t):t.isVariableDeclarator(o)&&t.isIdentifier(o.id)?o.id.name:t.isAssignmentExpression(o)?function(e,t){if(t.isIdentifier(e))return e.name;if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=lo(e.object,t),o=fo(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}(o.left,t):t.isObjectProperty(o)||t.isClassProperty(o)||t.isClassPrivateProperty(o)?mo(o.key,t):null}function lo(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=lo(e.object,t),o=fo(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function fo(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function mo(e,t){return t.isIdentifier(e)?e.name:t.isStringLiteral(e)||t.isNumericLiteral(e)||t.isBigIntLiteral(e)?String(e.value):t.isPrivateName(e)&&t.isIdentifier(e.id)?`#${e.id.name}`:null}function go(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function ho(e,t,n,o){const r=[];if(t)for(const t of e.params)for(const e of yo(t,o))"this"!==e&&r.push(e);if(n&&o.isBlockStatement(e.body)){const t=new Set(e.params.flatMap((e=>yo(e,o)))),n="id"in e&&o.isIdentifier(e.id)?e.id.name:"";for(const i of e.body.body)if(o.isVariableDeclaration(i))for(const e of i.declarations)for(const i of yo(e.id,o))t.has(i)||i===n||r.push(i)}return r.length>25?r.slice(0,25):r}function yo(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:yo(e.argument,t):t.isAssignmentPattern(e)?yo(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?yo(e.argument,t):yo(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?yo(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const bo=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let wo,vo,$o,ko,xo=!1;function Eo(e){try{return function(e){switch(e){case"@babel/parser":return P("@babel/parser");case"@babel/traverse":return P("@babel/traverse");case"@babel/types":return P("@babel/types");case"magic-string":return P("magic-string");default:throw new Error(`Unknown peer dependency: ${e}`)}}(e)}catch(e){throw function(e){if(!function(e){if(!(e instanceof Error))return!1;const t=e.code;if("MODULE_NOT_FOUND"!==t&&"ERR_MODULE_NOT_FOUND"!==t)return!1;return bo.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=bo.find((t=>e.message.includes(t))),n=t??bo.join(", ");return new Error(`Datadog Live Debugger could not load "${n}". It is an optional peer dependency that must be installed in your project when the \`liveDebugger\` plugin is enabled. Install the peer dependencies with: \`npm install --save-dev ${bo.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const So=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function Io(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,d=0,c=0,p=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:1,skippedUnsupportedCount:c,totalFunctions:p};if(!So.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};xo||(wo=Eo("@babel/parser").parse,vo=uo(Eo("@babel/traverse")),$o=Eo("@babel/types"),ko=uo(Eo("magic-string")),xo=!0);const l=wo(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let g=0;if(vo(l,{Function(e){if(p++,!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,$o))return void c++;if(r&&function(e,t,n){let o=e;for(;o;){if(go(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return go(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",$o))return void d++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,$o)))return void c++;if(s&&!po(e,$o))return void c++;let t=0;if(!po(e,$o)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=co(n,o,e,t,$o);try{const t=e.node,n=g++,o=`$dd_p${n}`,r=ho(t,!0,!1,$o),i=ho(t,!1,!0,$o),s=$o.isArrowFunctionExpression(t)&&!$o.isBlockStatement(t.body),a=[],d=s||!$o.isBlockStatement(t.body)||!Po(t.body.body,$o);let c;if(!s&&$o.isBlockStatement(t.body)&&jo(t.body.body,a,$o),!s&&$o.isBlockStatement(t.body)&&t.body.directives.length>0){c=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,needsTrailingReturn:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:c,functionId:l,probeVarName:o,probeIdx:String(n),entryVars:r,exitVars:i,returns:a}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};const h=new ko(t);for(let e=f.length-1;e>=0;e--)Do(h,t,f[e]);return{code:h.toString(),map:h.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p}}function Do(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,exitVars:a,returns:u,bodyStart:d,bodyEnd:c,functionEnd:p,isExpressionBody:l,bodyParenStart:f,directivesEnd:m}=n,g=`$dd_e${r}`,h=`$dd_l${r}`,y=`$dd_rv${r}`,b=s.join(", "),w=a.join(", "),v=""!==b,$=""!==w,k=v?`, ${g}()`:"",x=v?$?`, ${g}(), ${h}()`:`, ${g}()`:$?`, undefined, ${h}()`:"",E=`const ${o} = $dd_probes('${i}');`,S=v?`const ${g} = () => ({${b}});`:"",I=$?`const ${h} = () => ({${w}});`:"",D=`if (${o}) $dd_entry(${o}, this${k});`,j=`catch(e) { if (${o}) $dd_throw(${o}, e, this${k}); throw e; }`;if(l){if(null!=f){let n=-1;for(let e=c;e<p;e++)if(")"===t[e]){n=e;break}-1!==n&&(e.remove(f,f+1),e.remove(n,n+1))}const n=["{",E,S,I,"try {",D,`const ${y} = `].filter(Boolean).join("\n"),r=[";",`if (${o}) $dd_return(${o}, ${y}, this${x});`,`return ${y};`,`} ${j}`,"}"].join("\n");c-d>=2?(e.update(d,d+1,n+t[d]),e.update(c-1,c,t[c-1]+r)):e.update(d,c,n+t.slice(d,c)+r)}else{const r=[E,S,"try {",I,`let ${y};`,D].filter(Boolean).join("\n");for(const t of u)null!=t.argStart&&null!=t.argEnd?(e.appendLeft(t.argStart,`(${y} = `),e.appendLeft(t.argEnd,`, ${o} ? $dd_return(${o}, ${y}, this${x}) : ${y})`)):e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, this${x}); `);if(null!=m){const n=m-1;e.update(n,m,`${t[n]}\n${r}`)}else e.update(d,d+1,`${t[d]}${r}`);const i=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, this${x});\n`:""}} ${j}\n`;e.update(c-1,c,`${i}${t[c-1]}`)}}function jo(e,t,n){for(const o of e)if(n.isReturnStatement(o))t.push({start:o.start,end:o.end,argStart:o.argument?.start??void 0,argEnd:o.argument?.end??void 0});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))jo(o.body,t,n);else if(n.isIfStatement(o))jo([o.consequent],t,n),o.alternate&&jo([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))jo([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)jo(e.consequent,t,n);else n.isTryStatement(o)?(jo(o.block.body,t,n),o.handler&&jo(o.handler.body.body,t,n),o.finalizer&&jo(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&jo([o.body],t,n)}function Po(e,t){if(0===e.length)return!1;const n=e[e.length-1];if(t.isReturnStatement(n))return!0;if(t.isIfStatement(n)&&n.alternate){const e=t.isBlockStatement(n.consequent)?n.consequent.body:[n.consequent],o=t.isBlockStatement(n.alternate)?n.alternate.body:[n.alternate];return Po(e,t)&&Po(o,t)}return!1}const Ao=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Mo=t.bold.red,Co=Number(process.env.DD_LD_LIMIT)||1/0,No=(e,t)=>{const n=t.getLogger(ro);let o=0,r=0,i=0,s=0,a=0,u=0,d=0,c=0;return{name:ro,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(p,l){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?l.includes(e):e.test(l))))return{code:p}}for(const t of e.exclude){if("string"==typeof t?l.includes(t):t.test(l))return{code:p}}if(c>=Co)return{code:p};try{const f=Io({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,d+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&c++,0===f.instrumentedCount)return{code:p};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),g=f.map&&m?function(e,t,n,o){try{return w(e,((e,n)=>1===n.depth?t:null))}catch(t){return o.error(`Failed to compose source map for ${n}: ${t}`,{forward:!0}),e}}(f.map,m,l,n):f.map;return{code:f.code,map:g}}catch(e){return n.error(`Instrumentation Error in ${l}: ${e}`,{forward:!0}),{code:p}}}},buildEnd:()=>{d>0&&n.info(`Live Debugger: ${o}/${d} functions instrumented across ${u}/${c} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:c,instrumentedCount:o,totalFunctions:d,transformedFileCount:u}})}}},Oo=({options:e,context:t})=>{const n=((e,t)=>{const n=e[oo]||{},o=e.metadata?.version,r=[];if(void 0!==n.enable&&"boolean"!=typeof n.enable&&r.push(`${Mo("enable")} must be a boolean`),void 0!==n.include)if(Array.isArray(n.include)){for(const e of n.include)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Mo("include")} patterns must be strings or RegExp`);break}}else r.push(`${Mo("include")} must be an array of strings or RegExp`);if(void 0!==n.exclude)if(Array.isArray(n.exclude)){for(const e of n.exclude)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Mo("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Mo("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Mo("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Ao.includes(e)){r.push(`${Mo("functionTypes")} contains invalid value "${e}". Valid values: ${Ao.join(", ")}`);break}}else r.push(`${Mo("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Mo("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${ro}.`);return{enable:n.enable??!!e[oo],version:o,include:n.include||[/\.[jt]sx?$/],exclude:n.exclude||[/\/node_modules\//,/\.min\.js$/,/\/pyodide-lib\//,/^vite\//,/\0/,/commonjsHelpers\.js$/,/__vite-browser-external/,/@datadog\/browser-/,/browser-sdk\/packages\//],honorSkipComments:n.honorSkipComments??!0,functionTypes:n.functionTypes,namedOnly:n.namedOnly??!1}})(e,t.getLogger(ro));return n.enable?(t.inject({type:"code",position:Ee.BEFORE,injectIntoAllChunks:!0,value:ao(n.version)}),[No(n,t)]):[]};const Ro=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],To="metrics",_o="datadog-metrics-plugin",Fo=e=>Math.floor((e||Date.now())/1e3),Lo=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),zo=(e="")=>e.endsWith("/")?e:`${e}/`,Bo=(e,t)=>{let n=e;return e.split(zo(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},Ko=(e,t)=>e.split("!").pop().replace(zo(t),"./"),Uo=(e,t,n)=>{let o=e.name||e.userRequest;return o||(o=((e,t)=>{let n=e.userRequest;if(!n){let o;o=t.moduleGraph&&"function"==typeof t.moduleGraph.getIssuer?t.moduleGraph.getIssuer(e):e.issuer,n=o?.userRequest,n||(n=e._identifier?.split("!").pop())}return n||"unknown"})(e,t)),Ko(o||"no-name",n)},Vo=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),qo=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Ho=t.bold.red,Wo=t.bold.cyan,Jo=e=>(t,n)=>{let o,r;return"function"==typeof e?(o=e(t),r=e(n)):(o=t[e],r=n[e]),o>r?-1:o<r?1:0},Go=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Jo("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:X(e.duration)}))),top:!0};n.sort(Jo("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Yo=(e,t,n)=>{const o=[];var r;n&&(o.push(...Go("Loader",n.loaders)),o.push(...Go("Tapable",n.tapables)),o.push(...Go("Module",n.modules))),o.push(...(e=>{const t={name:"Module total dependents",values:[],top:!0},n={name:"Module total dependencies",values:[],top:!0},o={name:"Module size",values:[],top:!0},r={name:"Module aggregated size",values:[],top:!0},i=new Set,s=Y(e.build),a=new Map,u=new Map,d=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)d.has(n)||d.set(n,new Set),d.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(d.has(e.filepath)){const t=d.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),d.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=d.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const c=Array.from(i);return c.sort(Jo((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort(Jo((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort(Jo("size")),o.values=c.map((e=>({name:e.name,value:y(e.size)}))),c.sort(Jo("aggregatedSize")),r.values=c.map((e=>({name:e.name,value:y(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(Jo((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Jo((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Jo((e=>e.size))).map((e=>({name:e.name,value:e.inputs.length.toString()})))||[],top:!0}])),o.push(...(e=>{const t={name:"General Numbers",values:[],top:!1},n=e.build.inputs?e.build.inputs.length:0,o=e.build.outputs?e.build.outputs.length:0,r=e.build.warnings.length,i=e.build.errors.length,s=e.build.entries?e.build.entries.length:0;return e.build.start&&t.values.push({name:"Overhead duration",value:X(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:X(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:X(e.build.writeDuration)}),t.values.push({name:"Number of modules",value:n.toString()},{name:"Number of assets",value:o.toString()},{name:"Number of entries",value:s.toString()},{name:"Number of warnings",value:r.toString()},{name:"Number of errors",value:i.toString()}),[t]})(e));const i=(e=>{let t="";for(const t of e){t.top&&t.values.length>=5&&(t.values=t.values.slice(0,5),t.name=`Top 5 ${t.name}`);for(const e of t.values)e.name=Z(e.name,60)}const n=Math.max(...e.map((e=>e.name.length))),o=Math.max(...e.flatMap((e=>e.values.map((e=>e.name.length))))),r=Math.max(...e.flatMap((e=>e.values.map((e=>e.value.length))))),i=Math.max(n+4,o+r+4);for(const n of e){if(0===n.values.length)continue;const e=i-(n.name.length+4);t+=`\n== ${n.name} ${"=".repeat(e)}=\n`;for(const e of n.values){const n=r-e.value.length;t+=` [${Ho(e.value)}] ${" ".repeat(n)}${Wo(e.name)}\n`}}return t})(o);t.info(i)},Qo="api/v1/series",Xo=t.bold.green,Zo=["onStart","onLoad","onResolve","onEnd"],er=new Map,tr=new Map,nr=new Map,or=(e,t,n)=>{const o=Object.assign({},e);for(const r of Zo)o[r]=async(o,i)=>{const s=tr.get(t)||{name:t,increment:0,duration:0,events:{}};s.events[r]=s.events[r]||{name:r,values:[]};const a="onLoad"===r;return(0,e[r])(o,(async(...e)=>{const o=Ko(e[0].path,n),u=nr.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const d=v.now();try{return await i(...e)}finally{const n=v.now(),i=n-d,c={start:d,end:n,duration:i,context:qo(e)};if(s.events[r].values.push(c),s.duration+=i,s.increment+=1,tr.set(t,s),u.events[r].values.push(c),u.duration+=i,u.increment+=1,nr.set(o,u),a){const e=er.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(c),e.duration+=i,e.increment+=1,er.set(t,e)}}}))};return o},rr=(e,t)=>({setup:n=>{n.initialOptions.metafile=!0;const o=t.time("wrapping plugins");((e,t)=>{const n=e.initialOptions.plugins;if(n){const e=n.map((e=>({...e})));for(const o of n){const n=o.setup;o.setup=async r=>{const i=or(r,o.name,t);await n({...i,initialOptions:{...i.initialOptions,plugins:e}})}}}})(n,e.buildRoot),o.end(),n.onEnd((async n=>{if(!n.metafile)return void t.warn("Missing metafile, can't proceed with modules data.");const o=t.time("getting plugins results"),{plugins:r,loaders:i,modules:s}={plugins:tr,modules:nr,loaders:er};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class ir{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Uo(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Vo))(e);o.length||o.push("no-loader"),this.started[n]={module:Bo(n),timings:{start:v.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Uo(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=v.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},i=n.loaders.join(",");r.events[i]=r.events[i]||{name:i,values:[]},r.events[i].values.push(n.timings),r.increment+=1,r.duration+=o,t.set(n.module,r);for(const t of n.loaders){const n=e.get(t)||{name:t,increment:0,duration:0,events:{}};n.increment+=1,n.duration+=o,e.set(t,n)}}return{loaders:e,modules:t}}}class sr{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,r,i){const s=this.timings.get(t)||{name:t,duration:0,increment:0,events:{}};s.events[n]||(s.events[n]={name:n,values:[]}),s.events[n].values.push({start:r,end:i,duration:i-r,context:o,type:e}),s.duration+=i-r,s.increment+=1,this.timings.set(t,s)}getResults(){const e=this.timings;for(const[t,n]of this.timings){const o=n;o.duration=Object.values(n.events).map((e=>e.values.reduce(((e,t)=>e+t.end-t.start),0))).reduce(((e,t)=>e+t),0),e.set(t,o)}return{monitoredTaps:this.monitoredTaps,tapables:this.tapables,hooks:this.hooks,timings:e}}getPromiseTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,qo(r),i,v.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,qo(r),i,v.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r);return this.saveResult(e,n,o,qo(r),i,v.now()),s}}getTapPatch(e,t,n,o){switch(e){case"promise":return this.getPromiseTapPatch(e,t,n,o);case"async":return this.getAsyncTapPatch(e,t,n,o);default:return this.getDefaultTapPatch(e,t,n,o)}}newTap(e,t,n,o){return(r,i)=>{const s="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${s}`;if(this.monitoredTaps[u])return n.call(o,r,i);this.monitoredTaps[u]=!0;const d=this.getTapPatch(e,i,s,t);return n.call(o,r,d)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(_o)||(this.hooks[e]||(this.hooks[e]=[]),this.hooks[e].includes(t)||(this.hooks[e].push(t),this.replaceTaps(t,n)))}patchHooks(e){const t=e.constructor.name,n=Object.keys(e.hooks).filter((e=>!this.ignoredHooks.includes(e)&&!this.hooks[t]?.includes(e)));for(const o of n)this.patchHook(t,o,e.hooks[o])}checkNewHooks(){for(const e of this.tapables)this.patchHooks(e)}throughHooks(e){this.tapables.includes(e)||this.tapables.push(e),this.patchHooks(e)}}const ar=e=>async t=>{const n=e.getLogger(_o),o={name:_o},r=new sr(e.buildRoot),i=new ir(e.buildRoot),s=n.time("parse compiler hooks");r.throughHooks(t),s.end(),t.hooks.thisCompilation.tap(o,(e=>{const t=n.time("parse compilation hooks");r.throughHooks(e),t.end(),e.hooks.buildModule.tap(o,(t=>{i.startModule(t,e)})),e.hooks.succeedModule.tap(o,(t=>{i.doneModule(t,e)})),e.hooks.failedModule&&e.hooks.failedModule.tap(o,(t=>{i.doneModule(t,e)}))})),t.hooks.afterEmit.tapPromise(o,(async()=>{const{timings:t}=r.getResults(),{loaders:n,modules:o}=i.getResults();await e.asyncHook("timings",{tapables:t,loaders:n,modules:o})}))},ur={filters:Ro},dr=({options:e,context:t})=>{const n=t.getLogger(_o);let o=0;const r=((e,t)=>{const n=e[To],o=Fo(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enable:!!e[To],enableDefaultPrefix:!0,enableTracing:!1,filters:Ro,tags:[],...e[To],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),i=[];if(!r.enable)return i;const s={name:_o,enforce:"pre",esbuild:rr(t,n),webpack:ar(t),rspack:ar(t)},a=n.time("build",{start:!1}),u=r.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,c;const p=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-o;const e=n.time("aggregating metrics"),i=r.timestamp,s=n.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,d=new Map,c=new Map,p=new Map;for(const e of i){for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");p.has(n)||p.set(n,[]),p.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`entryName:${e}`))),c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");p.has(r)&&o.push(...p.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of i){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(c,i);s.end();const u=n.time("aggregate plugins metrics"),p=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"plugins.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values()){let e=0,r=0;for(const i of Object.values(o.events)){let s=0;r+=i.values.length;for(const t of i.values){const n=t.end-t.start;s+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,s]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,i.values.length]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(d?.tapables,i);u.end();const l=n.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(d?.loaders,i);l.end();const m=((e,t,n,o,r)=>{const i=new Set;for(const t of e){let e={...t,toSend:!0};if(n?.length)for(const t of n){const n=t({metric:e.metric,type:e.type,points:e.points,tags:e.tags});n?e={...n,toSend:e.toSend}:e.toSend=!1}i.add(Lo(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Lo({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i})(new Set([...a,...p,...f]),i,r.filters,r.tags,r.prefix);await t.asyncHook("metrics",m),e.end();const g=n.time("outputing report");Yo(t,n,d),g.end();const h=n.time("sending metrics to Datadog");await((e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.debug("No metrics to send.");const o=Array.from(e).filter((e=>e.toSend)).map((e=>({...e,toSend:void 0}))),r=new Map;for(const e of o)r.has(e.metric)||r.set(e.metric,0),r.set(e.metric,r.get(e.metric)+1);const i=Array.from(r.entries()).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>`${e} - ${t}`));return n.debug(`\nSending ${o.length} metrics with configuration:\n - intake: ${Xo(`https://api.${t.site}/${Qo}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),H({method:"POST",url:`https://api.${t.site}/${Qo}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))})(m,{apiKey:t.auth.apiKey,site:t.auth.site},n),h.end()},l={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){a.resume(),t.build.start=t.build.start||Date.now(),e[To]?.timestamp||(r.timestamp=Fo(t.build.start))},buildEnd(){a.end(),o=Date.now()},async timings(e){d=e,c&&await p()},async buildReport(e){c=e,!d&&u||await p()}};return r.enableTracing&&i.push(s),i.push(l),i},cr="output",pr="datadog-output-plugin",lr=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,fr=e=>{const t=void 0===e;return{build:lr("build",e?.build??t),bundler:lr("bundler",e?.bundler??t),dependencies:lr("dependencies",e?.dependencies??t),errors:lr("errors",e?.errors??t),logs:lr("logs",e?.logs??t),metrics:lr("metrics",e?.metrics??t),timings:lr("timings",e?.timings??t),warnings:lr("warnings",e?.warnings??t)}},mr=(e,t)=>n=>{n.hooks.done.tap("bundler-outputs",(n=>{t((()=>{const t=e.time("stats serialization"),o=n.toJson({all:!1,assets:!0,children:!0,chunks:!0,chunkGroupAuxiliary:!0,chunkGroupChildren:!0,chunkGroups:!0,chunkRelations:!0,entrypoints:!0,errors:!0,ids:!0,modules:!0,nestedModules:!0,relatedAssets:!0,warnings:!0,reasons:!1,chunkModules:!1});return t.end(),o}))}))},gr=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},hr=({options:e,context:t})=>{const n=(e=>({enable:!!e[cr],path:"./",...e[cr],files:fr(e[cr]?.files)}))(e),o=t.getLogger(pr);if(!n.enable)return[];const r=(e,r)=>{const i=n.files[e];if(!r||!1===i)return;t.queue((async()=>{const e=o.time(`output ${i}`),d=((e,t,n)=>{const o=u.isAbsolute(t)?t:u.resolve(e,t);return u.resolve(o,n)})(t.bundler.outDir,n.path,i);let c;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await be(u.dirname(e));const n=s.createWriteStream(e),o=new a(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(d,e)}catch(e){c=e}c?o.error(`Failed writing ${i}: ${c}`):o.debug(`Wrote "./${u.relative(t.buildRoot,d)}"`),e.end()})())};return[{name:pr,buildReport(e){const t=o.time("serialize report"),n=Y(e);t.end(),r("build",{bundler:n.bundler,metadata:n.metadata,start:n.start,end:n.end,duration:n.duration,writeDuration:n.writeDuration,entries:n.entries,outputs:n.outputs}),r("logs",n.logs),r("timings",n.timings),r("dependencies",n.inputs),r("errors",n.errors),r("warnings",n.warnings)},metrics(e){r("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{r("bundler",e.metafile)}))}},rspack:mr(o,(e=>{r("bundler",e)})),rollup:gr((e=>{r("bundler",e)})),vite:gr((e=>{r("bundler",e)})),webpack:mr(o,(e=>{r("bundler",e)}))}]},yr="rum",br="datadog-rum-plugin",wr=e=>`(function(c,n){try{if(typeof window==='undefined')return;var w=window,m=w[n]=w[n]||{},s=new Error().stack;s&&(m[s]=c)}catch(e){}})(${JSON.stringify(e)},${JSON.stringify("DD_SOURCE_CODE_CONTEXT")});`,vr="datadog-rum-privacy-plugin";const $r=(e,t)=>{const n=t.getLogger(vr),o=function(e,t){const n={privacy:{addToDictionaryHelper:{expression:{code:e}}}};return["esbuild","webpack","rspack"].includes(t)&&(n.output={...n.output,inlineSourceMap:!1,embedCodeInSourceMap:!0}),n}(e.helperCodeExpression,t.bundler.name);let r=0,i=0;return{name:vr,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(e,t){try{const n=function(e){if("rspack"===e?.framework||"webpack"===e?.framework)switch(typeof e.inputSourceMap){case"undefined":return;case"string":return e.inputSourceMap;default:return JSON.stringify(e.inputSourceMap)}}(this.getNativeBuildContext?.()),s=$({id:t,code:e,map:n},o);return 0===s.privacyDictionarySize?{code:e}:(r+=s.privacyDictionarySize,i++,s)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${r} entries across ${i} files`,{forward:!0,context:{dictionaryEntryCount:r,fileCount:i}})}}},kr=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,xr=(e,t)=>{const n=e.sdk;if(n.clientToken)return kr(e);if(!t.auth.apiKey||!t.auth.appKey)throw new Error('Missing "auth.apiKey" and/or "auth.appKey" to fetch "rum.sdk.clientToken".');return async()=>{let o;try{const e=await H({url:`https://api.${t.auth.site}/api/v2/rum/applications/${n.applicationId}`,type:"json",auth:t.auth});o=e.data?.attributes?.client_token}catch(e){throw new Error(`Could not fetch the clientToken: ${e.message}`)}if(!o)throw new Error("Missing clientToken in the API response.");return kr({...e,sdk:{clientToken:o,...n}})}},Er=e=>{const n=t.bold.red,o=e[yr]||{},r={errors:[]};if(!o.sdk)return r;o.sdk.applicationId||r.errors.push(`Missing ${n("applicationId")} in the SDK configuration.`),e.auth.apiKey&&e.auth.appKey||o.sdk.clientToken||r.errors.push(`Missing ${n('"auth.apiKey"')} and/or ${n('"auth.appKey"')} to fetch missing client token.`);const i={applicationId:"unknown_application_id",allowUntrustedEvents:!1,compressIntakeRequests:!1,defaultPrivacyLevel:"mask",enablePrivacyForActionName:!1,sessionReplaySampleRate:0,sessionSampleRate:100,silentMultipleInit:!1,site:e.auth.site||"datadoghq.com",startSessionReplayRecordingManually:!1,storeContextsAcrossPages:!1,telemetrySampleRate:20,traceSampleRate:100,trackingConsent:"granted",trackLongTasks:!1,trackResources:!1,trackUserInteractions:!1,trackViewsManually:!1};return r.config={...i,...o.sdk},r},Sr=e=>{const t=e[yr]||{},n={errors:[]};if(t.privacy){const e={exclude:[/\/node_modules\//,/\.preval\./,/^[!@#$%^&*()=+~`-]/],include:[/\.(?:c|m)?(?:j|t)sx?$/],addToDictionaryFunctionName:"$",helperCodeExpression:"/*__PURE__*/((q='$DD_A_Q',g=globalThis)=>(g[q]=g[q]||[],(v=>(g[q].push(v),v))))()"};n.config={...e,...t.privacy}}return n},Ir=e=>{const n=t.bold.red,o=e[yr]||{},r={errors:[]};if(!o.sourceCodeContext)return r;const i=o.sourceCodeContext;return i?.service&&"string"==typeof i.service||r.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),r.config={...i,version:i.version||e.metadata?.version},r},Dr=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=Er(e),r=Sr(e),i=Ir(e);if(n.push(...o.errors),n.push(...r.errors),n.push(...i.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${br}.`);const s={enable:!!e[yr],...e[yr],sdk:void 0,privacy:void 0,sourceCodeContext:void 0};return o.config&&(s.sdk=o.config),r.config&&(s.privacy=r.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(s.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),i.config&&(s.sourceCodeContext=i.config),s})(e,t.getLogger(br)),o=[];if(!n.enable)return o;if(n.sourceCodeContext&&t.inject({type:"code",position:Ee.BEFORE,injectIntoAllChunks:!0,value:wr(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:Ee.MIDDLE,value:u.join(j,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Ee.MIDDLE,value:xr(n,t)})),n.privacy){t.inject({type:"file",position:Ee.BEFORE,value:u.join(j,"./privacy-helpers.js")});const e=$r(n.privacy,t);o.push(e)}return o},jr="datadog-analytics-plugin",Pr=({context:e})=>{const t=e.getLogger(jr);return[{name:jr,async buildStart(){"production"===e.env&&e.queue((async()=>{try{await e.sendLog({message:"Build started",context:{plugins:e.pluginNames}})}catch(e){t.debug(`Could not submit data to Datadog: ${e}`)}})())}}]},Ar="datadog-async-queue-plugin",Mr=e=>{const{context:t,stores:n}=e,o=t.getLogger(Ar),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:Ar,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Cr=async(e,t,n)=>{const o=[],r=e.initialOptions.entryPoints,i=[],s=[];if(Array.isArray(r))for(const e of r){const t=e&&"object"==typeof e?e.in:e;i.push({path:t})}else r&&"object"==typeof r&&i.push(...Object.entries(r).map((([e,t])=>({name:e,path:t}))));const a=i.flatMap((e=>{return(t=e.path,t.includes("*")?h.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const i=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});i.errors.length&&s.push(...i.errors.map((e=>e.text))),i.path&&o.push({name:n.name,resolved:i.path,original:n.path})}));for(const e of s)n.error(e);return await Promise.all(a),o},Nr=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Or=/(\?|%3F|\|)+/gi,Rr=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=Fr(e),Nr.lastIndex=0,Nr.exec(t)?.[1]||"unknown");var t},Tr=["unknown","commonjsHelpers.js",`vite${u.sep}preload-helper.js`],_r=(e,t,n)=>{const o=new Set;for(const n of e){const e=Fr(n);G(n)||e===t||Tr.includes(e)||o.add(e)}return o},Fr=e=>e.split("!").pop().split(Or).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Lr=(e,t)=>G(t)?A:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(u.sep),o=e.split(u.sep).filter(((e,t)=>e===n[t])).join(u.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(Or).shift().replace(/^((\.\.?)?[/\\])+/g,""),zr=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[$n(t,e),n]))),Br=(e,t)=>({setup(n){const o=new Map;let r=[];const i=t.time("build report",{start:!1});n.onStart((async()=>{o.clear(),r=[],i.resume();const s=t.time("process entries");r.push(...await Cr(n,e,t));for(const t of r){const n=Lr(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}s.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),s=e.bundler.outDir,a=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const d=[],c=[],p=[],l=[],f=[],m={},g={},h=t.time("indexing metafile data"),y=zr(n.metafile.inputs,a),b=zr(n.metafile.outputs,a);h.end();const w=e=>{if(!G(e))return e;const t=y[$n(a,e)];if(!t)return e;const n=t.imports.find((e=>!G(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(G(e))continue;const n=$n(a,e),o={name:Lr(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Rr(e)};m[n]=o,d.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=$n(a,e),i=Lr(s,n),u=[];for(const e of Object.keys(r.inputs)){if(G(e))continue;const n=m[$n(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!u.length){const e=m[$n(a,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}u.push(e)}const d={name:i,filepath:n,inputs:u,size:r.bytes,type:Rr(n)};if(g[n]=d,"map"===d.type&&l.push(d),c.push(d),!r.entryPoint)continue;const f=m[$n(a,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...d,name:o.get(f.name)||f.name,outputs:[d],size:d.size};p.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of l){const n=g[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:g,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!G(e)&&!e.match(E),I=(e,n,o={})=>{if(!S(e))return o;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),o;if(o[r.filepath])return o;o[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),o;if(!i.imports||!i.imports.length)return o;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),c=i?u.dirname(e):a,p=$n(c,t.path);if(t.external){if(S(t.path)){const e=i?p:t.path,n=x.inputs.report[e]||{filepath:e,name:Lr(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),d.includes(n)||d.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(p,n,o)}return o},D=t.time("looping through entries");for(const e of p){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const j=t.time("aggregate dependencies and dependents");for(const e of d){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?u.dirname(e.filepath):a,i=$n(r,o.path);let s;if(o.external){const e=n?i:o.path;s=x.inputs.report[e]}else s=x.inputs.report[i];s?(e.dependencies.add(s),s.dependents.add(e)):t.debug(`Could not find input file of ${o.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}j.end(),e.build.outputs=c,e.build.inputs=d,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),Kr=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),i=t.time("filling inputs and outputs",{start:!1}),a=t.time("completing dependencies and dependents",{start:!1}),u=t.time("filling dependencies and dependents",{start:!1}),d=t.time("filling sourcemaps inputs",{start:!1}),c=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),c.clear(),p.clear(),l.clear()},onLog(t,n){"warn"===t&&e.build.warnings.push(n.message||n.toString())},renderError(t){t&&e.build.errors.push(t.message)},moduleParsed(e){n.resume();const t=Fr(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=_r(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=_r(new Set([...e.dynamicImporters,...e.importers]),t);for(const e of i)o.dependents.add(e);for(const e of r)o.dependencies.add(e);f.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,m){o.resume();const g=n.dir?$n(e.buildRoot,n.dir):e.bundler.outDir,h=new Set,y=new Set,b=new Map;a.resume();for(const[e,{dependencies:t,dependents:n}]of f){for(const n of t){const t=Fr(n),o=f.get(t)||{dependencies:new Set,dependents:new Set};o.dependents.has(e)||(o.dependents.add(e),f.set(t,o))}for(const t of n){const n=Fr(t),o=f.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),f.set(n,o))}}a.end(),i.resume();for(const[e,n]of Object.entries(m)){const o=$n(g,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),i=p.get(o)||{name:e,filepath:o,inputs:[],size:r,type:Rr(e)};if("map"===i.type&&y.add(i),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(Fr(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=s.statSync(e).size}catch(e){n=t.renderedLength}const o=c.get(e)||{name:Lr(g,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Rr(e)};i.inputs.push(o),c.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=Fr(e);if(!f.has(n)){b.set($n(g,n),i);continue}if(c.has(n)){t.debug(`Input report already there for ${n} from ${i.name}.`);continue}const o=c.get(n)||{name:Lr(g,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};i.inputs.push(o),c.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&h.add({...i,name:n.name,size:0,outputs:[i]}),p.set(i.filepath,i)}i.end();for(const[e,n]of b){const o=p.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of c){const o=f.get(e);if(o){for(const e of o.dependencies){const o=c.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Lr(g,e)} of ${n.name}`)}for(const e of o.dependents){const o=c.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Lr(g,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){d.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=p.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}d.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Lr(g,e),r=p.get(e);if(!r)return c.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[Lr(g,e)];if(!i)return t.debug(`Could not find asset for ${o}`),n;const s=[];"imports"in i&&s.push(...i.imports),"dynamicImports"in i&&s.push(...i.dynamicImports);for(const e of s)w($n(g,e),n);return n};r.resume();for(const e of h){const n=w(e.filepath);e.outputs=Array.from(n.values()),e.inputs=Array.from(new Set(e.outputs.flatMap((e=>e.inputs)))),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),l.has(e.filepath)&&t.debug(`Entry "${e.name}":"${Lr(g,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(c.values()),e.build.outputs=Array.from(p.values()),e.build.entries=Array.from(l.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},Ur=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,d=new Map,c=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||G(e)),g=e=>e.replace(/(^external[^"]+"|"$)/g,""),h=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=Fr(e);t.add(n),n.startsWith("external ")&&t.add(g(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(c.has(e)){const n=c.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else c.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=Fr(t.request);if(c.has(n))return c.get(n);if(e.context){const t=$n(Fr(e.context),n);if(c.has(t))return c.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],i=[],s=[],a.clear(),u.clear(),c.clear(),l.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),i=n.time("indexing modules");for(const e of t)h(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Lr(e.bundler.outDir,t),i=new Set(y(n).map((e=>{const o=b(n,e);if(!o?.identifier())return!1;const r=o.identifier();return!!m(r)&&(r!==t&&(w(o)?g(r):r))})).filter(Boolean));if(!m(t))continue;const s=l.get(t)||{dependents:new Set,dependencies:new Set};for(const e of i){const n=l.get(e)||{dependencies:new Set,dependents:new Set};n.dependents.add(t),s.dependencies.add(e),l.set(e,n)}l.set(t,s);const u=w(n)?{size:0,name:g(o),dependencies:new Set,dependents:new Set,filepath:t,type:"external"}:{size:n.size()||0,name:o,dependencies:new Set,dependents:new Set,filepath:t,type:Rr(t)};r.push(u),a.set(t,u),w(n)&&a.set(g(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=l.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,c=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>$n(e.bundler.outDir,t))),g=n.time("indexing chunks"),h=t.chunkGraph;for(const e of o){const t=l(e),n=(h?.getChunkModules(e)||[]).flatMap((e=>"modules"in e&&Array.isArray(e.modules)?e.modules.map((e=>e.identifier())):e.identifier())).filter(m);for(const e of t){if("map"===Rr(e))continue;const t=d.get(e)||new Set;for(const e of n)t.add(e);d.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of c){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:$n(e.bundler.outDir,t.name),type:Rr(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){p.push(o);continue}const r=d.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of p){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return new Set;t.add(e);const n=new Set(e.chunks);for(const o of e.childrenIterable||[]){const e=v(o,t);for(const t of e)n.add(t)}return n};for(const[o,r]of t.entrypoints){const t=new Map,i=new Map;let a=0;const d=v(r),c=Array.from(d).flatMap(l),p=r.chunks.filter((e=>h.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===Rr(e)));for(const e of c){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)i.has(e.filepath)||i.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:p?$n(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:p?Rr(p):"unknown"};s.push(f)}w.end();for(const n of t.errors)e.build.errors.push(n.message);for(const n of t.warnings)e.build.warnings.push(n.message);e.build.inputs=r,e.build.outputs=i,e.build.entries=s,f.end(),await e.asyncHook("buildReport",e.build)}))},Vr="datadog-build-report-plugin",qr=e=>{const{context:t}=e,n=t.getLogger(Vr);return[{name:Vr,enforce:"post",esbuild:Br(t,n),rspack:Ur(t,Vr,n),webpack:Ur(t,Vr,n),vite:Kr(t,n),rollup:Kr(t,n)}]},Hr="datadog-bundler-report-plugin",Wr=(e,t)=>t?u.isAbsolute(t)?t:u.resolve(e,t):"",Jr=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?u.dirname(e.file):void 0)).filter(Boolean)},Gr=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Wr(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Yr=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Jr(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=xn(r,process.cwd())),e.bundler.outDir=Wr(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Qr=e=>{const{context:t}=e,n=t.getLogger(Hr);return[{name:Hr,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Wr(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Wr(t.buildRoot,u.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Gr(t),rspack:Gr(t),vite:Yr(t),rollup:{options(e){let n;if("output"in e){const t=Jr(e.output);n=xn(t,process.cwd())}const o=(e=>{const t=new Set;if(e.input){const n=Array.isArray(e.input)?e.input:"object"==typeof e.input?Object.values(e.input):[e.input];for(const e of n){if("string"!=typeof e)throw new Error("Invalid input type");t.add(u.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=$n(process.cwd(),n);const e=xn([n,...o],process.cwd());t.buildRoot=e===u.sep?process.cwd():e}else t.buildRoot=xn(o,process.cwd()),t.bundler.outDir=u.resolve(process.cwd(),"dist");t.hook("buildRoot",t.buildRoot)},buildStart(e){t.bundler.rawConfig=e},renderStart(e){t.bundler.rawConfig.outputs=t.bundler.rawConfig.outputs||[],t.bundler.rawConfig.outputs.push(e),t.hook("bundlerReport",t.bundler);const o=Jr(e);xn(o,process.cwd()).startsWith(t.bundler.outDir)||n.warn("The output directory has been changed by a plugin and may introduce some inconsistencies in the build report.")}}}]},Xr="datadog-custom-hooks-plugin",Zr=e=>{const{context:t}=e,n=t.getLogger(Xr),o=e=>(o,...r)=>{const i=n.time(`execution | ${o}`,{tags:["type:custom-hook",`hook:${o}`]}),s=[],a=[];for(const n of t.plugins){if(!(o in n))continue;const t=n[o];if("function"==typeof t)try{const i=t(...r);i instanceof Promise&&(e||s.push(`Plugin "${n.name}" returned a promise on the non async hook "${o}".`),a.push(i))}catch(e){s.push(`Plugin "${n.name}" errored on hook "${o}". [${e}]`)}else s.push(`Plugin "${n.name}" has an invalid hook type for "${o}". [${typeof t}]`)}if(s.length>0){for(const e of s)n.error(e);throw new Error("Some plugins errored during the hook execution.")}return Promise.all(a).finally((()=>i.end()))};return t.hook=o(!1),t.asyncHook=o(!0),[{name:Xr,enforce:"pre"}]};class ei{constructor(e){this.trackedFilenames=new Map;for(const t of e){const e=this.getFilename(t),n=this.trackedFilenames.get(e);n?n.push(t):this.trackedFilenames.set(e,new Array(t))}}displaySource(e){return e.length<=40?e:`[...]${e.slice(-35)}`}matchSourcemap(e,t){const n=ve(e),o=JSON.parse(n);if(!o.sources)return void t("Missing 'sources' field in sourcemap.");const r=o.sources;if(0===r.length)return void t("Empty 'sources' field in sourcemap.");const i=this.matchSources(r);if(0!==i.length)return i;t(`${r.map(this.displaySource).join(", ")} not in the tracked files.`)}matchSources(e){let t=[];const n=new Set;for(const o of e){const e=this.getFilename(o);if(n.has(e))continue;n.add(e);const r=this.trackedFilenames.get(e);r&&(t=t.concat(r))}return t}rawTrackedFilesList(){let e=[];return this.trackedFilenames.forEach((t=>{e=e.concat(t)})),e}getFilename(e){let t=e.lastIndexOf("/");-1===t?t=0:t++;let n=e.lastIndexOf("?");return(-1===n||n<=t)&&(n=e.length),e.substring(t,n)}}const ti=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await ni(e);for(const e of t)if(e.name===n)return ee(e.refs.push);return ee(t[0].refs.push)},ni=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},oi=async e=>e.revparse("HEAD"),ri=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),ii=async e=>e.branch(),si=async e=>e.show(["-s","--format=%s"]),ai=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),ui="datadog-git-plugin",di=e=>{const{options:t,context:n}=e,o=n.getLogger(ui),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t=[oi(e),ii(e),si(e),ai(e),ri(e),ti(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,d,c,p,l,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:d,date:c},committer:{name:p,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new ei(s)}})(await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=k(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return k(t)})(u.dirname(e)));n.git=t,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:ui,enforce:"pre",buildRoot(e){if(Q(t))try{r.resume();const t=kn(e,".git");if(!t)return o.warn("No .git directory found, skipping git plugin."),void r.end();n.queue(i(t))}catch(e){o.error(`Could not get git information: ${e.message}`)}}}]},ci="datadog-injection-plugin",pi=/^https?:\/\//,li=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],fi=t.bold.yellow,mi=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))($n(t,e)),gi=async(e,t,n=process.cwd())=>{let o;const r=await(async e=>"function"==typeof e.value?e.value():e.value)(e);try{if("file"===e.type)o=r.match(pi)?await(async(e,t=5e3)=>{let n;return Promise.race([H({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await mi(r,n);else{if("code"!==e.type)throw new Error(`Invalid item type "${e.type}", only accepts "code" or "file".`);o=r}}catch(i){const s=`${e.type} - ${Z(r)}`;e.fallback?(t.debug(`Fallback for "${s}": ${i.toString()}`),o=await gi(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},hi=(e,t)=>{const n=e.filter((e=>e.position===t.position&&(!t.onAllChunks||e.injectIntoAllChunks)));if(0===n.length)return"";return`// begin injection by Datadog build plugins\n${n.map((e=>`(() => {${e.value}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},yi=async(e,t,n,o=process.cwd())=>{const r=await(async(e,t,n=process.cwd())=>{const o=new Map;for(const[r,i]of e.entries()){const e=await gi(i,t,n);if(e){const t=i.position||Ee.BEFORE;o.set(r,{value:e,injectIntoAllChunks:"injectIntoAllChunks"in i&&i.injectIntoAllChunks,position:t})}}return o})(t,e,o);for(const e of r.values())n.push(e)},bi=e=>e instanceof Error&&"code"in e,wi=e=>li.includes(e),vi=(e,t,n)=>{e.warn(`"${fi(t)}" files are not supported (${fi(n)}).`)},$i=s.promises,ki=(e,t,n)=>({setup(o){const{onStart:i,onResolve:a,onLoad:d,onEnd:c,esbuild:p,initialOptions:f}=o,m=[],g=`${t.bundler.name}.${Ee.MIDDLE}.${A}.js`,h=s.realpathSync(l.tmpdir()),y=u.resolve(h,g),b=new RegExp(`${g}$`),w=f.inject;f.inject=w?[...w]:[],f.inject.push(y),i((async()=>{m.push(...await Cr(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await be(u.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),a({filter:b},(async e=>({path:e.path,namespace:ci}))),d({filter:b,namespace:ci},(async()=>({contents:hi(n,{position:Ee.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),c((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=hi(n,{position:Ee.BEFORE}),i=hi(n,{position:Ee.AFTER}),s=hi(n,{position:Ee.BEFORE,onAllChunks:!0}),a=hi(n,{position:Ee.AFTER,onAllChunks:!0});if(!(r||i||s||a))return;const d=[];for(const[n,c]of Object.entries(o.metafile.outputs)){const o=c.entryPoint&&m.some((e=>e.resolved.endsWith(c.entryPoint))),l=o?r:s,f=o?i:a;if(!l&&!f)continue;const g=$n(t.buildRoot,n),{base:h,ext:y}=u.parse(g);wi(y)?d.push((async()=>{try{const e=await $i.readFile(g,"utf-8"),t=await p.transform(e,{loader:"default",banner:l,footer:f});await $i.writeFile(g,t.code)}catch(t){if(!bi(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${g}: ${t}`)}})()):vi(e,y,h)}await Promise.all(d)}))}}),xi=A,Ei="?inject-proxy",Si=(e,t)=>({banner(n){const o=hi(t,{position:Ee.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return wi(i)?o:(vi(e,i,r),"")},async resolveId(e,n,o){if(G(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&hi(t,{position:Ee.MIDDLE})){if(e.endsWith(".html"))return null;const t=await this.resolve(e,n,o);if(!t||t.external)return t;return(await this.load(t)).moduleSideEffects=!0,`${t.id}${Ei}`}return null},load(e){if(G(e))return hi(t,{position:Ee.MIDDLE});if(e.endsWith(Ei)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(xi)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=hi(t,{position:Ee.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return wi(i)?o:(vi(e,i,r),"")}}),Ii=(e,t,n,o,r)=>i=>{const a=new WeakMap,d=e.sources.ConcatSource,c=n.bundler.name,p=u.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${c}.${Ee.MIDDLE}.${A}.js`);we(p,"");i.hooks.shutdown.tap(ci,(()=>{var e;e=p,s.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await yi(t,o,r,n.buildRoot)};i.hooks.beforeRun.tapPromise(ci,l),i.hooks.watchRun.tapPromise(ci,l),i.hooks.compilation.tap(ci,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:ci,stage:o},(()=>{const e=hi(r,{position:Ee.BEFORE}),o=hi(r,{position:Ee.AFTER}),i=hi(r,{position:Ee.BEFORE,onAllChunks:!0}),s=hi(r,{position:Ee.AFTER,onAllChunks:!0});for(const r of n.chunks){let c=e,p=o;if(r.canBeInitial()||(c=i,p=s),""!==c||""!==p)for(const e of r.files){const{base:o,ext:r}=u.parse(e);wi(r)?n.updateAsset(e,(e=>{const t=a.get(e);if(!t||t.banner!==c||t.footer!==p){const t=new d(c,"\n",e,"\n",p);return a.set(e,{source:t,banner:c,footer:p}),t}return t.source})):vi(t,r,o)}}}))}));const f=(e=>{const n={import:[p]},o=e=>{for(const[n,o]of Object.entries(e))"object"==typeof o?(o.import=o.import||[],o.import.unshift(p)):"string"==typeof o?e[n]=[p,o]:Array.isArray(o)?o.unshift(p):t.error("Invalid entry type: "+typeof o)};return e?"function"==typeof e?async()=>{const t=await e();return o(t),t}:"object"!=typeof e?"string"==typeof e?[n,e]:(t.error("Invalid entry type: "+typeof e),e):(o(e),e):{ddHelper:n}})(i.options.entry);i.options.entry=f},Di=e=>{const{bundler:t,context:n}=e,o=n.getLogger(ci),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++ne}`,e)};const s={name:ci,enforce:"post",esbuild:ki(o,n,i),webpack:Ii(t,o,n,r,i),rspack:Ii(t,o,n,r,i),rollup:Si(o,i),vite:{...Si(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>hi(i,{position:Ee.MIDDLE})?[{tag:"script",attrs:{type:"module",src:"/@id/__datadog-helper-file"},injectTo:"head-prepend"}]:[]}}};var a;return a=n.bundler.name,["rspack","webpack"].includes(a)?s.load={filter:{id:M},handler:()=>({code:hi(i,{position:Ee.MIDDLE})})}:s.buildStart=async()=>{await yi(o,r,i,n.buildRoot)},[s]},ji="datadog-true-end-plugin",Pi=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=()=>{t.hook("syncTrueEnd")},r=async()=>{o(),await n()},i=e=>{e.hooks.shutdown.tapPromise(ji,r)},s={async writeBundle(){},async closeBundle(){await r()}};return[{name:ji,enforce:"post",webpack:i,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:s,rollup:s,rspack:i}]},Ai={[To]:ur},Mi=t.bold.red;var Ci="3.1.8-dev.0";const Ni=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,r)=>{const i=Date.now(),s=((e={})=>{const t=(e=>{const t=[];return void 0===e||void 0!==e.version&&"string"!=typeof e.version&&t.push("metadata.version must be a string"),t})(e.metadata),n=L("SITE"),o={site:B(n,"DATADOG_SITE/DD_SITE",t)??B(e.auth?.site,"auth.site",t)??O};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:L("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:L("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=R);const a=process.env.BUILD_PLUGINS_ENV||"production",u=C.includes(a)?a:"development",d=t.rspackVersion||t.version||t.VERSION,c=r.framework,p={bundler:{name:c,version:d},env:u,metadata:s.metadata||{},packageName:`@datadog/${c}-plugin`,version:n},l={errors:[],logs:[],queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:ae(n,o,t.logLevel),asyncHook:()=>{throw new Error("AsyncHook function called before it was initialized.")},hook:()=>{throw new Error("Hook function called before it was initialized.")},inject:()=>{throw new Error("Inject function called before it was initialized.")},plugins:[],queue:()=>{throw new Error("Queue function called before it was initialized.")},sendLog:W(n),start:e,version:n.version}})({start:o,options:s,data:p,stores:l}),m=f.getLogger("factory"),g=m.time("Plugins initialization",{start:i});f.pluginNames.push(R);const h=[];h.push(["analytics",Pr],["async-queue",Mr],["build-report",qr],["bundler-report",Qr],["custom-hooks",Zr],["git",di],["injection",Di],["true-end",Pi]),s.customPlugins&&h.push(["custom",s.customPlugins]),h.push(["apps",Bn],["error-tracking",no],["live-debugger",Oo],["metrics",dr],["output",hr],["rum",Dr]);for(const[e,n]of h)f.plugins.push(...ce(f,n,e)({bundler:t,context:f,options:s,data:p,stores:l}));return(e=>{const t=[];for(const n of F){const o=z(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>_(e))).join(" and "),i=_(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>T(e))).join(" and ");t.push(`${e} (same value)`)}}t.length&&e.info(`Overrides from environment:\n - ${t.join("\n - ")}`)})(m),f.pluginNames.push(...f.plugins.map((e=>e.name))),(e=>{const t=new Set(e.filter((t=>e.filter((e=>e===t)).length>1)));if(t.size>0)throw new Error(`Duplicate plugin names: ${Mi(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),g.end(),f.plugins}))})({bundler:x,version:Ci}).esbuild,Oi=Ci,Ri=Ai;export{Ni as datadogEsbuildPlugin,Ri as helpers,Oi as version};
|
|
1
|
+
import{createUnplugin as e}from"unplugin";import t from"chalk";import n from"async-retry";import{File as o}from"buffer";import r,{mkdtemp as i}from"fs/promises";import s from"fs";import{JsonStreamStringify as a}from"json-stream-stringify";import u from"path";import{Readable as d}from"stream";import{createHash as c,randomUUID as p}from"crypto";import l,{tmpdir as f}from"os";import*as m from"eslint-scope";import g from"jszip";import{glob as h}from"glob";import y from"pretty-bytes";import b from"p-queue";import w from"@jridgewell/remapping";import{performance as v}from"perf_hooks";import{instrument as $}from"@datadog/js-instrumentation-wasm";import{simpleGit as k}from"simple-git";import x from"esbuild";import E from"node:url";import S from"node:path";import I from"node:module";const D=E.fileURLToPath(import.meta.url),j=S.dirname(D),P=I.createRequire(import.meta.url),A="__datadog-helper-file",M=new RegExp(A),N=["development","production","test"],C=["datadoghq.com","us3.datadoghq.com","us5.datadoghq.com","datadoghq.eu","ddog-gov.com","us2.ddog-gov.com","ap1.datadoghq.com","ap2.datadoghq.com","datad0g.com"],O=C[0],R="datadog-build-plugins",T=t.bold.green,_=t.bold.yellow,F=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],L=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],z=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},B=(e,t,n)=>{if(void 0!==e)return(e=>C.some((t=>t===e)))(e)?e:void n.push(`${t} "${e}" is not a supported Datadog site. See the site parameters in https://docs.datadoghq.com/getting_started/site/.`)},K=e=>{if(null===e||"object"!=typeof e)return"";const t="title"in e&&"string"==typeof e.title?e.title:void 0,n="detail"in e&&"string"==typeof e.detail?e.detail:void 0;return t&&n?`${t}: ${n}`:t||(n?`detail: ${n}`:"")},U=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),V=async e=>{const{getForm:t,defaultHeaders:n={},zip:o=!0}=e,r=await t(),i=new Request("fake://url",{method:"POST",body:r});return{data:o?i.body.pipeThrough(new CompressionStream("gzip")):i.body,headers:{"Content-Encoding":o?"gzip":"multipart/form-data",...n,...Object.fromEntries(i.headers.entries())}}},q=[400,401,403,404,405,409,413],H=e=>{const{auth:t,url:o,method:r="GET",getData:i,type:s="text"}=e,a={retries:0===e.retries?0:e.retries||5,onRetry:e.onRetry,maxTimeout:e.maxTimeout,minTimeout:e.minTimeout};return n((async(e,n)=>{let a;try{const e={method:r,duplex:"half"};let n={"X-Datadog-Origin":"build-plugins"};if(t?.apiKey&&(n["DD-API-KEY"]=t.apiKey),t?.appKey&&(n["DD-APPLICATION-KEY"]=t.appKey),"function"==typeof i){const{data:t,headers:o}=await i();e.body=t,n={...n,...o}}a=await fetch(o,{...e,headers:n})}catch(t){return e(t),{}}if(!a.ok){let t=`HTTP ${a.status} ${a.statusText}`;try{const e=(e=>{try{const t=JSON.parse(e);if(null!==t&&"object"==typeof t)if("errors"in t&&Array.isArray(t.errors)){const e=t.errors.map(K).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=K(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(q.includes(a.status))return e(new Error(t)),{};throw new Error(t)}try{let e;return e="json"===s?await a.json():await a.text(),e}catch(t){return e(t),{}}}),a)},W=e=>({message:t,context:n})=>H({retries:2,minTimeout:100,url:"https://browser-http-intake.logs.datadoghq.com/v1/input/pub44d5f4eb86e1392037b7501f7adc540e",method:"POST",type:"json",getData:async()=>{const o={ddsource:e.packageName||R,message:t,service:"build-plugins",team:"language-foundations",env:e.env,version:e.version,bundler:{name:e.bundler.name,version:e.bundler.version},metadata:e.metadata,...n};return{data:JSON.stringify(o),headers:{"Content-Type":"application/json"}}}}),J=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),G=e=>e.includes(A),Y=e=>{const t={bundler:e.bundler,errors:e.errors,metadata:e.metadata,warnings:e.warnings,logs:e.logs,timings:e.timings,start:e.start,end:e.end,duration:e.duration,writeDuration:e.writeDuration,entries:[],inputs:[],outputs:[]};for(const n of e.entries||[]){const e={...n,inputs:[],outputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),n.outputs&&(e.outputs=n.outputs.map((e=>e.filepath))),t.entries.push(e)}for(const n of e.inputs||[]){const e={...n,dependencies:[],dependents:[]};if(n.dependencies)for(const t of n.dependencies)e.dependencies.push(t.filepath);if(n.dependents)for(const t of n.dependents)e.dependents.push(t.filepath);t.inputs.push(e)}for(const n of e.outputs||[]){const e={...n,inputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),t.outputs.push(e)}return t},Q=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},X=e=>{const t=Math.floor(e/1e3/60/60/24),n=new Date(e-24*t*60*60*1e3),o=n.getUTCHours(),r=n.getUTCMinutes(),i=n.getUTCSeconds(),s=n.getUTCMilliseconds(),a=`${t?`${t}d `:""}${o?`${o}h `:""}${r?`${r}m `:""}${i?`${i}s`:""}`.trim();return`${a}${!a||s?` ${s}ms`:""}`.trim()},Z=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),r=Math.min(10,Math.floor(o/2)),i=o-r;return`${e.slice(0,r)}${n}${e.slice(-i)}`},ee=(e="")=>{try{if(!e||e.startsWith("git@"))return e;const t=new URL(e),n="/"===t.pathname?"":t.pathname;return`${t.protocol?`${t.protocol}//`:""}${t.host}${n}`}catch{return e}},te=e=>Object.entries(e).map((([e,n])=>` - ${e}: ${t.bold.green((e=>{if(void 0===e)return"undefined";if(null===e)return"null";if(Array.isArray(e))return e.join(", ");if("object"==typeof e)try{return JSON.stringify(e,null,2)}catch{return String(e)}return e?.toString()??""})(n))}`)).join("\n");let ne=0;const oe={debug:0,info:1,warn:2,error:3,none:4},re=e=>e.split(">").map(J).join(">"),ie=(e,n,o,r)=>{const i=re(e);return(s,a="debug",{forward:u,context:d}={})=>{let c=t.dim,p=console.log;"error"===a?(c=t.red,p=console.error):"warn"===a?(c=t.yellow,p=console.warn):"info"===a&&(c=t.cyan,p=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=W(n);await t({message:f,context:{plugin:e,status:a,...d}})}catch(t){ie(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}oe[a]>=oe[r]&&p(`${c(l)} ${f}`)}},se=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:d=[]}=i,c={pluginName:e,label:r,spans:[],tags:[...d,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(c);const p=()=>c.spans.filter((e=>!e.end)),l=n=>{p().length||(!c.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),c.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=p();if(i?.length){i.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of i)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),l(e)}return{timer:c,resume:l,end:e=>{f(e,!1);const n=c.spans.reduce(((e,t)=>e+(t.end-t.start)),0);c.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(X(n))}`,s)},pause:f,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=p();for(const n of t)n.tags.push(...e)}else c.tags.push(...e)}}},ae=(e,t,n="warn")=>o=>{const r=ie(o,e,t,n);return{getLogger:r=>ae(e,t,n)(`${re(o)}>${r}`),time:se(o,t.timings,r),error:(e,t)=>r(e,"error",t),warn:(e,t)=>r(e,"warn",t),info:(e,t)=>r(e,"info",t),debug:(e,t)=>r(e,"debug",t)}},ue=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],de=(e,t,n,o)=>{const r=n=>function(...r){const i=o.time(`${e} | ${t}`,{log:!1,tags:["type:hook",`hook:${t}`]}),s=n.apply(this,r);return s instanceof Promise?s.finally((()=>{i.end()})):(i.end(),s)};return"object"==typeof n&&null!==n&&"handler"in n?{...n,handler:r(n.handler)}:r(n)},ce=(e,t,n)=>{const o=e.getLogger(R);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=J(e.name);for(const r of ue){const i=e[r];i&&(n[r]=de(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},pe=new Set,le=(e,t,n)=>{const o=e[t];if(o&&"object"==typeof o&&"enable"in o){const e=o.enable;if("boolean"!=typeof e&&void 0!==e&&(pe.has(t)||(pe.add(t),n.warn(`\`${t}.enable\` should be a boolean, got ${typeof e}. Non-boolean values are coerced today but will be rejected in the next major.`))),void 0!==e)return!!e}return!!o},fe="apps",me="datadog-apps-plugin",ge="api/unstable/app-builder-code/apps",he="datadog-apps-assets.zip",ye=/\.backend\.(ts|tsx|js|jsx)$/,be=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],we=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),ve=async e=>r.mkdir(e,{recursive:!0}),$e=(e,t)=>{var n;n=u.dirname(e),s.mkdirSync(n,{recursive:!0}),s.writeFileSync(e,t,{encoding:"utf-8"})},ke=e=>s.readFileSync(e,{encoding:"utf-8"}),xe=e=>{try{return s.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},Ee=async(e,t)=>{if("function"==typeof s.openAsBlob){const n=await s.openAsBlob(e,{type:t.contentType});return new o([n],t.filename)}{const n=d.toWeb(s.createReadStream(e)),r=await new Response(n).blob();return new o([r],t.filename,{type:t.contentType})}},Se=async e=>{const t={empty:!1,exists:!0};try{const{size:n}=await r.stat(e);0===n&&(t.empty=!0)}catch(e){if("ENOENT"!==e.code)throw e;t.exists=!1}return t};var Ie=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(Ie||{});function De(e,t){if(!function(e){return"Program"===e.type}(e))throw new Error(`Expected a Program node from this.parse() for ${t}, got ${e.type}`);return e}function je(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function Pe(e){return"type"===e.importKind||"type"===e.exportKind}function Ae(e,t){return function(e,t){const n=De(e,t),o=function(e){const t=new Map;for(const n of e.body)if("FunctionDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"function"});else if("ClassDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"class"});else if("VariableDeclaration"===n.type)for(const e of n.declarations)"Identifier"===e.id.type&&t.set(e.id.name,{kind:"variable",init:e.init});else if("ImportDeclaration"===n.type)for(const e of n.specifiers)t.set(e.local.name,{kind:"import"});return t}(n),r=[];for(const e of n.body){if("ExportDefaultDeclaration"===e.type)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);if("ExportAllDeclaration"===e.type)throw new Error(`"export *" is not supported in .backend.ts files. Use explicit named exports instead: ${t}`);if("ExportNamedDeclaration"!==e.type)continue;e.declaration&&r.push(...Ce(e.declaration,t).map((e=>({kind:"local",name:e,localName:e}))));const n="string"==typeof e.source?.value?e.source.value:null;for(const i of e.specifiers){if("Identifier"!==i.exported.type)continue;if("default"===i.exported.name)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);const e="Identifier"===i.local.type?i.local.name:"string"==typeof i.local.value?i.local.value:null;e&&(n?r.push({kind:"re-export",name:i.exported.name,localName:e,source:n}):("Identifier"===i.local.type&&Oe(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const Me=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function Ne(e){return null==e||Me.has(e.type)}function Ce(e,t){if("FunctionDeclaration"===e.type&&e.id)return[e.id.name];if("ClassDeclaration"===e.type)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${t}`);if("VariableDeclaration"===e.type)return e.declarations.flatMap((e=>{if("Identifier"!==e.id.type)throw new Error(`Destructured exports are not supported in backend files. Use individual named exports instead: ${t}`);if(Ne(e.init))throw new Error(`Non-function export "${e.id.name}" in backend file ${t}. Only function exports are supported — use "export function ${e.id.name}(…) { }" instead.`);return[e.id.name]}));throw new Error(`Unsupported export declaration type "${e.type}" in backend file ${t}. Only function and variable exports are allowed.`)}function Oe(e,t,n){const o=t.get(e);if(o){if("class"===o.kind)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${n}`);if("variable"===o.kind&&Ne(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function Re(e){const t=e.relativePath.split(u.sep).join("/");return`${c("sha256").update(t).digest("hex")}.${e.name}`}function Te(e){const t=[];for(const{exportName:n,queryName:o}of e)t.push(`export async function ${n}(...args) {`),t.push(` return globalThis.DD_APPS_RUNTIME.executeBackendFunction(${JSON.stringify(o)}, args);`),t.push("}"),t.push("");return t.join("\n")}function _e(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return P.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}(n)&&o.push("import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';"),o.push(""),o.push('/** @param {import("./context.types").Context} $ */'),o.push("export async function main($) {"),o.push(" globalThis.$ = $;"),o.push(""),o.push(" // Register the $.Actions-based implementation for executeAction"),o.push(" if (typeof setExecuteActionImplementation === 'function') {\n setExecuteActionImplementation(async (actionId, request) => {\n const actionPath = actionId.replace(/^com\\.datadoghq\\./, '');\n const pathParts = actionPath.split('.');\n let actionFn = $.Actions;\n for (const part of pathParts) {\n if (!actionFn) throw new Error('Action not found: ' + actionId);\n actionFn = actionFn[part];\n }\n if (typeof actionFn !== 'function') throw new Error('Action is not a function: ' + actionId);\n return actionFn(request);\n });\n }"),o.push(""),o.push(" const args = $.backendFunctionArgs ?? [];"),o.push(` const result = await ${e}(...args);`),o.push(" return result;"),o.push("}"),o.join("\n")}function Fe(e,t,n){const o={state:t},r=e=>{n._?.(e,o),function(e,t){return t[e.type]}(e,n)?.(e,o);for(const t of Object.keys(e))"type"!==t&&i(e[t])},i=e=>{if(Array.isArray(e))for(const t of e)Le(t)&&r(t);else Le(e)&&r(e)};r(e)}function Le(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function ze(e){Fe(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=m.analyze(e,{ecmaVersion:2022,ignoreEval:!0,sourceType:"module"}),n=new Map;for(const e of t.scopes)for(const t of e.references)n.set(t.identifier,t);return{scopeManager:t,referencesByIdentifier:n,moduleScope:Ve(t)}}function Be(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function Ke(e){return e.defs.some((e=>"ImportBinding"===e.type))}function Ue(e,t){return t.moduleScope.set.get(e)}function Ve(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function qe(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:He(e,t)},r=[];return Fe(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(Ye(o,t.unsupportedAliases,t.scopeAnalysis))throw et(n,"action-catalog call aliases");if(Ye(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw et(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!We(o,t.scopeAnalysis))return!1;if(e.optional||Ge(o))throw et(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function He(e,t){const n=new Set;return Fe(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&Ye(e.init,t.actionFunctions,t))return Xe(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&We(e.init,t))return Xe(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!Ye(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Ze(e.value))).map((e=>e.name));return Xe(e,t,n)}(e,t))n.add(o)},AssignmentExpression(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.left.type&&"Identifier"===e.right.type&&Ye(e.right,t.actionFunctions,t))return Qe([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&We(e.right,t))return Qe([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!Ye(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Ze(e.value)));return Qe(n,t)}(e,t))n.add(o)}}),n}function We(e,t){const n=Je(e);return!!n&&Ye(n,t.actionNamespaces,t)}function Je(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?Je(e.object):void 0}function Ge(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&Ge(e.object)}function Ye(e,t,n){return function(e,t,n){const o=Be(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function Qe(e,t){return e.flatMap((e=>{const n=Be(e,t.moduleScope);return n?[n]:[]}))}function Xe(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function Ze(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?Ze(e.argument):Ze(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?Ze(e):[]));case"RestElement":return Ze(e.argument);case"AssignmentPattern":return Ze(e.left);case"MemberExpression":return[]}}function et(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const tt="@datadog/action-catalog";function nt(e,t,n){const o=e.get(t);if(!o)return dt(t,[],n.name);const r=Be(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?ct(t,[],n.name):it({modules:e,visitedExports:new Set},t,r,[]):ct(t,[],n.name)}function ot(e,t,n,o){const r=e.modules.get(t);if(!r)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"export",exportName:n,message:`Module '${e}' was not collected while resolving export '${n}'.`,hops:t}}(t,o,n);if("default"===n)return at(t,o,n);const i=`${t}\0${n}`;if(e.visitedExports.has(i))return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"cycle",exportName:n,message:`Resolving export '${n}' from module '${e}' would cycle through the module graph.`,hops:t}}(t,o,n);e.visitedExports.add(i);try{const t=r.exportsByName.get(n);return t?function(e,t,n,o,r){if("unsupported"===o.kind)return function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-export",exportName:n,exportReason:o,message:`Export '${n}' from module '${e}' is unsupported: ${o}.`,hops:t}}(t.id,r,n,o.reason);if("re-export"===o.kind)return"default"===o.importedName?at(t.id,r,n):ot(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return it(e,t.id,o.variable,[...r,{kind:"local-export",moduleId:t.id,exportName:n,localName:o.variable.name}])}(e,r,n,t,o):function(e,t,n,o){let r;for(const i of t.starExports){const s=ot(e,i.resolvedId,n,[...o,{kind:"star-export",moduleId:t.id,exportName:n,sourceModuleId:i.resolvedId}]);if("unsupported"===s.kind){if("missing-export"===s.reason)continue;return s}if(!r||!rt(r,s)){if(r)return st(t.id,o,n);r=s}}return r??function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-export",exportName:n,message:`Module '${e}' does not expose export '${n}'.`,hops:t}}(t.id,o,n)}(e,r,n,o)}finally{e.visitedExports.delete(i)}}function rt(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function it(e,t,n,o){const r=e.modules.get(t);if(!r)return dt(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return ut(t,r,n);if("namespace"===o.kind)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"namespace-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported namespace import.`,hops:t}}(t,r,n);if("default"===o.importedName)return ut(t,r,n);return ot(e,o.resolvedId,o.importedName,[...r,{kind:"import",moduleId:t,localName:n,exportName:o.importedName,sourceModuleId:o.resolvedId}])}(e,r.id,n.name,i,o);const s=r.topLevelBindingsByVariable.get(n);return s?"const"===s.kind?{kind:"local",moduleId:r.id,variable:n,binding:s,hops:o}:"mutable"===s.kind?function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"mutable-binding",variableName:n,declarationKind:o,message:`Variable '${n}' in module '${e}' is declared with mutable '${o}'.`,hops:t}}(r.id,o,n.name,s.declarationKind):function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-binding",variableName:n,bindingReason:o,message:`Variable '${n}' in module '${e}' has unsupported binding: ${o}.`,hops:t}}(r.id,o,n.name,s.reason):function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-static-binding",variableName:n,message:`Variable '${n}' in module '${e}' does not have a recorded top-level static binding.`,hops:t}}(r.id,o,n.name)}function st(e,t,n){return{kind:"unsupported",moduleId:e,reason:"ambiguous-star-export",exportName:n,message:`Module '${e}' exposes ambiguous star exports for '${n}'.`,hops:t}}function at(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-export",exportName:n,message:`Export '${n}' from module '${e}' resolves through an unsupported default export.`,hops:t}}function ut(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported default import.`,hops:t}}function dt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"variable",variableName:n,message:`Module '${e}' was not collected while resolving variable '${n}'.`,hops:t}}function ct(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unresolved-identifier",variableName:n,message:`Identifier '${n}' in module '${e}' is not a resolvable reference.`,hops:t}}function pt(e,t,n){const o=kt(n);switch(o.type){case"Literal":return function(e,t){if("string"==typeof t.value)return{kind:"resolved",moduleId:e,value:t.value};return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-string-literal",valueType:t,message:`Literal value type '${t}' in module '${e}' is not a string.`}}(e,typeof t.value)}(t,o);case"TemplateLiteral":return function(e,t){if(t.expressions.length>0)return function(e){return{kind:"unsupported",moduleId:e,reason:"dynamic-template-literal",message:`Dynamic template literals in module '${e}' cannot be resolved to static strings.`}}(e);return{kind:"resolved",moduleId:e,value:t.quasis.map((e=>e.value.cooked??e.value.raw)).join("")}}(t,o);case"Identifier":return function(e,t,n){const o=nt(e.modules,t,n);if("unsupported"===o.kind)return Mt(o,n.name);if(!o.binding.expression)return Nt(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return It(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return pt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=lt(e,t,n);if("unsupported"===o.kind)return o;return pt(e,o.moduleId,o.expression)}(e,t,o);default:return function(e,t){return{kind:"unsupported",moduleId:e,reason:"unsupported-expression",expressionType:t,message:`Expression type '${t}' in module '${e}' cannot be resolved to a static string.`}}(t,o.type)}}function lt(e,t,n){if(n.optional)return function(e){return{kind:"unsupported",moduleId:e,reason:"optional-member-expression",message:`Optional member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if(n.computed)return function(e){return{kind:"unsupported",moduleId:e,reason:"computed-member-expression",message:`Computed member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if("Identifier"!==n.property.type)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-static-member-property",propertyType:t,message:`Member property type '${t}' in module '${e}' is not statically named.`}}(t,n.property.type);const o=ft(e,t,n.object);return"unsupported"===o.kind?o:function(e,t,n){let o;for(const r of t.properties){if("SpreadElement"===r.type)return At(e);if(r.computed)return St(e);if($t(r)===n){if(o)return Dt(e,n);if("init"!==r.kind)return Et(e,n);if(!mt(r))return Pt(e,n,r.value.type);o=r}}if(!o)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"missing-object-property",propertyName:t,message:`Static object in module '${e}' does not have property '${t}'.`}}(e,n);return{kind:"resolved",moduleId:e,expression:o.value}}(o.moduleId,o.expression,n.property.name)}function ft(e,t,n){if("Super"===n.type)return jt(t,n.type);const o=kt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=lt(e,t,o);return"unsupported"===n.kind?n:ft(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return jt(t,o.type);const r=nt(e.modules,t,o);if("unsupported"===r.kind)return Mt(r,o.name);if(!r.binding.expression)return Nt(r.moduleId,r.variable.name);if(e.mutatedImportedObjectVariables.has(r.variable))return function(e,t){return{kind:"unsupported",moduleId:e,reason:"imported-object-mutation",variableName:t,message:`Imported object '${t}' from module '${e}' is mutated in the module graph.`}}(r.moduleId,r.variable.name);if(e.seenVariables.has(r.variable))return It(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return ft(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function mt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function gt(e){const t=new Set;for(const n of e.values())Fe(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){yt(e.left,t)},UpdateExpression(e,{state:t}){yt(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&yt(e.argument,t)},ForInStatement(e,{state:t}){ht(e.left,t)},ForOfStatement(e,{state:t}){ht(e.left,t)}});return t}function ht(e,t){"VariableDeclaration"!==e.type&&yt(e,t)}function yt(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&yt(e.left,t):yt(e.argument,t);else for(const n of e.elements)n&&yt(n,t);else for(const n of e.properties)yt("RestElement"===n.type?n.argument:n.value,t);else{const n=vt(e);n&&bt(n,t)}else bt(e,t)}function bt(e,t){const n=wt(t,e,new Set);n&&t.mutatedVariables.add(n)}function wt(e,t,n){const o=Be(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),Ke(o)){const n=nt(e.modules,e.record.id,t);return"local"===n.kind?n.variable:void 0}const r=function(e){for(const t of e.defs){const e=t.node;if("VariableDeclarator"===e.type&&e.init)return e.init}return}(o);if(!r)return;const i=function(e){const t=kt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return vt(t);return}(r);return i?wt(e,i,n):void 0}function vt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?vt(e.object):void 0}function $t(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function kt(e){let t=e;for(;xt(t);)t=t.expression;return t}function xt(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function Et(e,t){return{kind:"unsupported",moduleId:e,reason:"accessor-object-property",propertyName:t,message:`Static object property '${t}' in module '${e}' is an accessor.`}}function St(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function It(e,t){return{kind:"unsupported",moduleId:e,reason:"cycle",variableName:t,message:`Resolving variable '${t}' in module '${e}' would cycle through static string values.`}}function Dt(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function jt(e,t){return{kind:"unsupported",moduleId:e,reason:"non-object-member-value",expressionType:t,message:`Expression type '${t}' in module '${e}' is not a static object value.`}}function Pt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unsupported-object-property-value",propertyName:t,valueType:n,message:`Static object property '${t}' in module '${e}' has unsupported value type '${n}'.`}}function At(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function Mt(e,t){return{kind:"unsupported",moduleId:e.moduleId,reason:"static-definition-unsupported",variableName:t,definition:e,message:`Variable '${t}' could not be resolved to a static definition: ${e.message}`}}function Nt(e,t){return{kind:"unsupported",moduleId:e,reason:"uninitialized-const",variableName:t,message:`Const variable '${t}' in module '${e}' does not have an initializer.`}}const Ct=new Set(["node_modules",".yarn"]);function Ot(e,t,n,o=[]){if(!Xt(e,t))return null;const r=De(n,e),i=ze(r),s=function(e,t){const n=function(e){return e.body.flatMap((e=>("ImportDeclaration"===e.type||"ExportNamedDeclaration"===e.type||"ExportAllDeclaration"===e.type)&&e.source&&je(e.source)?[e.source.value]:[]))}(e);return t.map(((e,t)=>({source:n[t]??e,resolvedId:e})))}(r,o);return{id:e,ast:r,scopeAnalysis:i,staticDependencies:s,unsupportedDependencies:Yt(r),importsByVariable:Rt(r,i,s),exportsByName:Tt(r,i,s),starExports:Lt(r,s),topLevelBindingsByVariable:zt(r,i)}}function Rt(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!je(r.source))continue;const e=Gt(n,r.source.value);for(const n of r.specifiers){const[r]=t.scopeManager.getDeclaredVariables(n);r&&("ImportSpecifier"!==n.type?o.set(r,{kind:"ImportDefaultSpecifier"===n.type?"default":"namespace",resolvedId:e}):o.set(r,{kind:"named",importedName:Wt(n.imported),resolvedId:e}))}}return o}function Tt(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&Ft(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):_t(r,t,n,o);return o}function _t(e,t,n,o){if(e.declaration)!function(e,t,n){if(!e)return;if("VariableDeclaration"===e.type){for(const o of e.declarations){const e=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const t of e)n.set(t.name,{kind:"unsupported",reason:"binding pattern export"});continue}const[r]=e;r&&n.set(o.id.name,{kind:"local",variable:r})}return}if(("FunctionDeclaration"===e.type||"ClassDeclaration"===e.type)&&e.id){const[o]=t.scopeManager.getDeclaredVariables(e);o&&n.set(e.id.name,{kind:"local",variable:o})}}(e.declaration,t,o);else if(e.source&&je(e.source)){const t=Gt(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=Wt(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:Wt(n.local),resolvedId:t}):o.set(e,{kind:"unsupported",reason:"default re-export",resolvedId:t})}}else for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=Wt(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=Ue(Wt(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function Ft(e,t,n){const o=Jt(e);o&&je(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Gt(t,e.source.value)})}function Lt(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||Jt(e)||!je(e.source)?[]:[{resolvedId:Gt(t,e.source.value)}]))}function zt(e,t){const n=new Map;for(const o of e.body)Bt(o,t,n);return function(e,t,n){Fe(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){Vt(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){Vt(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Vt(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){Ut(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){Ut(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function Bt(e,t,n){if("VariableDeclaration"===e.type)return void Kt(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void Kt(e.declaration,t,n);const o="ExportNamedDeclaration"===e.type||"ExportDefaultDeclaration"===e.type?e.declaration:e;if(o&&("FunctionDeclaration"===o.type||"ClassDeclaration"===o.type)&&o.id){const[e]=t.scopeManager.getDeclaredVariables(o);e&&n.set(e,{kind:"unsupported",reason:`${o.type} binding`})}}function Kt(e,t,n){for(const o of e.declarations){const r=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const e of r)n.set(e,{kind:"unsupported",reason:"binding pattern"});continue}const[i]=r;i&&("const"===e.kind?n.set(i,{kind:"const",expression:o.init??null}):n.set(i,{kind:"mutable",declarationKind:e.kind}))}}function Ut(e,t,n){"VariableDeclaration"!==e.type&&Vt(e,t,n)}function Vt(e,t,n){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&Vt(e.left,t,n):Vt(e.argument,t,n);else for(const o of e.elements)o&&Vt(o,t,n);else for(const o of e.properties)Vt("RestElement"===o.type?o.argument:o.value,t,n);else{const o=Ht(e);o&&qt(o,t,n,"mutated object binding")}else qt(e,t,n,"reassigned binding")}function qt(e,t,n,o){const r=Be(e,t);if(!r||Ke(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function Ht(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?Ht(e.object):void 0}function Wt(e){return"Identifier"===e.type?e.name:String(e.value)}function Jt(e){const t=e.exported;return t?Wt(t):void 0}function Gt(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function Yt(e){const t=[];return Fe(e,t,{ImportExpression(e,{state:t}){const n=function(e){return en(e.source,"non-literal dynamic import")}(e);Qt(n)&&t.push({specifier:n,kind:"dynamic-import"})},CallExpression(e,{state:t}){if(function(e){return"Import"===e.callee.type}(e)){const n=function(e){return en(e.arguments[0],"non-literal dynamic import")}(e);Qt(n)&&t.push({specifier:n,kind:"dynamic-import"})}else(function(e){if("Identifier"!==e.callee.type||"require"!==e.callee.name)return!1;const[t]=e.arguments;return!t||!je(t)||tn(t.value)})(e)&&t.push({specifier:Zt(e),kind:"require"})}}),t}function Qt(e){return"non-literal dynamic import"===e||tn(e)}function Xt(e,t){if(!be.some((t=>e.endsWith(t))))return!1;const n=u.relative(u.resolve(t),e);return!n.startsWith("..")&&!u.isAbsolute(n)&&!n.split(u.sep).some((e=>Ct.has(e)))}function Zt(e){return en(e.arguments[0],"local require")}function en(e,t){return je(e)?e.value:t}function tn(e){return e.startsWith(".")||e.startsWith("/")}function nn(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function on(e,t,n){const o=new Set;return function(e,t,n,o){const r=[e],i=new Set;for(;r.length>0;){const s=r.shift();if(i.has(s))continue;i.add(s);const a=t.get(s);if(!a)throw nn(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw nn(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Xt(i,n)){if(!t.has(i))throw nn(e,`uncollected local import ${i} from ${a.id}`);r.push(i)}}}}(e,t,n,(({record:e})=>{const n=function(e){const t=new Set,n=new Set;for(const r of e.body)if("ImportDeclaration"===r.type&&"string"==typeof(o=r.source.value)&&(o===tt||o.startsWith(`${tt}/`))&&!Pe(r))for(const e of r.specifiers)Pe(e)||("ImportNamespaceSpecifier"===e.type?n.add(e.local.name):t.add(e.local.name));var o;return{functions:t,namespaces:n}}(e.ast),r=function(e,t){const n=new Set,o=new Set;for(const r of e.scopeManager.scopes)for(const e of r.variables)Ke(e)&&(t.functions.has(e.name)&&n.add(e),t.namespaces.has(e.name)&&o.add(e));return{moduleScope:e,actionFunctions:n,actionNamespaces:o}}(e.scopeAnalysis,n);for(const n of qe(e.ast,r,e.id)){const r=rn(n,t,e);r&&o.add(r)}})),[...o].sort()}function rn(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw un(n.id,"non-object action-catalog call arguments");const r=function(e,t){let n;for(const o of e.properties){if("SpreadElement"===o.type)throw un(t,"spread object arguments");if(o.computed)throw un(t,"computed object property keys");if(an(o)){if(n)throw un(t,"multiple connectionId properties");if("init"!==o.kind)throw un(t,"accessor connectionId properties");if(!sn(o))throw un(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return pt({modules:e,mutatedImportedObjectVariables:gt(e),seenVariables:new Set},t,n)}(t,n.id,r.value);if("resolved"===i.kind)return i.value;throw s=n.id,a=`static string resolution ${function(e){return"static-definition-unsupported"===e.reason?`${e.reason}/${e.definition.reason}`:e.reason}(i)}: ${i.message}`,new Error(`Unsupported action-catalog connectionId in ${s}: ${a}.`);var s,a}function sn(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function an(e){return"connectionId"===function(e){if("Identifier"===e.key.type)return e.key.name;if("Literal"===e.key.type&&"string"==typeof e.key.value)return e.key.value;return}(e)}function un(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const dn=/^(?:\0|virtual:)/;function cn(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=pn(n.id);if(r=o,dn.test(r))return;var r;const i=Ot(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(pn));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function pn(e){return e.split("?")[0]}function ln(e,t){const n=cn(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>on(e,n.getModuleRecords(),t)}}function fn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function mn(e,t,n=[]){return{configFile:!1,root:e,logLevel:"silent",build:{minify:!1,target:"esnext",rollupOptions:{output:{format:"es",exports:"named",inlineDynamicImports:!0},preserveEntrySignatures:"exports-only",treeshake:!1,onwarn(e,t){"MODULE_LEVEL_DIRECTIVE"!==e.code&&t(e)}}},resolve:{extensions:[...be,".json"]},plugins:[fn("dd-backend-resolve",t),...n]}}function gn(e){return`${e.relativePath}/${e.name}`}async function hn(e,t,n,o){const r=gn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return _e(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=ln(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=mn(n,{[i]:s},[a.plugin]),d=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),c=Array.isArray(d)?d[0]:d;if(!("output"in c))throw new Error(`Unexpected vite.build result for "${r}"`);const p="chunk"===c.output[0].type?c.output[0].code:"",l={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${p.length} bytes)`),{func:l,code:p}}async function yn(e,t,n,o,r){const i=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,s=gn(t);r.debug(`Calling Datadog API: ${i}`);const a=JSON.stringify({data:{type:"queries",attributes:{query:{id:p(),name:s,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e,allowedConnectionIds:t.allowedConnectionIds,context:{backendFunctionArgs:n}}},onlyTriggerManually:!0}},template_params:{}}}}),u=await H({url:i,auth:o,method:"POST",type:"json",getData:()=>({data:a,headers:{"Content-Type":"application/json"}})}),d=u.data?.id;if(!d)throw new Error("No receipt ID returned from Datadog API");return r.debug(`Query execution started with receipt: ${d}`),async function(e,t,n){const o=`https://api.${t.site}/api/v2/app-builder/queries/execution-long-polling/${e}`,r=10;for(let e=0;e<r;e++){n.debug(`Long-poll attempt ${e+1}/${r}...`);const i=await H({url:o,auth:t,type:"json"});if(i.errors?.length){const e=i.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const s=i.data?.attributes;if(n.debug(`Long-poll response, done: ${s?.done}`),s?.done){if(!s.outputs)throw new Error("Query execution completed without outputs");return s.outputs}}throw new Error("Query execution timed out")}(d,o,r)}function bn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class wn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function vn(e,t,n){const{functionName:o,args:r=[]}=await function(e){return new Promise(((t,n)=>{let o="";e.on("data",(e=>{o+=e.toString()})),e.on("end",(()=>{try{t(JSON.parse(o))}catch{n(new Error("Invalid JSON body"))}})),e.on("error",n)}))}(e);if(!o||"string"!=typeof o)throw new wn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new wn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function $n(e,t,n,o,r){const i=t=>hn(e,t,o,r),s=t();s.length>0&&r.info(`Dev server middleware active for ${s.length} backend function(s): ${s.map((e=>e.name)).join(", ")}`);const a=n.apiKey&&n.appKey?{apiKey:n.apiKey,appKey:n.appKey,site:n.site}:void 0;return a||r.warn("Auth credentials not configured. The /__dd/executeAction endpoint will be unavailable. Set DD_API_KEY and DD_APP_KEY to enable remote execution."),(e,n,o)=>{if("POST"!==e.method)return void o();const s=(u=t(),new Map(u.map((e=>[Re(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await vn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){bn(t,e instanceof wn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,n,s,i).catch((()=>{bn(n,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void bn(n,403,"Auth credentials not configured. Set DD_API_KEY and DD_APP_KEY to enable remote execution.");(async function(e,t,n,o,r,i){try{const{func:s,code:a,args:u}=await vn(e,n,o),d=gn(s);i.debug(`Executing action: ${d} with args`);const c=await yn(a,s,u,r,i);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:c}))}catch(e){const n=e instanceof wn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";i.debug(`Error handling executeAction: ${o}`),bn(t,n,o)}})(e,n,s,i,a,r).catch((()=>{bn(n,500,"Unexpected error")}))}else o()}}const kn=async(e,t)=>{const n=(await Promise.all(e.map((e=>h(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>u.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(u.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(u.sep);if(!e.every((e=>e.startsWith(`${r}${u.sep}`))))break;n=r}return n})(o),i=o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o.split(u.sep).join("/")}}));return i},xn=(e,t)=>G(t)?A:t.startsWith(e)||u.isAbsolute(t)?t:u.resolve(e,t),En=(e,t)=>{let n,o=xn(process.cwd(),e);for(;!n;){const e=u.resolve(o,t);if(xe(e)&&(n=e),o=o.split(u.sep).slice(0,-1).join(u.sep),[u.sep,""].includes(o))break}return n},Sn=(e,t)=>{const n=[...e].map((e=>xn(t||process.cwd(),e).split(u.sep))),o=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<o;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(u.sep)||u.sep},In=t.bold.red,Dn=t.bold.yellow,jn=e=>{const t=En(e,"package.json");if(t)try{const e=ke(t);return JSON.parse(e)}catch(e){return}},Pn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=jn(e);o||t.warn(Dn("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(In("Unable to determine the app name to compute the app identifier."));const i=((e,t)=>{const n=e||(e=>{if(e&&e.repository)return"string"==typeof e.repository?e.repository:"url"in e.repository?e.repository.url:void 0})(t);if(!n)return;const o=ee(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(In("Unable to determine the git remote to compute the app identifier."));const s=n?.identifier||((e,t)=>{if(!e||!t)return;const n=`${e}:${t}`;return c("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(In("Unable to compute the app identifier.")),{identifier:s,name:r}},An=t.green.bold,Mn=t.yellow.bold,Nn=t.cyan.bold,Cn=t.bold,On=(e,t={},n)=>async()=>{const o=await Ee(e,{contentType:"application/zip",filename:he});return V({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,he);const t=L("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},Rn=async(e,t,n)=>{const o=[],r=[];if(!t.apiKey||!t.appKey)return o.push(new Error("Missing authentication token, need both app and api keys.")),{errors:o,warnings:r};if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:r};const i=(s=t.site,a=t.identifier,L("APPS_INTAKE_URL")||`https://api.${s}/${ge}/${a}/upload`);var s,a;const u=U({bundler:t.bundlerName,plugin:"apps",version:t.version}),c=te({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(u,null,2)}`}),p=`an archive of:\n - ${An(e.assets.length.toString())} files\n - ${An(y(e.size))}\n\nWith the configuration:\n${c}`;if(t.dryRun)return n.error(`\n${Nn("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:On(e.archivePath,u,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Mn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}});if(n.debug(`Uploaded ${p}\n`),o.app_builder_id){const e=`https://app.${t.site}/app-builder/apps/${o.app_builder_id}`;n.info(`Your application is available at:\n ${Nn(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${ge}/${t}/release/live`)(t.site,t.identifier);await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:e,method:"PUT",type:"json",getData:async()=>({data:d.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...u}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${Mn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${Cn(o.version_id)} to live.`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));o.push(t)}return{errors:o,warnings:r}},Tn=t.yellow.bold,_n=t.red.bold,Fn="manifest.json";async function Ln(e){const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-manifest-")),n=u.join(t,Fn);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[Re(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await we(t),e}return{manifestAsset:{absolutePath:n,relativePath:Fn},cleanup:()=>we(t)}}const zn=async({backendOutputs:e,backendFunctions:t,context:n,options:o})=>{const i=n.getLogger(me),{auth:a,buildRoot:d,bundler:{name:c,outDir:p},git:f,version:m}=n,h=i.time("handle assets");let y,b,w;try{const n=i.time("resolve identifier"),{name:h,identifier:w}=Pn(d,i,{url:f?.remote,name:o.name,identifier:o.identifier});if(!w||!h)throw new Error("Missing apps identification.\nEither:\n - pass an 'options.apps.identifier' and 'options.apps.name' to your plugin's configuration.\n - have a 'name' and a 'repository' in your 'package.json'.\n - have a valid remote url on your git project.\n");n.end();const v=u.relative(d,p),$=[...o.include,`${v}/**/*`],k=await kn($,d);if(!k.length)return void i.debug("No assets to upload.");const x=new Set(e.values()),E=k.filter((e=>!x.has(e.absolutePath))).map((e=>({...e,relativePath:`frontend/${e.relativePath}`})));for(const[t,n]of e)E.push({absolutePath:n,relativePath:`backend/${t}.js`});const{manifestAsset:S,cleanup:I}=await Ln(t);b=I,E.push(S);const D=i.time("archive assets"),j=await(async e=>{const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-")),n=u.join(t,he),o=new g;for(const t of e)o.file(t.relativePath,s.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=s.createWriteStream(n),i=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});i.on("error",t),r.on("error",t),r.on("close",e),i.pipe(r)}));const{size:i}=await r.stat(n);return{archivePath:n,size:i,assets:e}})(E);D.end(),y=u.dirname(j.archivePath);const P=i.time("upload assets"),{errors:A,warnings:M}=await Rn(j,{apiKey:a.apiKey,appKey:a.appKey,bundlerName:c,dryRun:o.dryRun,identifier:w,name:h,site:a.site,version:m},i);if(P.end(),M.length>0&&i.warn(`${Tn("Warnings while uploading assets:")}\n - ${M.join("\n - ")}`),A.length>0){const e=A.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){w=e,i.error(`${_n("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await we(y),b&&await b(),h.end(),w)throw w};const Bn=u.join(j,"./apps-runtime.mjs"),Kn=({bundler:e,context:t,options:n})=>{const o=t.getLogger(me),{auth:r,buildRoot:s}=t;t.inject({type:"file",position:Ie.MIDDLE,value:Bn});const{setBackendFunctions:a,getBackendFunctions:d}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[ye],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=Ae(this.parse(e),t);if(0===n.length)return o.warn(`Backend file ${t} has no exported functions. Did you forget to add a named export?`),a(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=u.relative(n,t).replace(ye,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:Re(e)})}return{functions:r,proxyCode:Te(i)}}(n,t,s);return a(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let r,a=new Map,c=d();if(c.length>0){const t=await async function(e,t,n,o){const r=await i(u.join(f(),"dd-apps-backend-")),s=new Map,a=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const i of t){const t=Re(i),d=`\0dd-backend:${t}`,c=_e(i.name,i.absolutePath,n),p=ln(i.absolutePath,n),l=mn(n,{[d]:c},[p.plugin]),f=await e({...l,build:{...l.build,write:!0,outDir:r,emptyOutDir:!1,rollupOptions:{...l.build.rollupOptions,input:{[t]:d},output:{...l.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=u.resolve(r,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}a.set(i.absolutePath,p.getAllowedConnectionIds())}return{outDir:r,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:a.get(e.absolutePath)})))}}(e.build,c,s,o);r=t.outDir,a=t.outputs,c=t.functions}try{await zn({backendOutputs:a,backendFunctions:c,context:t,options:n})}finally{r&&await we(r)}},configureServer(t){t.middlewares.use($n(e.build,d,r,s,o))}}},Un=({options:e,context:t,bundler:n})=>{const o=t.getLogger(me),r=(e=>{const t=e[fe]||{};return{include:t.include||[],dryRun:t.dryRun??!L("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim()}})(e);return"vite"!==t.bundler.name?(o.warn(`The apps plugin only supports Vite; skipping under '${t.bundler.name}'.`),[]):[{name:me,enforce:"post",vite:Kn({bundler:n,context:t,options:r})}]},Vn="errorTracking",qn="datadog-error-tracking-plugin",Hn=(e,n,o)=>{if(".map"!==u.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=u.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return u.join(e,t);try{const n=e.replace(/\/*$/,"/"),o=new URL(n),r=t.replace(/^[\\/]*/,"");return new URL(r,o).href}catch{return`${e}${t}`}})(e,i);return{minifiedFilePath:r,minifiedUrl:s,relativePath:i}},Wn=/[/]+|[\\]+/g,Jn=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Gn=(e,t)=>{const n=e.replace(Jn,"").split(Wn),o=t.replace(Jn,"").split(Wn),r=n.join("/");let i="";for(let e=0;e<o.length;e+=1){const t=o.slice(-e).join("/");r.startsWith(t)&&(i=t)}return i},Yn=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([Se(e.minifiedFilePath),Se(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Gn(e.relativePath,t)}})(e,n),i=[],s=[],a=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(o)try{a.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${u.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:o.hash,repository_url:o.remote}],version:1})})}catch(t){s.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&s.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:a,errors:i,warnings:s}},Qn=t.green.bold,Xn=t.yellow.bold,Zn=t.red.bold,eo=(e,t={})=>async()=>V({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await Ee(o.path,o.options):new Blob([o.value],{type:o.options.contentType});t.append(n,e,o.options.filename)}return t},defaultHeaders:t,zip:!0}),to=async(e,t,n,o)=>{const r=[],i=[];if(!n.apiKey)return r.push({error:new Error("No authentication token provided")}),{errors:r,warnings:i};if(0===e.length)return i.push("No sourcemaps to upload"),{errors:r,warnings:i};const s=o.time("Queue uploads"),a=new(b.default?b.default:b)({concurrency:t.maxConcurrency}),u=(d=n.site,L("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${d}/api/v2/srcmap`);var d;const c=U({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=te({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),l=`\nUploading ${Qn(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(l);const f=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};f.push(a.add((async()=>{try{await H({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:eo(s,c),onRetry:(t,n)=>{const r=`Failed to upload ${Xn(e.sourcemap)} | ${Xn(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}return s.end(),o.debug(`Queued ${Qn(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:i,errors:r}},no=async(e,t,n)=>{const o=n.time("get sourcemaps files"),r=((e,t)=>{if(!t.outputs||0===t.outputs.length)throw new Error("No output files found.");return t.outputs.filter((e=>e.filepath.endsWith(".map"))).map((e=>e.filepath)).map((n=>({...Hn(e.minifiedPathPrefix,t.outDir,n),sourcemapFilePath:n,minifiedPathPrefix:e.minifiedPathPrefix})))})(e.sourcemaps,{outDir:t.outDir,outputs:t.outputs});o.end();const i=n.time("send sourcemaps");await(async(e,t,n,o)=>{const r=Date.now(),i=t.minifiedPathPrefix,s={git_repository_url:n.git?.remote,git_commit_sha:n.git?.hash,plugin_version:n.version,project_path:n.outDir,service:t.service,type:"js_sourcemap",version:t.releaseVersion},a=o.time("Compute payloads"),u=await Promise.all(e.map((e=>Yn(e,s,i,n.git))));a.end();const d=u.map((e=>e.errors)).flat(),c=u.map((e=>e.warnings)).flat();if(c.length>0&&o.warn(`Warnings while preparing payloads:\n - ${c.join("\n - ")}`),d.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${d.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const p=o.time("Upload sourcemaps"),{errors:l,warnings:f}=await to(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site},o);if(p.end(),o.debug(`Done uploading ${Qn(`${e.length-l.length}/${e.length}`)} sourcemaps in ${Qn(X(Date.now()-r))}.`),l.length>0){const e=`Failed to upload some sourcemaps:\n - ${l.map((({metadata:e,error:t})=>{const n=t.cause||t.stack||t.message;return e?`${Zn(e.file)} | ${Zn(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,site:t.site,version:t.version},n),i.end()},oo=e=>{const n=t.bold.red,o=e[Vn]||{},r={errors:[]};if(o.sourcemaps){const t=o.sourcemaps,i=t.releaseVersion||e.metadata?.version;i||r.errors.push(`${n("sourcemaps.releaseVersion")} is required (set it directly or via ${n("metadata.version")}).`),t.releaseVersion&&e.metadata?.version&&t.releaseVersion!==e.metadata.version&&r.errors.push(`${n("sourcemaps.releaseVersion")} must match ${n("metadata.version")} when both are configured.`),t.service||r.errors.push(`${n("sourcemaps.service")} is required.`),t.minifiedPathPrefix||r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} is required.`),t.minifiedPathPrefix&&!(e=>{let t;try{t=new URL(e).host}catch{}return!(!t&&!e.startsWith("/"))})(t.minifiedPathPrefix)&&r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} must be a valid URL or start with '/'.`),i&&(r.config={bailOnError:!1,dryRun:!1,maxConcurrency:20,...t,releaseVersion:i})}return r},ro=({options:e,context:t})=>{const n=t.getLogger(qn),o=n.time("validate options"),r=((e,t)=>{const n=[],o=oo(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${qn}.`);return{...e[Vn],sourcemaps:o.config}})(e,n);let i,s;o.end();let a=!1;const u=async()=>{if(!r.sourcemaps||a)return;a=!0;const e=n.time("sourcemaps process");await no(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:i,outDir:t.bundler.outDir,outputs:s?.outputs||[],site:t.auth.site,version:t.version},n),e.end()};return[{name:qn,enforce:"post",async git(e){i=e,s&&await u()},async buildReport(t){s=t,!i&&Q(e)||await u()},async asyncTrueEnd(){a||await u()}}]},io="liveDebugger",so="datadog-live-debugger-plugin",ao="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",uo="__DD_LIVE_DEBUGGER_BUILD__",co=e=>void 0===e?ao:`${ao};if(typeof globalThis.${uo}==='undefined'){globalThis.${uo}={version:${JSON.stringify(e)}}}`;function po(e){return"function"==typeof e?e:e.default}function lo(e,t,n,o,r){const i=u.relative(t,e).replace(/\\/g,"/"),s=fo(n,r);if(s)return`${i};${s}`;const a=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${a}:${o}`}function fo(e,t){const n=e.node,o=e.parent;return"id"in n&&t.isIdentifier(n.id)?n.id.name:t.isObjectMethod(n)||t.isClassMethod(n)||t.isClassPrivateMethod(n)?ho(n.key,t):t.isVariableDeclarator(o)&&t.isIdentifier(o.id)?o.id.name:t.isAssignmentExpression(o)?function(e,t){if(t.isIdentifier(e))return e.name;if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=mo(e.object,t),o=go(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}(o.left,t):t.isObjectProperty(o)||t.isClassProperty(o)||t.isClassPrivateProperty(o)?ho(o.key,t):null}function mo(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=mo(e.object,t),o=go(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function go(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function ho(e,t){return t.isIdentifier(e)?e.name:t.isStringLiteral(e)||t.isNumericLiteral(e)||t.isBigIntLiteral(e)?String(e.value):t.isPrivateName(e)&&t.isIdentifier(e.id)?`#${e.id.name}`:null}function yo(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function bo(e,t,n,o){const r=[];if(t)for(const t of e.params)for(const e of wo(t,o))"this"!==e&&r.push(e);if(n&&o.isBlockStatement(e.body)){const t=new Set(e.params.flatMap((e=>wo(e,o)))),n="id"in e&&o.isIdentifier(e.id)?e.id.name:"";for(const i of e.body.body)if(o.isVariableDeclaration(i))for(const e of i.declarations)for(const i of wo(e.id,o))t.has(i)||i===n||r.push(i)}return r.length>25?r.slice(0,25):r}function wo(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:wo(e.argument,t):t.isAssignmentPattern(e)?wo(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?wo(e.argument,t):wo(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?wo(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const vo=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let $o,ko,xo,Eo,So=!1;function Io(e){try{return function(e){switch(e){case"@babel/parser":return P("@babel/parser");case"@babel/traverse":return P("@babel/traverse");case"@babel/types":return P("@babel/types");case"magic-string":return P("magic-string");default:throw new Error(`Unknown peer dependency: ${e}`)}}(e)}catch(e){throw function(e){if(!function(e){if(!(e instanceof Error))return!1;const t=e.code;if("MODULE_NOT_FOUND"!==t&&"ERR_MODULE_NOT_FOUND"!==t)return!1;return vo.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=vo.find((t=>e.message.includes(t))),n=t??vo.join(", ");return new Error(`Datadog Live Debugger could not load "${n}". It is an optional peer dependency that must be installed in your project when the \`liveDebugger\` plugin is enabled. Install the peer dependencies with: \`npm install --save-dev ${vo.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const Do=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function jo(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,d=0,c=0,p=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:1,skippedUnsupportedCount:c,totalFunctions:p};if(!Do.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};So||($o=Io("@babel/parser").parse,ko=po(Io("@babel/traverse")),xo=Io("@babel/types"),Eo=po(Io("magic-string")),So=!0);const l=$o(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let g=0;if(ko(l,{Function(e){if(p++,!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,xo))return void c++;if(r&&function(e,t,n){let o=e;for(;o;){if(yo(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return yo(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",xo))return void d++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,xo)))return void c++;if(s&&!fo(e,xo))return void c++;let t=0;if(!fo(e,xo)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=lo(n,o,e,t,xo);try{const t=e.node,n=g++,o=`$dd_p${n}`,r=bo(t,!0,!1,xo),i=bo(t,!1,!0,xo),s=xo.isArrowFunctionExpression(t)&&!xo.isBlockStatement(t.body),a=[],d=s||!xo.isBlockStatement(t.body)||!Mo(t.body.body,xo);let c;if(!s&&xo.isBlockStatement(t.body)&&Ao(t.body.body,a,xo),!s&&xo.isBlockStatement(t.body)&&t.body.directives.length>0){c=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,needsTrailingReturn:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:c,functionId:l,probeVarName:o,probeIdx:String(n),entryVars:r,exitVars:i,returns:a}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};const h=new Eo(t);for(let e=f.length-1;e>=0;e--)Po(h,t,f[e]);return{code:h.toString(),map:h.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p}}function Po(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,exitVars:a,returns:u,bodyStart:d,bodyEnd:c,functionEnd:p,isExpressionBody:l,bodyParenStart:f,directivesEnd:m}=n,g=`$dd_e${r}`,h=`$dd_l${r}`,y=`$dd_rv${r}`,b=s.join(", "),w=a.join(", "),v=""!==b,$=""!==w,k=v?`, ${g}()`:"",x=v?$?`, ${g}(), ${h}()`:`, ${g}()`:$?`, undefined, ${h}()`:"",E=`const ${o} = $dd_probes('${i}');`,S=v?`const ${g} = () => ({${b}});`:"",I=$?`const ${h} = () => ({${w}});`:"",D=`if (${o}) $dd_entry(${o}, this${k});`,j=`catch(e) { if (${o}) $dd_throw(${o}, e, this${k}); throw e; }`;if(l){if(null!=f){let n=-1;for(let e=c;e<p;e++)if(")"===t[e]){n=e;break}-1!==n&&(e.remove(f,f+1),e.remove(n,n+1))}const n=["{",E,S,I,"try {",D,`const ${y} = `].filter(Boolean).join("\n"),r=[";",`if (${o}) $dd_return(${o}, ${y}, this${x});`,`return ${y};`,`} ${j}`,"}"].join("\n");c-d>=2?(e.update(d,d+1,n+t[d]),e.update(c-1,c,t[c-1]+r)):e.update(d,c,n+t.slice(d,c)+r)}else{const r=[E,S,"try {",I,`let ${y};`,D].filter(Boolean).join("\n");for(const t of u)null!=t.argStart&&null!=t.argEnd?(e.appendLeft(t.argStart,`(${y} = `),e.appendLeft(t.argEnd,`, ${o} ? $dd_return(${o}, ${y}, this${x}) : ${y})`)):e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, this${x}); `);if(null!=m){const n=m-1;e.update(n,m,`${t[n]}\n${r}`)}else e.update(d,d+1,`${t[d]}${r}`);const i=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, this${x});\n`:""}} ${j}\n`;e.update(c-1,c,`${i}${t[c-1]}`)}}function Ao(e,t,n){for(const o of e)if(n.isReturnStatement(o))t.push({start:o.start,end:o.end,argStart:o.argument?.start??void 0,argEnd:o.argument?.end??void 0});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))Ao(o.body,t,n);else if(n.isIfStatement(o))Ao([o.consequent],t,n),o.alternate&&Ao([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))Ao([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)Ao(e.consequent,t,n);else n.isTryStatement(o)?(Ao(o.block.body,t,n),o.handler&&Ao(o.handler.body.body,t,n),o.finalizer&&Ao(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&Ao([o.body],t,n)}function Mo(e,t){if(0===e.length)return!1;const n=e[e.length-1];if(t.isReturnStatement(n))return!0;if(t.isIfStatement(n)&&n.alternate){const e=t.isBlockStatement(n.consequent)?n.consequent.body:[n.consequent],o=t.isBlockStatement(n.alternate)?n.alternate.body:[n.alternate];return Mo(e,t)&&Mo(o,t)}return!1}const No=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Co=t.bold.red,Oo=Number(process.env.DD_LD_LIMIT)||1/0,Ro=(e,t)=>{const n=t.getLogger(so);let o=0,r=0,i=0,s=0,a=0,u=0,d=0,c=0;return{name:so,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(p,l){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?l.includes(e):e.test(l))))return{code:p}}for(const t of e.exclude){if("string"==typeof t?l.includes(t):t.test(l))return{code:p}}if(c>=Oo)return{code:p};try{const f=jo({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,d+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&c++,0===f.instrumentedCount)return{code:p};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),g=f.map&&m?function(e,t,n,o){try{return w(e,((e,n)=>1===n.depth?t:null))}catch(t){return o.error(`Failed to compose source map for ${n}: ${t}`,{forward:!0}),e}}(f.map,m,l,n):f.map;return{code:f.code,map:g}}catch(e){return n.error(`Instrumentation Error in ${l}: ${e}`,{forward:!0}),{code:p}}}},buildEnd:()=>{d>0&&n.info(`Live Debugger: ${o}/${d} functions instrumented across ${u}/${c} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:c,instrumentedCount:o,totalFunctions:d,transformedFileCount:u}})}}},To=({options:e,context:t})=>{const n=((e,t)=>{const n=e[io]||{},o=e.metadata?.version,r=[];if(void 0!==n.include)if(Array.isArray(n.include)){for(const e of n.include)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Co("include")} patterns must be strings or RegExp`);break}}else r.push(`${Co("include")} must be an array of strings or RegExp`);if(void 0!==n.exclude)if(Array.isArray(n.exclude)){for(const e of n.exclude)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Co("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Co("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Co("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!No.includes(e)){r.push(`${Co("functionTypes")} contains invalid value "${e}". Valid values: ${No.join(", ")}`);break}}else r.push(`${Co("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Co("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${so}.`);return{version:o,include:n.include||[/\.[jt]sx?$/],exclude:n.exclude||[/\/node_modules\//,/\.min\.js$/,/\/pyodide-lib\//,/^vite\//,/\0/,/commonjsHelpers\.js$/,/__vite-browser-external/,/@datadog\/browser-/,/browser-sdk\/packages\//],honorSkipComments:n.honorSkipComments??!0,functionTypes:n.functionTypes,namedOnly:n.namedOnly??!1}})(e,t.getLogger(so));return t.inject({type:"code",position:Ie.BEFORE,injectIntoAllChunks:!0,value:co(n.version)}),[Ro(n,t)]};const _o=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],Fo="metrics",Lo="datadog-metrics-plugin",zo=e=>Math.floor((e||Date.now())/1e3),Bo=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),Ko=(e="")=>e.endsWith("/")?e:`${e}/`,Uo=(e,t)=>{let n=e;return e.split(Ko(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},Vo=(e,t)=>e.split("!").pop().replace(Ko(t),"./"),qo=(e,t,n)=>{let o=e.name||e.userRequest;return o||(o=((e,t)=>{let n=e.userRequest;if(!n){let o;o=t.moduleGraph&&"function"==typeof t.moduleGraph.getIssuer?t.moduleGraph.getIssuer(e):e.issuer,n=o?.userRequest,n||(n=e._identifier?.split("!").pop())}return n||"unknown"})(e,t)),Vo(o||"no-name",n)},Ho=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),Wo=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Jo=t.bold.red,Go=t.bold.cyan,Yo=e=>(t,n)=>{let o,r;return"function"==typeof e?(o=e(t),r=e(n)):(o=t[e],r=n[e]),o>r?-1:o<r?1:0},Qo=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Yo("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:X(e.duration)}))),top:!0};n.sort(Yo("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Xo=(e,t,n)=>{const o=[];var r;n&&(o.push(...Qo("Loader",n.loaders)),o.push(...Qo("Tapable",n.tapables)),o.push(...Qo("Module",n.modules))),o.push(...(e=>{const t={name:"Module total dependents",values:[],top:!0},n={name:"Module total dependencies",values:[],top:!0},o={name:"Module size",values:[],top:!0},r={name:"Module aggregated size",values:[],top:!0},i=new Set,s=Y(e.build),a=new Map,u=new Map,d=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)d.has(n)||d.set(n,new Set),d.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(d.has(e.filepath)){const t=d.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),d.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=d.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const c=Array.from(i);return c.sort(Yo((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort(Yo((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort(Yo("size")),o.values=c.map((e=>({name:e.name,value:y(e.size)}))),c.sort(Yo("aggregatedSize")),r.values=c.map((e=>({name:e.name,value:y(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(Yo((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Yo((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Yo((e=>e.size))).map((e=>({name:e.name,value:e.inputs.length.toString()})))||[],top:!0}])),o.push(...(e=>{const t={name:"General Numbers",values:[],top:!1},n=e.build.inputs?e.build.inputs.length:0,o=e.build.outputs?e.build.outputs.length:0,r=e.build.warnings.length,i=e.build.errors.length,s=e.build.entries?e.build.entries.length:0;return e.build.start&&t.values.push({name:"Overhead duration",value:X(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:X(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:X(e.build.writeDuration)}),t.values.push({name:"Number of modules",value:n.toString()},{name:"Number of assets",value:o.toString()},{name:"Number of entries",value:s.toString()},{name:"Number of warnings",value:r.toString()},{name:"Number of errors",value:i.toString()}),[t]})(e));const i=(e=>{let t="";for(const t of e){t.top&&t.values.length>=5&&(t.values=t.values.slice(0,5),t.name=`Top 5 ${t.name}`);for(const e of t.values)e.name=Z(e.name,60)}const n=Math.max(...e.map((e=>e.name.length))),o=Math.max(...e.flatMap((e=>e.values.map((e=>e.name.length))))),r=Math.max(...e.flatMap((e=>e.values.map((e=>e.value.length))))),i=Math.max(n+4,o+r+4);for(const n of e){if(0===n.values.length)continue;const e=i-(n.name.length+4);t+=`\n== ${n.name} ${"=".repeat(e)}=\n`;for(const e of n.values){const n=r-e.value.length;t+=` [${Jo(e.value)}] ${" ".repeat(n)}${Go(e.name)}\n`}}return t})(o);t.info(i)},Zo="api/v1/series",er=t.bold.green,tr=["onStart","onLoad","onResolve","onEnd"],nr=new Map,or=new Map,rr=new Map,ir=(e,t,n)=>{const o=Object.assign({},e);for(const r of tr)o[r]=async(o,i)=>{const s=or.get(t)||{name:t,increment:0,duration:0,events:{}};s.events[r]=s.events[r]||{name:r,values:[]};const a="onLoad"===r;return(0,e[r])(o,(async(...e)=>{const o=Vo(e[0].path,n),u=rr.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const d=v.now();try{return await i(...e)}finally{const n=v.now(),i=n-d,c={start:d,end:n,duration:i,context:Wo(e)};if(s.events[r].values.push(c),s.duration+=i,s.increment+=1,or.set(t,s),u.events[r].values.push(c),u.duration+=i,u.increment+=1,rr.set(o,u),a){const e=nr.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(c),e.duration+=i,e.increment+=1,nr.set(t,e)}}}))};return o},sr=(e,t)=>({setup:n=>{n.initialOptions.metafile=!0;const o=t.time("wrapping plugins");((e,t)=>{const n=e.initialOptions.plugins;if(n){const e=n.map((e=>({...e})));for(const o of n){const n=o.setup;o.setup=async r=>{const i=ir(r,o.name,t);await n({...i,initialOptions:{...i.initialOptions,plugins:e}})}}}})(n,e.buildRoot),o.end(),n.onEnd((async n=>{if(!n.metafile)return void t.warn("Missing metafile, can't proceed with modules data.");const o=t.time("getting plugins results"),{plugins:r,loaders:i,modules:s}={plugins:or,modules:rr,loaders:nr};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class ar{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=qo(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Ho))(e);o.length||o.push("no-loader"),this.started[n]={module:Uo(n),timings:{start:v.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=qo(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=v.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},i=n.loaders.join(",");r.events[i]=r.events[i]||{name:i,values:[]},r.events[i].values.push(n.timings),r.increment+=1,r.duration+=o,t.set(n.module,r);for(const t of n.loaders){const n=e.get(t)||{name:t,increment:0,duration:0,events:{}};n.increment+=1,n.duration+=o,e.set(t,n)}}return{loaders:e,modules:t}}}class ur{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,r,i){const s=this.timings.get(t)||{name:t,duration:0,increment:0,events:{}};s.events[n]||(s.events[n]={name:n,values:[]}),s.events[n].values.push({start:r,end:i,duration:i-r,context:o,type:e}),s.duration+=i-r,s.increment+=1,this.timings.set(t,s)}getResults(){const e=this.timings;for(const[t,n]of this.timings){const o=n;o.duration=Object.values(n.events).map((e=>e.values.reduce(((e,t)=>e+t.end-t.start),0))).reduce(((e,t)=>e+t),0),e.set(t,o)}return{monitoredTaps:this.monitoredTaps,tapables:this.tapables,hooks:this.hooks,timings:e}}getPromiseTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,Wo(r),i,v.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,Wo(r),i,v.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r);return this.saveResult(e,n,o,Wo(r),i,v.now()),s}}getTapPatch(e,t,n,o){switch(e){case"promise":return this.getPromiseTapPatch(e,t,n,o);case"async":return this.getAsyncTapPatch(e,t,n,o);default:return this.getDefaultTapPatch(e,t,n,o)}}newTap(e,t,n,o){return(r,i)=>{const s="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${s}`;if(this.monitoredTaps[u])return n.call(o,r,i);this.monitoredTaps[u]=!0;const d=this.getTapPatch(e,i,s,t);return n.call(o,r,d)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(Lo)||(this.hooks[e]||(this.hooks[e]=[]),this.hooks[e].includes(t)||(this.hooks[e].push(t),this.replaceTaps(t,n)))}patchHooks(e){const t=e.constructor.name,n=Object.keys(e.hooks).filter((e=>!this.ignoredHooks.includes(e)&&!this.hooks[t]?.includes(e)));for(const o of n)this.patchHook(t,o,e.hooks[o])}checkNewHooks(){for(const e of this.tapables)this.patchHooks(e)}throughHooks(e){this.tapables.includes(e)||this.tapables.push(e),this.patchHooks(e)}}const dr=e=>async t=>{const n=e.getLogger(Lo),o={name:Lo},r=new ur(e.buildRoot),i=new ar(e.buildRoot),s=n.time("parse compiler hooks");r.throughHooks(t),s.end(),t.hooks.thisCompilation.tap(o,(e=>{const t=n.time("parse compilation hooks");r.throughHooks(e),t.end(),e.hooks.buildModule.tap(o,(t=>{i.startModule(t,e)})),e.hooks.succeedModule.tap(o,(t=>{i.doneModule(t,e)})),e.hooks.failedModule&&e.hooks.failedModule.tap(o,(t=>{i.doneModule(t,e)}))})),t.hooks.afterEmit.tapPromise(o,(async()=>{const{timings:t}=r.getResults(),{loaders:n,modules:o}=i.getResults();await e.asyncHook("timings",{tapables:t,loaders:n,modules:o})}))},cr={filters:_o},pr=({options:e,context:t})=>{const n=t.getLogger(Lo);let o=0;const r=((e,t)=>{const n=e[Fo],o=zo(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enableDefaultPrefix:!0,enableTracing:!1,filters:_o,tags:[],...e[Fo],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),i=[],s={name:Lo,enforce:"pre",esbuild:sr(t,n),webpack:dr(t),rspack:dr(t)},a=n.time("build",{start:!1}),u=r.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,c;const p=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-o;const e=n.time("aggregating metrics"),i=r.timestamp,s=n.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,d=new Map,c=new Map,p=new Map;for(const e of i){for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");p.has(n)||p.set(n,[]),p.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`entryName:${e}`))),c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");p.has(r)&&o.push(...p.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of i){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(c,i);s.end();const u=n.time("aggregate plugins metrics"),p=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"plugins.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values()){let e=0,r=0;for(const i of Object.values(o.events)){let s=0;r+=i.values.length;for(const t of i.values){const n=t.end-t.start;s+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,s]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,i.values.length]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(d?.tapables,i);u.end();const l=n.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(d?.loaders,i);l.end();const m=((e,t,n,o,r)=>{const i=new Set;for(const t of e){let e={...t,toSend:!0};if(n?.length)for(const t of n){const n=t({metric:e.metric,type:e.type,points:e.points,tags:e.tags});n?e={...n,toSend:e.toSend}:e.toSend=!1}i.add(Bo(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Bo({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i})(new Set([...a,...p,...f]),i,r.filters,r.tags,r.prefix);await t.asyncHook("metrics",m),e.end();const g=n.time("outputing report");Xo(t,n,d),g.end();const h=n.time("sending metrics to Datadog");await((e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.debug("No metrics to send.");const o=Array.from(e).filter((e=>e.toSend)).map((e=>({...e,toSend:void 0}))),r=new Map;for(const e of o)r.has(e.metric)||r.set(e.metric,0),r.set(e.metric,r.get(e.metric)+1);const i=Array.from(r.entries()).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>`${e} - ${t}`));n.debug(`\nSending ${o.length} metrics with configuration:\n - intake: ${er(`https://api.${t.site}/${Zo}`)}\n\nMetrics:\n - ${i.join("\n - ")}`);const s=[];for(let e=0;e<o.length;e+=500)s.push(o.slice(e,e+500));return s.length>1&&n.debug(`Sending metrics in ${s.length} batches of up to 500.`),Promise.all(s.map((e=>H({method:"POST",url:`https://api.${t.site}/${Zo}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:e})})})))).catch((e=>{n.error(`Error sending metrics ${e}`)}))})(m,{apiKey:t.auth.apiKey,site:t.auth.site},n),h.end()},l={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){a.resume(),t.build.start=t.build.start||Date.now(),e[Fo]?.timestamp||(r.timestamp=zo(t.build.start))},buildEnd(){a.end(),o=Date.now()},async timings(e){d=e,c&&await p()},async buildReport(e){c=e,!d&&u||await p()}};return r.enableTracing&&i.push(s),i.push(l),i},lr="output",fr="datadog-output-plugin",mr=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,gr=e=>{const t=void 0===e;return{build:mr("build",e?.build??t),bundler:mr("bundler",e?.bundler??t),dependencies:mr("dependencies",e?.dependencies??t),errors:mr("errors",e?.errors??t),logs:mr("logs",e?.logs??t),metrics:mr("metrics",e?.metrics??t),timings:mr("timings",e?.timings??t),warnings:mr("warnings",e?.warnings??t)}},hr=(e,t)=>n=>{n.hooks.done.tap("bundler-outputs",(n=>{t((()=>{const t=e.time("stats serialization"),o=n.toJson({all:!1,assets:!0,children:!0,chunks:!0,chunkGroupAuxiliary:!0,chunkGroupChildren:!0,chunkGroups:!0,chunkRelations:!0,entrypoints:!0,errors:!0,ids:!0,modules:!0,nestedModules:!0,relatedAssets:!0,warnings:!0,reasons:!1,chunkModules:!1});return t.end(),o}))}))},yr=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},br=({options:e,context:t})=>{const n=t.getLogger(fr),o=(e=>({path:"./",...e[lr],files:gr(e[lr]?.files)}))(e),r=(e,r)=>{const i=o.files[e];if(!r||!1===i)return;t.queue((async()=>{const e=n.time(`output ${i}`),d=((e,t,n)=>{const o=u.isAbsolute(t)?t:u.resolve(e,t);return u.resolve(o,n)})(t.bundler.outDir,o.path,i);let c;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await ve(u.dirname(e));const n=s.createWriteStream(e),o=new a(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(d,e)}catch(e){c=e}c?n.error(`Failed writing ${i}: ${c}`):n.debug(`Wrote "./${u.relative(t.buildRoot,d)}"`),e.end()})())};return[{name:fr,buildReport(e){const t=n.time("serialize report"),o=Y(e);t.end(),r("build",{bundler:o.bundler,metadata:o.metadata,start:o.start,end:o.end,duration:o.duration,writeDuration:o.writeDuration,entries:o.entries,outputs:o.outputs}),r("logs",o.logs),r("timings",o.timings),r("dependencies",o.inputs),r("errors",o.errors),r("warnings",o.warnings)},metrics(e){r("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{r("bundler",e.metafile)}))}},rspack:hr(n,(e=>{r("bundler",e)})),rollup:yr((e=>{r("bundler",e)})),vite:yr((e=>{r("bundler",e)})),webpack:hr(n,(e=>{r("bundler",e)}))}]},wr="rum",vr="datadog-rum-plugin",$r=e=>`(function(c,n){try{if(typeof window==='undefined')return;var w=window,m=w[n]=w[n]||{},s=new Error().stack;s&&(m[s]=c)}catch(e){}})(${JSON.stringify(e)},${JSON.stringify("DD_SOURCE_CODE_CONTEXT")});`,kr="datadog-rum-privacy-plugin";const xr=(e,t)=>{const n=t.getLogger(kr),o=function(e,t){const n={privacy:{addToDictionaryHelper:{expression:{code:e}}}};return["esbuild","webpack","rspack"].includes(t)&&(n.output={...n.output,inlineSourceMap:!1,embedCodeInSourceMap:!0}),n}(e.helperCodeExpression,t.bundler.name);let r=0,i=0;return{name:kr,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(e,t){try{const n=function(e){if("rspack"===e?.framework||"webpack"===e?.framework)switch(typeof e.inputSourceMap){case"undefined":return;case"string":return e.inputSourceMap;default:return JSON.stringify(e.inputSourceMap)}}(this.getNativeBuildContext?.()),s=$({id:t,code:e,map:n},o);return 0===s.privacyDictionarySize?{code:e}:(r+=s.privacyDictionarySize,i++,s)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${r} entries across ${i} files`,{forward:!0,context:{dictionaryEntryCount:r,fileCount:i}})}}},Er=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Sr=(e,t)=>{const n=e.sdk;if(n.clientToken)return Er(e);if(!t.auth.apiKey||!t.auth.appKey)throw new Error('Missing "auth.apiKey" and/or "auth.appKey" to fetch "rum.sdk.clientToken".');return async()=>{let o;try{const e=await H({url:`https://api.${t.auth.site}/api/v2/rum/applications/${n.applicationId}`,type:"json",auth:t.auth});o=e.data?.attributes?.client_token}catch(e){throw new Error(`Could not fetch the clientToken: ${e.message}`)}if(!o)throw new Error("Missing clientToken in the API response.");return Er({...e,sdk:{clientToken:o,...n}})}},Ir=e=>{const n=t.bold.red,o=e[wr]||{},r={errors:[]};if(!o.sdk)return r;o.sdk.applicationId||r.errors.push(`Missing ${n("applicationId")} in the SDK configuration.`),e.auth.apiKey&&e.auth.appKey||o.sdk.clientToken||r.errors.push(`Missing ${n('"auth.apiKey"')} and/or ${n('"auth.appKey"')} to fetch missing client token.`);const i={applicationId:"unknown_application_id",allowUntrustedEvents:!1,compressIntakeRequests:!1,defaultPrivacyLevel:"mask",enablePrivacyForActionName:!1,sessionReplaySampleRate:0,sessionSampleRate:100,silentMultipleInit:!1,site:e.auth.site||"datadoghq.com",startSessionReplayRecordingManually:!1,storeContextsAcrossPages:!1,telemetrySampleRate:20,traceSampleRate:100,trackingConsent:"granted",trackLongTasks:!1,trackResources:!1,trackUserInteractions:!1,trackViewsManually:!1};return r.config={...i,...o.sdk},r},Dr=e=>{const t=e[wr]||{},n={errors:[]};if(t.privacy){const e={exclude:[/\/node_modules\//,/\.preval\./,/^[!@#$%^&*()=+~`-]/],include:[/\.(?:c|m)?(?:j|t)sx?$/],addToDictionaryFunctionName:"$",helperCodeExpression:"/*__PURE__*/((q='$DD_A_Q',g=globalThis)=>(g[q]=g[q]||[],(v=>(g[q].push(v),v))))()"};n.config={...e,...t.privacy}}return n},jr=e=>{const n=t.bold.red,o=e[wr]||{},r={errors:[]};if(!o.sourceCodeContext)return r;const i=o.sourceCodeContext;return i?.service&&"string"==typeof i.service||r.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),r.config={...i,version:i.version||e.metadata?.version},r},Pr=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=Ir(e),r=Dr(e),i=jr(e);if(n.push(...o.errors),n.push(...r.errors),n.push(...i.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${vr}.`);const s={...e[wr],sdk:void 0,privacy:void 0,sourceCodeContext:void 0};return o.config&&(s.sdk=o.config),r.config&&(s.privacy=r.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(s.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),i.config&&(s.sourceCodeContext=i.config),s})(e,t.getLogger(vr)),o=[];if(n.sourceCodeContext&&t.inject({type:"code",position:Ie.BEFORE,injectIntoAllChunks:!0,value:$r(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:Ie.MIDDLE,value:u.join(j,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Ie.MIDDLE,value:Sr(n,t)})),n.privacy){t.inject({type:"file",position:Ie.BEFORE,value:u.join(j,"./privacy-helpers.js")});const e=xr(n.privacy,t);o.push(e)}return o},Ar="datadog-analytics-plugin",Mr=({context:e})=>{const t=e.getLogger(Ar);return[{name:Ar,async buildStart(){"production"===e.env&&e.queue((async()=>{try{await e.sendLog({message:"Build started",context:{plugins:e.pluginNames}})}catch(e){t.debug(`Could not submit data to Datadog: ${e}`)}})())}}]},Nr="datadog-async-queue-plugin",Cr=e=>{const{context:t,stores:n}=e,o=t.getLogger(Nr),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:Nr,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Or=async(e,t,n)=>{const o=[],r=e.initialOptions.entryPoints,i=[],s=[];if(Array.isArray(r))for(const e of r){const t=e&&"object"==typeof e?e.in:e;i.push({path:t})}else r&&"object"==typeof r&&i.push(...Object.entries(r).map((([e,t])=>({name:e,path:t}))));const a=i.flatMap((e=>{return(t=e.path,t.includes("*")?h.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const i=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});i.errors.length&&s.push(...i.errors.map((e=>e.text))),i.path&&o.push({name:n.name,resolved:i.path,original:n.path})}));for(const e of s)n.error(e);return await Promise.all(a),o},Rr=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Tr=/(\?|%3F|\|)+/gi,_r=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=zr(e),Rr.lastIndex=0,Rr.exec(t)?.[1]||"unknown");var t},Fr=["unknown","commonjsHelpers.js",`vite${u.sep}preload-helper.js`],Lr=(e,t,n)=>{const o=new Set;for(const n of e){const e=zr(n);G(n)||e===t||Fr.includes(e)||o.add(e)}return o},zr=e=>e.split("!").pop().split(Tr).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Br=(e,t)=>G(t)?A:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(u.sep),o=e.split(u.sep).filter(((e,t)=>e===n[t])).join(u.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(Tr).shift().replace(/^((\.\.?)?[/\\])+/g,""),Kr=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[xn(t,e),n]))),Ur=(e,t)=>({setup(n){const o=new Map;let r=[];const i=t.time("build report",{start:!1});n.onStart((async()=>{o.clear(),r=[],i.resume();const s=t.time("process entries");r.push(...await Or(n,e,t));for(const t of r){const n=Br(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}s.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),s=e.bundler.outDir,a=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const d=[],c=[],p=[],l=[],f=[],m={},g={},h=t.time("indexing metafile data"),y=Kr(n.metafile.inputs,a),b=Kr(n.metafile.outputs,a);h.end();const w=e=>{if(!G(e))return e;const t=y[xn(a,e)];if(!t)return e;const n=t.imports.find((e=>!G(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(G(e))continue;const n=xn(a,e),o={name:Br(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:_r(e)};m[n]=o,d.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=xn(a,e),i=Br(s,n),u=[];for(const e of Object.keys(r.inputs)){if(G(e))continue;const n=m[xn(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!u.length){const e=m[xn(a,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}u.push(e)}const d={name:i,filepath:n,inputs:u,size:r.bytes,type:_r(n)};if(g[n]=d,"map"===d.type&&l.push(d),c.push(d),!r.entryPoint)continue;const f=m[xn(a,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...d,name:o.get(f.name)||f.name,outputs:[d],size:d.size};p.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of l){const n=g[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:g,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!G(e)&&!e.match(E),I=(e,n,o={})=>{if(!S(e))return o;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),o;if(o[r.filepath])return o;o[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),o;if(!i.imports||!i.imports.length)return o;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),c=i?u.dirname(e):a,p=xn(c,t.path);if(t.external){if(S(t.path)){const e=i?p:t.path,n=x.inputs.report[e]||{filepath:e,name:Br(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),d.includes(n)||d.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(p,n,o)}return o},D=t.time("looping through entries");for(const e of p){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const j=t.time("aggregate dependencies and dependents");for(const e of d){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?u.dirname(e.filepath):a,i=xn(r,o.path);let s;if(o.external){const e=n?i:o.path;s=x.inputs.report[e]}else s=x.inputs.report[i];s?(e.dependencies.add(s),s.dependents.add(e)):t.debug(`Could not find input file of ${o.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}j.end(),e.build.outputs=c,e.build.inputs=d,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),Vr=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),i=t.time("filling inputs and outputs",{start:!1}),a=t.time("completing dependencies and dependents",{start:!1}),u=t.time("filling dependencies and dependents",{start:!1}),d=t.time("filling sourcemaps inputs",{start:!1}),c=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),c.clear(),p.clear(),l.clear()},onLog(t,n){"warn"===t&&e.build.warnings.push(n.message||n.toString())},renderError(t){t&&e.build.errors.push(t.message)},moduleParsed(e){n.resume();const t=zr(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=Lr(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=Lr(new Set([...e.dynamicImporters,...e.importers]),t);for(const e of i)o.dependents.add(e);for(const e of r)o.dependencies.add(e);f.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,m){o.resume();const g=n.dir?xn(e.buildRoot,n.dir):e.bundler.outDir,h=new Set,y=new Set,b=new Map;a.resume();for(const[e,{dependencies:t,dependents:n}]of f){for(const n of t){const t=zr(n),o=f.get(t)||{dependencies:new Set,dependents:new Set};o.dependents.has(e)||(o.dependents.add(e),f.set(t,o))}for(const t of n){const n=zr(t),o=f.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),f.set(n,o))}}a.end(),i.resume();for(const[e,n]of Object.entries(m)){const o=xn(g,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),i=p.get(o)||{name:e,filepath:o,inputs:[],size:r,type:_r(e)};if("map"===i.type&&y.add(i),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(zr(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=s.statSync(e).size}catch(e){n=t.renderedLength}const o=c.get(e)||{name:Br(g,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:_r(e)};i.inputs.push(o),c.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=zr(e);if(!f.has(n)){b.set(xn(g,n),i);continue}if(c.has(n)){t.debug(`Input report already there for ${n} from ${i.name}.`);continue}const o=c.get(n)||{name:Br(g,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};i.inputs.push(o),c.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&h.add({...i,name:n.name,size:0,outputs:[i]}),p.set(i.filepath,i)}i.end();for(const[e,n]of b){const o=p.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of c){const o=f.get(e);if(o){for(const e of o.dependencies){const o=c.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Br(g,e)} of ${n.name}`)}for(const e of o.dependents){const o=c.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Br(g,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){d.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=p.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}d.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Br(g,e),r=p.get(e);if(!r)return c.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[Br(g,e)];if(!i)return t.debug(`Could not find asset for ${o}`),n;const s=[];"imports"in i&&s.push(...i.imports),"dynamicImports"in i&&s.push(...i.dynamicImports);for(const e of s)w(xn(g,e),n);return n};r.resume();for(const e of h){const n=w(e.filepath);e.outputs=Array.from(n.values()),e.inputs=Array.from(new Set(e.outputs.flatMap((e=>e.inputs)))),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),l.has(e.filepath)&&t.debug(`Entry "${e.name}":"${Br(g,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(c.values()),e.build.outputs=Array.from(p.values()),e.build.entries=Array.from(l.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},qr=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,d=new Map,c=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||G(e)),g=e=>e.replace(/(^external[^"]+"|"$)/g,""),h=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=zr(e);t.add(n),n.startsWith("external ")&&t.add(g(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(c.has(e)){const n=c.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else c.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=zr(t.request);if(c.has(n))return c.get(n);if(e.context){const t=xn(zr(e.context),n);if(c.has(t))return c.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],i=[],s=[],a.clear(),u.clear(),c.clear(),l.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),i=n.time("indexing modules");for(const e of t)h(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Br(e.bundler.outDir,t),i=new Set(y(n).map((e=>{const o=b(n,e);if(!o?.identifier())return!1;const r=o.identifier();return!!m(r)&&(r!==t&&(w(o)?g(r):r))})).filter(Boolean));if(!m(t))continue;const s=l.get(t)||{dependents:new Set,dependencies:new Set};for(const e of i){const n=l.get(e)||{dependencies:new Set,dependents:new Set};n.dependents.add(t),s.dependencies.add(e),l.set(e,n)}l.set(t,s);const u=w(n)?{size:0,name:g(o),dependencies:new Set,dependents:new Set,filepath:t,type:"external"}:{size:n.size()||0,name:o,dependencies:new Set,dependents:new Set,filepath:t,type:_r(t)};r.push(u),a.set(t,u),w(n)&&a.set(g(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=l.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,c=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>xn(e.bundler.outDir,t))),g=n.time("indexing chunks"),h=t.chunkGraph;for(const e of o){const t=l(e),n=(h?.getChunkModules(e)||[]).flatMap((e=>"modules"in e&&Array.isArray(e.modules)?e.modules.map((e=>e.identifier())):e.identifier())).filter(m);for(const e of t){if("map"===_r(e))continue;const t=d.get(e)||new Set;for(const e of n)t.add(e);d.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of c){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:xn(e.bundler.outDir,t.name),type:_r(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){p.push(o);continue}const r=d.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of p){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return new Set;t.add(e);const n=new Set(e.chunks);for(const o of e.childrenIterable||[]){const e=v(o,t);for(const t of e)n.add(t)}return n};for(const[o,r]of t.entrypoints){const t=new Map,i=new Map;let a=0;const d=v(r),c=Array.from(d).flatMap(l),p=r.chunks.filter((e=>h.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===_r(e)));for(const e of c){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)i.has(e.filepath)||i.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:p?xn(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:p?_r(p):"unknown"};s.push(f)}w.end();for(const n of t.errors)e.build.errors.push(n.message);for(const n of t.warnings)e.build.warnings.push(n.message);e.build.inputs=r,e.build.outputs=i,e.build.entries=s,f.end(),await e.asyncHook("buildReport",e.build)}))},Hr="datadog-build-report-plugin",Wr=e=>{const{context:t}=e,n=t.getLogger(Hr);return[{name:Hr,enforce:"post",esbuild:Ur(t,n),rspack:qr(t,Hr,n),webpack:qr(t,Hr,n),vite:Vr(t,n),rollup:Vr(t,n)}]},Jr="datadog-bundler-report-plugin",Gr=(e,t)=>t?u.isAbsolute(t)?t:u.resolve(e,t):"",Yr=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?u.dirname(e.file):void 0)).filter(Boolean)},Qr=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Gr(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Xr=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Yr(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=Sn(r,process.cwd())),e.bundler.outDir=Gr(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Zr=e=>{const{context:t}=e,n=t.getLogger(Jr);return[{name:Jr,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Gr(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Gr(t.buildRoot,u.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Qr(t),rspack:Qr(t),vite:Xr(t),rollup:{options(e){let n;if("output"in e){const t=Yr(e.output);n=Sn(t,process.cwd())}const o=(e=>{const t=new Set;if(e.input){const n=Array.isArray(e.input)?e.input:"object"==typeof e.input?Object.values(e.input):[e.input];for(const e of n){if("string"!=typeof e)throw new Error("Invalid input type");t.add(u.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=xn(process.cwd(),n);const e=Sn([n,...o],process.cwd());t.buildRoot=e===u.sep?process.cwd():e}else t.buildRoot=Sn(o,process.cwd()),t.bundler.outDir=u.resolve(process.cwd(),"dist");t.hook("buildRoot",t.buildRoot)},buildStart(e){t.bundler.rawConfig=e},renderStart(e){t.bundler.rawConfig.outputs=t.bundler.rawConfig.outputs||[],t.bundler.rawConfig.outputs.push(e),t.hook("bundlerReport",t.bundler);const o=Yr(e);Sn(o,process.cwd()).startsWith(t.bundler.outDir)||n.warn("The output directory has been changed by a plugin and may introduce some inconsistencies in the build report.")}}}]},ei="datadog-custom-hooks-plugin",ti=e=>{const{context:t}=e,n=t.getLogger(ei),o=e=>(o,...r)=>{const i=n.time(`execution | ${o}`,{tags:["type:custom-hook",`hook:${o}`]}),s=[],a=[];for(const n of t.plugins){if(!(o in n))continue;const t=n[o];if("function"==typeof t)try{const i=t(...r);i instanceof Promise&&(e||s.push(`Plugin "${n.name}" returned a promise on the non async hook "${o}".`),a.push(i))}catch(e){s.push(`Plugin "${n.name}" errored on hook "${o}". [${e}]`)}else s.push(`Plugin "${n.name}" has an invalid hook type for "${o}". [${typeof t}]`)}if(s.length>0){for(const e of s)n.error(e);throw new Error("Some plugins errored during the hook execution.")}return Promise.all(a).finally((()=>i.end()))};return t.hook=o(!1),t.asyncHook=o(!0),[{name:ei,enforce:"pre"}]};class ni{constructor(e){this.trackedFilenames=new Map;for(const t of e){const e=this.getFilename(t),n=this.trackedFilenames.get(e);n?n.push(t):this.trackedFilenames.set(e,new Array(t))}}displaySource(e){return e.length<=40?e:`[...]${e.slice(-35)}`}matchSourcemap(e,t){const n=ke(e),o=JSON.parse(n);if(!o.sources)return void t("Missing 'sources' field in sourcemap.");const r=o.sources;if(0===r.length)return void t("Empty 'sources' field in sourcemap.");const i=this.matchSources(r);if(0!==i.length)return i;t(`${r.map(this.displaySource).join(", ")} not in the tracked files.`)}matchSources(e){let t=[];const n=new Set;for(const o of e){const e=this.getFilename(o);if(n.has(e))continue;n.add(e);const r=this.trackedFilenames.get(e);r&&(t=t.concat(r))}return t}rawTrackedFilesList(){let e=[];return this.trackedFilenames.forEach((t=>{e=e.concat(t)})),e}getFilename(e){let t=e.lastIndexOf("/");-1===t?t=0:t++;let n=e.lastIndexOf("?");return(-1===n||n<=t)&&(n=e.length),e.substring(t,n)}}const oi=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await ri(e);for(const e of t)if(e.name===n)return ee(e.refs.push);return ee(t[0].refs.push)},ri=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},ii=async e=>e.revparse("HEAD"),si=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),ai=async e=>e.branch(),ui=async e=>e.show(["-s","--format=%s"]),di=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),ci="datadog-git-plugin",pi=e=>{const{options:t,context:n}=e,o=n.getLogger(ci),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t=[ii(e),ai(e),ui(e),di(e),si(e),oi(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,d,c,p,l,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:d,date:c},committer:{name:p,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new ni(s)}})(await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=k(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return k(t)})(u.dirname(e)));n.git=t,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:ci,enforce:"pre",buildRoot(e){if(Q(t))try{r.resume();const t=En(e,".git");if(!t)return o.warn("No .git directory found, skipping git plugin."),void r.end();n.queue(i(t))}catch(e){o.error(`Could not get git information: ${e.message}`)}}}]},li="datadog-injection-plugin",fi=/^https?:\/\//,mi=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],gi=t.bold.yellow,hi=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(xn(t,e)),yi=async(e,t,n=process.cwd())=>{let o;const r=await(async e=>"function"==typeof e.value?e.value():e.value)(e);try{if("file"===e.type)o=r.match(fi)?await(async(e,t=5e3)=>{let n;return Promise.race([H({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await hi(r,n);else{if("code"!==e.type)throw new Error(`Invalid item type "${e.type}", only accepts "code" or "file".`);o=r}}catch(i){const s=`${e.type} - ${Z(r)}`;e.fallback?(t.debug(`Fallback for "${s}": ${i.toString()}`),o=await yi(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},bi=(e,t)=>{const n=e.filter((e=>e.position===t.position&&(!t.onAllChunks||e.injectIntoAllChunks)));if(0===n.length)return"";return`// begin injection by Datadog build plugins\n${n.map((e=>`(() => {${e.value}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},wi=async(e,t,n,o=process.cwd())=>{const r=await(async(e,t,n=process.cwd())=>{const o=new Map;for(const[r,i]of e.entries()){const e=await yi(i,t,n);if(e){const t=i.position||Ie.BEFORE;o.set(r,{value:e,injectIntoAllChunks:"injectIntoAllChunks"in i&&i.injectIntoAllChunks,position:t})}}return o})(t,e,o);for(const e of r.values())n.push(e)},vi=e=>e instanceof Error&&"code"in e,$i=e=>mi.includes(e),ki=(e,t,n)=>{e.warn(`"${gi(t)}" files are not supported (${gi(n)}).`)},xi=s.promises,Ei=(e,t,n)=>({setup(o){const{onStart:i,onResolve:a,onLoad:d,onEnd:c,esbuild:p,initialOptions:f}=o,m=[],g=`${t.bundler.name}.${Ie.MIDDLE}.${A}.js`,h=s.realpathSync(l.tmpdir()),y=u.resolve(h,g),b=new RegExp(`${g}$`),w=f.inject;f.inject=w?[...w]:[],f.inject.push(y),i((async()=>{m.push(...await Or(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await ve(u.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),a({filter:b},(async e=>({path:e.path,namespace:li}))),d({filter:b,namespace:li},(async()=>({contents:bi(n,{position:Ie.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),c((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=bi(n,{position:Ie.BEFORE}),i=bi(n,{position:Ie.AFTER}),s=bi(n,{position:Ie.BEFORE,onAllChunks:!0}),a=bi(n,{position:Ie.AFTER,onAllChunks:!0});if(!(r||i||s||a))return;const d=[];for(const[n,c]of Object.entries(o.metafile.outputs)){const o=c.entryPoint&&m.some((e=>e.resolved.endsWith(c.entryPoint))),l=o?r:s,f=o?i:a;if(!l&&!f)continue;const g=xn(t.buildRoot,n),{base:h,ext:y}=u.parse(g);$i(y)?d.push((async()=>{try{const e=await xi.readFile(g,"utf-8"),t=await p.transform(e,{loader:"default",banner:l,footer:f});await xi.writeFile(g,t.code)}catch(t){if(!vi(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${g}: ${t}`)}})()):ki(e,y,h)}await Promise.all(d)}))}}),Si=A,Ii="?inject-proxy",Di=(e,t)=>({banner(n){const o=bi(t,{position:Ie.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return $i(i)?o:(ki(e,i,r),"")},async resolveId(e,n,o){if(G(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&bi(t,{position:Ie.MIDDLE})){if(e.endsWith(".html"))return null;const t=await this.resolve(e,n,o);if(!t||t.external)return t;return(await this.load(t)).moduleSideEffects=!0,`${t.id}${Ii}`}return null},load(e){if(G(e))return bi(t,{position:Ie.MIDDLE});if(e.endsWith(Ii)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(Si)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=bi(t,{position:Ie.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return $i(i)?o:(ki(e,i,r),"")}}),ji=(e,t,n,o,r)=>i=>{const a=new WeakMap,d=e.sources.ConcatSource,c=n.bundler.name,p=u.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${c}.${Ie.MIDDLE}.${A}.js`);$e(p,"");i.hooks.shutdown.tap(li,(()=>{var e;e=p,s.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await wi(t,o,r,n.buildRoot)};i.hooks.beforeRun.tapPromise(li,l),i.hooks.watchRun.tapPromise(li,l),i.hooks.compilation.tap(li,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:li,stage:o},(()=>{const e=bi(r,{position:Ie.BEFORE}),o=bi(r,{position:Ie.AFTER}),i=bi(r,{position:Ie.BEFORE,onAllChunks:!0}),s=bi(r,{position:Ie.AFTER,onAllChunks:!0});for(const r of n.chunks){let c=e,p=o;if(r.canBeInitial()||(c=i,p=s),""!==c||""!==p)for(const e of r.files){const{base:o,ext:r}=u.parse(e);$i(r)?n.updateAsset(e,(e=>{const t=a.get(e);if(!t||t.banner!==c||t.footer!==p){const t=new d(c,"\n",e,"\n",p);return a.set(e,{source:t,banner:c,footer:p}),t}return t.source})):ki(t,r,o)}}}))}));const f=(e=>{const n={import:[p]},o=e=>{for(const[n,o]of Object.entries(e))"object"==typeof o?(o.import=o.import||[],o.import.unshift(p)):"string"==typeof o?e[n]=[p,o]:Array.isArray(o)?o.unshift(p):t.error("Invalid entry type: "+typeof o)};return e?"function"==typeof e?async()=>{const t=await e();return o(t),t}:"object"!=typeof e?"string"==typeof e?[n,e]:(t.error("Invalid entry type: "+typeof e),e):(o(e),e):{ddHelper:n}})(i.options.entry);i.options.entry=f},Pi=e=>{const{bundler:t,context:n}=e,o=n.getLogger(li),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++ne}`,e)};const s={name:li,enforce:"post",esbuild:Ei(o,n,i),webpack:ji(t,o,n,r,i),rspack:ji(t,o,n,r,i),rollup:Di(o,i),vite:{...Di(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>bi(i,{position:Ie.MIDDLE})?[{tag:"script",attrs:{type:"module",src:"/@id/__datadog-helper-file"},injectTo:"head-prepend"}]:[]}}};var a;return a=n.bundler.name,["rspack","webpack"].includes(a)?s.load={filter:{id:M},handler:()=>({code:bi(i,{position:Ie.MIDDLE})})}:s.buildStart=async()=>{await wi(o,r,i,n.buildRoot)},[s]},Ai="datadog-true-end-plugin",Mi=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=()=>{t.hook("syncTrueEnd")},r=async()=>{o(),await n()},i=e=>{e.hooks.shutdown.tapPromise(Ai,r)},s={async writeBundle(){},async closeBundle(){await r()}};return[{name:Ai,enforce:"post",webpack:i,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:s,rollup:s,rspack:i}]},Ni={[Fo]:cr},Ci=t.bold.red;var Oi="3.1.8-dev.1";const Ri=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,r)=>{const i=Date.now(),s=((e={})=>{const t=(e=>{const t=[];return void 0===e||void 0!==e.version&&"string"!=typeof e.version&&t.push("metadata.version must be a string"),t})(e.metadata),n=L("SITE"),o={site:B(n,"DATADOG_SITE/DD_SITE",t)??B(e.auth?.site,"auth.site",t)??O};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:L("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:L("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=R);const a=process.env.BUILD_PLUGINS_ENV||"production",u=N.includes(a)?a:"development",d=t.rspackVersion||t.version||t.VERSION,c=r.framework,p={bundler:{name:c,version:d},env:u,metadata:s.metadata||{},packageName:`@datadog/${c}-plugin`,version:n},l={errors:[],logs:[],queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:ae(n,o,t.logLevel),asyncHook:()=>{throw new Error("AsyncHook function called before it was initialized.")},hook:()=>{throw new Error("Hook function called before it was initialized.")},inject:()=>{throw new Error("Inject function called before it was initialized.")},plugins:[],queue:()=>{throw new Error("Queue function called before it was initialized.")},sendLog:W(n),start:e,version:n.version}})({start:o,options:s,data:p,stores:l}),m=f.getLogger("factory"),g=m.time("Plugins initialization",{start:i});f.pluginNames.push(R);const h=[];h.push(["analytics",Mr],["async-queue",Cr],["build-report",Wr],["bundler-report",Zr],["custom-hooks",ti],["git",pi],["injection",Pi],["true-end",Mi]),s.customPlugins&&h.push(["custom",s.customPlugins]);const y=[["apps",fe,Un],["error-tracking",Vn,ro],["live-debugger",io,To],["metrics",Fo,pr],["output",lr,br],["rum",wr,Pr]];for(const[e,t,n]of y)le(s,t,m)&&h.push([e,n]);for(const[e,n]of h)f.plugins.push(...ce(f,n,e)({bundler:t,context:f,options:s,data:p,stores:l}));return(e=>{const t=[];for(const n of F){const o=z(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>_(e))).join(" and "),i=_(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>T(e))).join(" and ");t.push(`${e} (same value)`)}}t.length&&e.info(`Overrides from environment:\n - ${t.join("\n - ")}`)})(m),f.pluginNames.push(...f.plugins.map((e=>e.name))),(e=>{const t=new Set(e.filter((t=>e.filter((e=>e===t)).length>1)));if(t.size>0)throw new Error(`Duplicate plugin names: ${Ci(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),g.end(),f.plugins}))})({bundler:x,version:Oi}).esbuild,Ti=Oi,_i=Ni;export{Ri as datadogEsbuildPlugin,_i as helpers,Ti as version};
|
|
2
2
|
//# sourceMappingURL=index.mjs.map
|