@datadog/esbuild-plugin 3.2.1 → 3.2.3
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 +7 -2
- 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 +7 -6
package/dist/src/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var e=require("unplugin"),t=require("chalk"),n=require("async-retry"),o=require("buffer"),r=require("fs/promises"),i=require("fs"),s=require("json-stream-stringify"),a=require("path"),u=require("stream"),c=require("crypto"),d=require("os"),p=require("eslint-scope"),l=require("jszip"),f=require("glob"),m=require("pretty-bytes"),g=require("p-queue"),h=require("@jridgewell/remapping"),y=require("perf_hooks"),b=require("@datadog/js-instrumentation-wasm"),w=require("simple-git"),v=require("esbuild");function $(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var o=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,o.get?o:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var k=$(p);const x="__datadog-helper-file",E=new RegExp(x),S=["development","production","test"],I=["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"],D=I[0],j="datadog-build-plugins",P=t.bold.green,M=t.bold.yellow,A=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],C=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],N=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},O=(e,t,n)=>{if(void 0!==e)return(e=>I.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/.`)},T=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}`:"")},R=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),_=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())}}},F=[400,401,403,404,405,409,413],z=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(T).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=T(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(F.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)},L=e=>({message:t,context:n})=>z({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||j,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"}}}}),q=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),B=e=>e.includes(x),K=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},U=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},V=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()},H=(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)}`},W=(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}},J=e=>e.trim().toLowerCase().replace(/[^a-z0-9_:./-]+/g,"_").replace(/^_+|_+$/g,"")||"unknown",G=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 Y=0;const Q={debug:0,info:1,warn:2,error:3,none:4},Z=e=>e.split(">").map(q).join(">"),X=(e,n,o,r)=>{const i=Z(e);return(s,a="debug",{forward:u,context:c}={})=>{let d=t.dim,p=console.log;"error"===a?(d=t.red,p=console.error):"warn"===a?(d=t.yellow,p=console.warn):"info"===a&&(d=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=L(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){X(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}Q[a]>=Q[r]&&p(`${d(l)} ${f}`)}},ee=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:c=[]}=i,d={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(d);const p=()=>d.spans.filter((e=>!e.end)),l=n=>{p().length||(!d.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),d.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:d,resume:l,end:e=>{f(e,!1);const n=d.spans.reduce(((e,t)=>e+(t.end-t.start)),0);d.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(V(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 d.tags.push(...e)}}},te=(e,t,n="warn")=>o=>{const r=X(o,e,t,n);return{getLogger:r=>te(e,t,n)(`${Z(o)}>${r}`),time:ee(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)}},ne=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],oe=(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)},re=(e,t,n)=>{const o=e.getLogger(j);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=q(e.name);for(const r of ne){const i=e[r];i&&(n[r]=oe(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},ie=new Set,se=(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&&(ie.has(t)||(ie.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},ae="apps",ue="datadog-apps-plugin",ce="api/unstable/app-builder-code/apps",de="datadog-apps-assets.zip",pe=/\.backend\.(ts|tsx|js|jsx)$/,le=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],fe=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),me=async e=>r.mkdir(e,{recursive:!0}),ge=(e,t)=>{var n;n=a.dirname(e),i.mkdirSync(n,{recursive:!0}),i.writeFileSync(e,t,{encoding:"utf-8"})},he=e=>i.readFileSync(e,{encoding:"utf-8"}),ye=e=>{try{return i.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},be=async(e,t)=>{if("function"==typeof i.openAsBlob){const n=await i.openAsBlob(e,{type:t.contentType});return new o.File([n],t.filename)}{const n=u.Readable.toWeb(i.createReadStream(e)),r=await new Response(n).blob();return new o.File([r],t.filename,{type:t.contentType})}},we=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 ve=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(ve||{});function $e(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 ke(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function xe(e){return"type"===e.importKind||"type"===e.exportKind}function Ee(e,t){return function(e,t){const n=$e(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(...De(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&&je(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const Se=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function Ie(e){return null==e||Se.has(e.type)}function De(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(Ie(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 je(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&&Ie(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function Pe(e){const t=e.relativePath.split(a.sep).join("/");return`${c.createHash("sha256").update(t).digest("hex")}.${e.name}`}function Me(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 Ae(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return require.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 Ce(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)Ne(t)&&r(t);else Ne(e)&&r(e)};r(e)}function Ne(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function Oe(e){Ce(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=k.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:Fe(t)}}function Te(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function Re(e){return e.defs.some((e=>"ImportBinding"===e.type))}function _e(e,t){return t.moduleScope.set.get(e)}function Fe(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function ze(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:Le(e,t)},r=[];return Ce(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(Ue(o,t.unsupportedAliases,t.scopeAnalysis))throw Je(n,"action-catalog call aliases");if(Ue(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw Je(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||Ke(o))throw Je(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function Le(e,t){const n=new Set;return Ce(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&Ue(e.init,t.actionFunctions,t))return He(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&qe(e.init,t))return He(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!Ue(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:We(e.value))).map((e=>e.name));return He(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&&Ue(e.right,t.actionFunctions,t))return Ve([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&qe(e.right,t))return Ve([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!Ue(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:We(e.value)));return Ve(n,t)}(e,t))n.add(o)}}),n}function qe(e,t){const n=Be(e);return!!n&&Ue(n,t.actionNamespaces,t)}function Be(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?Be(e.object):void 0}function Ke(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&Ke(e.object)}function Ue(e,t,n){return function(e,t,n){const o=Te(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function Ve(e,t){return e.flatMap((e=>{const n=Te(e,t.moduleScope);return n?[n]:[]}))}function He(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function We(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?We(e.argument):We(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?We(e):[]));case"RestElement":return We(e.argument);case"AssignmentPattern":return We(e.left);case"MemberExpression":return[]}}function Je(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const Ge="@datadog/action-catalog";function Ye(e,t,n){const o=e.get(t);if(!o)return ot(t,[],n.name);const r=Te(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?rt(t,[],n.name):Xe({modules:e,visitedExports:new Set},t,r,[]):rt(t,[],n.name)}function Qe(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 tt(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?tt(t.id,r,n):Qe(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return Xe(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=Qe(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||!Ze(r,s)){if(r)return et(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 Ze(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function Xe(e,t,n,o){const r=e.modules.get(t);if(!r)return ot(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return nt(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 nt(t,r,n);return Qe(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 et(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 tt(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 nt(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 ot(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 rt(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 it(e,t,n){const o=ht(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=Ye(e.modules,t,n);if("unsupported"===o.kind)return St(o,n.name);if(!o.binding.expression)return It(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return vt(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return it(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=st(e,t,n);if("unsupported"===o.kind)return o;return it(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 st(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=at(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 Et(e);if(r.computed)return wt(e);if(gt(r)===n){if(o)return $t(e,n);if("init"!==r.kind)return bt(e,n);if(!ut(r))return xt(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 at(e,t,n){if("Super"===n.type)return kt(t,n.type);const o=ht(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=st(e,t,o);return"unsupported"===n.kind?n:at(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return kt(t,o.type);const r=Ye(e.modules,t,o);if("unsupported"===r.kind)return St(r,o.name);if(!r.binding.expression)return It(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 vt(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return at(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function ut(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function ct(e){const t=new Set;for(const n of e.values())Ce(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){pt(e.left,t)},UpdateExpression(e,{state:t}){pt(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&pt(e.argument,t)},ForInStatement(e,{state:t}){dt(e.left,t)},ForOfStatement(e,{state:t}){dt(e.left,t)}});return t}function dt(e,t){"VariableDeclaration"!==e.type&&pt(e,t)}function pt(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&pt(e.left,t):pt(e.argument,t);else for(const n of e.elements)n&&pt(n,t);else for(const n of e.properties)pt("RestElement"===n.type?n.argument:n.value,t);else{const n=mt(e);n&<(n,t)}else lt(e,t)}function lt(e,t){const n=ft(t,e,new Set);n&&t.mutatedVariables.add(n)}function ft(e,t,n){const o=Te(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),Re(o)){const n=Ye(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=ht(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return mt(t);return}(r);return i?ft(e,i,n):void 0}function mt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?mt(e.object):void 0}function gt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function ht(e){let t=e;for(;yt(t);)t=t.expression;return t}function yt(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function bt(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 wt(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function vt(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 $t(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function kt(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 xt(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 Et(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function St(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 It(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 Dt=new Set(["node_modules",".yarn"]);function jt(e,t,n,o=[]){if(!Ht(e,t))return null;const r=$e(n,e),i=Oe(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&&ke(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:Ut(r),importsByVariable:Pt(r,i,s),exportsByName:Mt(r,i,s),starExports:Nt(r,s),topLevelBindingsByVariable:Ot(r,i)}}function Pt(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!ke(r.source))continue;const e=Kt(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 Mt(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&Ct(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):At(r,t,n,o);return o}function At(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&&ke(e.source)){const t=Kt(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=_e(qt(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function Ct(e,t,n){const o=Bt(e);o&&ke(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Kt(t,e.source.value)})}function Nt(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||Bt(e)||!ke(e.source)?[]:[{resolvedId:Kt(t,e.source.value)}]))}function Ot(e,t){const n=new Map;for(const o of e.body)Tt(o,t,n);return function(e,t,n){Ce(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){Ft(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){Ft(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Ft(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){_t(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){_t(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function Tt(e,t,n){if("VariableDeclaration"===e.type)return void Rt(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void Rt(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 Rt(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 _t(e,t,n){"VariableDeclaration"!==e.type&&Ft(e,t,n)}function Ft(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&&Ft(e.left,t,n):Ft(e.argument,t,n);else for(const o of e.elements)o&&Ft(o,t,n);else for(const o of e.properties)Ft("RestElement"===o.type?o.argument:o.value,t,n);else{const o=Lt(e);o&&zt(o,t,n,"mutated object binding")}else zt(e,t,n,"reassigned binding")}function zt(e,t,n,o){const r=Te(e,t);if(!r||Re(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function Lt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?Lt(e.object):void 0}function qt(e){return"Identifier"===e.type?e.name:String(e.value)}function Bt(e){const t=e.exported;return t?qt(t):void 0}function Kt(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function Ut(e){const t=[];return Ce(e,t,{ImportExpression(e,{state:t}){const n=function(e){return Jt(e.source,"non-literal dynamic import")}(e);Vt(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 Jt(e.arguments[0],"non-literal dynamic import")}(e);Vt(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||!ke(t)||Gt(t.value)})(e)&&t.push({specifier:Wt(e),kind:"require"})}}),t}function Vt(e){return"non-literal dynamic import"===e||Gt(e)}function Ht(e,t){if(!le.some((t=>e.endsWith(t))))return!1;const n=a.relative(a.resolve(t),e);return!n.startsWith("..")&&!a.isAbsolute(n)&&!n.split(a.sep).some((e=>Dt.has(e)))}function Wt(e){return Jt(e.arguments[0],"local require")}function Jt(e,t){return ke(e)?e.value:t}function Gt(e){return e.startsWith(".")||e.startsWith("/")}function Yt(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function Qt(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 Yt(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw Yt(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Ht(i,n)){if(!t.has(i))throw Yt(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===Ge||o.startsWith(`${Ge}/`))&&!xe(r))for(const e of r.specifiers)xe(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)Re(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 ze(e.ast,r,e.id)){const r=Zt(n,t,e);r&&o.add(r)}})),[...o].sort()}function Zt(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw tn(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 tn(t,"spread object arguments");if(o.computed)throw tn(t,"computed object property keys");if(en(o)){if(n)throw tn(t,"multiple connectionId properties");if("init"!==o.kind)throw tn(t,"accessor connectionId properties");if(!Xt(o))throw tn(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return it({modules:e,mutatedImportedObjectVariables:ct(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 Xt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function en(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 tn(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const nn=/^(?:\0|virtual:)/;function on(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=rn(n.id);if(r=o,nn.test(r))return;var r;const i=jt(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(rn));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function rn(e){return e.split("?")[0]}function sn(e,t){const n=on(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>Qt(e,n.getModuleRecords(),t)}}function an(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function un(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:[...le,".json"]},plugins:[an("dd-backend-resolve",t),...n]}}function cn(e){return`${e.relativePath}/${e.name}`}async function dn(e,t,n,o){const r=cn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return Ae(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=sn(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=un(n,{[i]:s},[a.plugin]),c=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),d=Array.isArray(c)?c[0]:c;if(!("output"in d))throw new Error(`Unexpected vite.build result for "${r}"`);const p="chunk"===d.output[0].type?d.output[0].code:"",l={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${p.length} bytes)`),{func:l,code:p}}async function pn(e,t,n,o,r){const i=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,s=cn(t);r.debug(`Calling Datadog API: ${i}`);const a=JSON.stringify({data:{type:"queries",attributes:{query:{id:c.randomUUID(),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 z({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 z({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 ln(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class fn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function mn(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 fn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new fn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function gn(e,t,n,o,r){const i=t=>dn(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=>[Pe(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await mn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){ln(t,e instanceof fn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,n,s,i).catch((()=>{ln(n,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void ln(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 mn(e,n,o),c=cn(s);i.debug(`Executing action: ${c} with args`);const d=await pn(a,s,u,r,i);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:d}))}catch(e){const n=e instanceof fn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";i.debug(`Error handling executeAction: ${o}`),ln(t,n,o)}})(e,n,s,i,a,r).catch((()=>{ln(n,500,"Unexpected error")}))}else o()}}const hn=async(e,t)=>{const n=(await Promise.all(e.map((e=>f.glob(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>a.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(a.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(a.sep);if(!e.every((e=>e.startsWith(`${r}${a.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(a.sep).join("/")}}));return i},yn=(e,t)=>B(t)?x:t.startsWith(e)||a.isAbsolute(t)?t:a.resolve(e,t),bn=(e,t)=>{let n,o=yn(process.cwd(),e);for(;!n;){const e=a.resolve(o,t);if(ye(e)&&(n=e),o=o.split(a.sep).slice(0,-1).join(a.sep),[a.sep,""].includes(o))break}return n},wn=(e,t)=>{const n=[...e].map((e=>yn(t||process.cwd(),e).split(a.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(a.sep)||a.sep},vn=t.bold.red,$n=t.bold.yellow,kn=e=>{const t=bn(e,"package.json");if(t)try{const e=he(t);return JSON.parse(e)}catch(e){return}},xn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=kn(e);o||t.warn($n("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(vn("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=W(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(vn("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.createHash("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(vn("Unable to compute the app identifier.")),{identifier:s,name:r}},En=t.green.bold,Sn=t.yellow.bold,In=t.cyan.bold,Dn=t.bold,jn=(e,t={},n)=>async()=>{const o=await be(e,{contentType:"application/zip",filename:de});return _({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,de);const t=C("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},Pn=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,C("APPS_INTAKE_URL")||`https://api.${s}/${ce}/${a}/upload`);var s,a;const c=R({bundler:t.bundlerName,plugin:"apps",version:t.version}),d=G({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),p=`an archive of:\n - ${En(e.assets.length.toString())} files\n - ${En(m(e.size))}\n\nWith the configuration:\n${d}`;if(t.dryRun)return n.error(`\n${In("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await z({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:jn(e.archivePath,c,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Sn(`${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 ${In(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${ce}/${t}/release/live`)(t.site,t.identifier);await z({auth:{apiKey:t.apiKey,appKey:t.appKey},url:e,method:"PUT",type:"json",getData:async()=>({data:u.Readable.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...c}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${Sn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${Dn(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}},Mn=t.yellow.bold,An=t.red.bold,Cn="manifest.json";async function Nn(e){const t=await r.mkdtemp(a.join(d.tmpdir(),"dd-apps-manifest-")),n=a.join(t,Cn);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[Pe(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await fe(t),e}return{manifestAsset:{absolutePath:n,relativePath:Cn},cleanup:()=>fe(t)}}const On=async({backendOutputs:e,backendFunctions:t,context:n,options:o})=>{const s=n.getLogger(ue),{auth:u,buildRoot:c,bundler:{name:p,outDir:f},git:m,version:g}=n,h=s.time("handle assets");let y,b,w;try{const n=s.time("resolve identifier"),{name:h,identifier:w}=xn(c,s,{url:m?.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=a.relative(c,f),$=[...o.include,`${v}/**/*`],k=await hn($,c);if(!k.length)return void s.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 Nn(t);b=I,E.push(S);const D=s.time("archive assets"),j=await(async e=>{const t=await r.mkdtemp(a.join(d.tmpdir(),"dd-apps-")),n=a.join(t,de),o=new l;for(const t of e)o.file(t.relativePath,i.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=i.createWriteStream(n),s=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});s.on("error",t),r.on("error",t),r.on("close",e),s.pipe(r)}));const{size:s}=await r.stat(n);return{archivePath:n,size:s,assets:e}})(E);D.end(),y=a.dirname(j.archivePath);const P=s.time("upload assets"),{errors:M,warnings:A}=await Pn(j,{apiKey:u.apiKey,appKey:u.appKey,bundlerName:p,dryRun:o.dryRun,identifier:w,name:h,site:u.site,version:g},s);if(P.end(),A.length>0&&s.warn(`${Mn("Warnings while uploading assets:")}\n - ${A.join("\n - ")}`),M.length>0){const e=M.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){w=e,s.error(`${An("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await fe(y),b&&await b(),h.end(),w)throw w};const Tn=a.join(__dirname,"./apps-runtime.mjs"),Rn=({bundler:e,context:t,options:n})=>{const o=t.getLogger(ue),{auth:i,buildRoot:s}=t;t.inject({type:"file",position:ve.MIDDLE,value:Tn});const{setBackendFunctions:u,getBackendFunctions:c}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[pe],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=Ee(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?`),u(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=a.relative(n,t).replace(pe,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:Pe(e)})}return{functions:r,proxyCode:Me(i)}}(n,t,s);return u(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let i,u=new Map,p=c();if(p.length>0){const t=await async function(e,t,n,o){const i=await r.mkdtemp(a.join(d.tmpdir(),"dd-apps-backend-")),s=new Map,u=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const r of t){const t=Pe(r),c=`\0dd-backend:${t}`,d=Ae(r.name,r.absolutePath,n),p=sn(r.absolutePath,n),l=un(n,{[c]:d},[p.plugin]),f=await e({...l,build:{...l.build,write:!0,outDir:i,emptyOutDir:!1,rollupOptions:{...l.build.rollupOptions,input:{[t]:c},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=a.resolve(i,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}u.set(r.absolutePath,p.getAllowedConnectionIds())}return{outDir:i,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:u.get(e.absolutePath)})))}}(e.build,p,s,o);i=t.outDir,u=t.outputs,p=t.functions}try{await On({backendOutputs:u,backendFunctions:p,context:t,options:n})}finally{i&&await fe(i)}},configureServer(t){t.middlewares.use(gn(e.build,c,i,s,o))}}},_n=({options:e,context:t,bundler:n})=>{const o=t.getLogger(ue),r=(e=>{const t=e[ae]||{};return{include:t.include||[],dryRun:t.dryRun??!C("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:ue,enforce:"post",vite:Rn({bundler:n,context:t,options:r})}]},Fn="errorTracking",zn="datadog-error-tracking-plugin",Ln=(e,n,o)=>{if(".map"!==a.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=a.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return a.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,Bn=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Kn=(e,t)=>{const n=e.replace(Bn,"").split(qn),o=t.replace(Bn,"").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},Un=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([we(e.minifiedFilePath),we(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Kn(e.relativePath,t)}})(e,n),i=[],s=[],u=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{u.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${a.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:u,errors:i,warnings:s}},Vn=e=>{const t=e.message.match(/HTTP (\d{3})/);return t?`status_code:${t[1]}`:"status_code:unknown"},Hn=e=>{const t=Vn(e);return"status_code:unknown"!==t?`error_type:http_${t.replace("status_code:","")}`:`error_type:${J(e.name||"unknown")}`},Wn=(e,t,n)=>{const o=((e,t)=>`${e}|${t.join("|")}`)(t,n),r=e.metrics.get(o);r?r.value++:e.metrics.set(o,{name:t,value:1,tags:n})},Jn=(e,t,n)=>{Wn(e,"retry",[...e.baseTags,`attempt:${n}`,Vn(t),Hn(t)])},Gn=(e,t)=>{Wn(e,"failure",[...e.baseTags,Vn(t),Hn(t)])},Yn=(e,t)=>{if(!t.sendMetrics)return;if(!e.metrics.size)return;const n=(e=>{const t=Math.floor(Date.now()/1e3);return Array.from(e.metrics.values()).map((e=>({metric:`sourcemaps.upload.${e.name}`,type:"count",points:[[t,e.value]],tags:e.tags})))})(e);for(const e of n)t.addMetric(e)},Qn=t.green.bold,Zn=t.yellow.bold,Xn=t.red.bold,eo=(e,t={})=>async()=>_({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await be(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(g.default?g.default:g)({concurrency:t.maxConcurrency}),u=(c=n.site,C("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const d=R({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=(e=>({metrics:new Map,baseTags:[`service:${e.service}`]}))(t),l=G({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),f=`\nUploading ${Qn(e.length.toString())} sourcemaps with configuration:\n${l}`;o.debug(f);const m=[];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,".")};m.push(a.add((async()=>{try{await z({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:eo(s,d),onRetry:(t,n)=>{Jn(p,t,n);const r=`Failed to upload ${Zn(e.sourcemap)} | ${Zn(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(Gn(p,n),r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}s.end(),o.debug(`Queued ${Qn(e.length.toString())} uploads.`);try{await Promise.all(m),await a.onIdle()}finally{Yn(p,n)}return{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=>({...Ln(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=>Un(e,s,i,n.git))));a.end();const c=u.map((e=>e.errors)).flat(),d=u.map((e=>e.warnings)).flat();if(d.length>0&&o.warn(`Warnings while preparing payloads:\n - ${d.join("\n - ")}`),c.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${c.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,sendMetrics:n.sendMetrics,addMetric:n.addMetric},o);if(p.end(),o.debug(`Done uploading ${Qn(`${e.length-l.length}/${e.length}`)} sourcemaps in ${Qn(V(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?`${Xn(e.file)} | ${Xn(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,{addMetric:t.addMetric,apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,sendMetrics:t.sendMetrics,site:t.site,version:t.version},n),i.end()},oo=e=>{const n=t.bold.red,o=e[Fn]||{},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(zn),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 ${zn}.`);return{...e[Fn],sourcemaps:o.config}})(e,n);o.end();const i=se(e,"metrics",n);let s,a,u=!1;const c=async()=>{if(!r.sourcemaps||u)return;u=!0;const e=n.time("sourcemaps process");await no(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:s,addMetric:t.addMetric,outDir:t.bundler.outDir,outputs:a?.outputs||[],sendMetrics:i,site:t.auth.site,version:t.version},n),e.end()};return[{name:zn,enforce:"post",async git(e){s=e,a&&await c()},async buildReport(t){a=t,!s&&U(e)||await c()},async asyncTrueEnd(){u||await c()}}]},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=a.relative(t,e).replace(/\\/g,"/"),s=fo(n,r);if(s)return`${i};${s}`;const u=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${u}:${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){const n=[];if(t.isBlockStatement(e.body)){const o=e.params.flatMap((e=>Eo(e,t))),r=new Set(o),i="id"in e&&t.isIdentifier(e.id)?e.id.name:"";for(const o of e.body.body)if(t.isVariableDeclaration(o)){const e=o.end;if(null==e)continue;for(const s of o.declarations)for(const o of Eo(s.id,t))r.has(o)||o===i||n.push({name:o,declarationEnd:e,temporalDeadZones:[]})}}const o=n.length>25?n.slice(0,25):n;if(t.isBlockStatement(e.body)){const n=o.map((({name:e})=>e)),r=new Set(n),i=function(e,t,n){const o=new Map;for(const r of e.body)wo(r,t,o,n);return o}(e.body,r,t);for(const e of o)e.temporalDeadZones=i.get(e.name)??[]}return o}function wo(e,t,n,o){o.isFunctionDeclaration(e)||o.isClassDeclaration(e)||(o.isBlockStatement(e)?vo(e,t,n,o):o.isIfStatement(e)?(wo(e.consequent,t,n,o),e.alternate&&wo(e.alternate,t,n,o)):o.isForStatement(e)||o.isForInStatement(e)||o.isForOfStatement(e)||o.isWhileStatement(e)||o.isDoWhileStatement(e)?wo(e.body,t,n,o):o.isSwitchStatement(e)?function(e,t,n,o){for(const r of e.cases){$o(r.consequent,e.start,t,n,o);for(const e of r.consequent)wo(e,t,n,o)}}(e,t,n,o):o.isTryStatement(e)?(vo(e.block,t,n,o),e.handler&&vo(e.handler.body,t,n,o),e.finalizer&&vo(e.finalizer,t,n,o)):(o.isLabeledStatement(e)||o.isWithStatement(e))&&wo(e.body,t,n,o))}function vo(e,t,n,o){$o(e.body,e.start,t,n,o);for(const r of e.body)wo(r,t,n,o)}function $o(e,t,n,o,r){if(null!=t)for(const i of e)r.isVariableDeclaration(i)&&"var"!==i.kind?ko(i,t,n,o,r):r.isClassDeclaration(i)&&i.id&&xo(i.id.name,t,i.end,n,o)}function ko(e,t,n,o,r){for(const i of e.declarations)for(const s of Eo(i.id,r))xo(s,t,e.end,n,o)}function xo(e,t,n,o,r){if(null==n||!o.has(e))return;const i=r.get(e)??[];i.push({start:t,end:n}),r.set(e,i)}function Eo(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:Eo(e.argument,t):t.isAssignmentPattern(e)?Eo(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?Eo(e.argument,t):Eo(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?Eo(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const So=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let Io,Do,jo,Po,Mo=!1;function Ao(e){try{return function(e){switch(e){case"@babel/parser":return require("@babel/parser");case"@babel/traverse":return require("@babel/traverse");case"@babel/types":return require("@babel/types");case"magic-string":return require("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 So.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=So.find((t=>e.message.includes(t))),n=t??So.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 ${So.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const Co=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function No(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,c=0,d=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:c,skippedFileCount:1,skippedUnsupportedCount:d,totalFunctions:p};if(!Co.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p};Mo||(Io=Ao("@babel/parser").parse,Do=po(Ao("@babel/traverse")),jo=Ao("@babel/types"),Po=po(Ao("magic-string")),Mo=!0);const l=Io(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map,g=new Set,h=new Map,y=new Map;let b=0;if(Do(l,{Function(e){p++;const t=function(e,t){if(t.isClassMethod(e.node)&&"constructor"===e.node.kind&&Lo(e,t))return e.node;return}(e,jo);if(t&&(m.set(t,t.body.start),h.set(t,function(e,t){const n=[];for(const o of e)Ro(o,n,t);return n}(t.body.body,jo))),!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,jo))return void d++;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",jo))return void c++;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,jo)))return void d++;if(s&&!fo(e,jo))return void d++;let l=0;if(!fo(e,jo)){const t=e.parentPath?.node;t&&(l=y.get(t)||0,y.set(t,l+1))}const w=lo(n,o,e,l,jo);try{const t=e.node,n=b++,o=`$dd_p${n}`,r=function(e,t){const n=[];for(const o of e.params)for(const e of Eo(o,t))"this"!==e&&n.push(e);return n.length>25?n.slice(0,25):n}(t,jo),i=bo(t,jo),s=jo.isArrowFunctionExpression(t)&&!jo.isBlockStatement(t.body),a=s&&jo.isSequenceExpression(t.body),c=function(e,t){if(t.isFunction(e.node)&&!t.isArrowFunctionExpression(e.node))return;let n=e.parentPath;for(;n;){const e=n.node;if(t.isClassMethod(e)&&"constructor"===e.kind){if(!Lo(n,t))return;return{node:e,parent:n.parent,parentPath:n.parentPath}}if(t.isFunction(e)){if(t.isArrowFunctionExpression(e)){n=n.parentPath;continue}return}n=n.parentPath}return}(e,jo),d=null!=c;c&&(g.add(c.node),m.set(c.node,c.node.body.start));const p=[],l=s||!jo.isBlockStatement(t.body)||!Ko(t.body.body,jo);let h;if(!s&&jo.isBlockStatement(t.body)&&Bo(t.body.body,p,jo),!s&&jo.isBlockStatement(t.body)&&t.body.directives.length>0){h=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,hasSequenceExpressionBody:a,aliasesExpressionBodySuperCall:d&&s&&zo(t.body,jo),needsTrailingReturn:l,useThisAlias:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:h,functionId:w,probeVarName:o,probeIdx:String(n),entryVars:r,localVars:i,returns:p}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p};const w=new Po(t),v=function(e){const t=new Set;for(const n of e)n.aliasesExpressionBodySuperCall&&t.add(Fo({start:n.bodyStart,end:n.bodyEnd}));return t}(f),$=function(e,t,n,o){const r=[];for(const i of e){const e=t.get(i);null!=e&&r.push({bodyStart:e,superCalls:(n.get(i)??[]).filter((e=>!o.has(Fo(e))))})}return r}(g,m,h,v);for(let e=f.length-1;e>=0;e--)Oo(w,t,f[e]);for(const e of $)To(w,t,e);return{code:w.toString(),map:w.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p}}function Oo(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,localVars:a,returns:u,bodyStart:c,bodyEnd:d,functionEnd:p,isExpressionBody:l,hasSequenceExpressionBody:f,aliasesExpressionBodySuperCall:m,useThisAlias:g,bodyParenStart:h,directivesEnd:y}=n,b=`$dd_e${r}`,w=`$dd_rv${r}`,v=g?"$dd_t":"this",$=s.join(", "),k=""!==$,x=k?`, ${b}()`:"";const E=`const ${o} = $dd_probes('${i.replace(/['\\\n\r\u2028\u2029]/g,(e=>{switch(e){case"'":return"\\'";case"\\":return"\\\\";case"\n":return"\\n";case"\r":return"\\r";case"\u2028":return"\\u2028";case"\u2029":return"\\u2029";default:return e}}))}');`,S=k?`const ${b} = () => ({${$}});`:"",I=`if (${o}) $dd_entry(${o}, ${v}${x});`,D=`catch(e) { if (${o}) $dd_throw(${o}, e, ${v}${x}); throw e; }`;if(l){if(null!=h){const n=function(e,t,n){const o=[];for(let r=t;r<n;r++)"("===e[r]&&o.push(r);return o}(t,h,c),o=function(e,t,n){const o=[];for(let r=n-1;r>=t;r--)")"===e[r]&&o.push(r);return o}(t,d,p),r=Math.min(n.length,o.length);for(let t=0;t<r;t++){const r=n[t],i=o[t];e.remove(r,r+1),e.remove(i,i+1)}}const n=["{",E,S,"try {",I,m?`const ${w} = ($dd_t = `:`const ${w} = `].filter(Boolean).join("\n");let r=f?");":";";m&&(r=f?"));":");");const i=[r,`if (${o}) $dd_return(${o}, ${w}, ${v}${qo(b,k,a,d)});`,`return ${w};`,`} ${D}`,"}"].join("\n");if(d-c>=2){const o=f?`${n}(${t[c]}`:n+t[c];e.update(c,c+1,o),e.update(d-1,d,t[d-1]+i)}else e.update(c,d,n+t.slice(c,d)+i)}else{const r=[E,S,"try {",`let ${w};`,I].filter(Boolean).join("\n");for(const t of u){const n=qo(b,k,a,t.start);if(null!=t.argStart&&null!=t.argEnd){const r=t.hasSequenceExpressionArgument?`(${w} = (`:`(${w} = `,i=t.hasSequenceExpressionArgument?")":"";e.appendLeft(t.argStart,r),e.appendLeft(t.argEnd,`${i}, ${o} ? $dd_return(${o}, ${w}, ${v}${n}) : ${w})`)}else e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, ${v}${n}); `)}if(null!=y){const n=y-1;e.update(n,y,`${t[n]}\n${r}`)}else e.update(c,c+1,`${t[c]}${r}`);const i=qo(b,k,a,d),s=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, ${v}${i});\n`:""}} ${D}\n`;e.update(d-1,d,`${s}${t[d-1]}`)}}function To(e,t,n){e.update(n.bodyStart,n.bodyStart+1,`${t[n.bodyStart]}let $dd_t;`);for(const t of n.superCalls)e.appendLeft(t.start,"($dd_t = "),e.appendLeft(t.end,")")}function Ro(e,t,n){zo(e,n)&&t.push({start:e.start,end:e.end});const o=Object.values(e);for(const e of o)if(Array.isArray(e))for(const o of e)_o(o,t,n);else _o(e,t,n)}function _o(e,t,n){n.isNode(e)&&(n.isFunction(e)&&!n.isArrowFunctionExpression(e)||Ro(e,t,n))}function Fo(e){return`${e.start}:${e.end}`}function zo(e,t){return t.isCallExpression(e)&&t.isSuper(e.callee)}function Lo(e,t){const n=e.parentPath?.parentPath;if(!n)return!1;const o=n.node;return(t.isClassDeclaration(o)||t.isClassExpression(o))&&null!=o.superClass}function qo(e,t,n,o){const r=function(e,t){const n=e.filter((({declarationEnd:e,temporalDeadZones:n})=>e<=t&&!function(e,t){return e.some((({start:e,end:n})=>e<=t&&t<n))}(n,t))).map((({name:e})=>e));if(0===n.length)return;return`{${n.join(", ")}}`}(n,o);return t&&r?`, ${e}(), ${r}`:t?`, ${e}()`:r?`, undefined, ${r}`:""}function Bo(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,hasSequenceExpressionArgument:n.isSequenceExpression(o.argument)});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))Bo(o.body,t,n);else if(n.isIfStatement(o))Bo([o.consequent],t,n),o.alternate&&Bo([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))Bo([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)Bo(e.consequent,t,n);else n.isTryStatement(o)?(Bo(o.block.body,t,n),o.handler&&Bo(o.handler.body.body,t,n),o.finalizer&&Bo(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&Bo([o.body],t,n)}function Ko(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 Ko(e,t)&&Ko(o,t)}return!1}const Uo=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Vo=t.bold.red,Ho=Number(process.env.DD_LD_LIMIT)||1/0,Wo=(e,t)=>{const n=t.getLogger(so);let o=0,r=0,i=0,s=0,a=0,u=0,c=0,d=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(d>=Ho)return{code:p};try{const f=No({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,c+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&d++,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 h(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:()=>{c>0&&n.info(`Live Debugger: ${o}/${c} functions instrumented across ${u}/${d} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:d,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},Jo=({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(`${Vo("include")} patterns must be strings or RegExp`);break}}else r.push(`${Vo("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(`${Vo("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Vo("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Vo("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Uo.includes(e)){r.push(`${Vo("functionTypes")} contains invalid value "${e}". Valid values: ${Uo.join(", ")}`);break}}else r.push(`${Vo("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Vo("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:ve.BEFORE,injectIntoAllChunks:!0,value:co(n.version)}),[Wo(n,t)]};const Go=[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};/^sourcemaps\.upload\.(failure|retry)$/.test(e.metric)&&(t.count=0),/(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}],Yo="metrics",Qo="datadog-metrics-plugin",Zo=e=>Math.floor((e||Date.now())/1e3),Xo=(e,t)=>{const n=[`bundler:${J(e.bundler.name)}`,`plugin_version:${J(e.version)}`,`site:${J(e.auth.site)}`];return e.build.metadata.name&&n.push(`build_name:${J(e.build.metadata.name)}`),e.build.metadata.version&&n.push(`build_version:${J(e.build.metadata.version)}`),[...n,...t]},er=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),tr=(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(er(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(er({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i},nr=(e="")=>e.endsWith("/")?e:`${e}/`,or=(e,t)=>{let n=e;return e.split(nr(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},rr=(e,t)=>e.split("!").pop().replace(nr(t),"./"),ir=(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)),rr(o||"no-name",n)},sr=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),ar=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),ur=t.bold.red,cr=t.bold.cyan,dr=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},pr=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(dr("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:V(e.duration)}))),top:!0};n.sort(dr("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},lr=(e,t,n)=>{const o=[];var r;n&&(o.push(...pr("Loader",n.loaders)),o.push(...pr("Tapable",n.tapables)),o.push(...pr("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=K(e.build),a=new Map,u=new Map,c=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)c.has(n)||c.set(n,new Set),c.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(c.has(e.filepath)){const t=c.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),c.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=c.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 d=Array.from(i);return d.sort(dr((e=>e.dependents.size))),t.values=d.map((e=>({name:e.name,value:e.dependents.size.toString()}))),d.sort(dr((e=>e.dependencies.size))),n.values=d.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),d.sort(dr("size")),o.values=d.map((e=>({name:e.name,value:m(e.size)}))),d.sort(dr("aggregatedSize")),r.values=d.map((e=>({name:e.name,value:m(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(dr((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(dr((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(dr((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:V(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:V(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:V(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=H(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+=` [${ur(e.value)}] ${" ".repeat(n)}${cr(e.name)}\n`}}return t})(o);t.info(i)},fr="api/v1/series",mr=t.bold.green,gr=(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: ${mr(`https://api.${t.site}/${fr}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),z({method:"POST",url:`https://api.${t.site}/${fr}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))},hr=["onStart","onLoad","onResolve","onEnd"],yr=new Map,br=new Map,wr=new Map,vr=(e,t,n)=>{const o=Object.assign({},e);for(const r of hr)o[r]=async(o,i)=>{const s=br.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=rr(e[0].path,n),u=wr.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=y.performance.now();try{return await i(...e)}finally{const n=y.performance.now(),i=n-c,d={start:c,end:n,duration:i,context:ar(e)};if(s.events[r].values.push(d),s.duration+=i,s.increment+=1,br.set(t,s),u.events[r].values.push(d),u.duration+=i,u.increment+=1,wr.set(o,u),a){const e=yr.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(d),e.duration+=i,e.increment+=1,yr.set(t,e)}}}))};return o},$r=(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=vr(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:br,modules:wr,loaders:yr};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class kr{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=ir(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(sr))(e);o.length||o.push("no-loader"),this.started[n]={module:or(n),timings:{start:y.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=ir(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=y.performance.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 xr{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=y.performance.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,ar(r),i,y.performance.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=y.performance.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,ar(r),i,y.performance.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=y.performance.now(),s=t.apply(this,r);return this.saveResult(e,n,o,ar(r),i,y.performance.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 c=this.getTapPatch(e,i,s,t);return n.call(o,r,c)}}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(Qo)||(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 Er=e=>async t=>{const n=e.getLogger(Qo),o={name:Qo},r=new xr(e.buildRoot),i=new kr(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})}))},Sr={filters:Go},Ir=({options:e,context:t,stores:n})=>{const o=t.getLogger(Qo);let r=0;((e,t)=>{e.addMetric=e=>{t.metrics.add(e)}})(t,n);const i=((e,t)=>{const n=e[Yo],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:Go,tags:[],...e[Yo],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[],a={name:Qo,enforce:"pre",esbuild:$r(t,o),webpack:Er(t),rspack:Er(t)},u=o.time("build",{start:!1}),c=i.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,p;const l=async()=>{if(!n.metrics.size)return;const e=o.time("aggregating collected metrics"),r=(()=>{const e=new Set(n.metrics);n.metrics.clear();const o=Xo(t,i.tags);return tr(e,i.timestamp,i.filters,o,i.prefix)})();await t.asyncHook("metrics",r),e.end();const s=o.time("sending collected metrics to Datadog");await gr(r,{apiKey:t.auth.apiKey,site:t.auth.site},o),s.end()},f=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-r;const e=o.time("aggregating metrics"),n=i.timestamp,s=o.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,c=new Map,d=new Map,p=new Map;for(const e of i){for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.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)d.has(t.filepath)||d.set(t.filepath,[]),d.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}`];c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`entryName:${e}`))),d.has(e.filepath)&&o.push(...d.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})(p,n);s.end();const u=o.time("aggregate plugins metrics"),c=((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,n);u.end();const l=o.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,n);l.end();const m=new Set([...a,...c,...f]),g=Xo(t,i.tags),h=tr(m,n,i.filters,g,i.prefix);await t.asyncHook("metrics",h),e.end();const y=o.time("outputing report");lr(t,o,d),y.end();const b=o.time("sending metrics to Datadog");await gr(h,{apiKey:t.auth.apiKey,site:t.auth.site},o),b.end()},m={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){u.resume(),t.build.start=t.build.start||Date.now(),e[Yo]?.timestamp||(i.timestamp=Zo(t.build.start))},buildEnd(){u.end(),r=Date.now()},async timings(e){d=e,p&&await f()},async buildReport(e){p=e,!d&&c||await f()},async flush(){await l()}};return i.enableTracing&&s.push(a),s.push(m),s},Dr="output",jr="datadog-output-plugin",Pr=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,Mr=e=>{const t=void 0===e;return{build:Pr("build",e?.build??t),bundler:Pr("bundler",e?.bundler??t),dependencies:Pr("dependencies",e?.dependencies??t),errors:Pr("errors",e?.errors??t),logs:Pr("logs",e?.logs??t),metrics:Pr("metrics",e?.metrics??t),timings:Pr("timings",e?.timings??t),warnings:Pr("warnings",e?.warnings??t)}},Ar=(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}))}))},Cr=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},Nr=({options:e,context:t})=>{const n=t.getLogger(jr),o=(e=>({path:"./",...e[Dr],files:Mr(e[Dr]?.files)}))(e),r=(e,r)=>{const u=o.files[e];if(!r||!1===u)return;t.queue((async()=>{const e=n.time(`output ${u}`),c=((e,t,n)=>{const o=a.isAbsolute(t)?t:a.resolve(e,t);return a.resolve(o,n)})(t.bundler.outDir,o.path,u);let d;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await me(a.dirname(e));const n=i.createWriteStream(e),o=new s.JsonStreamStringify(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(c,e)}catch(e){d=e}d?n.error(`Failed writing ${u}: ${d}`):n.debug(`Wrote "./${a.relative(t.buildRoot,c)}"`),e.end()})())};return[{name:jr,buildReport(e){const t=n.time("serialize report"),o=K(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:Ar(n,(e=>{r("bundler",e)})),rollup:Cr((e=>{r("bundler",e)})),vite:Cr((e=>{r("bundler",e)})),webpack:Ar(n,(e=>{r("bundler",e)}))}]},Or="rum",Tr="datadog-rum-plugin",Rr=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")});`,_r="datadog-rum-privacy-plugin";const Fr=(e,t)=>{const n=t.getLogger(_r),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:_r,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=b.instrument({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}})}}},zr=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Lr=(e,t)=>{const n=e.sdk;if(n.clientToken)return zr(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 z({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 zr({...e,sdk:{clientToken:o,...n}})}},qr=e=>{const n=t.bold.red,o=e[Or]||{},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},Br=e=>{const t=e[Or]||{},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},Kr=e=>{const n=t.bold.red,o=e[Or]||{},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},Ur=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=qr(e),r=Br(e),i=Kr(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 ${Tr}.`);const s={...e[Or],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(Tr)),o=[];if(n.sourceCodeContext&&t.inject({type:"code",position:ve.BEFORE,injectIntoAllChunks:!0,value:Rr(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:ve.MIDDLE,value:a.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:ve.MIDDLE,value:Lr(n,t)})),n.privacy){t.inject({type:"file",position:ve.BEFORE,value:a.join(__dirname,"./privacy-helpers.js")});const e=Fr(n.privacy,t);o.push(e)}return o},Vr="datadog-analytics-plugin",Hr=({context:e})=>{const t=e.getLogger(Vr);return[{name:Vr,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}`)}})())}}]},Wr="datadog-async-queue-plugin",Jr=e=>{const{context:t,stores:n}=e,o=t.getLogger(Wr),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:Wr,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Gr=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("*")?f.glob.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},Yr=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Qr=/(\?|%3F|\|)+/gi,Zr=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=ti(e),Yr.lastIndex=0,Yr.exec(t)?.[1]||"unknown");var t},Xr=["unknown","commonjsHelpers.js",`vite${a.sep}preload-helper.js`],ei=(e,t,n)=>{const o=new Set;for(const n of e){const e=ti(n);B(n)||e===t||Xr.includes(e)||o.add(e)}return o},ti=e=>e.split("!").pop().split(Qr).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),ni=(e,t)=>B(t)?x:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(a.sep),o=e.split(a.sep).filter(((e,t)=>e===n[t])).join(a.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(Qr).shift().replace(/^((\.\.?)?[/\\])+/g,""),oi=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[yn(t,e),n]))),ri=(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 Gr(n,e,t));for(const t of r){const n=ni(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,u=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 c=[],d=[],p=[],l=[],f=[],m={},g={},h=t.time("indexing metafile data"),y=oi(n.metafile.inputs,u),b=oi(n.metafile.outputs,u);h.end();const w=e=>{if(!B(e))return e;const t=y[yn(u,e)];if(!t)return e;const n=t.imports.find((e=>!B(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(B(e))continue;const n=yn(u,e),o={name:ni(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Zr(e)};m[n]=o,c.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=yn(u,e),i=ni(s,n),a=[];for(const e of Object.keys(r.inputs)){if(B(e))continue;const n=m[yn(u,e)];n?a.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!a.length){const e=m[yn(u,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}a.push(e)}const c={name:i,filepath:n,inputs:a,size:r.bytes,type:Zr(n)};if(g[n]=c,"map"===c.type&&l.push(c),d.push(c),!r.entryPoint)continue;const f=m[yn(u,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...c,name:o.get(f.name)||f.name,outputs:[c],size:c.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=>!B(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(/^\.\.?\//),d=i?a.dirname(e):u,p=yn(d,t.path);if(t.external){if(S(t.path)){const e=i?p:t.path,n=x.inputs.report[e]||{filepath:e,name:ni(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),c.includes(n)||c.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 c){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?a.dirname(e.filepath):u,i=yn(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=d,e.build.inputs=c,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),ii=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),s=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}),c=t.time("filling sourcemaps inputs",{start:!1}),d=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),d.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=ti(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=ei(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=ei(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?yn(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=ti(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=ti(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(),s.resume();for(const[e,n]of Object.entries(m)){const o=yn(g,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),s=p.get(o)||{name:e,filepath:o,inputs:[],size:r,type:Zr(e)};if("map"===s.type&&y.add(s),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(ti(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=i.statSync(e).size}catch(e){n=t.renderedLength}const o=d.get(e)||{name:ni(g,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Zr(e)};s.inputs.push(o),d.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=ti(e);if(!f.has(n)){b.set(yn(g,n),s);continue}if(d.has(n)){t.debug(`Input report already there for ${n} from ${s.name}.`);continue}const o=d.get(n)||{name:ni(g,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};s.inputs.push(o),d.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&h.add({...s,name:n.name,size:0,outputs:[s]}),p.set(s.filepath,s)}s.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 d){const o=f.get(e);if(o){for(const e of o.dependencies){const o=d.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${ni(g,e)} of ${n.name}`)}for(const e of o.dependents){const o=d.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${ni(g,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){c.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}`)}c.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=ni(g,e),r=p.get(e);if(!r)return d.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[ni(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(yn(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}":"${ni(g,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(d.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)}}},si=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,c=new Map,d=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||B(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=ti(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(d.has(e)){const n=d.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else d.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=ti(t.request);if(d.has(n))return d.get(n);if(e.context){const t=yn(ti(e.context),n);if(d.has(t))return d.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(),d.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=ni(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:Zr(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,d=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>yn(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"===Zr(e))continue;const t=c.get(e)||new Set;for(const e of n)t.add(e);c.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of d){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:yn(e.bundler.outDir,t.name),type:Zr(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){p.push(o);continue}const r=c.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 c=v(r),d=Array.from(c).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"===Zr(e)));for(const e of d){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?yn(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:p?Zr(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)}))},ai="datadog-build-report-plugin",ui=e=>{const{context:t}=e,n=t.getLogger(ai);return[{name:ai,enforce:"post",esbuild:ri(t,n),rspack:si(t,ai,n),webpack:si(t,ai,n),vite:ii(t,n),rollup:ii(t,n)}]},ci="datadog-bundler-report-plugin",di=(e,t)=>t?a.isAbsolute(t)?t:a.resolve(e,t):"",pi=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?a.dirname(e.file):void 0)).filter(Boolean)},li=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=di(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},fi=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=pi(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=wn(r,process.cwd())),e.bundler.outDir=di(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),mi=e=>{const{context:t}=e,n=t.getLogger(ci);return[{name:ci,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=di(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=di(t.buildRoot,a.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:li(t),rspack:li(t),vite:fi(t),rollup:{options(e){let n;if("output"in e){const t=pi(e.output);n=wn(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(a.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=yn(process.cwd(),n);const e=wn([n,...o],process.cwd());t.buildRoot=e===a.sep?process.cwd():e}else t.buildRoot=wn(o,process.cwd()),t.bundler.outDir=a.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=pi(e);wn(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.")}}}]},gi="datadog-custom-hooks-plugin",hi=e=>{const{context:t}=e,n=t.getLogger(gi),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:gi,enforce:"pre"}]};class yi{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=he(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 bi=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await wi(e);for(const e of t)if(e.name===n)return W(e.refs.push);return W(t[0].refs.push)},wi=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},vi=async e=>e.revparse("HEAD"),$i=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),ki=async e=>e.branch(),xi=async e=>e.show(["-s","--format=%s"]),Ei=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),Si="datadog-git-plugin",Ii=e=>{const{options:t,context:n}=e,o=n.getLogger(Si),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=w.simpleGit(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return w.simpleGit(t)})(a.dirname(e));if(0===(await t.getRemotes(!0)).length)return o.warn("No git remotes available, skipping git plugin. This is expected for a repository that has not been pushed yet."),void r.end();const i=await(async e=>{const t=[vi(e),ki(e),xi(e),Ei(e),$i(e),bi(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,c,d,p,l,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:c,date:d},committer:{name:p,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new yi(s)}})(t);n.git=i,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:Si,enforce:"pre",buildRoot(e){if(U(t))try{r.resume();const t=bn(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}`)}}}]},Di="datadog-injection-plugin",ji=/^https?:\/\//,Pi=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],Mi=t.bold.yellow,Ai=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(yn(t,e)),Ci=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(ji)?await(async(e,t=5e3)=>{let n;return Promise.race([z({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await Ai(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} - ${H(r)}`;e.fallback?(t.debug(`Fallback for "${s}": ${i.toString()}`),o=await Ci(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},Ni=(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`},Oi=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 Ci(i,t,n);if(e){const t=i.position||ve.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)},Ti=e=>e instanceof Error&&"code"in e,Ri=e=>Pi.includes(e),_i=(e,t,n)=>{e.warn(`"${Mi(t)}" files are not supported (${Mi(n)}).`)},Fi=i.promises,zi=(e,t,n)=>({setup(o){const{onStart:s,onResolve:u,onLoad:c,onEnd:p,esbuild:l,initialOptions:f}=o,m=[],g=`${t.bundler.name}.${ve.MIDDLE}.${x}.js`,h=i.realpathSync(d.tmpdir()),y=a.resolve(h,g),b=new RegExp(`${g}$`),w=f.inject;f.inject=w?[...w]:[],f.inject.push(y),s((async()=>{m.push(...await Gr(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await me(a.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),u({filter:b},(async e=>({path:e.path,namespace:Di}))),c({filter:b,namespace:Di},(async()=>({contents:Ni(n,{position:ve.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),p((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=Ni(n,{position:ve.BEFORE}),i=Ni(n,{position:ve.AFTER}),s=Ni(n,{position:ve.BEFORE,onAllChunks:!0}),u=Ni(n,{position:ve.AFTER,onAllChunks:!0});if(!(r||i||s||u))return;const c=[];for(const[n,d]of Object.entries(o.metafile.outputs)){const o=d.entryPoint&&m.some((e=>e.resolved.endsWith(d.entryPoint))),p=o?r:s,f=o?i:u;if(!p&&!f)continue;const g=yn(t.buildRoot,n),{base:h,ext:y}=a.parse(g);Ri(y)?c.push((async()=>{try{const e=await Fi.readFile(g,"utf-8"),t=await l.transform(e,{loader:"default",banner:p,footer:f});await Fi.writeFile(g,t.code)}catch(t){if(!Ti(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${g}: ${t}`)}})()):_i(e,y,h)}await Promise.all(c)}))}}),Li=x,qi="?inject-proxy",Bi=(e,t)=>({banner(n){const o=Ni(t,{position:ve.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=a.parse(n.fileName);return Ri(i)?o:(_i(e,i,r),"")},async resolveId(e,n,o){if(B(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&Ni(t,{position:ve.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}${qi}`}return null},load(e){if(B(e))return Ni(t,{position:ve.MIDDLE});if(e.endsWith(qi)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(Li)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=Ni(t,{position:ve.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=a.parse(n.fileName);return Ri(i)?o:(_i(e,i,r),"")}}),Ki=(e,t,n,o,r)=>s=>{const u=new WeakMap,c=e.sources.ConcatSource,d=n.bundler.name,p=a.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${d}.${ve.MIDDLE}.${x}.js`);ge(p,"");s.hooks.shutdown.tap(Di,(()=>{var e;e=p,i.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await Oi(t,o,r,n.buildRoot)};s.hooks.beforeRun.tapPromise(Di,l),s.hooks.watchRun.tapPromise(Di,l),s.hooks.compilation.tap(Di,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:Di,stage:o},(()=>{const e=Ni(r,{position:ve.BEFORE}),o=Ni(r,{position:ve.AFTER}),i=Ni(r,{position:ve.BEFORE,onAllChunks:!0}),s=Ni(r,{position:ve.AFTER,onAllChunks:!0});for(const r of n.chunks){let d=e,p=o;if(r.canBeInitial()||(d=i,p=s),""!==d||""!==p)for(const e of r.files){const{base:o,ext:r}=a.parse(e);Ri(r)?n.updateAsset(e,(e=>{const t=u.get(e);if(!t||t.banner!==d||t.footer!==p){const t=new c(d,"\n",e,"\n",p);return u.set(e,{source:t,banner:d,footer:p}),t}return t.source})):_i(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}})(s.options.entry);s.options.entry=f},Ui=e=>{const{bundler:t,context:n}=e,o=n.getLogger(Di),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++Y}`,e)};const s={name:Di,enforce:"post",esbuild:zi(o,n,i),webpack:Ki(t,o,n,r,i),rspack:Ki(t,o,n,r,i),rollup:Bi(o,i),vite:{...Bi(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>Ni(i,{position:ve.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:E},handler:()=>({code:Ni(i,{position:ve.MIDDLE})})}:s.buildStart=async()=>{await Oi(o,r,i,n.buildRoot)},[s]},Vi="datadog-true-end-plugin",Hi=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=async()=>{await t.asyncHook("flush")},r=()=>{t.hook("syncTrueEnd")},i=async()=>{r(),await n(),await o()},s=e=>{e.hooks.shutdown.tapPromise(Vi,i)},a={async writeBundle(){},async closeBundle(){await i()}};return[{name:Vi,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n(),await o()})),e.onDispose((()=>{r()}))}},vite:a,rollup:a,rspack:s}]},Wi={[Yo]:Sr},Ji=t.bold.red;var Gi="3.2.1";const Yi=(({bundler:t,version:n})=>{const o=Date.now();return e.createUnplugin(((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=C("SITE"),o={site:O(n,"DATADOG_SITE/DD_SITE",t)??O(e.auth?.site,"auth.site",t)??D};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:C("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:C("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=j);const a=process.env.BUILD_PLUGINS_ENV||"production",u=S.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,d=r.framework,p={bundler:{name:d,version:c},env:u,metadata:s.metadata||{},packageName:`@datadog/${d}-plugin`,version:n},l={errors:[],logs:[],metrics:new Set,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{addMetric:()=>{throw new Error("AddMetric function called before it was initialized.")},auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:te(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:L(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(j);const h=[];h.push(["analytics",Hr],["async-queue",Jr],["build-report",ui],["bundler-report",mi],["custom-hooks",hi],["git",Ii],["injection",Ui],["true-end",Hi]),s.customPlugins&&h.push(["custom",s.customPlugins]);const y=[["apps",ae,_n],["error-tracking",Fn,ro],["live-debugger",io,Jo],["metrics",Yo,Ir],["output",Dr,Nr],["rum",Or,Ur]];for(const[e,t,n]of y)se(s,t,m)&&h.push([e,n]);for(const[e,n]of h)f.plugins.push(...re(f,n,e)({bundler:t,context:f,options:s,data:p,stores:l}));return(e=>{const t=[];for(const n of A){const o=N(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>M(e))).join(" and "),i=M(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>P(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: ${Ji(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),g.end(),f.plugins}))})({bundler:v,version:Gi}).esbuild,Qi=Gi,Zi=Wi;exports.datadogEsbuildPlugin=Yi,exports.helpers=Zi,exports.version=Qi;
|
|
1
|
+
"use strict";var e=require("unplugin"),t=require("chalk"),n=require("async-retry"),o=require("buffer"),r=require("fs/promises"),i=require("fs"),s=require("json-stream-stringify"),a=require("path"),u=require("stream"),c=require("child_process"),d=require("crypto"),l=require("http"),p=require("os"),f=require("eslint-scope"),m=require("jszip"),h=require("glob"),g=require("pretty-bytes"),y=require("p-queue"),b=require("@jridgewell/remapping"),w=require("perf_hooks"),v=require("@datadog/js-instrumentation-wasm"),$=require("simple-git"),k=require("magic-string"),x=require("esbuild");function E(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var o=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,o.get?o:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var S=E(f);const I="__datadog-helper-file",D=new RegExp(I),P=["development","production","test"],A=["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"],j=A[0],M="datadog-build-plugins",O=t.bold.green,T=t.bold.yellow,C=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","APPS_AUTH_METHOD","SITE"],N=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],R=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},_=(e,t,n)=>{if(void 0!==e)return(e=>A.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/.`)},F=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}`:"")},z=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),L=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],U=async 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&&"accessToken"in t?t.accessToken&&(n.Authorization=`Bearer ${t.accessToken}`):(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(F).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=F(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)},B=e=>({message:t,context:n})=>U({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||M,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"}}}}),V=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),H=e=>e.includes(I),K=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},W=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},J=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()},G=(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)}`},Y=(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}},Q=e=>e.trim().toLowerCase().replace(/[^a-z0-9_:./-]+/g,"_").replace(/^_+|_+$/g,"")||"unknown",Z=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"),X={debug:0,info:1,warn:2,error:3,none:4},ee=e=>e.split(">").map(V).join(">"),te=(e,n,o,r)=>{const i=ee(e);return(s,a="debug",{forward:u,context:c}={})=>{let d=t.dim,l=console.log;"error"===a?(d=t.red,l=console.error):"warn"===a?(d=t.yellow,l=console.warn):"info"===a&&(d=t.cyan,l=console.log);const p=`[${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=B(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){te(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}X[a]>=X[r]&&l(`${d(p)} ${f}`)}},ne=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:c=[]}=i,d={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(d);const l=()=>d.spans.filter((e=>!e.end)),p=n=>{l().length||(!d.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),d.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=l();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),p(e)}return{timer:d,resume:p,end:e=>{f(e,!1);const n=d.spans.reduce(((e,t)=>e+(t.end-t.start)),0);d.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(J(n))}`,s)},pause:f,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=l();for(const n of t)n.tags.push(...e)}else d.tags.push(...e)}}},oe=(e,t,n="warn")=>o=>{const r=te(o,e,t,n);return{getLogger:r=>oe(e,t,n)(`${ee(o)}>${r}`),time:ne(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)}},re=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],ie=(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)},se=(e,t,n)=>{const o=e.getLogger(M);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=V(e.name);for(const r of re){const i=e[r];i&&(n[r]=ie(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},ae=new Set,ue=(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&&(ae.has(t)||(ae.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},ce="apps",de="datadog-apps-plugin",le="api/unstable/app-builder-code/apps",pe="datadog-apps-assets.zip",fe=/\.backend\.(ts|tsx|js|jsx)$/,me=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],he=["apiKey","oauth"],ge=e=>{const t=e[ce]||{},n=(e=>{if(void 0!==e){if(he.includes(e))return e;throw new Error(`apps.authOverrides.method must be one of: ${he.join(", ")}`)}})(N("APPS_AUTH_METHOD")||t.authOverrides?.method)||((e=>Boolean((N("API_KEY")||e.auth?.apiKey)&&(N("APP_KEY")||e.auth?.appKey)))(e)?"apiKey":"oauth");return{include:t.include||[],dryRun:t.dryRun??!N("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim(),authOverrides:{method:n}}},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=a.dirname(e),i.mkdirSync(n,{recursive:!0}),i.writeFileSync(e,t,{encoding:"utf-8"})},ve=e=>i.readFileSync(e,{encoding:"utf-8"}),$e=e=>{try{return i.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},ke=async(e,t)=>{if("function"==typeof i.openAsBlob){const n=await i.openAsBlob(e,{type:t.contentType});return new o.File([n],t.filename)}{const n=u.Readable.toWeb(i.createReadStream(e)),r=await new Response(n).blob();return new o.File([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||{});const Se=()=>import("oauth4webapi"),Ie=t.cyan.bold,De=e=>e.toString("base64url"),Pe=e=>({client_id:e}),Ae=e=>({issuer:new URL(e.authorizationUrl).origin,authorization_endpoint:e.authorizationUrl,token_endpoint:e.tokenUrl}),je=(e,t)=>`${e}:${t.clientId}:${((e,t)=>d.createHash("sha256").update([t.clientId,e,t.authorizationUrl,t.tokenUrl].join("|")).digest("hex").slice(0,16))(e,t)}`,Me=(e,t,n)=>{e.writeHead(t,{"Content-Type":"text/html; charset=UTF-8"}),e.end(n)},Oe=(e,t,n=Date.now())=>({accessToken:e.access_token,expiresAt:"number"==typeof e.expires_in?n+1e3*e.expires_in:void 0,expiresIn:e.expires_in,refreshToken:e.refresh_token,scope:e.scope,site:t,tokenType:e.token_type}),Te=e=>null!==e&&"object"==typeof e&&!Array.isArray(e),Ce=e=>e instanceof Error?e.message:String(e),Ne=e=>{const t=Ce(e).toLowerCase();return"NoEntry"===(e=>Te(e)&&"string"==typeof e.code?e.code:void 0)(e)||t.includes("noentry")||t.includes("no matching entry")||t.includes("not found")},Re=async(e,t)=>{const{AsyncEntry:n}=await import("@napi-rs/keyring");return new n("datadog-build-plugins:oauth",je(e,t))},_e=(e,t)=>new Error(`Could not ${e} Datadog OAuth token in the OS credential store. ${t instanceof Error?t.message:String(t)}`),Fe=async(e,t)=>{try{const n=await Re(e,t),o=await n.getPassword();if(!o)return;const r=JSON.parse(o);return(e=>{if(Te(e)&&1===e.version&&Te(e.token)&&"string"==typeof e.token.accessToken&&"string"==typeof e.token.clientId&&"string"==typeof e.token.site)return e})(r)?.token}catch(e){if(Ne(e))return;throw _e("read",e)}},ze=async(e,t,n,o=e.site)=>{if(t.cacheTokens)try{await(async(e,t,n)=>{try{const o=await Re(e,n),r={version:1,token:t};await o.setPassword(JSON.stringify(r))}catch(e){throw _e("save",e)}})(o,((e,t)=>({accessToken:e.accessToken,clientId:t,expiresAt:e.expiresAt,refreshToken:e.refreshToken,scope:e.scope,site:e.site,tokenType:e.tokenType}))(e,t.clientId),t),n.debug("Saved Datadog OAuth token to the OS credential store.")}catch(e){n.warn(`Could not save Datadog OAuth token to the OS credential store; continuing without a persistent cache. ${Ce(e)}`)}},Le=async(e,t,n)=>{if(t.cacheTokens)try{await(async(e,t)=>{try{const n=await Re(e,t);await n.deletePassword()}catch(e){if(!Ne(e))throw _e("delete",e)}})(e,t)}catch(e){n.warn(`Could not delete cached Datadog OAuth token. ${Ce(e)}`)}},qe=async(e,t,n)=>{if(!t.cacheTokens)return;let o;try{o=await Fe(e,t)}catch(e){n.warn(`Could not read cached Datadog OAuth token; starting browser authorization. ${Ce(e)}`)}if(o){if(void 0===(r=o).expiresAt||r.expiresAt>Date.now()+3e5)return n.debug("Using cached Datadog OAuth access token."),(e=>({accessToken:e.accessToken,expiresAt:e.expiresAt,refreshToken:e.refreshToken,scope:e.scope,site:e.site,tokenType:e.tokenType}))(o);var r;if(o.refreshToken)try{n.debug("Refreshing cached Datadog OAuth access token.");const r=await(async(e,t,n)=>{const o=await Se(),r=Ae(t),i=Pe(t.clientId),s=await o.refreshTokenGrantRequest(r,i,o.None(),n),a=await o.processRefreshTokenResponse(r,i,s);return Oe({...a,refresh_token:a.refresh_token||n},e)})(e,t,o.refreshToken);return await ze(r,t,n),r}catch(o){return n.warn(`Cached Datadog OAuth token could not be refreshed; starting browser authorization. ${o instanceof Error?o.message:String(o)}`),void await Le(e,t,n)}}},Ue=async(e,t,n)=>{const o=await Se(),r=Ae(t),i=Pe(t.clientId),s=De(d.randomBytes(32)),a=await(async e=>(await Se()).calculatePKCECodeChallenge(e))(s),u=De(d.randomBytes(32)),p=(e=>{const t=new URL(e.authorizationUrl);return t.searchParams.set("redirect_uri",e.redirectUri),t.searchParams.set("client_id",e.clientId),t.searchParams.set("response_type","code"),t.searchParams.set("code_challenge",e.codeChallenge),t.searchParams.set("code_challenge_method","S256"),t.searchParams.set("state",e.state),t})({authorizationUrl:t.authorizationUrl,clientId:t.clientId,codeChallenge:a,redirectUri:t.redirectUri,state:u}),f=(async e=>{const t=new URL(e.redirectUri),n=Number(t.port||80);if("http:"!==t.protocol)throw new Error("OAuth redirect URI must use http for the local OAuth callback.");if(!Number.isInteger(n)||n<=0)throw new Error("OAuth redirect URI must include a valid port.");let o,r=!1;const i=l.createServer();try{return await new Promise(((s,a)=>{const u=e=>{r||(r=!0,e())};i.on("request",((n,o)=>{const r=new URL(n.url||"/",t.origin);if(r.pathname!==t.pathname)return void Me(o,404,"Not found.");let i;try{i=e.oauth.validateAuthResponse(e.authorizationServer,e.client,r,e.state)}catch(e){return Me(o,400,"OAuth authorization failed. You may now close this tab."),void u((()=>a(e instanceof Error?e:new Error(String(e)))))}if(!i.get("code"))return Me(o,400,"Missing OAuth authorization code. You may now close this tab."),void u((()=>a(new Error("Missing OAuth authorization code."))));Me(o,200,"OAuth authorization complete. You may now close this tab."),u((()=>s({callbackParameters:i})))})),i.once("error",(e=>u((()=>a(e))))),o=setTimeout((()=>{u((()=>a(new Error(`Timed out waiting for OAuth callback after ${e.timeoutMs}ms.`))))}),e.timeoutMs);try{const e="localhost"===t.hostname?void 0:t.hostname;i.listen(n,e)}catch(e){u((()=>a(e instanceof Error?e:new Error(String(e)))))}}))}finally{o&&clearTimeout(o),i.listening&&(i.close(),i.closeAllConnections?.(),i.closeIdleConnections?.())}})({authorizationServer:r,client:i,oauth:o,redirectUri:t.redirectUri,state:u,timeoutMs:t.timeoutMs});n.info(`Authorize Datadog Apps upload:\n ${Ie(p.toString())}`),t.openBrowser&&((e,t)=>{const n="darwin"===process.platform?{command:"open",args:[e]}:"win32"===process.platform?{command:"cmd",args:["/c","start","",e]}:{command:"xdg-open",args:[e]};try{const e=c.spawn(n.command,n.args,{detached:!0,stdio:"ignore"});e.once("error",(e=>{t.warn(`Could not open browser automatically: ${Ce(e)}`)})),e.unref()}catch(e){t.warn(`Could not open browser automatically: ${Ce(e)}`)}})(p.toString(),n);return(async e=>{const t=await Se(),n=Ae(e),o=Pe(e.clientId),r=await t.authorizationCodeGrantRequest(n,o,t.None(),e.callbackParameters,e.redirectUri,e.codeVerifier),i=await t.processAuthorizationCodeResponse(n,o,r);return Oe(i,e.site)})({callbackParameters:(await f).callbackParameters,clientId:t.clientId,codeVerifier:s,redirectUri:t.redirectUri,site:e,tokenUrl:t.tokenUrl,authorizationUrl:t.authorizationUrl})},Be=new Map,Ve=(e,t)=>{const n=(e=>{const t=(e=>"datad0g.com"===e?"f4bacdd2-0c8c-49f5-bf3e-a62ba3ec02e6":"e17b9ffa-3daf-4124-ba1b-4ac8c547d506")(e),n=`https://api.${e}/oauth2/v1`;return{authorizationUrl:`${n}/authorize`,cacheTokens:!0,clientId:t,openBrowser:!0,redirectUri:"http://localhost:8060",timeoutMs:3e5,tokenUrl:`${n}/token`}})(e),o=`${e}:${n.clientId}`;let r=Be.get(o);return r||(r=(async(e,t,n)=>{const o=await qe(e,t,n);if(o)return o;const r=await Ue(e,t,n);return await ze(r,t,n,e),r})(e,n,t).catch((e=>{throw Be.delete(o),e})),Be.set(o,r)),r},He='Set apps.authOverrides.method: "oauth" or DD_APPS_AUTH_METHOD=oauth to use OAuth, or set DD_API_KEY and DD_APP_KEY to use API/App key auth.';class Ke extends Error{constructor(){super(`Missing authentication. ${He}`),this.statusCode=400,this.name="MissingAuthenticationError"}}const We=(e,t,n)=>{if("oauth"===e)return e=>(async({auth:e,log:t,...n})=>{const{site:o}=e,r=await Ve(o,t);if(!r.accessToken)throw new Error("OAuth authentication did not return an access token.");return U({...n,auth:{accessToken:r.accessToken}})})({...e,auth:t,log:n});if(t.apiKey&&t.appKey)return e=>U({...e,auth:{apiKey:t.apiKey,appKey:t.appKey}});throw new Ke};function Je(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 Ge(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function Ye(e){return"type"===e.importKind||"type"===e.exportKind}function Qe(e,t){return function(e,t){const n=Je(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(...et(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&&tt(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const Ze=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function Xe(e){return null==e||Ze.has(e.type)}function et(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(Xe(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 tt(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&&Xe(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function nt(e){const t=e.relativePath.split(a.sep).join("/");return`${d.createHash("sha256").update(t).digest("hex")}.${e.name}`}function ot(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 rt(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return require.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 it(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)st(t)&&r(t);else st(e)&&r(e)};r(e)}function st(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function at(e){it(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=S.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:lt(t)}}function ut(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function ct(e){return e.defs.some((e=>"ImportBinding"===e.type))}function dt(e,t){return t.moduleScope.set.get(e)}function lt(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function pt(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:ft(e,t)},r=[];return it(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(yt(o,t.unsupportedAliases,t.scopeAnalysis))throw $t(n,"action-catalog call aliases");if(yt(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw $t(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!mt(o,t.scopeAnalysis))return!1;if(e.optional||gt(o))throw $t(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function ft(e,t){const n=new Set;return it(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&yt(e.init,t.actionFunctions,t))return wt(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&mt(e.init,t))return wt(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!yt(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:vt(e.value))).map((e=>e.name));return wt(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&&yt(e.right,t.actionFunctions,t))return bt([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&mt(e.right,t))return bt([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!yt(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:vt(e.value)));return bt(n,t)}(e,t))n.add(o)}}),n}function mt(e,t){const n=ht(e);return!!n&&yt(n,t.actionNamespaces,t)}function ht(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?ht(e.object):void 0}function gt(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&>(e.object)}function yt(e,t,n){return function(e,t,n){const o=ut(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function bt(e,t){return e.flatMap((e=>{const n=ut(e,t.moduleScope);return n?[n]:[]}))}function wt(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function vt(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?vt(e.argument):vt(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?vt(e):[]));case"RestElement":return vt(e.argument);case"AssignmentPattern":return vt(e.left);case"MemberExpression":return[]}}function $t(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const kt="@datadog/action-catalog";function xt(e,t,n){const o=e.get(t);if(!o)return jt(t,[],n.name);const r=ut(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?Mt(t,[],n.name):It({modules:e,visitedExports:new Set},t,r,[]):Mt(t,[],n.name)}function Et(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 Pt(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?Pt(t.id,r,n):Et(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=Et(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||!St(r,s)){if(r)return Dt(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 St(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 jt(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return At(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 At(t,r,n);return Et(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 Dt(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 Pt(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 At(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 jt(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 Mt(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 Ot(e,t,n){const o=Bt(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=xt(e.modules,t,n);if("unsupported"===o.kind)return Zt(o,n.name);if(!o.binding.expression)return Xt(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return Wt(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return Ot(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=Tt(e,t,n);if("unsupported"===o.kind)return o;return Ot(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 Tt(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=Ct(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 Qt(e);if(r.computed)return Kt(e);if(Ut(r)===n){if(o)return Jt(e,n);if("init"!==r.kind)return Ht(e,n);if(!Nt(r))return Yt(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 Ct(e,t,n){if("Super"===n.type)return Gt(t,n.type);const o=Bt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=Tt(e,t,o);return"unsupported"===n.kind?n:Ct(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return Gt(t,o.type);const r=xt(e.modules,t,o);if("unsupported"===r.kind)return Zt(r,o.name);if(!r.binding.expression)return Xt(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 Wt(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return Ct(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function Nt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function Rt(e){const t=new Set;for(const n of e.values())it(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){Ft(e.left,t)},UpdateExpression(e,{state:t}){Ft(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Ft(e.argument,t)},ForInStatement(e,{state:t}){_t(e.left,t)},ForOfStatement(e,{state:t}){_t(e.left,t)}});return t}function _t(e,t){"VariableDeclaration"!==e.type&&Ft(e,t)}function Ft(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&Ft(e.left,t):Ft(e.argument,t);else for(const n of e.elements)n&&Ft(n,t);else for(const n of e.properties)Ft("RestElement"===n.type?n.argument:n.value,t);else{const n=qt(e);n&&zt(n,t)}else zt(e,t)}function zt(e,t){const n=Lt(t,e,new Set);n&&t.mutatedVariables.add(n)}function Lt(e,t,n){const o=ut(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),ct(o)){const n=xt(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=Bt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return qt(t);return}(r);return i?Lt(e,i,n):void 0}function qt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?qt(e.object):void 0}function Ut(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function Bt(e){let t=e;for(;Vt(t);)t=t.expression;return t}function Vt(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function Ht(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 Kt(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function Wt(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 Jt(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function Gt(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 Yt(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 Qt(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function Zt(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 Xt(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 en=new Set(["node_modules",".yarn"]);function tn(e,t,n,o=[]){if(!vn(e,t))return null;const r=Je(n,e),i=at(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&&Ge(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:bn(r),importsByVariable:nn(r,i,s),exportsByName:on(r,i,s),starExports:an(r,s),topLevelBindingsByVariable:un(r,i)}}function nn(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!Ge(r.source))continue;const e=yn(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:hn(n.imported),resolvedId:e}))}}return o}function on(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&sn(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):rn(r,t,n,o);return o}function rn(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&&Ge(e.source)){const t=yn(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=hn(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:hn(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=hn(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=dt(hn(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function sn(e,t,n){const o=gn(e);o&&Ge(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:yn(t,e.source.value)})}function an(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||gn(e)||!Ge(e.source)?[]:[{resolvedId:yn(t,e.source.value)}]))}function un(e,t){const n=new Map;for(const o of e.body)cn(o,t,n);return function(e,t,n){it(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){pn(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){pn(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&pn(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){ln(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){ln(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function cn(e,t,n){if("VariableDeclaration"===e.type)return void dn(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void dn(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 dn(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 ln(e,t,n){"VariableDeclaration"!==e.type&&pn(e,t,n)}function pn(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&&pn(e.left,t,n):pn(e.argument,t,n);else for(const o of e.elements)o&&pn(o,t,n);else for(const o of e.properties)pn("RestElement"===o.type?o.argument:o.value,t,n);else{const o=mn(e);o&&fn(o,t,n,"mutated object binding")}else fn(e,t,n,"reassigned binding")}function fn(e,t,n,o){const r=ut(e,t);if(!r||ct(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function mn(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?mn(e.object):void 0}function hn(e){return"Identifier"===e.type?e.name:String(e.value)}function gn(e){const t=e.exported;return t?hn(t):void 0}function yn(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function bn(e){const t=[];return it(e,t,{ImportExpression(e,{state:t}){const n=function(e){return kn(e.source,"non-literal dynamic import")}(e);wn(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 kn(e.arguments[0],"non-literal dynamic import")}(e);wn(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||!Ge(t)||xn(t.value)})(e)&&t.push({specifier:$n(e),kind:"require"})}}),t}function wn(e){return"non-literal dynamic import"===e||xn(e)}function vn(e,t){if(!me.some((t=>e.endsWith(t))))return!1;const n=a.relative(a.resolve(t),e);return!n.startsWith("..")&&!a.isAbsolute(n)&&!n.split(a.sep).some((e=>en.has(e)))}function $n(e){return kn(e.arguments[0],"local require")}function kn(e,t){return Ge(e)?e.value:t}function xn(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 Sn(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(vn(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===kt||o.startsWith(`${kt}/`))&&!Ye(r))for(const e of r.specifiers)Ye(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)ct(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 pt(e.ast,r,e.id)){const r=In(n,t,e);r&&o.add(r)}})),[...o].sort()}function In(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw An(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 An(t,"spread object arguments");if(o.computed)throw An(t,"computed object property keys");if(Pn(o)){if(n)throw An(t,"multiple connectionId properties");if("init"!==o.kind)throw An(t,"accessor connectionId properties");if(!Dn(o))throw An(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return Ot({modules:e,mutatedImportedObjectVariables:Rt(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 Dn(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function Pn(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 An(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const jn=/^(?:\0|virtual:)/;function Mn(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=On(n.id);if(r=o,jn.test(r))return;var r;const i=tn(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(On));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function On(e){return e.split("?")[0]}function Tn(e,t){const n=Mn(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>Sn(e,n.getModuleRecords(),t)}}function Cn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function Nn(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:[...me,".json"]},plugins:[Cn("dd-backend-resolve",t),...n]}}function Rn(e){return`${e.relativePath}/${e.name}`}async function _n(e,t,n,o){const r=Rn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return rt(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=Tn(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=Nn(n,{[i]:s},[a.plugin]),c=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),d=Array.isArray(c)?c[0]:c;if(!("output"in d))throw new Error(`Unexpected vite.build result for "${r}"`);const l="chunk"===d.output[0].type?d.output[0].code:"",p={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${l.length} bytes)`),{func:p,code:l}}async function Fn(e,t,n,o,r,i){const s=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,a=Rn(t);i.debug(`Calling Datadog API: ${s}`);const u=JSON.stringify({data:{type:"queries",attributes:{query:{id:d.randomUUID(),name:a,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e,allowedConnectionIds:t.allowedConnectionIds,context:{backendFunctionArgs:n}}},onlyTriggerManually:!0}},template_params:{}}}}),c=await r({url:s,method:"POST",type:"json",getData:()=>({data:u,headers:{"Content-Type":"application/json"}})}),l=c.data?.id;if(!l)throw new Error("No receipt ID returned from Datadog API");return i.debug(`Query execution started with receipt: ${l}`),async function(e,t,n,o){const r=`https://api.${t.site}/api/v2/app-builder/queries/execution-long-polling/${e}`,i=10;for(let e=0;e<i;e++){o.debug(`Long-poll attempt ${e+1}/${i}...`);const t=await n({url:r,type:"json"});if(t.errors?.length){const e=t.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const s=t.data?.attributes;if(o.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")}(l,o,r,i)}function zn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class Ln extends Error{constructor(e,t){super(t),this.statusCode=e}}async function qn(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 Ln(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new Ln(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function Un(e,t,n,o,r,i){const s=t=>_n(e,t,r,i),a=t();return a.length>0&&i.info(`Dev server middleware active for ${a.length} backend function(s): ${a.map((e=>e.name)).join(", ")}`),o||i.warn(`Auth credentials not configured. The /__dd/executeAction endpoint will be unavailable. ${He}`),(e,r,a)=>{if("POST"!==e.method)return void a();const u=(c=t(),new Map(c.map((e=>[nt(e),e]))));var c;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await qn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){zn(t,e instanceof Ln?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,r,u,s).catch((()=>{zn(r,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!o)return void zn(r,400,`Auth credentials not configured. ${He}`);(async function(e,t,n,o,r,i,s){try{const{func:a,code:u,args:c}=await qn(e,n,o),d=Rn(a);s.debug(`Executing action: ${d} with args`);const l=await Fn(u,a,c,r,i,s);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:l}))}catch(e){const n=e instanceof Ln?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";s.debug(`Error handling executeAction: ${o}`),zn(t,n,o)}})(e,r,u,s,n,o,i).catch((()=>{zn(r,500,"Unexpected error")}))}else a()}}const Bn=async(e,t)=>{const n=(await Promise.all(e.map((e=>h.glob(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>a.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(a.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(a.sep);if(!e.every((e=>e.startsWith(`${r}${a.sep}`))))break;n=r}return n})(o);return o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o.split(a.sep).join("/")}}))},Vn=(e,t)=>H(t)?I:t.startsWith(e)||a.isAbsolute(t)?t:a.resolve(e,t),Hn=(e,t)=>{let n,o=Vn(process.cwd(),e);for(;!n;){const e=a.resolve(o,t);if($e(e)&&(n=e),o=o.split(a.sep).slice(0,-1).join(a.sep),[a.sep,""].includes(o))break}return n},Kn=(e,t)=>{const n=[...e].map((e=>Vn(t||process.cwd(),e).split(a.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(a.sep)||a.sep},Wn=t.bold.red,Jn=t.bold.yellow,Gn=e=>{const t=Hn(e,"package.json");if(t)try{const e=ve(t);return JSON.parse(e)}catch(e){return}},Yn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=Gn(e);o||t.warn(Jn("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(Wn("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=Y(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(Wn("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 d.createHash("sha256").update(n).digest("hex").slice(0,32)})(i,r);return s&&r||t.error(Wn("Unable to compute the app identifier.")),{identifier:s,name:r}},Qn=t.green.bold,Zn=t.yellow.bold,Xn=t.cyan.bold,eo=t.bold,to=(e,t={},n)=>async()=>{const o=await ke(e,{contentType:"application/zip",filename:pe});return L({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,pe);const t=N("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},no=async(e,t,n)=>{const o=[],r=[],i=t.doAuthenticatedRequest;if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:r};const s=(a=t.site,c=t.identifier,N("APPS_INTAKE_URL")||`https://api.${a}/${le}/${c}/upload`);var a,c;const d=z({bundler:t.bundlerName,plugin:"apps",version:t.version}),l=Z({identifier:t.identifier,intakeUrl:s,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),p=`an archive of:\n - ${Qn(e.assets.length.toString())} files\n - ${Qn(g(e.size))}\n\nWith the configuration:\n${l}`;if(t.dryRun)return n.error(`\n${Xn("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await i({url:s,method:"POST",type:"json",getData:to(e.archivePath,d,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Zn(`${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 ${Xn(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${le}/${t}/release/live`)(t.site,t.identifier);await i({url:e,method:"PUT",type:"json",getData:async()=>({data:u.Readable.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...d}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${Zn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${eo(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}},oo=t.yellow.bold,ro=t.red.bold,io="manifest.json";async function so(e){const t=await r.mkdtemp(a.join(p.tmpdir(),"dd-apps-manifest-")),n=a.join(t,io);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[nt(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await ye(t),e}return{manifestAsset:{absolutePath:n,relativePath:io},cleanup:()=>ye(t)}}const ao=async({backendOutputs:e,backendFunctions:t,context:n,doAuthenticatedRequest:o,options:s})=>{const u=n.getLogger(de),{auth:c,buildRoot:d,bundler:{name:l,outDir:f},git:h,version:g}=n,y=u.time("handle assets");let b,w,v;try{const n=u.time("resolve identifier"),{name:y,identifier:v}=Yn(d,u,{url:h?.remote,name:s.name,identifier:s.identifier});if(!v||!y)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 $=a.relative(d,f),k=[...s.include,`${$}/**/*`],x=await Bn(k,d);if(!x.length)return void u.debug("No assets to upload.");const E=new Set(e.values()),S=x.filter((e=>!E.has(e.absolutePath))).map((e=>({...e,relativePath:`frontend/${e.relativePath}`})));for(const[t,n]of e)S.push({absolutePath:n,relativePath:`backend/${t}.js`});const{manifestAsset:I,cleanup:D}=await so(t);w=D,S.push(I);const P=u.time("archive assets"),A=await(async e=>{const t=await r.mkdtemp(a.join(p.tmpdir(),"dd-apps-")),n=a.join(t,pe),o=new m;for(const t of e)o.file(t.relativePath,i.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=i.createWriteStream(n),s=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});s.on("error",t),r.on("error",t),r.on("close",e),s.pipe(r)}));const{size:s}=await r.stat(n);return{archivePath:n,size:s,assets:e}})(S);P.end(),b=a.dirname(A.archivePath);const j=u.time("upload assets"),{errors:M,warnings:O}=await no(A,{bundlerName:l,doAuthenticatedRequest:o,dryRun:s.dryRun,identifier:v,name:y,site:c.site,version:g},u);if(j.end(),O.length>0&&u.warn(`${oo("Warnings while uploading assets:")}\n - ${O.join("\n - ")}`),M.length>0){const e=M.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){v=e,u.error(`${ro("Failed to upload assets:")}\n${e?.message||e}`)}if(b&&await ye(b),w&&await w(),y.end(),v)throw v};const uo=a.join(__dirname,"./apps-runtime.mjs"),co=async()=>{throw new Error("Dry run should not perform authenticated requests.")},lo=({bundler:e,context:t,options:n})=>{const o=t.getLogger(de),{auth:i,buildRoot:s}=t;t.inject({type:"file",position:Ee.MIDDLE,value:uo});const{setBackendFunctions:u,getBackendFunctions:c}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[fe],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=Qe(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?`),u(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=a.relative(n,t).replace(fe,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:nt(e)})}return{functions:r,proxyCode:ot(i)}}(n,t,s);return u(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let u,d=new Map,l=c();if(l.length>0){const t=await async function(e,t,n,o){const i=await r.mkdtemp(a.join(p.tmpdir(),"dd-apps-backend-")),s=new Map,u=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const r of t){const t=nt(r),c=`\0dd-backend:${t}`,d=rt(r.name,r.absolutePath,n),l=Tn(r.absolutePath,n),p=Nn(n,{[c]:d},[l.plugin]),f=await e({...p,build:{...p.build,write:!0,outDir:i,emptyOutDir:!1,rollupOptions:{...p.build.rollupOptions,input:{[t]:c},output:{...p.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=a.resolve(i,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}u.set(r.absolutePath,l.getAllowedConnectionIds())}return{outDir:i,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:u.get(e.absolutePath)})))}}(e.build,l,s,o);u=t.outDir,d=t.outputs,l=t.functions}try{const e=n.dryRun?co:We(n.authOverrides.method,i,o);await ao({backendOutputs:d,backendFunctions:l,context:t,doAuthenticatedRequest:e,options:n})}finally{u&&await ye(u)}},configureServer(t){let r;try{r=We(n.authOverrides.method,i,o)}catch(e){if(!(e instanceof Ke))throw e}t.middlewares.use(Un(e.build,c,i,r,s,o))}}},po=({options:e,context:t,bundler:n})=>{const o=t.getLogger(de),r=ge(e);return"vite"!==t.bundler.name?(o.warn(`The apps plugin only supports Vite; skipping under '${t.bundler.name}'.`),[]):[{name:de,enforce:"post",vite:lo({bundler:n,context:t,options:r})}]},fo="errorTracking",mo="datadog-error-tracking-plugin",ho=(e,n,o)=>{if(".map"!==a.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=a.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return a.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}},go=/[/]+|[\\]+/g,yo=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,bo=(e,t)=>{const n=e.replace(yo,"").split(go),o=t.replace(yo,"").split(go),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},wo=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:bo(e.relativePath,t)}})(e,n),i=[],s=[],u=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{u.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${a.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:u,errors:i,warnings:s}},vo=e=>{const t=e.message.match(/HTTP (\d{3})/);return t?`status_code:${t[1]}`:"status_code:unknown"},$o=e=>{const t=vo(e);return"status_code:unknown"!==t?`error_type:http_${t.replace("status_code:","")}`:`error_type:${Q(e.name||"unknown")}`},ko=(e,t,n)=>{const o=((e,t)=>`${e}|${t.join("|")}`)(t,n),r=e.metrics.get(o);r?r.value++:e.metrics.set(o,{name:t,value:1,tags:n})},xo=(e,t,n)=>{ko(e,"retry",[...e.baseTags,`attempt:${n}`,vo(t),$o(t)])},Eo=(e,t)=>{ko(e,"failure",[...e.baseTags,vo(t),$o(t)])},So=(e,t)=>{if(!t.sendMetrics)return;if(!e.metrics.size)return;const n=(e=>{const t=Math.floor(Date.now()/1e3);return Array.from(e.metrics.values()).map((e=>({metric:`sourcemaps.upload.${e.name}`,type:"count",points:[[t,e.value]],tags:e.tags})))})(e);for(const e of n)t.addMetric(e)},Io=t.green.bold,Do=t.yellow.bold,Po=t.red.bold,Ao=(e,t={})=>async()=>L({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}),jo=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(y.default?y.default:y)({concurrency:t.maxConcurrency}),u=(c=n.site,N("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const d=z({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),l=(e=>({metrics:new Map,baseTags:[`service:${e.service}`]}))(t),p=Z({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),f=`\nUploading ${Io(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(f);const m=[];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,".")};m.push(a.add((async()=>{try{await U({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:Ao(s,d),onRetry:(t,n)=>{xo(l,t,n);const r=`Failed to upload ${Do(e.sourcemap)} | ${Do(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(Eo(l,n),r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}s.end(),o.debug(`Queued ${Io(e.length.toString())} uploads.`);try{await Promise.all(m),await a.onIdle()}finally{So(l,n)}return{warnings:i,errors:r}},Mo=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=>({...ho(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=>wo(e,s,i,n.git))));a.end();const c=u.map((e=>e.errors)).flat(),d=u.map((e=>e.warnings)).flat();if(d.length>0&&o.warn(`Warnings while preparing payloads:\n - ${d.join("\n - ")}`),c.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${c.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const l=o.time("Upload sourcemaps"),{errors:p,warnings:f}=await jo(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site,sendMetrics:n.sendMetrics,addMetric:n.addMetric},o);if(l.end(),o.debug(`Done uploading ${Io(`${e.length-p.length}/${e.length}`)} sourcemaps in ${Io(J(Date.now()-r))}.`),p.length>0){const e=`Failed to upload some sourcemaps:\n - ${p.map((({metadata:e,error:t})=>{const n=t.cause||t.stack||t.message;return e?`${Po(e.file)} | ${Po(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,{addMetric:t.addMetric,apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,sendMetrics:t.sendMetrics,site:t.site,version:t.version},n),i.end()},Oo=e=>{const n=t.bold.red,o=e[fo]||{},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},To=({options:e,context:t})=>{const n=t.getLogger(mo),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 ${mo}.`);return{...e[fo],sourcemaps:o.config}})(e,n);o.end();const i=ue(e,"metrics",n);let s,a,u=!1;const c=async()=>{if(!r.sourcemaps||u)return;u=!0;const e=n.time("sourcemaps process");await Mo(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:s,addMetric:t.addMetric,outDir:t.bundler.outDir,outputs:a?.outputs||[],sendMetrics:i,site:t.auth.site,version:t.version},n),e.end()};return[{name:mo,enforce:"post",async git(e){s=e,a&&await c()},async buildReport(t){a=t,!s&&W(e)||await c()},async asyncTrueEnd(){u||await c()}}]},Co="liveDebugger",No="datadog-live-debugger-plugin",Ro="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",_o="__DD_LIVE_DEBUGGER_BUILD__",Fo=e=>void 0===e?Ro:`${Ro};if(typeof globalThis.${_o}==='undefined'){globalThis.${_o}={version:${JSON.stringify(e)}}}`;function zo(e){return"function"==typeof e?e:e.default}function Lo(e,t,n,o,r){const i=a.relative(t,e).replace(/\\/g,"/"),s=qo(n,r);if(s)return`${i};${s}`;const u=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${u}:${o}`}function qo(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)?Vo(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=Uo(e.object,t),o=Bo(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)?Vo(o.key,t):null}function Uo(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=Uo(e.object,t),o=Bo(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function Bo(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function Vo(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 Ho(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function Ko(e,t){const n=[];if(t.isBlockStatement(e.body)){const o=e.params.flatMap((e=>Zo(e,t))),r=new Set(o),i="id"in e&&t.isIdentifier(e.id)?e.id.name:"";for(const o of e.body.body)if(t.isVariableDeclaration(o)){const e=o.end;if(null==e)continue;for(const s of o.declarations)for(const o of Zo(s.id,t))r.has(o)||o===i||n.push({name:o,declarationEnd:e,temporalDeadZones:[]})}}const o=n.length>25?n.slice(0,25):n;if(t.isBlockStatement(e.body)){const n=o.map((({name:e})=>e)),r=new Set(n),i=function(e,t,n){const o=new Map;for(const r of e.body)Wo(r,t,o,n);return o}(e.body,r,t);for(const e of o)e.temporalDeadZones=i.get(e.name)??[]}return o}function Wo(e,t,n,o){o.isFunctionDeclaration(e)||o.isClassDeclaration(e)||(o.isBlockStatement(e)?Jo(e,t,n,o):o.isIfStatement(e)?(Wo(e.consequent,t,n,o),e.alternate&&Wo(e.alternate,t,n,o)):o.isForStatement(e)||o.isForInStatement(e)||o.isForOfStatement(e)||o.isWhileStatement(e)||o.isDoWhileStatement(e)?Wo(e.body,t,n,o):o.isSwitchStatement(e)?function(e,t,n,o){for(const r of e.cases){Go(r.consequent,e.start,t,n,o);for(const e of r.consequent)Wo(e,t,n,o)}}(e,t,n,o):o.isTryStatement(e)?(Jo(e.block,t,n,o),e.handler&&Jo(e.handler.body,t,n,o),e.finalizer&&Jo(e.finalizer,t,n,o)):(o.isLabeledStatement(e)||o.isWithStatement(e))&&Wo(e.body,t,n,o))}function Jo(e,t,n,o){Go(e.body,e.start,t,n,o);for(const r of e.body)Wo(r,t,n,o)}function Go(e,t,n,o,r){if(null!=t)for(const i of e)r.isVariableDeclaration(i)&&"var"!==i.kind?Yo(i,t,n,o,r):r.isClassDeclaration(i)&&i.id&&Qo(i.id.name,t,i.end,n,o)}function Yo(e,t,n,o,r){for(const i of e.declarations)for(const s of Zo(i.id,r))Qo(s,t,e.end,n,o)}function Qo(e,t,n,o,r){if(null==n||!o.has(e))return;const i=r.get(e)??[];i.push({start:t,end:n}),r.set(e,i)}function Zo(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:Zo(e.argument,t):t.isAssignmentPattern(e)?Zo(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?Zo(e.argument,t):Zo(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?Zo(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const Xo=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let er,tr,nr,or,rr=!1;function ir(e){try{return function(e){switch(e){case"@babel/parser":return require("@babel/parser");case"@babel/traverse":return require("@babel/traverse");case"@babel/types":return require("@babel/types");case"magic-string":return require("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 Xo.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=Xo.find((t=>e.message.includes(t))),n=t??Xo.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 ${Xo.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const sr=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function ar(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,c=0,d=0,l=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:1,skippedUnsupportedCount:d,totalFunctions:l};if(!sr.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l};rr||(er=ir("@babel/parser").parse,tr=zo(ir("@babel/traverse")),nr=ir("@babel/types"),or=zo(ir("magic-string")),rr=!0);const p=er(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map,h=new Set,g=new Map,y=new Map;let b=0;if(tr(p,{Function(e){l++;const t=function(e,t){if(t.isClassMethod(e.node)&&"constructor"===e.node.kind&&mr(e,t))return e.node;return}(e,nr);if(t&&(m.set(t,t.body.start),g.set(t,function(e,t){const n=[];for(const o of e)dr(o,n,t);return n}(t.body.body,nr))),!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,nr))return void d++;if(r&&function(e,t,n){let o=e;for(;o;){if(Ho(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return Ho(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",nr))return void c++;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,nr)))return void d++;if(s&&!qo(e,nr))return void d++;let p=0;if(!qo(e,nr)){const t=e.parentPath?.node;t&&(p=y.get(t)||0,y.set(t,p+1))}const w=Lo(n,o,e,p,nr);try{const t=e.node,n=b++,o=`$dd_p${n}`,r=function(e,t){const n=[];for(const o of e.params)for(const e of Zo(o,t))"this"!==e&&n.push(e);return n.length>25?n.slice(0,25):n}(t,nr),i=Ko(t,nr),s=nr.isArrowFunctionExpression(t)&&!nr.isBlockStatement(t.body),a=s&&nr.isSequenceExpression(t.body),c=function(e,t){if(t.isFunction(e.node)&&!t.isArrowFunctionExpression(e.node))return;let n=e.parentPath;for(;n;){const e=n.node;if(t.isClassMethod(e)&&"constructor"===e.kind){if(!mr(n,t))return;return{node:e,parent:n.parent,parentPath:n.parentPath}}if(t.isFunction(e)){if(t.isArrowFunctionExpression(e)){n=n.parentPath;continue}return}n=n.parentPath}return}(e,nr),d=null!=c;c&&(h.add(c.node),m.set(c.node,c.node.body.start));const l=[],p=s||!nr.isBlockStatement(t.body)||!yr(t.body.body,nr);let g;if(!s&&nr.isBlockStatement(t.body)&&gr(t.body.body,l,nr),!s&&nr.isBlockStatement(t.body)&&t.body.directives.length>0){g=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,hasSequenceExpressionBody:a,aliasesExpressionBodySuperCall:d&&s&&fr(t.body,nr),needsTrailingReturn:p,useThisAlias:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:g,functionId:w,probeVarName:o,probeIdx:String(n),entryVars:r,localVars:i,returns:l}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l};const w=new or(t),v=function(e){const t=new Set;for(const n of e)n.aliasesExpressionBodySuperCall&&t.add(pr({start:n.bodyStart,end:n.bodyEnd}));return t}(f),$=function(e,t,n,o){const r=[];for(const i of e){const e=t.get(i);null!=e&&r.push({bodyStart:e,superCalls:(n.get(i)??[]).filter((e=>!o.has(pr(e))))})}return r}(h,m,g,v);for(let e=f.length-1;e>=0;e--)ur(w,t,f[e]);for(const e of $)cr(w,t,e);return{code:w.toString(),map:w.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l}}function ur(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,localVars:a,returns:u,bodyStart:c,bodyEnd:d,functionEnd:l,isExpressionBody:p,hasSequenceExpressionBody:f,aliasesExpressionBodySuperCall:m,useThisAlias:h,bodyParenStart:g,directivesEnd:y}=n,b=`$dd_e${r}`,w=`$dd_rv${r}`,v=h?"$dd_t":"this",$=s.join(", "),k=""!==$,x=k?`, ${b}()`:"";const E=`const ${o} = $dd_probes('${i.replace(/['\\\n\r\u2028\u2029]/g,(e=>{switch(e){case"'":return"\\'";case"\\":return"\\\\";case"\n":return"\\n";case"\r":return"\\r";case"\u2028":return"\\u2028";case"\u2029":return"\\u2029";default:return e}}))}');`,S=k?`const ${b} = () => ({${$}});`:"",I=`if (${o}) $dd_entry(${o}, ${v}${x});`,D=`catch(e) { if (${o}) $dd_throw(${o}, e, ${v}${x}); throw e; }`;if(p){if(null!=g){const n=function(e,t,n){const o=[];for(let r=t;r<n;r++)"("===e[r]&&o.push(r);return o}(t,g,c),o=function(e,t,n){const o=[];for(let r=n-1;r>=t;r--)")"===e[r]&&o.push(r);return o}(t,d,l),r=Math.min(n.length,o.length);for(let t=0;t<r;t++){const r=n[t],i=o[t];e.remove(r,r+1),e.remove(i,i+1)}}const n=["{",E,S,"try {",I,m?`const ${w} = ($dd_t = `:`const ${w} = `].filter(Boolean).join("\n");let r=f?");":";";m&&(r=f?"));":");");const i=[r,`if (${o}) $dd_return(${o}, ${w}, ${v}${hr(b,k,a,d)});`,`return ${w};`,`} ${D}`,"}"].join("\n");if(d-c>=2){const o=f?`${n}(${t[c]}`:n+t[c];e.update(c,c+1,o),e.update(d-1,d,t[d-1]+i)}else e.update(c,d,n+t.slice(c,d)+i)}else{const r=[E,S,"try {",`let ${w};`,I].filter(Boolean).join("\n");for(const t of u){const n=hr(b,k,a,t.start);if(null!=t.argStart&&null!=t.argEnd){const r=t.hasSequenceExpressionArgument?`(${w} = (`:`(${w} = `,i=t.hasSequenceExpressionArgument?")":"";e.appendLeft(t.argStart,r),e.appendLeft(t.argEnd,`${i}, ${o} ? $dd_return(${o}, ${w}, ${v}${n}) : ${w})`)}else e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, ${v}${n}); `)}if(null!=y){const n=y-1;e.update(n,y,`${t[n]}\n${r}`)}else e.update(c,c+1,`${t[c]}${r}`);const i=hr(b,k,a,d),s=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, ${v}${i});\n`:""}} ${D}\n`;e.update(d-1,d,`${s}${t[d-1]}`)}}function cr(e,t,n){e.update(n.bodyStart,n.bodyStart+1,`${t[n.bodyStart]}let $dd_t;`);for(const t of n.superCalls)e.appendLeft(t.start,"($dd_t = "),e.appendLeft(t.end,")")}function dr(e,t,n){fr(e,n)&&t.push({start:e.start,end:e.end});const o=Object.values(e);for(const e of o)if(Array.isArray(e))for(const o of e)lr(o,t,n);else lr(e,t,n)}function lr(e,t,n){n.isNode(e)&&(n.isFunction(e)&&!n.isArrowFunctionExpression(e)||dr(e,t,n))}function pr(e){return`${e.start}:${e.end}`}function fr(e,t){return t.isCallExpression(e)&&t.isSuper(e.callee)}function mr(e,t){const n=e.parentPath?.parentPath;if(!n)return!1;const o=n.node;return(t.isClassDeclaration(o)||t.isClassExpression(o))&&null!=o.superClass}function hr(e,t,n,o){const r=function(e,t){const n=e.filter((({declarationEnd:e,temporalDeadZones:n})=>e<=t&&!function(e,t){return e.some((({start:e,end:n})=>e<=t&&t<n))}(n,t))).map((({name:e})=>e));if(0===n.length)return;return`{${n.join(", ")}}`}(n,o);return t&&r?`, ${e}(), ${r}`:t?`, ${e}()`:r?`, undefined, ${r}`:""}function gr(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,hasSequenceExpressionArgument:n.isSequenceExpression(o.argument)});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))gr(o.body,t,n);else if(n.isIfStatement(o))gr([o.consequent],t,n),o.alternate&&gr([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))gr([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)gr(e.consequent,t,n);else n.isTryStatement(o)?(gr(o.block.body,t,n),o.handler&&gr(o.handler.body.body,t,n),o.finalizer&&gr(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&gr([o.body],t,n)}function yr(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 yr(e,t)&&yr(o,t)}return!1}const br=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],wr=t.bold.red,vr=Number(process.env.DD_LD_LIMIT)||1/0,$r=(e,t)=>{const n=t.getLogger(No);let o=0,r=0,i=0,s=0,a=0,u=0,c=0,d=0;return{name:No,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(l,p){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?p.includes(e):e.test(p))))return{code:l}}for(const t of e.exclude){if("string"==typeof t?p.includes(t):t.test(p))return{code:l}}if(d>=vr)return{code:l};try{const f=ar({code:l,filePath:p,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,c+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&d++,0===f.instrumentedCount)return{code:l};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),h=f.map&&m?function(e,t,n,o){try{return b(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,p,n):f.map;return{code:f.code,map:h}}catch(e){return n.error(`Instrumentation Error in ${p}: ${e}`,{forward:!0}),{code:l}}}},buildEnd:()=>{c>0&&n.info(`Live Debugger: ${o}/${c} functions instrumented across ${u}/${d} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:d,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},kr=({options:e,context:t})=>{const n=((e,t)=>{const n=e[Co]||{},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(`${wr("include")} patterns must be strings or RegExp`);break}}else r.push(`${wr("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(`${wr("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${wr("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${wr("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!br.includes(e)){r.push(`${wr("functionTypes")} contains invalid value "${e}". Valid values: ${br.join(", ")}`);break}}else r.push(`${wr("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${wr("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${No}.`);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(No));return t.inject({type:"code",position:Ee.BEFORE,injectIntoAllChunks:!0,value:Fo(n.version)}),[$r(n,t)]};const xr=[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};/^sourcemaps\.upload\.(failure|retry)$/.test(e.metric)&&(t.count=0),/(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}],Er="metrics",Sr="datadog-metrics-plugin",Ir=e=>Math.floor((e||Date.now())/1e3),Dr=(e,t)=>{const n=[`bundler:${Q(e.bundler.name)}`,`plugin_version:${Q(e.version)}`,`site:${Q(e.auth.site)}`];return e.build.metadata.name&&n.push(`build_name:${Q(e.build.metadata.name)}`),e.build.metadata.version&&n.push(`build_version:${Q(e.build.metadata.version)}`),[...n,...t]},Pr=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),Ar=(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(Pr(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Pr({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i},jr=(e="")=>e.endsWith("/")?e:`${e}/`,Mr=(e,t)=>{let n=e;return e.split(jr(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},Or=(e,t)=>e.split("!").pop().replace(jr(t),"./"),Tr=(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)),Or(o||"no-name",n)},Cr=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),Nr=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Rr=t.bold.red,_r=t.bold.cyan,Fr=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},zr=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Fr("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:J(e.duration)}))),top:!0};n.sort(Fr("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Lr=(e,t,n)=>{const o=[];var r;n&&(o.push(...zr("Loader",n.loaders)),o.push(...zr("Tapable",n.tapables)),o.push(...zr("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=K(e.build),a=new Map,u=new Map,c=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)c.has(n)||c.set(n,new Set),c.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(c.has(e.filepath)){const t=c.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),c.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=c.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 d=Array.from(i);return d.sort(Fr((e=>e.dependents.size))),t.values=d.map((e=>({name:e.name,value:e.dependents.size.toString()}))),d.sort(Fr((e=>e.dependencies.size))),n.values=d.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),d.sort(Fr("size")),o.values=d.map((e=>({name:e.name,value:g(e.size)}))),d.sort(Fr("aggregatedSize")),r.values=d.map((e=>({name:e.name,value:g(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(Fr((e=>e.size))).map((e=>({name:e.name,value:g(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Fr((e=>e.size))).map((e=>({name:e.name,value:g(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Fr((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:J(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:J(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:J(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=G(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+=` [${Rr(e.value)}] ${" ".repeat(n)}${_r(e.name)}\n`}}return t})(o);t.info(i)},qr="api/v1/series",Ur=t.bold.green,Br=(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: ${Ur(`https://api.${t.site}/${qr}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),U({method:"POST",url:`https://api.${t.site}/${qr}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))},Vr=["onStart","onLoad","onResolve","onEnd"],Hr=new Map,Kr=new Map,Wr=new Map,Jr=(e,t,n)=>{const o=Object.assign({},e);for(const r of Vr)o[r]=async(o,i)=>{const s=Kr.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=Or(e[0].path,n),u=Wr.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=w.performance.now();try{return await i(...e)}finally{const n=w.performance.now(),i=n-c,d={start:c,end:n,duration:i,context:Nr(e)};if(s.events[r].values.push(d),s.duration+=i,s.increment+=1,Kr.set(t,s),u.events[r].values.push(d),u.duration+=i,u.increment+=1,Wr.set(o,u),a){const e=Hr.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(d),e.duration+=i,e.increment+=1,Hr.set(t,e)}}}))};return o},Gr=(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=Jr(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:Kr,modules:Wr,loaders:Hr};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class Yr{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Tr(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Cr))(e);o.length||o.push("no-loader"),this.started[n]={module:Mr(n),timings:{start:w.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Tr(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=w.performance.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 Qr{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=w.performance.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,Nr(r),i,w.performance.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=w.performance.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,Nr(r),i,w.performance.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=w.performance.now(),s=t.apply(this,r);return this.saveResult(e,n,o,Nr(r),i,w.performance.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 c=this.getTapPatch(e,i,s,t);return n.call(o,r,c)}}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(Sr)||(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 Zr=e=>async t=>{const n=e.getLogger(Sr),o={name:Sr},r=new Qr(e.buildRoot),i=new Yr(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})}))},Xr={filters:xr},ei=({options:e,context:t,stores:n})=>{const o=t.getLogger(Sr);let r=0;((e,t)=>{e.addMetric=e=>{t.metrics.add(e)}})(t,n);const i=((e,t)=>{const n=e[Er],o=Ir(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enableDefaultPrefix:!0,enableTracing:!1,filters:xr,tags:[],...e[Er],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[],a={name:Sr,enforce:"pre",esbuild:Gr(t,o),webpack:Zr(t),rspack:Zr(t)},u=o.time("build",{start:!1}),c=i.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,l;const p=async()=>{if(!n.metrics.size)return;const e=o.time("aggregating collected metrics"),r=(()=>{const e=new Set(n.metrics);n.metrics.clear();const o=Dr(t,i.tags);return Ar(e,i.timestamp,i.filters,o,i.prefix)})();await t.asyncHook("metrics",r),e.end();const s=o.time("sending collected metrics to Datadog");await Br(r,{apiKey:t.auth.apiKey,site:t.auth.site},o),s.end()},f=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-r;const e=o.time("aggregating metrics"),n=i.timestamp,s=o.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,c=new Map,d=new Map,l=new Map;for(const e of i){for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");l.has(n)||l.set(n,[]),l.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.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}`];c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`entryName:${e}`))),d.has(e.filepath)&&o.push(...d.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$/,"");l.has(r)&&o.push(...l.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})(l,n);s.end();const u=o.time("aggregate plugins metrics"),c=((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,n);u.end();const p=o.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,n);p.end();const m=new Set([...a,...c,...f]),h=Dr(t,i.tags),g=Ar(m,n,i.filters,h,i.prefix);await t.asyncHook("metrics",g),e.end();const y=o.time("outputing report");Lr(t,o,d),y.end();const b=o.time("sending metrics to Datadog");await Br(g,{apiKey:t.auth.apiKey,site:t.auth.site},o),b.end()},m={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){u.resume(),t.build.start=t.build.start||Date.now(),e[Er]?.timestamp||(i.timestamp=Ir(t.build.start))},buildEnd(){u.end(),r=Date.now()},async timings(e){d=e,l&&await f()},async buildReport(e){l=e,!d&&c||await f()},async flush(){await p()}};return i.enableTracing&&s.push(a),s.push(m),s},ti="output",ni="datadog-output-plugin",oi=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,ri=e=>{const t=void 0===e;return{build:oi("build",e?.build??t),bundler:oi("bundler",e?.bundler??t),dependencies:oi("dependencies",e?.dependencies??t),errors:oi("errors",e?.errors??t),logs:oi("logs",e?.logs??t),metrics:oi("metrics",e?.metrics??t),timings:oi("timings",e?.timings??t),warnings:oi("warnings",e?.warnings??t)}},ii=(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}))}))},si=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},ai=({options:e,context:t})=>{const n=t.getLogger(ni),o=(e=>({path:"./",...e[ti],files:ri(e[ti]?.files)}))(e),r=(e,r)=>{const u=o.files[e];if(!r||!1===u)return;t.queue((async()=>{const e=n.time(`output ${u}`),c=((e,t,n)=>{const o=a.isAbsolute(t)?t:a.resolve(e,t);return a.resolve(o,n)})(t.bundler.outDir,o.path,u);let d;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await be(a.dirname(e));const n=i.createWriteStream(e),o=new s.JsonStreamStringify(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(c,e)}catch(e){d=e}d?n.error(`Failed writing ${u}: ${d}`):n.debug(`Wrote "./${a.relative(t.buildRoot,c)}"`),e.end()})())};return[{name:ni,buildReport(e){const t=n.time("serialize report"),o=K(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:ii(n,(e=>{r("bundler",e)})),rollup:si((e=>{r("bundler",e)})),vite:si((e=>{r("bundler",e)})),webpack:ii(n,(e=>{r("bundler",e)}))}]},ui="rum",ci="datadog-rum-plugin",di=["8","9","a","b"],li=(e,t)=>{const n={service:e.service,version:e.version};return e.debugId&&(n.ddDebugId=t?(e=>{const t=d.createHash("sha256").update(e).digest("hex").slice(0,32),n=`${t.slice(0,12)}4${t.slice(13)}`,o=n.charCodeAt(16)%4,r=`${n.slice(0,16)}${di[o]}${n.slice(17)}`;return[r.slice(0,8),r.slice(8,12),r.slice(12,16),r.slice(16,20),r.slice(20,32)].join("-")})(t):d.randomUUID()),`(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(n)},${JSON.stringify("DD_SOURCE_CODE_CONTEXT")});`},pi="datadog-rum-privacy-plugin";const fi=(e,t)=>{const n=t.getLogger(pi),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:pi,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=v.instrument({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}})}}},mi=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,hi=(e,t)=>{const n=e.sdk;if(n.clientToken)return mi(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 U({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 mi({...e,sdk:{clientToken:o,...n}})}},gi=e=>{const n=t.bold.red,o=e[ui]||{},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},yi=e=>{const t=e[ui]||{},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},bi=e=>{const n=t.bold.red,o=e[ui]||{},r={errors:[]};if(!o.sourceCodeContext)return r;const i=o.sourceCodeContext;return i?.debugId||i?.service&&"string"==typeof i.service||r.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),r.config={...i,version:i.version||e.metadata?.version},r},wi=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=gi(e),r=yi(e),i=bi(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 ${ci}.`);const s={...e[ui],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(ci)),o=[],r=n.sourceCodeContext;if(r&&t.inject({type:"code",position:Ee.BEFORE,injectIntoAllChunks:!0,value:e=>li(r,e)}),n.sdk&&(t.inject({type:"file",position:Ee.MIDDLE,value:a.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Ee.MIDDLE,value:hi(n,t)})),n.privacy){t.inject({type:"file",position:Ee.BEFORE,value:a.join(__dirname,"./privacy-helpers.js")});const e=fi(n.privacy,t);o.push(e)}return o},vi="datadog-analytics-plugin",$i=({context:e})=>{const t=e.getLogger(vi);return[{name:vi,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}`)}})())}}]},ki="datadog-async-queue-plugin",xi=e=>{const{context:t,stores:n}=e,o=t.getLogger(ki),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:ki,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Ei=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.glob.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},Si=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Ii=/(\?|%3F|\|)+/gi,Di=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=ji(e),Si.lastIndex=0,Si.exec(t)?.[1]||"unknown");var t},Pi=["unknown","commonjsHelpers.js",`vite${a.sep}preload-helper.js`],Ai=(e,t,n)=>{const o=new Set;for(const n of e){const e=ji(n);H(n)||e===t||Pi.includes(e)||o.add(e)}return o},ji=e=>e.split("!").pop().split(Ii).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Mi=(e,t)=>H(t)?I:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(a.sep),o=e.split(a.sep).filter(((e,t)=>e===n[t])).join(a.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(Ii).shift().replace(/^((\.\.?)?[/\\])+/g,""),Oi=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[Vn(t,e),n]))),Ti=(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 Ei(n,e,t));for(const t of r){const n=Mi(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,u=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 c=[],d=[],l=[],p=[],f=[],m={},h={},g=t.time("indexing metafile data"),y=Oi(n.metafile.inputs,u),b=Oi(n.metafile.outputs,u);g.end();const w=e=>{if(!H(e))return e;const t=y[Vn(u,e)];if(!t)return e;const n=t.imports.find((e=>!H(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(H(e))continue;const n=Vn(u,e),o={name:Mi(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Di(e)};m[n]=o,c.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=Vn(u,e),i=Mi(s,n),a=[];for(const e of Object.keys(r.inputs)){if(H(e))continue;const n=m[Vn(u,e)];n?a.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!a.length){const e=m[Vn(u,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}a.push(e)}const c={name:i,filepath:n,inputs:a,size:r.bytes,type:Di(n)};if(h[n]=c,"map"===c.type&&p.push(c),d.push(c),!r.entryPoint)continue;const f=m[Vn(u,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...c,name:o.get(f.name)||f.name,outputs:[c],size:c.size};l.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of p){const n=h[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:h,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!H(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(/^\.\.?\//),d=i?a.dirname(e):u,l=Vn(d,t.path);if(t.external){if(S(t.path)){const e=i?l:t.path,n=x.inputs.report[e]||{filepath:e,name:Mi(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),c.includes(n)||c.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(l,n,o)}return o},D=t.time("looping through entries");for(const e of l){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 P=t.time("aggregate dependencies and dependents");for(const e of c){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?a.dirname(e.filepath):u,i=Vn(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}`)}P.end(),e.build.outputs=d,e.build.inputs=c,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),Ci=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),s=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}),c=t.time("filling sourcemaps inputs",{start:!1}),d=new Map,l=new Map,p=new Map,f=new Map;return{buildStart(){f.clear(),d.clear(),l.clear(),p.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=ji(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=Ai(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=Ai(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 h=n.dir?Vn(e.buildRoot,n.dir):e.bundler.outDir,g=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=ji(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=ji(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(),s.resume();for(const[e,n]of Object.entries(m)){const o=Vn(h,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),s=l.get(o)||{name:e,filepath:o,inputs:[],size:r,type:Di(e)};if("map"===s.type&&y.add(s),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(ji(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=i.statSync(e).size}catch(e){n=t.renderedLength}const o=d.get(e)||{name:Mi(h,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Di(e)};s.inputs.push(o),d.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=ji(e);if(!f.has(n)){b.set(Vn(h,n),s);continue}if(d.has(n)){t.debug(`Input report already there for ${n} from ${s.name}.`);continue}const o=d.get(n)||{name:Mi(h,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};s.inputs.push(o),d.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...s,name:n.name,size:0,outputs:[s]}),l.set(s.filepath,s)}s.end();for(const[e,n]of b){const o=l.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 d){const o=f.get(e);if(o){for(const e of o.dependencies){const o=d.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Mi(h,e)} of ${n.name}`)}for(const e of o.dependents){const o=d.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Mi(h,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){c.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=l.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}c.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Mi(h,e),r=l.get(e);if(!r)return d.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[Mi(h,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(Vn(h,e),n);return n};r.resume();for(const e of g){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),p.has(e.filepath)&&t.debug(`Entry "${e.name}":"${Mi(h,e.filepath)}" already reported.`),p.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(d.values()),e.build.outputs=Array.from(l.values()),e.build.entries=Array.from(p.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},Ni=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,c=new Map,d=new Map,l=[],p=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||H(e)),h=e=>e.replace(/(^external[^"]+"|"$)/g,""),g=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=ji(e);t.add(n),n.startsWith("external ")&&t.add(h(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(d.has(e)){const n=d.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else d.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=ji(t.request);if(d.has(n))return d.get(n);if(e.context){const t=Vn(ji(e.context),n);if(d.has(t))return d.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(),d.clear(),p.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)g(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Mi(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)?h(r):r))})).filter(Boolean));if(!m(t))continue;const s=p.get(t)||{dependents:new Set,dependencies:new Set};for(const e of i){const n=p.get(e)||{dependencies:new Set,dependents:new Set};n.dependents.add(t),s.dependencies.add(e),p.set(e,n)}p.set(t,s);const u=w(n)?{size:0,name:h(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:Di(t)};r.push(u),a.set(t,u),w(n)&&a.set(h(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=p.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,d=t.getAssets(),p=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>Vn(e.bundler.outDir,t))),h=n.time("indexing chunks"),g=t.chunkGraph;for(const e of o){const t=p(e),n=(g?.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"===Di(e))continue;const t=c.get(e)||new Set;for(const e of n)t.add(e);c.set(e,t)}}h.end();const y=n.time("building outputs");for(const t of d){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:Vn(e.bundler.outDir,t.name),type:Di(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){l.push(o);continue}const r=c.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 l){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 c=v(r),d=Array.from(c).flatMap(p),l=r.chunks.filter((e=>g.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===Di(e)));for(const e of d){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:l?Vn(e.bundler.outDir,l):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:l?Di(l):"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)}))},Ri="datadog-build-report-plugin",_i=e=>{const{context:t}=e,n=t.getLogger(Ri);return[{name:Ri,enforce:"post",esbuild:Ti(t,n),rspack:Ni(t,Ri,n),webpack:Ni(t,Ri,n),vite:Ci(t,n),rollup:Ci(t,n)}]},Fi="datadog-bundler-report-plugin",zi=(e,t)=>t?a.isAbsolute(t)?t:a.resolve(e,t):"",Li=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?a.dirname(e.file):void 0)).filter(Boolean)},qi=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=zi(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Ui=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Li(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=Kn(r,process.cwd())),e.bundler.outDir=zi(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Bi=e=>{const{context:t}=e,n=t.getLogger(Fi);return[{name:Fi,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=zi(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=zi(t.buildRoot,a.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:qi(t),rspack:qi(t),vite:Ui(t),rollup:{options(e){let n;if("output"in e){const t=Li(e.output);n=Kn(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(a.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=Vn(process.cwd(),n);const e=Kn([n,...o],process.cwd());t.buildRoot=e===a.sep?process.cwd():e}else t.buildRoot=Kn(o,process.cwd()),t.bundler.outDir=a.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=Li(e);Kn(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.")}}}]},Vi="datadog-custom-hooks-plugin",Hi=e=>{const{context:t}=e,n=t.getLogger(Vi),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:Vi,enforce:"pre"}]};class Ki{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 Wi=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await Ji(e);for(const e of t)if(e.name===n)return Y(e.refs.push);return Y(t[0].refs.push)},Ji=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},Gi=async e=>e.revparse("HEAD"),Yi=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),Qi=async e=>e.branch(),Zi=async e=>e.show(["-s","--format=%s"]),Xi=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),es="datadog-git-plugin",ts=e=>{const{options:t,context:n}=e,o=n.getLogger(es),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=$.simpleGit(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return $.simpleGit(t)})(a.dirname(e));if(0===(await t.getRemotes(!0)).length)return o.warn("No git remotes available, skipping git plugin. This is expected for a repository that has not been pushed yet."),void r.end();const i=await(async e=>{const t=[Gi(e),Qi(e),Zi(e),Xi(e),Yi(e),Wi(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,c,d,l,p,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:c,date:d},committer:{name:l,email:p,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new Ki(s)}})(t);n.git=i,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:es,enforce:"pre",buildRoot(e){if(W(t))try{r.resume();const t=Hn(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}`)}}}]},ns="datadog-injection-plugin",os=/^https?:\/\//,rs=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],is=t.bold.yellow,ss=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(Vn(t,e));function as(e){return e.some((e=>e.injectIntoAllChunks))}const us=(e,t,n)=>{const o=e.filter((e=>e.position===t&&(!n||n.isEntry||e.injectIntoAllChunks))).map((e=>hs(e.value)?e.value(n):e.value)).filter(Boolean);if(0===o.length)return"";return`// begin injection by Datadog build plugins\n${o.map((e=>`(() => {${e}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},cs=async(e,t,n=process.cwd())=>{const o=hs(e.value)?await e.value():e.value;try{if("file"===e.type){const e=o;return await(e.match(os)?(async(e,t=5e3)=>{let n;return Promise.race([U({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(e):ss(e,n))}return o}catch(r){const i=`${e.type} - ${G(o)}`;return e.fallback?(t.debug(`Fallback for "${i}": ${r.toString()}`),cs(e.fallback,t,n)):(t.warn(`Failed "${i}": ${r.toString()}`),"")}},ds=async(e,t,n,o=process.cwd())=>{const r=t.filter(ms).map((e=>{const t=e.value;return{...e,value:e=>t(e.sourceOrHash)}})),i=t.filter((e=>!ms(e))),s=await Promise.all(i.map((async t=>({...t,value:await cs(t,e,o)})))),a=e=>({...e,position:e.position??Ee.BEFORE});n.push(...r.map(a),...s.map(a))},ls=e=>e instanceof Error&&"code"in e,ps=e=>rs.includes(e),fs=(e,t,n)=>{e.warn(`"${is(t)}" files are not supported (${is(n)}).`)},ms=e=>"function"==typeof e.value&&1===e.value.length,hs=e=>"function"==typeof e,gs=i.promises,ys=(e,t,n)=>({setup(o){const{onStart:s,onResolve:u,onLoad:c,onEnd:d,esbuild:l,initialOptions:f}=o,m=[],h=`${t.bundler.name}.${Ee.MIDDLE}.${I}.js`,g=i.realpathSync(p.tmpdir()),y=a.resolve(g,h),b=new RegExp(`${h}$`),w=f.inject;f.inject=w?[...w]:[],f.inject.push(y),s((async()=>{m.push(...await Ei(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await be(a.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),u({filter:b},(async e=>({path:e.path,namespace:ns}))),c({filter:b,namespace:ns},(async()=>({contents:us(n,Ee.MIDDLE)||" ",resolveDir:t.buildRoot,loader:"js"}))),d((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");if(!function(e){return e.some((e=>e.position===Ee.BEFORE||e.position===Ee.AFTER))}(n))return;const r=[];for(const[i,s]of Object.entries(o.metafile.outputs)){const o=Boolean(s.entryPoint&&m.some((e=>e.resolved.endsWith(s.entryPoint))));if(!o&&!as(n))continue;const u=Vn(t.buildRoot,i),{base:c,ext:d}=a.parse(u);ps(d)?r.push((async()=>{try{const e=`${u}.map`,t=await gs.readFile(u,"utf-8"),r=await gs.readFile(e,"utf-8").catch((()=>!1)),i=a.basename(u),s=us(n,Ee.BEFORE,{sourceOrHash:t,fileName:i,isEntry:o}),c=us(n,Ee.AFTER,{sourceOrHash:t,fileName:i,isEntry:o});if(!s&&!c)return;const d=t.replace(/\n?\/\/# sourceMappingURL=.*$/m,""),p=r?`${d}\n//# sourceMappingURL=data:application/json;base64,${Buffer.from(r).toString("base64")}`:d,f=await l.transform(p,{loader:"default",banner:s,footer:c,sourcemap:r?"external":void 0,sourcefile:i});await Promise.all([gs.writeFile(u,f.code),r&&f.map?gs.writeFile(e,f.map):null])}catch(t){if(!ls(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${u}: ${t}`)}})()):fs(e,d,c)}await Promise.all(r)}))}}),bs=I,ws="?inject-proxy",vs=(e,t)=>({renderChunk(n,o){const{base:r,ext:i}=a.parse(o.fileName);if(!ps(i))return fs(e,i,r),null;const s=us(t,Ee.BEFORE,{sourceOrHash:n,fileName:o.fileName,isEntry:o.isEntry}),u=us(t,Ee.AFTER,{sourceOrHash:n,fileName:o.fileName,isEntry:o.isEntry});if(!s&&!u)return null;const c=new k(n);return s&&c.prepend(`${s}\n`),u&&c.append(`\n${u}`),{code:c.toString(),map:c.generateMap({file:o.fileName,hires:"boundary"})}},async resolveId(e,n,o){if(H(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&us(t,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}${ws}`}return null},load(e){if(H(e))return us(t,Ee.MIDDLE);if(e.endsWith(ws)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(bs)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null}}),$s=(e,t,n,o,r)=>s=>{const u=new WeakMap,c=e.sources.ConcatSource,d=n.bundler.name,l=a.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${d}.${Ee.MIDDLE}.${I}.js`);we(l,"");s.hooks.shutdown.tap(ns,(()=>{var e;e=l,i.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const p=async()=>{await ds(t,o,r,n.buildRoot)};s.hooks.beforeRun.tapPromise(ns,p),s.hooks.watchRun.tapPromise(ns,p),s.hooks.compilation.tap(ns,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:ns,stage:o},(()=>{for(const e of n.chunks){const o=e.canBeInitial(),i=e.contentHash?.javascript??e.hash;for(const s of e.files){const{base:e,ext:d}=a.parse(s);if(!ps(d)){fs(t,d,e);continue}const l=a.basename(s),p=us(r,Ee.BEFORE,{sourceOrHash:i,fileName:l,isEntry:o}),f=us(r,Ee.AFTER,{sourceOrHash:i,fileName:l,isEntry:o});""===p&&""===f||n.updateAsset(s,(e=>{const t=u.get(e);if(!t||t.banner!==p||t.footer!==f){const t=new c(p,"\n",e,"\n",f);return u.set(e,{source:t,banner:p,footer:f}),t}return t.source}))}}}))}));const f=(e=>{const n={import:[l]},o=e=>{for(const[n,o]of Object.entries(e))"object"==typeof o?(o.import=o.import||[],o.import.unshift(l)):"string"==typeof o?e[n]=[l,o]:Array.isArray(o)?o.unshift(l):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}})(s.options.entry);s.options.entry=f},ks=e=>{const{bundler:t,context:n}=e,o=n.getLogger(ns),r=[],i=[];n.inject=e=>{r.push(e)};const s={name:ns,enforce:"post",esbuild:ys(o,n,i),webpack:$s(t,o,n,r,i),rspack:$s(t,o,n,r,i),rollup:vs(o,i),vite:{...vs(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>us(i,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:D},handler:()=>({code:us(i,Ee.MIDDLE)})}:s.buildStart=async()=>{await ds(o,r,i,n.buildRoot)},[s]},xs="datadog-true-end-plugin",Es=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=async()=>{await t.asyncHook("flush")},r=()=>{t.hook("syncTrueEnd")},i=async()=>{r(),await n(),await o()},s=e=>{e.hooks.shutdown.tapPromise(xs,i)},a={async writeBundle(){},async closeBundle(){await i()}};return[{name:xs,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n(),await o()})),e.onDispose((()=>{r()}))}},vite:a,rollup:a,rspack:s}]},Ss={[Er]:Xr},Is=t.bold.red;var Ds="3.2.3";const Ps=(({bundler:t,version:n})=>{const o=Date.now();return e.createUnplugin(((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=N("SITE"),o={site:_(n,"DATADOG_SITE/DD_SITE",t)??_(e.auth?.site,"auth.site",t)??j};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:N("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:N("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=M);const a=process.env.BUILD_PLUGINS_ENV||"production",u=P.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,d=r.framework,l={bundler:{name:d,version:c},env:u,metadata:s.metadata||{},packageName:`@datadog/${d}-plugin`,version:n},p={errors:[],logs:[],metrics:new Set,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{addMetric:()=>{throw new Error("AddMetric function called before it was initialized.")},auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:oe(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:B(n),start:e,version:n.version}})({start:o,options:s,data:l,stores:p}),m=f.getLogger("factory"),h=m.time("Plugins initialization",{start:i});f.pluginNames.push(M);const g=[];g.push(["analytics",$i],["async-queue",xi],["build-report",_i],["bundler-report",Bi],["custom-hooks",Hi],["git",ts],["injection",ks],["true-end",Es]),s.customPlugins&&g.push(["custom",s.customPlugins]);const y=[["apps",ce,po],["error-tracking",fo,To],["live-debugger",Co,kr],["metrics",Er,ei],["output",ti,ai],["rum",ui,wi]];for(const[e,t,n]of y)ue(s,t,m)&&g.push([e,n]);for(const[e,n]of g)f.plugins.push(...se(f,n,e)({bundler:t,context:f,options:s,data:l,stores:p}));return(e=>{const t=[];for(const n of C){const o=R(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>T(e))).join(" and "),i=T(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>O(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: ${Is(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),h.end(),f.plugins}))})({bundler:x,version:Ds}).esbuild,As=Ds,js=Ss;exports.datadogEsbuildPlugin=Ps,exports.helpers=js,exports.version=As;
|
|
2
2
|
//# sourceMappingURL=index.js.map
|