@datadog/esbuild-plugin 3.1.8-dev.0 → 3.1.8-dev.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/index.d.ts +5302 -288
- package/dist/src/index.js +1 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/index.mjs +1 -1
- package/dist/src/index.mjs.map +1 -1
- package/package.json +2 -2
package/dist/src/index.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"),d=require("crypto"),c=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,A=t.bold.yellow,M=["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/.`)},R=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}`:"")},T=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],L=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(R).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=R(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)},z=e=>({message:t,context:n})=>L({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=>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 G=0;const Y={debug:0,info:1,warn:2,error:3,none:4},Q=e=>e.split(">").map(q).join(">"),X=(e,n,o,r)=>{const i=Q(e);return(s,a="debug",{forward:u,context:d}={})=>{let c=t.dim,p=console.log;"error"===a?(c=t.red,p=console.error):"warn"===a?(c=t.yellow,p=console.warn):"info"===a&&(c=t.cyan,p=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=z(n);await t({message:f,context:{plugin:e,status:a,...d}})}catch(t){X(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}Y[a]>=Y[r]&&p(`${c(l)} ${f}`)}},Z=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:d=[]}=i,c={pluginName:e,label:r,spans:[],tags:[...d,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(c);const p=()=>c.spans.filter((e=>!e.end)),l=n=>{p().length||(!c.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),c.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=p();if(i?.length){i.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of i)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),l(e)}return{timer:c,resume:l,end:e=>{f(e,!1);const n=c.spans.reduce(((e,t)=>e+(t.end-t.start)),0);c.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(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 c.tags.push(...e)}}},ee=(e,t,n="warn")=>o=>{const r=X(o,e,t,n);return{getLogger:r=>ee(e,t,n)(`${Q(o)}>${r}`),time:Z(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)}},te=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],ne=(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)},oe=(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 te){const i=e[r];i&&(n[r]=ne(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},re="apps",ie="datadog-apps-plugin",se="api/unstable/app-builder-code/apps",ae="datadog-apps-assets.zip",ue=/\.backend\.(ts|tsx|js|jsx)$/,de=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],ce=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),pe=async e=>r.mkdir(e,{recursive:!0}),le=(e,t)=>{var n;n=a.dirname(e),i.mkdirSync(n,{recursive:!0}),i.writeFileSync(e,t,{encoding:"utf-8"})},fe=e=>i.readFileSync(e,{encoding:"utf-8"}),me=e=>{try{return i.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},ge=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})}},he=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 ye=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(ye||{});function be(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 we(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function ve(e){return"type"===e.importKind||"type"===e.exportKind}function $e(e,t){return function(e,t){const n=be(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(...Ee(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&&Se(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const ke=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function xe(e){return null==e||ke.has(e.type)}function Ee(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 Se(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 Ie(e){const t=e.relativePath.split(a.sep).join("/");return`${d.createHash("sha256").update(t).digest("hex")}.${e.name}`}function De(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 je(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 Pe(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)Ae(t)&&r(t);else Ae(e)&&r(e)};r(e)}function Ae(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function Me(e){Pe(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:Re(t)}}function Ce(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function Ne(e){return e.defs.some((e=>"ImportBinding"===e.type))}function Oe(e,t){return t.moduleScope.set.get(e)}function Re(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function Te(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:_e(e,t)},r=[];return Pe(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(qe(o,t.unsupportedAliases,t.scopeAnalysis))throw Ve(n,"action-catalog call aliases");if(qe(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw Ve(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!Fe(o,t.scopeAnalysis))return!1;if(e.optional||ze(o))throw Ve(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function _e(e,t){const n=new Set;return Pe(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&qe(e.init,t.actionFunctions,t))return Ke(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&Fe(e.init,t))return Ke(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!qe(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Ue(e.value))).map((e=>e.name));return Ke(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&&qe(e.right,t.actionFunctions,t))return Be([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&Fe(e.right,t))return Be([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!qe(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Ue(e.value)));return Be(n,t)}(e,t))n.add(o)}}),n}function Fe(e,t){const n=Le(e);return!!n&&qe(n,t.actionNamespaces,t)}function Le(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?Le(e.object):void 0}function ze(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&ze(e.object)}function qe(e,t,n){return function(e,t,n){const o=Ce(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function Be(e,t){return e.flatMap((e=>{const n=Ce(e,t.moduleScope);return n?[n]:[]}))}function Ke(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function Ue(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?Ue(e.argument):Ue(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?Ue(e):[]));case"RestElement":return Ue(e.argument);case"AssignmentPattern":return Ue(e.left);case"MemberExpression":return[]}}function Ve(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const He="@datadog/action-catalog";function We(e,t,n){const o=e.get(t);if(!o)return et(t,[],n.name);const r=Ce(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?tt(t,[],n.name):Ye({modules:e,visitedExports:new Set},t,r,[]):tt(t,[],n.name)}function Je(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 Xe(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?Xe(t.id,r,n):Je(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return Ye(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=Je(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||!Ge(r,s)){if(r)return Qe(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 Ge(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function Ye(e,t,n,o){const r=e.modules.get(t);if(!r)return et(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return Ze(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 Ze(t,r,n);return Je(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 Qe(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 Xe(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 Ze(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 et(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 tt(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 nt(e,t,n){const o=ft(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=We(e.modules,t,n);if("unsupported"===o.kind)return kt(o,n.name);if(!o.binding.expression)return xt(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return yt(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return nt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=ot(e,t,n);if("unsupported"===o.kind)return o;return nt(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 ot(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=rt(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 $t(e);if(r.computed)return ht(e);if(lt(r)===n){if(o)return bt(e,n);if("init"!==r.kind)return gt(e,n);if(!it(r))return vt(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 rt(e,t,n){if("Super"===n.type)return wt(t,n.type);const o=ft(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=ot(e,t,o);return"unsupported"===n.kind?n:rt(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return wt(t,o.type);const r=We(e.modules,t,o);if("unsupported"===r.kind)return kt(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 yt(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return rt(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function it(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function st(e){const t=new Set;for(const n of e.values())Pe(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){ut(e.left,t)},UpdateExpression(e,{state:t}){ut(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&ut(e.argument,t)},ForInStatement(e,{state:t}){at(e.left,t)},ForOfStatement(e,{state:t}){at(e.left,t)}});return t}function at(e,t){"VariableDeclaration"!==e.type&&ut(e,t)}function ut(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&ut(e.left,t):ut(e.argument,t);else for(const n of e.elements)n&&ut(n,t);else for(const n of e.properties)ut("RestElement"===n.type?n.argument:n.value,t);else{const n=pt(e);n&&dt(n,t)}else dt(e,t)}function dt(e,t){const n=ct(t,e,new Set);n&&t.mutatedVariables.add(n)}function ct(e,t,n){const o=Ce(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),Ne(o)){const n=We(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=ft(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return pt(t);return}(r);return i?ct(e,i,n):void 0}function pt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?pt(e.object):void 0}function lt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function ft(e){let t=e;for(;mt(t);)t=t.expression;return t}function mt(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function gt(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 ht(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function yt(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 bt(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function wt(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 vt(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 $t(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function kt(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 Et=new Set(["node_modules",".yarn"]);function St(e,t,n,o=[]){if(!Kt(e,t))return null;const r=be(n,e),i=Me(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&&we(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:qt(r),importsByVariable:It(r,i,s),exportsByName:Dt(r,i,s),starExports:At(r,s),topLevelBindingsByVariable:Mt(r,i)}}function It(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!we(r.source))continue;const e=zt(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:Ft(n.imported),resolvedId:e}))}}return o}function Dt(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&Pt(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):jt(r,t,n,o);return o}function jt(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&&we(e.source)){const t=zt(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=Ft(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:Ft(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=Ft(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=Oe(Ft(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function Pt(e,t,n){const o=Lt(e);o&&we(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:zt(t,e.source.value)})}function At(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||Lt(e)||!we(e.source)?[]:[{resolvedId:zt(t,e.source.value)}]))}function Mt(e,t){const n=new Map;for(const o of e.body)Ct(o,t,n);return function(e,t,n){Pe(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){Rt(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){Rt(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Rt(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){Ot(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){Ot(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function Ct(e,t,n){if("VariableDeclaration"===e.type)return void Nt(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void Nt(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 Nt(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 Ot(e,t,n){"VariableDeclaration"!==e.type&&Rt(e,t,n)}function Rt(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&&Rt(e.left,t,n):Rt(e.argument,t,n);else for(const o of e.elements)o&&Rt(o,t,n);else for(const o of e.properties)Rt("RestElement"===o.type?o.argument:o.value,t,n);else{const o=_t(e);o&&Tt(o,t,n,"mutated object binding")}else Tt(e,t,n,"reassigned binding")}function Tt(e,t,n,o){const r=Ce(e,t);if(!r||Ne(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function _t(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?_t(e.object):void 0}function Ft(e){return"Identifier"===e.type?e.name:String(e.value)}function Lt(e){const t=e.exported;return t?Ft(t):void 0}function zt(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function qt(e){const t=[];return Pe(e,t,{ImportExpression(e,{state:t}){const n=function(e){return Vt(e.source,"non-literal dynamic import")}(e);Bt(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 Vt(e.arguments[0],"non-literal dynamic import")}(e);Bt(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||!we(t)||Ht(t.value)})(e)&&t.push({specifier:Ut(e),kind:"require"})}}),t}function Bt(e){return"non-literal dynamic import"===e||Ht(e)}function Kt(e,t){if(!de.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=>Et.has(e)))}function Ut(e){return Vt(e.arguments[0],"local require")}function Vt(e,t){return we(e)?e.value:t}function Ht(e){return e.startsWith(".")||e.startsWith("/")}function Wt(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function Jt(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 Wt(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw Wt(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Kt(i,n)){if(!t.has(i))throw Wt(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===He||o.startsWith(`${He}/`))&&!ve(r))for(const e of r.specifiers)ve(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)Ne(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 Te(e.ast,r,e.id)){const r=Gt(n,t,e);r&&o.add(r)}})),[...o].sort()}function Gt(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw Xt(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 Xt(t,"spread object arguments");if(o.computed)throw Xt(t,"computed object property keys");if(Qt(o)){if(n)throw Xt(t,"multiple connectionId properties");if("init"!==o.kind)throw Xt(t,"accessor connectionId properties");if(!Yt(o))throw Xt(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return nt({modules:e,mutatedImportedObjectVariables:st(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 Yt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function Qt(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 Xt(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const Zt=/^(?:\0|virtual:)/;function en(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=tn(n.id);if(r=o,Zt.test(r))return;var r;const i=St(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(tn));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function tn(e){return e.split("?")[0]}function nn(e,t){const n=en(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>Jt(e,n.getModuleRecords(),t)}}function on(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function rn(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:[...de,".json"]},plugins:[on("dd-backend-resolve",t),...n]}}function sn(e){return`${e.relativePath}/${e.name}`}async function an(e,t,n,o){const r=sn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return je(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=nn(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=rn(n,{[i]:s},[a.plugin]),d=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),c=Array.isArray(d)?d[0]:d;if(!("output"in c))throw new Error(`Unexpected vite.build result for "${r}"`);const p="chunk"===c.output[0].type?c.output[0].code:"",l={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${p.length} bytes)`),{func:l,code:p}}async function un(e,t,n,o,r){const i=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,s=sn(t);r.debug(`Calling Datadog API: ${i}`);const a=JSON.stringify({data:{type:"queries",attributes:{query:{id:d.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 L({url:i,auth:o,method:"POST",type:"json",getData:()=>({data:a,headers:{"Content-Type":"application/json"}})}),c=u.data?.id;if(!c)throw new Error("No receipt ID returned from Datadog API");return r.debug(`Query execution started with receipt: ${c}`),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 L({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")}(c,o,r)}function dn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class cn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function pn(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 cn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new cn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function ln(e,t,n,o,r){const i=t=>an(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=>[Ie(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await pn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){dn(t,e instanceof cn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,n,s,i).catch((()=>{dn(n,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void dn(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 pn(e,n,o),d=sn(s);i.debug(`Executing action: ${d} with args`);const c=await un(a,s,u,r,i);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:c}))}catch(e){const n=e instanceof cn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";i.debug(`Error handling executeAction: ${o}`),dn(t,n,o)}})(e,n,s,i,a,r).catch((()=>{dn(n,500,"Unexpected error")}))}else o()}}const fn=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},mn=(e,t)=>B(t)?x:t.startsWith(e)||a.isAbsolute(t)?t:a.resolve(e,t),gn=(e,t)=>{let n,o=mn(process.cwd(),e);for(;!n;){const e=a.resolve(o,t);if(me(e)&&(n=e),o=o.split(a.sep).slice(0,-1).join(a.sep),[a.sep,""].includes(o))break}return n},hn=(e,t)=>{const n=[...e].map((e=>mn(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},yn=t.bold.red,bn=t.bold.yellow,wn=e=>{const t=gn(e,"package.json");if(t)try{const e=fe(t);return JSON.parse(e)}catch(e){return}},vn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=wn(e);o||t.warn(bn("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(yn("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(yn("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("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(yn("Unable to compute the app identifier.")),{identifier:s,name:r}},$n=t.green.bold,kn=t.yellow.bold,xn=t.cyan.bold,En=t.bold,Sn=(e,t={},n)=>async()=>{const o=await ge(e,{contentType:"application/zip",filename:ae});return _({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ae);const t=C("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},In=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}/${se}/${a}/upload`);var s,a;const d=T({bundler:t.bundlerName,plugin:"apps",version:t.version}),c=J({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),p=`an archive of:\n - ${$n(e.assets.length.toString())} files\n - ${$n(m(e.size))}\n\nWith the configuration:\n${c}`;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 L({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:Sn(e.archivePath,d,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${kn(`${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}/${se}/${t}/release/live`)(t.site,t.identifier);await L({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",...d}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${kn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${En(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}},Dn=t.yellow.bold,jn=t.red.bold,Pn="manifest.json";async function An(e){const t=await r.mkdtemp(a.join(c.tmpdir(),"dd-apps-manifest-")),n=a.join(t,Pn);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[Ie(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await ce(t),e}return{manifestAsset:{absolutePath:n,relativePath:Pn},cleanup:()=>ce(t)}}const Mn=async({backendOutputs:e,backendFunctions:t,context:n,options:o})=>{const s=n.getLogger(ie),{auth:u,buildRoot:d,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}=vn(d,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(d,f),$=[...o.include,`${v}/**/*`],k=await fn($,d);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 An(t);b=I,E.push(S);const D=s.time("archive assets"),j=await(async e=>{const t=await r.mkdtemp(a.join(c.tmpdir(),"dd-apps-")),n=a.join(t,ae),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:A,warnings:M}=await In(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(),M.length>0&&s.warn(`${Dn("Warnings while uploading assets:")}\n - ${M.join("\n - ")}`),A.length>0){const e=A.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){w=e,s.error(`${jn("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await ce(y),b&&await b(),h.end(),w)throw w};const Cn=a.join(__dirname,"./apps-runtime.mjs"),Nn=({bundler:e,context:t,options:n})=>{const o=t.getLogger(ie),{auth:i,buildRoot:s}=t;t.inject({type:"file",position:ye.MIDDLE,value:Cn});const{setBackendFunctions:u,getBackendFunctions:d}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[ue],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=$e(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(ue,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:Ie(e)})}return{functions:r,proxyCode:De(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=d();if(p.length>0){const t=await async function(e,t,n,o){const i=await r.mkdtemp(a.join(c.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=Ie(r),d=`\0dd-backend:${t}`,c=je(r.name,r.absolutePath,n),p=nn(r.absolutePath,n),l=rn(n,{[d]:c},[p.plugin]),f=await e({...l,build:{...l.build,write:!0,outDir:i,emptyOutDir:!1,rollupOptions:{...l.build.rollupOptions,input:{[t]:d},output:{...l.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=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 Mn({backendOutputs:u,backendFunctions:p,context:t,options:n})}finally{i&&await ce(i)}},configureServer(t){t.middlewares.use(ln(e.build,d,i,s,o))}}},On=({options:e,context:t,bundler:n})=>{const o=t.getLogger(ie),r=(e=>{const t=e[re]||{};return{enable:t.enable??!!e[re],include:t.include||[],dryRun:t.dryRun??!C("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim()}})(e);return r.enable?"vite"!==t.bundler.name?(o.warn(`The apps plugin only supports Vite; skipping under '${t.bundler.name}'.`),[]):[{name:ie,enforce:"post",vite:Nn({bundler:n,context:t,options:r})}]:[]},Rn="errorTracking",Tn="datadog-error-tracking-plugin",_n=(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}},Fn=/[/]+|[\\]+/g,Ln=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,zn=(e,t)=>{const n=e.replace(Ln,"").split(Fn),o=t.replace(Ln,"").split(Fn),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},qn=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([he(e.minifiedFilePath),he(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:zn(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}},Bn=t.green.bold,Kn=t.yellow.bold,Un=t.red.bold,Vn=(e,t={})=>async()=>_({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await ge(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}),Hn=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=(d=n.site,C("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${d}/api/v2/srcmap`);var d;const c=T({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=J({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),l=`\nUploading ${Bn(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(l);const f=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};f.push(a.add((async()=>{try{await L({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:Vn(s,c),onRetry:(t,n)=>{const r=`Failed to upload ${Kn(e.sourcemap)} | ${Kn(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}return s.end(),o.debug(`Queued ${Bn(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:i,errors:r}},Wn=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=>({..._n(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=>qn(e,s,i,n.git))));a.end();const d=u.map((e=>e.errors)).flat(),c=u.map((e=>e.warnings)).flat();if(c.length>0&&o.warn(`Warnings while preparing payloads:\n - ${c.join("\n - ")}`),d.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${d.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const p=o.time("Upload sourcemaps"),{errors:l,warnings:f}=await Hn(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site},o);if(p.end(),o.debug(`Done uploading ${Bn(`${e.length-l.length}/${e.length}`)} sourcemaps in ${Bn(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?`${Un(e.file)} | ${Un(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,site:t.site,version:t.version},n),i.end()},Jn=e=>{const n=t.bold.red,o=e[Rn]||{},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},Gn=({options:e,context:t})=>{const n=t.getLogger(Tn),o=n.time("validate options"),r=((e,t)=>{const n=[],o=Jn(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Tn}.`);const r={enable:!!e[Rn],...e[Rn],sourcemaps:void 0};return o.config&&(r.sourcemaps=o.config),r})(e,n);if(o.end(),!r.enable)return[];let i,s,a=!1;const u=async()=>{if(!r.sourcemaps||a)return;a=!0;const e=n.time("sourcemaps process");await Wn(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:i,outDir:t.bundler.outDir,outputs:s?.outputs||[],site:t.auth.site,version:t.version},n),e.end()};return[{name:Tn,enforce:"post",async git(e){i=e,s&&await u()},async buildReport(t){s=t,!i&&U(e)||await u()},async asyncTrueEnd(){a||await u()}}]},Yn="liveDebugger",Qn="datadog-live-debugger-plugin",Xn="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",Zn="__DD_LIVE_DEBUGGER_BUILD__",eo=e=>void 0===e?Xn:`${Xn};if(typeof globalThis.${Zn}==='undefined'){globalThis.${Zn}={version:${JSON.stringify(e)}}}`;function to(e){return"function"==typeof e?e:e.default}function no(e,t,n,o,r){const i=a.relative(t,e).replace(/\\/g,"/"),s=oo(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 oo(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)?so(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=ro(e.object,t),o=io(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)?so(o.key,t):null}function ro(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=ro(e.object,t),o=io(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function io(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function so(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 ao(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function uo(e,t,n,o){const r=[];if(t)for(const t of e.params)for(const e of co(t,o))"this"!==e&&r.push(e);if(n&&o.isBlockStatement(e.body)){const t=new Set(e.params.flatMap((e=>co(e,o)))),n="id"in e&&o.isIdentifier(e.id)?e.id.name:"";for(const i of e.body.body)if(o.isVariableDeclaration(i))for(const e of i.declarations)for(const i of co(e.id,o))t.has(i)||i===n||r.push(i)}return r.length>25?r.slice(0,25):r}function co(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:co(e.argument,t):t.isAssignmentPattern(e)?co(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?co(e.argument,t):co(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?co(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const po=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let lo,fo,mo,go,ho=!1;function yo(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 po.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=po.find((t=>e.message.includes(t))),n=t??po.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 ${po.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const bo=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function wo(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,d=0,c=0,p=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:1,skippedUnsupportedCount:c,totalFunctions:p};if(!bo.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};ho||(lo=yo("@babel/parser").parse,fo=to(yo("@babel/traverse")),mo=yo("@babel/types"),go=to(yo("magic-string")),ho=!0);const l=lo(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let g=0;if(fo(l,{Function(e){if(p++,!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,mo))return void c++;if(r&&function(e,t,n){let o=e;for(;o;){if(ao(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return ao(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",mo))return void d++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,mo)))return void c++;if(s&&!oo(e,mo))return void c++;let t=0;if(!oo(e,mo)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=no(n,o,e,t,mo);try{const t=e.node,n=g++,o=`$dd_p${n}`,r=uo(t,!0,!1,mo),i=uo(t,!1,!0,mo),s=mo.isArrowFunctionExpression(t)&&!mo.isBlockStatement(t.body),a=[],d=s||!mo.isBlockStatement(t.body)||!ko(t.body.body,mo);let c;if(!s&&mo.isBlockStatement(t.body)&&$o(t.body.body,a,mo),!s&&mo.isBlockStatement(t.body)&&t.body.directives.length>0){c=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,needsTrailingReturn:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:c,functionId:l,probeVarName:o,probeIdx:String(n),entryVars:r,exitVars:i,returns:a}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};const h=new go(t);for(let e=f.length-1;e>=0;e--)vo(h,t,f[e]);return{code:h.toString(),map:h.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p}}function vo(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,exitVars:a,returns:u,bodyStart:d,bodyEnd:c,functionEnd:p,isExpressionBody:l,bodyParenStart:f,directivesEnd:m}=n,g=`$dd_e${r}`,h=`$dd_l${r}`,y=`$dd_rv${r}`,b=s.join(", "),w=a.join(", "),v=""!==b,$=""!==w,k=v?`, ${g}()`:"",x=v?$?`, ${g}(), ${h}()`:`, ${g}()`:$?`, undefined, ${h}()`:"",E=`const ${o} = $dd_probes('${i}');`,S=v?`const ${g} = () => ({${b}});`:"",I=$?`const ${h} = () => ({${w}});`:"",D=`if (${o}) $dd_entry(${o}, this${k});`,j=`catch(e) { if (${o}) $dd_throw(${o}, e, this${k}); throw e; }`;if(l){if(null!=f){let n=-1;for(let e=c;e<p;e++)if(")"===t[e]){n=e;break}-1!==n&&(e.remove(f,f+1),e.remove(n,n+1))}const n=["{",E,S,I,"try {",D,`const ${y} = `].filter(Boolean).join("\n"),r=[";",`if (${o}) $dd_return(${o}, ${y}, this${x});`,`return ${y};`,`} ${j}`,"}"].join("\n");c-d>=2?(e.update(d,d+1,n+t[d]),e.update(c-1,c,t[c-1]+r)):e.update(d,c,n+t.slice(d,c)+r)}else{const r=[E,S,"try {",I,`let ${y};`,D].filter(Boolean).join("\n");for(const t of u)null!=t.argStart&&null!=t.argEnd?(e.appendLeft(t.argStart,`(${y} = `),e.appendLeft(t.argEnd,`, ${o} ? $dd_return(${o}, ${y}, this${x}) : ${y})`)):e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, this${x}); `);if(null!=m){const n=m-1;e.update(n,m,`${t[n]}\n${r}`)}else e.update(d,d+1,`${t[d]}${r}`);const i=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, this${x});\n`:""}} ${j}\n`;e.update(c-1,c,`${i}${t[c-1]}`)}}function $o(e,t,n){for(const o of e)if(n.isReturnStatement(o))t.push({start:o.start,end:o.end,argStart:o.argument?.start??void 0,argEnd:o.argument?.end??void 0});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))$o(o.body,t,n);else if(n.isIfStatement(o))$o([o.consequent],t,n),o.alternate&&$o([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))$o([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)$o(e.consequent,t,n);else n.isTryStatement(o)?($o(o.block.body,t,n),o.handler&&$o(o.handler.body.body,t,n),o.finalizer&&$o(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&$o([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 xo=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Eo=t.bold.red,So=Number(process.env.DD_LD_LIMIT)||1/0,Io=(e,t)=>{const n=t.getLogger(Qn);let o=0,r=0,i=0,s=0,a=0,u=0,d=0,c=0;return{name:Qn,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(p,l){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?l.includes(e):e.test(l))))return{code:p}}for(const t of e.exclude){if("string"==typeof t?l.includes(t):t.test(l))return{code:p}}if(c>=So)return{code:p};try{const f=wo({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,d+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&c++,0===f.instrumentedCount)return{code:p};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),g=f.map&&m?function(e,t,n,o){try{return 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:()=>{d>0&&n.info(`Live Debugger: ${o}/${d} functions instrumented across ${u}/${c} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:c,instrumentedCount:o,totalFunctions:d,transformedFileCount:u}})}}},Do=({options:e,context:t})=>{const n=((e,t)=>{const n=e[Yn]||{},o=e.metadata?.version,r=[];if(void 0!==n.enable&&"boolean"!=typeof n.enable&&r.push(`${Eo("enable")} must be a boolean`),void 0!==n.include)if(Array.isArray(n.include)){for(const e of n.include)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Eo("include")} patterns must be strings or RegExp`);break}}else r.push(`${Eo("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(`${Eo("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Eo("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Eo("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!xo.includes(e)){r.push(`${Eo("functionTypes")} contains invalid value "${e}". Valid values: ${xo.join(", ")}`);break}}else r.push(`${Eo("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Eo("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${Qn}.`);return{enable:n.enable??!!e[Yn],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(Qn));return n.enable?(t.inject({type:"code",position:ye.BEFORE,injectIntoAllChunks:!0,value:eo(n.version)}),[Io(n,t)]):[]};const jo=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],Po="metrics",Ao="datadog-metrics-plugin",Mo=e=>Math.floor((e||Date.now())/1e3),Co=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),No=(e="")=>e.endsWith("/")?e:`${e}/`,Oo=(e,t)=>{let n=e;return e.split(No(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},Ro=(e,t)=>e.split("!").pop().replace(No(t),"./"),To=(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)),Ro(o||"no-name",n)},_o=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),Fo=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Lo=t.bold.red,zo=t.bold.cyan,qo=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},Bo=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(qo("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:V(e.duration)}))),top:!0};n.sort(qo("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Ko=(e,t,n)=>{const o=[];var r;n&&(o.push(...Bo("Loader",n.loaders)),o.push(...Bo("Tapable",n.tapables)),o.push(...Bo("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,d=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)d.has(n)||d.set(n,new Set),d.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(d.has(e.filepath)){const t=d.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),d.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=d.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const c=Array.from(i);return c.sort(qo((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort(qo((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort(qo("size")),o.values=c.map((e=>({name:e.name,value:m(e.size)}))),c.sort(qo("aggregatedSize")),r.values=c.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(qo((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(qo((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(qo((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+=` [${Lo(e.value)}] ${" ".repeat(n)}${zo(e.name)}\n`}}return t})(o);t.info(i)},Uo="api/v1/series",Vo=t.bold.green,Ho=["onStart","onLoad","onResolve","onEnd"],Wo=new Map,Jo=new Map,Go=new Map,Yo=(e,t,n)=>{const o=Object.assign({},e);for(const r of Ho)o[r]=async(o,i)=>{const s=Jo.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=Ro(e[0].path,n),u=Go.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const d=y.performance.now();try{return await i(...e)}finally{const n=y.performance.now(),i=n-d,c={start:d,end:n,duration:i,context:Fo(e)};if(s.events[r].values.push(c),s.duration+=i,s.increment+=1,Jo.set(t,s),u.events[r].values.push(c),u.duration+=i,u.increment+=1,Go.set(o,u),a){const e=Wo.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(c),e.duration+=i,e.increment+=1,Wo.set(t,e)}}}))};return o},Qo=(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=Yo(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:Jo,modules:Go,loaders:Wo};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class Xo{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=To(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(_o))(e);o.length||o.push("no-loader"),this.started[n]={module:Oo(n),timings:{start:y.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=To(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 Zo{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,Fo(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,Fo(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,Fo(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 d=this.getTapPatch(e,i,s,t);return n.call(o,r,d)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(Ao)||(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(Ao),o={name:Ao},r=new Zo(e.buildRoot),i=new Xo(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})}))},tr={filters:jo},nr=({options:e,context:t})=>{const n=t.getLogger(Ao);let o=0;const r=((e,t)=>{const n=e[Po],o=Mo(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enable:!!e[Po],enableDefaultPrefix:!0,enableTracing:!1,filters:jo,tags:[],...e[Po],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),i=[];if(!r.enable)return i;const s={name:Ao,enforce:"pre",esbuild:Qo(t,n),webpack:er(t),rspack:er(t)},a=n.time("build",{start:!1}),u=r.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,c;const p=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-o;const e=n.time("aggregating metrics"),i=r.timestamp,s=n.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,d=new Map,c=new Map,p=new Map;for(const e of i){for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");p.has(n)||p.set(n,[]),p.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`entryName:${e}`))),c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");p.has(r)&&o.push(...p.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of i){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(c,i);s.end();const u=n.time("aggregate plugins metrics"),p=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"plugins.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values()){let e=0,r=0;for(const i of Object.values(o.events)){let s=0;r+=i.values.length;for(const t of i.values){const n=t.end-t.start;s+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,s]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,i.values.length]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(d?.tapables,i);u.end();const l=n.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(d?.loaders,i);l.end();const m=((e,t,n,o,r)=>{const i=new Set;for(const t of e){let e={...t,toSend:!0};if(n?.length)for(const t of n){const n=t({metric:e.metric,type:e.type,points:e.points,tags:e.tags});n?e={...n,toSend:e.toSend}:e.toSend=!1}i.add(Co(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Co({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i})(new Set([...a,...p,...f]),i,r.filters,r.tags,r.prefix);await t.asyncHook("metrics",m),e.end();const g=n.time("outputing report");Ko(t,n,d),g.end();const h=n.time("sending metrics to Datadog");await((e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.debug("No metrics to send.");const o=Array.from(e).filter((e=>e.toSend)).map((e=>({...e,toSend:void 0}))),r=new Map;for(const e of o)r.has(e.metric)||r.set(e.metric,0),r.set(e.metric,r.get(e.metric)+1);const i=Array.from(r.entries()).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>`${e} - ${t}`));return n.debug(`\nSending ${o.length} metrics with configuration:\n - intake: ${Vo(`https://api.${t.site}/${Uo}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),L({method:"POST",url:`https://api.${t.site}/${Uo}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))})(m,{apiKey:t.auth.apiKey,site:t.auth.site},n),h.end()},l={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){a.resume(),t.build.start=t.build.start||Date.now(),e[Po]?.timestamp||(r.timestamp=Mo(t.build.start))},buildEnd(){a.end(),o=Date.now()},async timings(e){d=e,c&&await p()},async buildReport(e){c=e,!d&&u||await p()}};return r.enableTracing&&i.push(s),i.push(l),i},or="output",rr="datadog-output-plugin",ir=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,sr=e=>{const t=void 0===e;return{build:ir("build",e?.build??t),bundler:ir("bundler",e?.bundler??t),dependencies:ir("dependencies",e?.dependencies??t),errors:ir("errors",e?.errors??t),logs:ir("logs",e?.logs??t),metrics:ir("metrics",e?.metrics??t),timings:ir("timings",e?.timings??t),warnings:ir("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}))}))},ur=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},dr=({options:e,context:t})=>{const n=(e=>({enable:!!e[or],path:"./",...e[or],files:sr(e[or]?.files)}))(e),o=t.getLogger(rr);if(!n.enable)return[];const r=(e,r)=>{const u=n.files[e];if(!r||!1===u)return;t.queue((async()=>{const e=o.time(`output ${u}`),d=((e,t,n)=>{const o=a.isAbsolute(t)?t:a.resolve(e,t);return a.resolve(o,n)})(t.bundler.outDir,n.path,u);let c;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await pe(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})(d,e)}catch(e){c=e}c?o.error(`Failed writing ${u}: ${c}`):o.debug(`Wrote "./${a.relative(t.buildRoot,d)}"`),e.end()})())};return[{name:rr,buildReport(e){const t=o.time("serialize report"),n=K(e);t.end(),r("build",{bundler:n.bundler,metadata:n.metadata,start:n.start,end:n.end,duration:n.duration,writeDuration:n.writeDuration,entries:n.entries,outputs:n.outputs}),r("logs",n.logs),r("timings",n.timings),r("dependencies",n.inputs),r("errors",n.errors),r("warnings",n.warnings)},metrics(e){r("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{r("bundler",e.metafile)}))}},rspack:ar(o,(e=>{r("bundler",e)})),rollup:ur((e=>{r("bundler",e)})),vite:ur((e=>{r("bundler",e)})),webpack:ar(o,(e=>{r("bundler",e)}))}]},cr="rum",pr="datadog-rum-plugin",lr=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")});`,fr="datadog-rum-privacy-plugin";const mr=(e,t)=>{const n=t.getLogger(fr),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:fr,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}})}}},gr=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,hr=(e,t)=>{const n=e.sdk;if(n.clientToken)return gr(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 L({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 gr({...e,sdk:{clientToken:o,...n}})}},yr=e=>{const n=t.bold.red,o=e[cr]||{},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[cr]||{},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},wr=e=>{const n=t.bold.red,o=e[cr]||{},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},vr=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=yr(e),r=br(e),i=wr(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 ${pr}.`);const s={enable:!!e[cr],...e[cr],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(pr)),o=[];if(!n.enable)return o;if(n.sourceCodeContext&&t.inject({type:"code",position:ye.BEFORE,injectIntoAllChunks:!0,value:lr(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:ye.MIDDLE,value:a.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:ye.MIDDLE,value:hr(n,t)})),n.privacy){t.inject({type:"file",position:ye.BEFORE,value:a.join(__dirname,"./privacy-helpers.js")});const e=mr(n.privacy,t);o.push(e)}return o},$r="datadog-analytics-plugin",kr=({context:e})=>{const t=e.getLogger($r);return[{name:$r,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}`)}})())}}]},xr="datadog-async-queue-plugin",Er=e=>{const{context:t,stores:n}=e,o=t.getLogger(xr),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:xr,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Sr=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},Ir=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Dr=/(\?|%3F|\|)+/gi,jr=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=Mr(e),Ir.lastIndex=0,Ir.exec(t)?.[1]||"unknown");var t},Pr=["unknown","commonjsHelpers.js",`vite${a.sep}preload-helper.js`],Ar=(e,t,n)=>{const o=new Set;for(const n of e){const e=Mr(n);B(n)||e===t||Pr.includes(e)||o.add(e)}return o},Mr=e=>e.split("!").pop().split(Dr).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Cr=(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(Dr).shift().replace(/^((\.\.?)?[/\\])+/g,""),Nr=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[mn(t,e),n]))),Or=(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 Sr(n,e,t));for(const t of r){const n=Cr(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 d=[],c=[],p=[],l=[],f=[],m={},g={},h=t.time("indexing metafile data"),y=Nr(n.metafile.inputs,u),b=Nr(n.metafile.outputs,u);h.end();const w=e=>{if(!B(e))return e;const t=y[mn(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=mn(u,e),o={name:Cr(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:jr(e)};m[n]=o,d.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=mn(u,e),i=Cr(s,n),a=[];for(const e of Object.keys(r.inputs)){if(B(e))continue;const n=m[mn(u,e)];n?a.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!a.length){const e=m[mn(u,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}a.push(e)}const d={name:i,filepath:n,inputs:a,size:r.bytes,type:jr(n)};if(g[n]=d,"map"===d.type&&l.push(d),c.push(d),!r.entryPoint)continue;const f=m[mn(u,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...d,name:o.get(f.name)||f.name,outputs:[d],size:d.size};p.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of l){const n=g[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:g,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!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(/^\.\.?\//),c=i?a.dirname(e):u,p=mn(c,t.path);if(t.external){if(S(t.path)){const e=i?p:t.path,n=x.inputs.report[e]||{filepath:e,name:Cr(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),d.includes(n)||d.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(p,n,o)}return o},D=t.time("looping through entries");for(const e of p){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const j=t.time("aggregate dependencies and dependents");for(const e of d){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?a.dirname(e.filepath):u,i=mn(r,o.path);let s;if(o.external){const e=n?i:o.path;s=x.inputs.report[e]}else s=x.inputs.report[i];s?(e.dependencies.add(s),s.dependents.add(e)):t.debug(`Could not find input file of ${o.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}j.end(),e.build.outputs=c,e.build.inputs=d,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),Rr=(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}),d=t.time("filling sourcemaps inputs",{start:!1}),c=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),c.clear(),p.clear(),l.clear()},onLog(t,n){"warn"===t&&e.build.warnings.push(n.message||n.toString())},renderError(t){t&&e.build.errors.push(t.message)},moduleParsed(e){n.resume();const t=Mr(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=Ar(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=Ar(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?mn(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=Mr(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=Mr(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=mn(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:jr(e)};if("map"===s.type&&y.add(s),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(Mr(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=i.statSync(e).size}catch(e){n=t.renderedLength}const o=c.get(e)||{name:Cr(g,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:jr(e)};s.inputs.push(o),c.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=Mr(e);if(!f.has(n)){b.set(mn(g,n),s);continue}if(c.has(n)){t.debug(`Input report already there for ${n} from ${s.name}.`);continue}const o=c.get(n)||{name:Cr(g,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};s.inputs.push(o),c.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 c){const o=f.get(e);if(o){for(const e of o.dependencies){const o=c.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Cr(g,e)} of ${n.name}`)}for(const e of o.dependents){const o=c.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Cr(g,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){d.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=p.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}d.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Cr(g,e),r=p.get(e);if(!r)return c.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[Cr(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(mn(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}":"${Cr(g,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(c.values()),e.build.outputs=Array.from(p.values()),e.build.entries=Array.from(l.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},Tr=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,d=new Map,c=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||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=Mr(e);t.add(n),n.startsWith("external ")&&t.add(g(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(c.has(e)){const n=c.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else c.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=Mr(t.request);if(c.has(n))return c.get(n);if(e.context){const t=mn(Mr(e.context),n);if(c.has(t))return c.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],i=[],s=[],a.clear(),u.clear(),c.clear(),l.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),i=n.time("indexing modules");for(const e of t)h(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Cr(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:jr(t)};r.push(u),a.set(t,u),w(n)&&a.set(g(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=l.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,c=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>mn(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"===jr(e))continue;const t=d.get(e)||new Set;for(const e of n)t.add(e);d.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of c){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:mn(e.bundler.outDir,t.name),type:jr(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){p.push(o);continue}const r=d.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of p){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return new Set;t.add(e);const n=new Set(e.chunks);for(const o of e.childrenIterable||[]){const e=v(o,t);for(const t of e)n.add(t)}return n};for(const[o,r]of t.entrypoints){const t=new Map,i=new Map;let a=0;const d=v(r),c=Array.from(d).flatMap(l),p=r.chunks.filter((e=>h.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===jr(e)));for(const e of c){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)i.has(e.filepath)||i.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:p?mn(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:p?jr(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)}))},_r="datadog-build-report-plugin",Fr=e=>{const{context:t}=e,n=t.getLogger(_r);return[{name:_r,enforce:"post",esbuild:Or(t,n),rspack:Tr(t,_r,n),webpack:Tr(t,_r,n),vite:Rr(t,n),rollup:Rr(t,n)}]},Lr="datadog-bundler-report-plugin",zr=(e,t)=>t?a.isAbsolute(t)?t:a.resolve(e,t):"",qr=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)},Br=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=zr(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Kr=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=qr(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=hn(r,process.cwd())),e.bundler.outDir=zr(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Ur=e=>{const{context:t}=e,n=t.getLogger(Lr);return[{name:Lr,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=zr(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=zr(t.buildRoot,a.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Br(t),rspack:Br(t),vite:Kr(t),rollup:{options(e){let n;if("output"in e){const t=qr(e.output);n=hn(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=mn(process.cwd(),n);const e=hn([n,...o],process.cwd());t.buildRoot=e===a.sep?process.cwd():e}else t.buildRoot=hn(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=qr(e);hn(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.")}}}]},Vr="datadog-custom-hooks-plugin",Hr=e=>{const{context:t}=e,n=t.getLogger(Vr),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:Vr,enforce:"pre"}]};class Wr{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=fe(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 Jr=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await Gr(e);for(const e of t)if(e.name===n)return W(e.refs.push);return W(t[0].refs.push)},Gr=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},Yr=async e=>e.revparse("HEAD"),Qr=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),Xr=async e=>e.branch(),Zr=async e=>e.show(["-s","--format=%s"]),ei=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),ti="datadog-git-plugin",ni=e=>{const{options:t,context:n}=e,o=n.getLogger(ti),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t=[Yr(e),Xr(e),Zr(e),ei(e),Qr(e),Jr(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,d,c,p,l,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:d,date:c},committer:{name:p,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new Wr(s)}})(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)));n.git=t,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:ti,enforce:"pre",buildRoot(e){if(U(t))try{r.resume();const t=gn(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}`)}}}]},oi="datadog-injection-plugin",ri=/^https?:\/\//,ii=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],si=t.bold.yellow,ai=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(mn(t,e)),ui=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(ri)?await(async(e,t=5e3)=>{let n;return Promise.race([L({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 ui(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},di=(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`},ci=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 ui(i,t,n);if(e){const t=i.position||ye.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)},pi=e=>e instanceof Error&&"code"in e,li=e=>ii.includes(e),fi=(e,t,n)=>{e.warn(`"${si(t)}" files are not supported (${si(n)}).`)},mi=i.promises,gi=(e,t,n)=>({setup(o){const{onStart:s,onResolve:u,onLoad:d,onEnd:p,esbuild:l,initialOptions:f}=o,m=[],g=`${t.bundler.name}.${ye.MIDDLE}.${x}.js`,h=i.realpathSync(c.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 Sr(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await pe(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:oi}))),d({filter:b,namespace:oi},(async()=>({contents:di(n,{position:ye.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),p((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=di(n,{position:ye.BEFORE}),i=di(n,{position:ye.AFTER}),s=di(n,{position:ye.BEFORE,onAllChunks:!0}),u=di(n,{position:ye.AFTER,onAllChunks:!0});if(!(r||i||s||u))return;const d=[];for(const[n,c]of Object.entries(o.metafile.outputs)){const o=c.entryPoint&&m.some((e=>e.resolved.endsWith(c.entryPoint))),p=o?r:s,f=o?i:u;if(!p&&!f)continue;const g=mn(t.buildRoot,n),{base:h,ext:y}=a.parse(g);li(y)?d.push((async()=>{try{const e=await mi.readFile(g,"utf-8"),t=await l.transform(e,{loader:"default",banner:p,footer:f});await mi.writeFile(g,t.code)}catch(t){if(!pi(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${g}: ${t}`)}})()):fi(e,y,h)}await Promise.all(d)}))}}),hi=x,yi="?inject-proxy",bi=(e,t)=>({banner(n){const o=di(t,{position:ye.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=a.parse(n.fileName);return li(i)?o:(fi(e,i,r),"")},async resolveId(e,n,o){if(B(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&di(t,{position:ye.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}${yi}`}return null},load(e){if(B(e))return di(t,{position:ye.MIDDLE});if(e.endsWith(yi)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(hi)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=di(t,{position:ye.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=a.parse(n.fileName);return li(i)?o:(fi(e,i,r),"")}}),wi=(e,t,n,o,r)=>s=>{const u=new WeakMap,d=e.sources.ConcatSource,c=n.bundler.name,p=a.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${c}.${ye.MIDDLE}.${x}.js`);le(p,"");s.hooks.shutdown.tap(oi,(()=>{var e;e=p,i.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await ci(t,o,r,n.buildRoot)};s.hooks.beforeRun.tapPromise(oi,l),s.hooks.watchRun.tapPromise(oi,l),s.hooks.compilation.tap(oi,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:oi,stage:o},(()=>{const e=di(r,{position:ye.BEFORE}),o=di(r,{position:ye.AFTER}),i=di(r,{position:ye.BEFORE,onAllChunks:!0}),s=di(r,{position:ye.AFTER,onAllChunks:!0});for(const r of n.chunks){let c=e,p=o;if(r.canBeInitial()||(c=i,p=s),""!==c||""!==p)for(const e of r.files){const{base:o,ext:r}=a.parse(e);li(r)?n.updateAsset(e,(e=>{const t=u.get(e);if(!t||t.banner!==c||t.footer!==p){const t=new d(c,"\n",e,"\n",p);return u.set(e,{source:t,banner:c,footer:p}),t}return t.source})):fi(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},vi=e=>{const{bundler:t,context:n}=e,o=n.getLogger(oi),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++G}`,e)};const s={name:oi,enforce:"post",esbuild:gi(o,n,i),webpack:wi(t,o,n,r,i),rspack:wi(t,o,n,r,i),rollup:bi(o,i),vite:{...bi(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>di(i,{position:ye.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:di(i,{position:ye.MIDDLE})})}:s.buildStart=async()=>{await ci(o,r,i,n.buildRoot)},[s]},$i="datadog-true-end-plugin",ki=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=()=>{t.hook("syncTrueEnd")},r=async()=>{o(),await n()},i=e=>{e.hooks.shutdown.tapPromise($i,r)},s={async writeBundle(){},async closeBundle(){await r()}};return[{name:$i,enforce:"post",webpack:i,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:s,rollup:s,rspack:i}]},xi={[Po]:tr},Ei=t.bold.red;var Si="3.1.8-dev.0";const Ii=(({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",d=t.rspackVersion||t.version||t.VERSION,c=r.framework,p={bundler:{name:c,version:d},env:u,metadata:s.metadata||{},packageName:`@datadog/${c}-plugin`,version:n},l={errors:[],logs:[],queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:ee(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:z(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",kr],["async-queue",Er],["build-report",Fr],["bundler-report",Ur],["custom-hooks",Hr],["git",ni],["injection",vi],["true-end",ki]),s.customPlugins&&h.push(["custom",s.customPlugins]),h.push(["apps",On],["error-tracking",Gn],["live-debugger",Do],["metrics",nr],["output",dr],["rum",vr]);for(const[e,n]of h)f.plugins.push(...oe(f,n,e)({bundler:t,context:f,options:s,data:p,stores:l}));return(e=>{const t=[];for(const n of M){const o=N(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>A(e))).join(" and "),i=A(`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: ${Ei(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),g.end(),f.plugins}))})({bundler:v,version:Si}).esbuild,Di=Si,ji=xi;exports.datadogEsbuildPlugin=Ii,exports.helpers=ji,exports.version=Di;
|
|
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"),d=require("crypto"),c=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,A=t.bold.yellow,M=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],N=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],C=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/.`)},R=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}`:"")},T=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],L=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(R).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=R(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)},z=e=>({message:t,context:n})=>L({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=>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 G=0;const Y={debug:0,info:1,warn:2,error:3,none:4},Q=e=>e.split(">").map(q).join(">"),X=(e,n,o,r)=>{const i=Q(e);return(s,a="debug",{forward:u,context:d}={})=>{let c=t.dim,p=console.log;"error"===a?(c=t.red,p=console.error):"warn"===a?(c=t.yellow,p=console.warn):"info"===a&&(c=t.cyan,p=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=z(n);await t({message:f,context:{plugin:e,status:a,...d}})}catch(t){X(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}Y[a]>=Y[r]&&p(`${c(l)} ${f}`)}},Z=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:d=[]}=i,c={pluginName:e,label:r,spans:[],tags:[...d,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(c);const p=()=>c.spans.filter((e=>!e.end)),l=n=>{p().length||(!c.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),c.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=p();if(i?.length){i.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of i)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),l(e)}return{timer:c,resume:l,end:e=>{f(e,!1);const n=c.spans.reduce(((e,t)=>e+(t.end-t.start)),0);c.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(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 c.tags.push(...e)}}},ee=(e,t,n="warn")=>o=>{const r=X(o,e,t,n);return{getLogger:r=>ee(e,t,n)(`${Q(o)}>${r}`),time:Z(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)}},te=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],ne=(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)},oe=(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 te){const i=e[r];i&&(n[r]=ne(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},re=new Set,ie=(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&&(re.has(t)||(re.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},se="apps",ae="datadog-apps-plugin",ue="api/unstable/app-builder-code/apps",de="datadog-apps-assets.zip",ce=/\.backend\.(ts|tsx|js|jsx)$/,pe=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],le=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),fe=async e=>r.mkdir(e,{recursive:!0}),me=(e,t)=>{var n;n=a.dirname(e),i.mkdirSync(n,{recursive:!0}),i.writeFileSync(e,t,{encoding:"utf-8"})},ge=e=>i.readFileSync(e,{encoding:"utf-8"}),he=e=>{try{return i.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},ye=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})}},be=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 we=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(we||{});function ve(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 $e(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function ke(e){return"type"===e.importKind||"type"===e.exportKind}function xe(e,t){return function(e,t){const n=ve(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(...Ie(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&&De(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const Ee=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function Se(e){return null==e||Ee.has(e.type)}function Ie(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(Se(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 De(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&&Se(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function je(e){const t=e.relativePath.split(a.sep).join("/");return`${d.createHash("sha256").update(t).digest("hex")}.${e.name}`}function Pe(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 Me(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 Ce(e){Me(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:_e(t)}}function Oe(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function Re(e){return e.defs.some((e=>"ImportBinding"===e.type))}function Te(e,t){return t.moduleScope.set.get(e)}function _e(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function Fe(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:Le(e,t)},r=[];return Me(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(Ke(o,t.unsupportedAliases,t.scopeAnalysis))throw We(n,"action-catalog call aliases");if(Ke(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw We(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!ze(o,t.scopeAnalysis))return!1;if(e.optional||Be(o))throw We(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 Me(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&Ke(e.init,t.actionFunctions,t))return Ve(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&ze(e.init,t))return Ve(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!Ke(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:He(e.value))).map((e=>e.name));return Ve(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&&Ke(e.right,t.actionFunctions,t))return Ue([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&ze(e.right,t))return Ue([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!Ke(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:He(e.value)));return Ue(n,t)}(e,t))n.add(o)}}),n}function ze(e,t){const n=qe(e);return!!n&&Ke(n,t.actionNamespaces,t)}function qe(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?qe(e.object):void 0}function Be(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&Be(e.object)}function Ke(e,t,n){return function(e,t,n){const o=Oe(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function Ue(e,t){return e.flatMap((e=>{const n=Oe(e,t.moduleScope);return n?[n]:[]}))}function Ve(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function He(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?He(e.argument):He(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?He(e):[]));case"RestElement":return He(e.argument);case"AssignmentPattern":return He(e.left);case"MemberExpression":return[]}}function We(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const Je="@datadog/action-catalog";function Ge(e,t,n){const o=e.get(t);if(!o)return nt(t,[],n.name);const r=Oe(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?ot(t,[],n.name):Xe({modules:e,visitedExports:new Set},t,r,[]):ot(t,[],n.name)}function Ye(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 et(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?et(t.id,r,n):Ye(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=Ye(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||!Qe(r,s)){if(r)return Ze(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 Qe(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 nt(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return tt(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 tt(t,r,n);return Ye(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 Ze(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 et(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 tt(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 nt(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 ot(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 rt(e,t,n){const o=gt(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=Ge(e.modules,t,n);if("unsupported"===o.kind)return Et(o,n.name);if(!o.binding.expression)return St(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 rt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=it(e,t,n);if("unsupported"===o.kind)return o;return rt(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 it(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=st(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 xt(e);if(r.computed)return bt(e);if(mt(r)===n){if(o)return vt(e,n);if("init"!==r.kind)return yt(e,n);if(!at(r))return kt(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 st(e,t,n){if("Super"===n.type)return $t(t,n.type);const o=gt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=it(e,t,o);return"unsupported"===n.kind?n:st(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return $t(t,o.type);const r=Ge(e.modules,t,o);if("unsupported"===r.kind)return Et(r,o.name);if(!r.binding.expression)return St(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 st(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function at(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function ut(e){const t=new Set;for(const n of e.values())Me(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){ct(e.left,t)},UpdateExpression(e,{state:t}){ct(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&ct(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&&ct(e,t)}function ct(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&ct(e.left,t):ct(e.argument,t);else for(const n of e.elements)n&&ct(n,t);else for(const n of e.properties)ct("RestElement"===n.type?n.argument:n.value,t);else{const n=ft(e);n&&pt(n,t)}else pt(e,t)}function pt(e,t){const n=lt(t,e,new Set);n&&t.mutatedVariables.add(n)}function lt(e,t,n){const o=Oe(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),Re(o)){const n=Ge(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=gt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return ft(t);return}(r);return i?lt(e,i,n):void 0}function ft(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?ft(e.object):void 0}function mt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function gt(e){let t=e;for(;ht(t);)t=t.expression;return t}function ht(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function yt(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 bt(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 vt(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function $t(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 kt(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 xt(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function Et(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 St(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 It=new Set(["node_modules",".yarn"]);function Dt(e,t,n,o=[]){if(!Vt(e,t))return null;const r=ve(n,e),i=Ce(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&&$e(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:Kt(r),importsByVariable:jt(r,i,s),exportsByName:Pt(r,i,s),starExports:Nt(r,s),topLevelBindingsByVariable:Ct(r,i)}}function jt(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!$e(r.source))continue;const e=Bt(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:zt(n.imported),resolvedId:e}))}}return o}function Pt(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&Mt(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&&$e(e.source)){const t=Bt(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=zt(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:zt(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=zt(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=Te(zt(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function Mt(e,t,n){const o=qt(e);o&&$e(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Bt(t,e.source.value)})}function Nt(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||qt(e)||!$e(e.source)?[]:[{resolvedId:Bt(t,e.source.value)}]))}function Ct(e,t){const n=new Map;for(const o of e.body)Ot(o,t,n);return function(e,t,n){Me(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){_t(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){_t(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&_t(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){Tt(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){Tt(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function Ot(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 Tt(e,t,n){"VariableDeclaration"!==e.type&&_t(e,t,n)}function _t(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&&_t(e.left,t,n):_t(e.argument,t,n);else for(const o of e.elements)o&&_t(o,t,n);else for(const o of e.properties)_t("RestElement"===o.type?o.argument:o.value,t,n);else{const o=Lt(e);o&&Ft(o,t,n,"mutated object binding")}else Ft(e,t,n,"reassigned binding")}function Ft(e,t,n,o){const r=Oe(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 zt(e){return"Identifier"===e.type?e.name:String(e.value)}function qt(e){const t=e.exported;return t?zt(t):void 0}function Bt(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function Kt(e){const t=[];return Me(e,t,{ImportExpression(e,{state:t}){const n=function(e){return Wt(e.source,"non-literal dynamic import")}(e);Ut(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 Wt(e.arguments[0],"non-literal dynamic import")}(e);Ut(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||!$e(t)||Jt(t.value)})(e)&&t.push({specifier:Ht(e),kind:"require"})}}),t}function Ut(e){return"non-literal dynamic import"===e||Jt(e)}function Vt(e,t){if(!pe.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=>It.has(e)))}function Ht(e){return Wt(e.arguments[0],"local require")}function Wt(e,t){return $e(e)?e.value:t}function Jt(e){return e.startsWith(".")||e.startsWith("/")}function Gt(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function Yt(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 Gt(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw Gt(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Vt(i,n)){if(!t.has(i))throw Gt(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===Je||o.startsWith(`${Je}/`))&&!ke(r))for(const e of r.specifiers)ke(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 Fe(e.ast,r,e.id)){const r=Qt(n,t,e);r&&o.add(r)}})),[...o].sort()}function Qt(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw en(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 en(t,"spread object arguments");if(o.computed)throw en(t,"computed object property keys");if(Zt(o)){if(n)throw en(t,"multiple connectionId properties");if("init"!==o.kind)throw en(t,"accessor connectionId properties");if(!Xt(o))throw en(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return rt({modules:e,mutatedImportedObjectVariables:ut(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 Zt(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 en(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const tn=/^(?:\0|virtual:)/;function nn(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=on(n.id);if(r=o,tn.test(r))return;var r;const i=Dt(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 rn(e,t){const n=nn(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>Yt(e,n.getModuleRecords(),t)}}function sn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function an(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:[...pe,".json"]},plugins:[sn("dd-backend-resolve",t),...n]}}function un(e){return`${e.relativePath}/${e.name}`}async function dn(e,t,n,o){const r=un(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=rn(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=an(n,{[i]:s},[a.plugin]),d=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),c=Array.isArray(d)?d[0]:d;if(!("output"in c))throw new Error(`Unexpected vite.build result for "${r}"`);const p="chunk"===c.output[0].type?c.output[0].code:"",l={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${p.length} bytes)`),{func:l,code:p}}async function cn(e,t,n,o,r){const i=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,s=un(t);r.debug(`Calling Datadog API: ${i}`);const a=JSON.stringify({data:{type:"queries",attributes:{query:{id:d.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 L({url:i,auth:o,method:"POST",type:"json",getData:()=>({data:a,headers:{"Content-Type":"application/json"}})}),c=u.data?.id;if(!c)throw new Error("No receipt ID returned from Datadog API");return r.debug(`Query execution started with receipt: ${c}`),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 L({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")}(c,o,r)}function pn(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 fn(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 mn(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=>[je(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await fn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){pn(t,e instanceof ln?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,n,s,i).catch((()=>{pn(n,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void pn(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 fn(e,n,o),d=un(s);i.debug(`Executing action: ${d} with args`);const c=await cn(a,s,u,r,i);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:c}))}catch(e){const n=e instanceof ln?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";i.debug(`Error handling executeAction: ${o}`),pn(t,n,o)}})(e,n,s,i,a,r).catch((()=>{pn(n,500,"Unexpected error")}))}else o()}}const gn=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},hn=(e,t)=>B(t)?x:t.startsWith(e)||a.isAbsolute(t)?t:a.resolve(e,t),yn=(e,t)=>{let n,o=hn(process.cwd(),e);for(;!n;){const e=a.resolve(o,t);if(he(e)&&(n=e),o=o.split(a.sep).slice(0,-1).join(a.sep),[a.sep,""].includes(o))break}return n},bn=(e,t)=>{const n=[...e].map((e=>hn(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,vn=t.bold.yellow,$n=e=>{const t=yn(e,"package.json");if(t)try{const e=ge(t);return JSON.parse(e)}catch(e){return}},kn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=$n(e);o||t.warn(vn("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=W(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("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(wn("Unable to compute the app identifier.")),{identifier:s,name:r}},xn=t.green.bold,En=t.yellow.bold,Sn=t.cyan.bold,In=t.bold,Dn=(e,t={},n)=>async()=>{const o=await ye(e,{contentType:"application/zip",filename:de});return _({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,de);const t=N("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},jn=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,N("APPS_INTAKE_URL")||`https://api.${s}/${ue}/${a}/upload`);var s,a;const d=T({bundler:t.bundlerName,plugin:"apps",version:t.version}),c=J({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),p=`an archive of:\n - ${xn(e.assets.length.toString())} files\n - ${xn(m(e.size))}\n\nWith the configuration:\n${c}`;if(t.dryRun)return n.error(`\n${Sn("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await L({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:Dn(e.archivePath,d,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${En(`${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 ${Sn(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${ue}/${t}/release/live`)(t.site,t.identifier);await L({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",...d}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${En(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${In(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}},Pn=t.yellow.bold,An=t.red.bold,Mn="manifest.json";async function Nn(e){const t=await r.mkdtemp(a.join(c.tmpdir(),"dd-apps-manifest-")),n=a.join(t,Mn);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[je(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await le(t),e}return{manifestAsset:{absolutePath:n,relativePath:Mn},cleanup:()=>le(t)}}const Cn=async({backendOutputs:e,backendFunctions:t,context:n,options:o})=>{const s=n.getLogger(ae),{auth:u,buildRoot:d,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}=kn(d,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(d,f),$=[...o.include,`${v}/**/*`],k=await gn($,d);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(c.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:A,warnings:M}=await jn(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(),M.length>0&&s.warn(`${Pn("Warnings while uploading assets:")}\n - ${M.join("\n - ")}`),A.length>0){const e=A.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){w=e,s.error(`${An("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await le(y),b&&await b(),h.end(),w)throw w};const On=a.join(__dirname,"./apps-runtime.mjs"),Rn=({bundler:e,context:t,options:n})=>{const o=t.getLogger(ae),{auth:i,buildRoot:s}=t;t.inject({type:"file",position:we.MIDDLE,value:On});const{setBackendFunctions:u,getBackendFunctions:d}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[ce],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=xe(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(ce,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:je(e)})}return{functions:r,proxyCode:Pe(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=d();if(p.length>0){const t=await async function(e,t,n,o){const i=await r.mkdtemp(a.join(c.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=je(r),d=`\0dd-backend:${t}`,c=Ae(r.name,r.absolutePath,n),p=rn(r.absolutePath,n),l=an(n,{[d]:c},[p.plugin]),f=await e({...l,build:{...l.build,write:!0,outDir:i,emptyOutDir:!1,rollupOptions:{...l.build.rollupOptions,input:{[t]:d},output:{...l.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=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 Cn({backendOutputs:u,backendFunctions:p,context:t,options:n})}finally{i&&await le(i)}},configureServer(t){t.middlewares.use(mn(e.build,d,i,s,o))}}},Tn=({options:e,context:t,bundler:n})=>{const o=t.getLogger(ae),r=(e=>{const t=e[se]||{};return{include:t.include||[],dryRun:t.dryRun??!N("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:ae,enforce:"post",vite:Rn({bundler:n,context:t,options:r})}]},_n="errorTracking",Fn="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}},zn=/[/]+|[\\]+/g,qn=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Bn=(e,t)=>{const n=e.replace(qn,"").split(zn),o=t.replace(qn,"").split(zn),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},Kn=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([be(e.minifiedFilePath),be(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Bn(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}},Un=t.green.bold,Vn=t.yellow.bold,Hn=t.red.bold,Wn=(e,t={})=>async()=>_({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await ye(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}),Jn=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=(d=n.site,N("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${d}/api/v2/srcmap`);var d;const c=T({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=J({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),l=`\nUploading ${Un(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(l);const f=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};f.push(a.add((async()=>{try{await L({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:Wn(s,c),onRetry:(t,n)=>{const r=`Failed to upload ${Vn(e.sourcemap)} | ${Vn(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}return s.end(),o.debug(`Queued ${Un(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:i,errors:r}},Gn=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=>Kn(e,s,i,n.git))));a.end();const d=u.map((e=>e.errors)).flat(),c=u.map((e=>e.warnings)).flat();if(c.length>0&&o.warn(`Warnings while preparing payloads:\n - ${c.join("\n - ")}`),d.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${d.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const p=o.time("Upload sourcemaps"),{errors:l,warnings:f}=await Jn(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site},o);if(p.end(),o.debug(`Done uploading ${Un(`${e.length-l.length}/${e.length}`)} sourcemaps in ${Un(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?`${Hn(e.file)} | ${Hn(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,site:t.site,version:t.version},n),i.end()},Yn=e=>{const n=t.bold.red,o=e[_n]||{},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},Qn=({options:e,context:t})=>{const n=t.getLogger(Fn),o=n.time("validate options"),r=((e,t)=>{const n=[],o=Yn(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Fn}.`);return{...e[_n],sourcemaps:o.config}})(e,n);let i,s;o.end();let a=!1;const u=async()=>{if(!r.sourcemaps||a)return;a=!0;const e=n.time("sourcemaps process");await Gn(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:i,outDir:t.bundler.outDir,outputs:s?.outputs||[],site:t.auth.site,version:t.version},n),e.end()};return[{name:Fn,enforce:"post",async git(e){i=e,s&&await u()},async buildReport(t){s=t,!i&&U(e)||await u()},async asyncTrueEnd(){a||await u()}}]},Xn="liveDebugger",Zn="datadog-live-debugger-plugin",eo="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",to="__DD_LIVE_DEBUGGER_BUILD__",no=e=>void 0===e?eo:`${eo};if(typeof globalThis.${to}==='undefined'){globalThis.${to}={version:${JSON.stringify(e)}}}`;function oo(e){return"function"==typeof e?e:e.default}function ro(e,t,n,o,r){const i=a.relative(t,e).replace(/\\/g,"/"),s=io(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 io(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)?uo(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=so(e.object,t),o=ao(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)?uo(o.key,t):null}function so(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=so(e.object,t),o=ao(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function ao(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function uo(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 co(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function po(e,t,n,o){const r=[];if(t)for(const t of e.params)for(const e of lo(t,o))"this"!==e&&r.push(e);if(n&&o.isBlockStatement(e.body)){const t=new Set(e.params.flatMap((e=>lo(e,o)))),n="id"in e&&o.isIdentifier(e.id)?e.id.name:"";for(const i of e.body.body)if(o.isVariableDeclaration(i))for(const e of i.declarations)for(const i of lo(e.id,o))t.has(i)||i===n||r.push(i)}return r.length>25?r.slice(0,25):r}function lo(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:lo(e.argument,t):t.isAssignmentPattern(e)?lo(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?lo(e.argument,t):lo(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?lo(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const fo=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let mo,go,ho,yo,bo=!1;function wo(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 fo.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=fo.find((t=>e.message.includes(t))),n=t??fo.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 ${fo.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const vo=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function $o(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,d=0,c=0,p=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:1,skippedUnsupportedCount:c,totalFunctions:p};if(!vo.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};bo||(mo=wo("@babel/parser").parse,go=oo(wo("@babel/traverse")),ho=wo("@babel/types"),yo=oo(wo("magic-string")),bo=!0);const l=mo(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let g=0;if(go(l,{Function(e){if(p++,!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,ho))return void c++;if(r&&function(e,t,n){let o=e;for(;o;){if(co(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return co(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",ho))return void d++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,ho)))return void c++;if(s&&!io(e,ho))return void c++;let t=0;if(!io(e,ho)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=ro(n,o,e,t,ho);try{const t=e.node,n=g++,o=`$dd_p${n}`,r=po(t,!0,!1,ho),i=po(t,!1,!0,ho),s=ho.isArrowFunctionExpression(t)&&!ho.isBlockStatement(t.body),a=[],d=s||!ho.isBlockStatement(t.body)||!Eo(t.body.body,ho);let c;if(!s&&ho.isBlockStatement(t.body)&&xo(t.body.body,a,ho),!s&&ho.isBlockStatement(t.body)&&t.body.directives.length>0){c=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,needsTrailingReturn:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:c,functionId:l,probeVarName:o,probeIdx:String(n),entryVars:r,exitVars:i,returns:a}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};const h=new yo(t);for(let e=f.length-1;e>=0;e--)ko(h,t,f[e]);return{code:h.toString(),map:h.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p}}function ko(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,exitVars:a,returns:u,bodyStart:d,bodyEnd:c,functionEnd:p,isExpressionBody:l,bodyParenStart:f,directivesEnd:m}=n,g=`$dd_e${r}`,h=`$dd_l${r}`,y=`$dd_rv${r}`,b=s.join(", "),w=a.join(", "),v=""!==b,$=""!==w,k=v?`, ${g}()`:"",x=v?$?`, ${g}(), ${h}()`:`, ${g}()`:$?`, undefined, ${h}()`:"",E=`const ${o} = $dd_probes('${i}');`,S=v?`const ${g} = () => ({${b}});`:"",I=$?`const ${h} = () => ({${w}});`:"",D=`if (${o}) $dd_entry(${o}, this${k});`,j=`catch(e) { if (${o}) $dd_throw(${o}, e, this${k}); throw e; }`;if(l){if(null!=f){let n=-1;for(let e=c;e<p;e++)if(")"===t[e]){n=e;break}-1!==n&&(e.remove(f,f+1),e.remove(n,n+1))}const n=["{",E,S,I,"try {",D,`const ${y} = `].filter(Boolean).join("\n"),r=[";",`if (${o}) $dd_return(${o}, ${y}, this${x});`,`return ${y};`,`} ${j}`,"}"].join("\n");c-d>=2?(e.update(d,d+1,n+t[d]),e.update(c-1,c,t[c-1]+r)):e.update(d,c,n+t.slice(d,c)+r)}else{const r=[E,S,"try {",I,`let ${y};`,D].filter(Boolean).join("\n");for(const t of u)null!=t.argStart&&null!=t.argEnd?(e.appendLeft(t.argStart,`(${y} = `),e.appendLeft(t.argEnd,`, ${o} ? $dd_return(${o}, ${y}, this${x}) : ${y})`)):e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, this${x}); `);if(null!=m){const n=m-1;e.update(n,m,`${t[n]}\n${r}`)}else e.update(d,d+1,`${t[d]}${r}`);const i=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, this${x});\n`:""}} ${j}\n`;e.update(c-1,c,`${i}${t[c-1]}`)}}function xo(e,t,n){for(const o of e)if(n.isReturnStatement(o))t.push({start:o.start,end:o.end,argStart:o.argument?.start??void 0,argEnd:o.argument?.end??void 0});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))xo(o.body,t,n);else if(n.isIfStatement(o))xo([o.consequent],t,n),o.alternate&&xo([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))xo([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)xo(e.consequent,t,n);else n.isTryStatement(o)?(xo(o.block.body,t,n),o.handler&&xo(o.handler.body.body,t,n),o.finalizer&&xo(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&xo([o.body],t,n)}function Eo(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 Eo(e,t)&&Eo(o,t)}return!1}const So=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Io=t.bold.red,Do=Number(process.env.DD_LD_LIMIT)||1/0,jo=(e,t)=>{const n=t.getLogger(Zn);let o=0,r=0,i=0,s=0,a=0,u=0,d=0,c=0;return{name:Zn,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(p,l){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?l.includes(e):e.test(l))))return{code:p}}for(const t of e.exclude){if("string"==typeof t?l.includes(t):t.test(l))return{code:p}}if(c>=Do)return{code:p};try{const f=$o({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,d+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&c++,0===f.instrumentedCount)return{code:p};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),g=f.map&&m?function(e,t,n,o){try{return 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:()=>{d>0&&n.info(`Live Debugger: ${o}/${d} functions instrumented across ${u}/${c} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:c,instrumentedCount:o,totalFunctions:d,transformedFileCount:u}})}}},Po=({options:e,context:t})=>{const n=((e,t)=>{const n=e[Xn]||{},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(`${Io("include")} patterns must be strings or RegExp`);break}}else r.push(`${Io("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(`${Io("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Io("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Io("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!So.includes(e)){r.push(`${Io("functionTypes")} contains invalid value "${e}". Valid values: ${So.join(", ")}`);break}}else r.push(`${Io("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Io("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${Zn}.`);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(Zn));return t.inject({type:"code",position:we.BEFORE,injectIntoAllChunks:!0,value:no(n.version)}),[jo(n,t)]};const Ao=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],Mo="metrics",No="datadog-metrics-plugin",Co=e=>Math.floor((e||Date.now())/1e3),Oo=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),Ro=(e="")=>e.endsWith("/")?e:`${e}/`,To=(e,t)=>{let n=e;return e.split(Ro(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},_o=(e,t)=>e.split("!").pop().replace(Ro(t),"./"),Fo=(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)),_o(o||"no-name",n)},Lo=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),zo=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),qo=t.bold.red,Bo=t.bold.cyan,Ko=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},Uo=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Ko("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:V(e.duration)}))),top:!0};n.sort(Ko("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Vo=(e,t,n)=>{const o=[];var r;n&&(o.push(...Uo("Loader",n.loaders)),o.push(...Uo("Tapable",n.tapables)),o.push(...Uo("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,d=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)d.has(n)||d.set(n,new Set),d.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(d.has(e.filepath)){const t=d.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),d.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=d.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const c=Array.from(i);return c.sort(Ko((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort(Ko((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort(Ko("size")),o.values=c.map((e=>({name:e.name,value:m(e.size)}))),c.sort(Ko("aggregatedSize")),r.values=c.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(Ko((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Ko((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Ko((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+=` [${qo(e.value)}] ${" ".repeat(n)}${Bo(e.name)}\n`}}return t})(o);t.info(i)},Ho="api/v1/series",Wo=t.bold.green,Jo=["onStart","onLoad","onResolve","onEnd"],Go=new Map,Yo=new Map,Qo=new Map,Xo=(e,t,n)=>{const o=Object.assign({},e);for(const r of Jo)o[r]=async(o,i)=>{const s=Yo.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=_o(e[0].path,n),u=Qo.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const d=y.performance.now();try{return await i(...e)}finally{const n=y.performance.now(),i=n-d,c={start:d,end:n,duration:i,context:zo(e)};if(s.events[r].values.push(c),s.duration+=i,s.increment+=1,Yo.set(t,s),u.events[r].values.push(c),u.duration+=i,u.increment+=1,Qo.set(o,u),a){const e=Go.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(c),e.duration+=i,e.increment+=1,Go.set(t,e)}}}))};return o},Zo=(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=Xo(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:Yo,modules:Qo,loaders:Go};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class er{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Fo(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Lo))(e);o.length||o.push("no-loader"),this.started[n]={module:To(n),timings:{start:y.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Fo(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 tr{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,zo(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,zo(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,zo(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 d=this.getTapPatch(e,i,s,t);return n.call(o,r,d)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(No)||(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 nr=e=>async t=>{const n=e.getLogger(No),o={name:No},r=new tr(e.buildRoot),i=new er(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})}))},or={filters:Ao},rr=({options:e,context:t})=>{const n=t.getLogger(No);let o=0;const r=((e,t)=>{const n=e[Mo],o=Co(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enableDefaultPrefix:!0,enableTracing:!1,filters:Ao,tags:[],...e[Mo],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),i=[],s={name:No,enforce:"pre",esbuild:Zo(t,n),webpack:nr(t),rspack:nr(t)},a=n.time("build",{start:!1}),u=r.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,c;const p=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-o;const e=n.time("aggregating metrics"),i=r.timestamp,s=n.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,d=new Map,c=new Map,p=new Map;for(const e of i){for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");p.has(n)||p.set(n,[]),p.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`entryName:${e}`))),c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");p.has(r)&&o.push(...p.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of i){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(c,i);s.end();const u=n.time("aggregate plugins metrics"),p=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"plugins.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values()){let e=0,r=0;for(const i of Object.values(o.events)){let s=0;r+=i.values.length;for(const t of i.values){const n=t.end-t.start;s+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,s]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,i.values.length]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(d?.tapables,i);u.end();const l=n.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(d?.loaders,i);l.end();const m=((e,t,n,o,r)=>{const i=new Set;for(const t of e){let e={...t,toSend:!0};if(n?.length)for(const t of n){const n=t({metric:e.metric,type:e.type,points:e.points,tags:e.tags});n?e={...n,toSend:e.toSend}:e.toSend=!1}i.add(Oo(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Oo({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i})(new Set([...a,...p,...f]),i,r.filters,r.tags,r.prefix);await t.asyncHook("metrics",m),e.end();const g=n.time("outputing report");Vo(t,n,d),g.end();const h=n.time("sending metrics to Datadog");await((e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.debug("No metrics to send.");const o=Array.from(e).filter((e=>e.toSend)).map((e=>({...e,toSend:void 0}))),r=new Map;for(const e of o)r.has(e.metric)||r.set(e.metric,0),r.set(e.metric,r.get(e.metric)+1);const i=Array.from(r.entries()).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>`${e} - ${t}`));n.debug(`\nSending ${o.length} metrics with configuration:\n - intake: ${Wo(`https://api.${t.site}/${Ho}`)}\n\nMetrics:\n - ${i.join("\n - ")}`);const s=[];for(let e=0;e<o.length;e+=500)s.push(o.slice(e,e+500));return s.length>1&&n.debug(`Sending metrics in ${s.length} batches of up to 500.`),Promise.all(s.map((e=>L({method:"POST",url:`https://api.${t.site}/${Ho}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:e})})})))).catch((e=>{n.error(`Error sending metrics ${e}`)}))})(m,{apiKey:t.auth.apiKey,site:t.auth.site},n),h.end()},l={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){a.resume(),t.build.start=t.build.start||Date.now(),e[Mo]?.timestamp||(r.timestamp=Co(t.build.start))},buildEnd(){a.end(),o=Date.now()},async timings(e){d=e,c&&await p()},async buildReport(e){c=e,!d&&u||await p()}};return r.enableTracing&&i.push(s),i.push(l),i},ir="output",sr="datadog-output-plugin",ar=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,ur=e=>{const t=void 0===e;return{build:ar("build",e?.build??t),bundler:ar("bundler",e?.bundler??t),dependencies:ar("dependencies",e?.dependencies??t),errors:ar("errors",e?.errors??t),logs:ar("logs",e?.logs??t),metrics:ar("metrics",e?.metrics??t),timings:ar("timings",e?.timings??t),warnings:ar("warnings",e?.warnings??t)}},dr=(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)))}}},pr=({options:e,context:t})=>{const n=t.getLogger(sr),o=(e=>({path:"./",...e[ir],files:ur(e[ir]?.files)}))(e),r=(e,r)=>{const u=o.files[e];if(!r||!1===u)return;t.queue((async()=>{const e=n.time(`output ${u}`),d=((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 c;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await fe(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})(d,e)}catch(e){c=e}c?n.error(`Failed writing ${u}: ${c}`):n.debug(`Wrote "./${a.relative(t.buildRoot,d)}"`),e.end()})())};return[{name:sr,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:dr(n,(e=>{r("bundler",e)})),rollup:cr((e=>{r("bundler",e)})),vite:cr((e=>{r("bundler",e)})),webpack:dr(n,(e=>{r("bundler",e)}))}]},lr="rum",fr="datadog-rum-plugin",mr=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")});`,gr="datadog-rum-privacy-plugin";const hr=(e,t)=>{const n=t.getLogger(gr),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:gr,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}})}}},yr=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,br=(e,t)=>{const n=e.sdk;if(n.clientToken)return yr(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 L({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 yr({...e,sdk:{clientToken:o,...n}})}},wr=e=>{const n=t.bold.red,o=e[lr]||{},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},vr=e=>{const t=e[lr]||{},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},$r=e=>{const n=t.bold.red,o=e[lr]||{},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},kr=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=wr(e),r=vr(e),i=$r(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 ${fr}.`);const s={...e[lr],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(fr)),o=[];if(n.sourceCodeContext&&t.inject({type:"code",position:we.BEFORE,injectIntoAllChunks:!0,value:mr(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:we.MIDDLE,value:a.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:we.MIDDLE,value:br(n,t)})),n.privacy){t.inject({type:"file",position:we.BEFORE,value:a.join(__dirname,"./privacy-helpers.js")});const e=hr(n.privacy,t);o.push(e)}return o},xr="datadog-analytics-plugin",Er=({context:e})=>{const t=e.getLogger(xr);return[{name:xr,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}`)}})())}}]},Sr="datadog-async-queue-plugin",Ir=e=>{const{context:t,stores:n}=e,o=t.getLogger(Sr),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:Sr,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Dr=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},jr=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Pr=/(\?|%3F|\|)+/gi,Ar=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=Cr(e),jr.lastIndex=0,jr.exec(t)?.[1]||"unknown");var t},Mr=["unknown","commonjsHelpers.js",`vite${a.sep}preload-helper.js`],Nr=(e,t,n)=>{const o=new Set;for(const n of e){const e=Cr(n);B(n)||e===t||Mr.includes(e)||o.add(e)}return o},Cr=e=>e.split("!").pop().split(Pr).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Or=(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(Pr).shift().replace(/^((\.\.?)?[/\\])+/g,""),Rr=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[hn(t,e),n]))),Tr=(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 Dr(n,e,t));for(const t of r){const n=Or(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 d=[],c=[],p=[],l=[],f=[],m={},g={},h=t.time("indexing metafile data"),y=Rr(n.metafile.inputs,u),b=Rr(n.metafile.outputs,u);h.end();const w=e=>{if(!B(e))return e;const t=y[hn(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=hn(u,e),o={name:Or(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Ar(e)};m[n]=o,d.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=hn(u,e),i=Or(s,n),a=[];for(const e of Object.keys(r.inputs)){if(B(e))continue;const n=m[hn(u,e)];n?a.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!a.length){const e=m[hn(u,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}a.push(e)}const d={name:i,filepath:n,inputs:a,size:r.bytes,type:Ar(n)};if(g[n]=d,"map"===d.type&&l.push(d),c.push(d),!r.entryPoint)continue;const f=m[hn(u,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...d,name:o.get(f.name)||f.name,outputs:[d],size:d.size};p.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of l){const n=g[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:g,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!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(/^\.\.?\//),c=i?a.dirname(e):u,p=hn(c,t.path);if(t.external){if(S(t.path)){const e=i?p:t.path,n=x.inputs.report[e]||{filepath:e,name:Or(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),d.includes(n)||d.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(p,n,o)}return o},D=t.time("looping through entries");for(const e of p){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const j=t.time("aggregate dependencies and dependents");for(const e of d){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?a.dirname(e.filepath):u,i=hn(r,o.path);let s;if(o.external){const e=n?i:o.path;s=x.inputs.report[e]}else s=x.inputs.report[i];s?(e.dependencies.add(s),s.dependents.add(e)):t.debug(`Could not find input file of ${o.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}j.end(),e.build.outputs=c,e.build.inputs=d,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),_r=(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}),d=t.time("filling sourcemaps inputs",{start:!1}),c=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),c.clear(),p.clear(),l.clear()},onLog(t,n){"warn"===t&&e.build.warnings.push(n.message||n.toString())},renderError(t){t&&e.build.errors.push(t.message)},moduleParsed(e){n.resume();const t=Cr(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=Nr(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=Nr(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?hn(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=Cr(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=Cr(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=hn(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:Ar(e)};if("map"===s.type&&y.add(s),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(Cr(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=i.statSync(e).size}catch(e){n=t.renderedLength}const o=c.get(e)||{name:Or(g,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Ar(e)};s.inputs.push(o),c.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=Cr(e);if(!f.has(n)){b.set(hn(g,n),s);continue}if(c.has(n)){t.debug(`Input report already there for ${n} from ${s.name}.`);continue}const o=c.get(n)||{name:Or(g,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};s.inputs.push(o),c.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 c){const o=f.get(e);if(o){for(const e of o.dependencies){const o=c.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Or(g,e)} of ${n.name}`)}for(const e of o.dependents){const o=c.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Or(g,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){d.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=p.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}d.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Or(g,e),r=p.get(e);if(!r)return c.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[Or(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(hn(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}":"${Or(g,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(c.values()),e.build.outputs=Array.from(p.values()),e.build.entries=Array.from(l.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},Fr=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,d=new Map,c=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||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=Cr(e);t.add(n),n.startsWith("external ")&&t.add(g(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(c.has(e)){const n=c.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else c.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=Cr(t.request);if(c.has(n))return c.get(n);if(e.context){const t=hn(Cr(e.context),n);if(c.has(t))return c.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],i=[],s=[],a.clear(),u.clear(),c.clear(),l.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),i=n.time("indexing modules");for(const e of t)h(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Or(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:Ar(t)};r.push(u),a.set(t,u),w(n)&&a.set(g(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=l.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,c=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>hn(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"===Ar(e))continue;const t=d.get(e)||new Set;for(const e of n)t.add(e);d.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of c){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:hn(e.bundler.outDir,t.name),type:Ar(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){p.push(o);continue}const r=d.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of p){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return new Set;t.add(e);const n=new Set(e.chunks);for(const o of e.childrenIterable||[]){const e=v(o,t);for(const t of e)n.add(t)}return n};for(const[o,r]of t.entrypoints){const t=new Map,i=new Map;let a=0;const d=v(r),c=Array.from(d).flatMap(l),p=r.chunks.filter((e=>h.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===Ar(e)));for(const e of c){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)i.has(e.filepath)||i.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:p?hn(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:p?Ar(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)}))},Lr="datadog-build-report-plugin",zr=e=>{const{context:t}=e,n=t.getLogger(Lr);return[{name:Lr,enforce:"post",esbuild:Tr(t,n),rspack:Fr(t,Lr,n),webpack:Fr(t,Lr,n),vite:_r(t,n),rollup:_r(t,n)}]},qr="datadog-bundler-report-plugin",Br=(e,t)=>t?a.isAbsolute(t)?t:a.resolve(e,t):"",Kr=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)},Ur=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Br(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Vr=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Kr(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=bn(r,process.cwd())),e.bundler.outDir=Br(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Hr=e=>{const{context:t}=e,n=t.getLogger(qr);return[{name:qr,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Br(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Br(t.buildRoot,a.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Ur(t),rspack:Ur(t),vite:Vr(t),rollup:{options(e){let n;if("output"in e){const t=Kr(e.output);n=bn(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=hn(process.cwd(),n);const e=bn([n,...o],process.cwd());t.buildRoot=e===a.sep?process.cwd():e}else t.buildRoot=bn(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=Kr(e);bn(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.")}}}]},Wr="datadog-custom-hooks-plugin",Jr=e=>{const{context:t}=e,n=t.getLogger(Wr),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:Wr,enforce:"pre"}]};class Gr{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=ge(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 Yr=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await Qr(e);for(const e of t)if(e.name===n)return W(e.refs.push);return W(t[0].refs.push)},Qr=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},Xr=async e=>e.revparse("HEAD"),Zr=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),ei=async e=>e.branch(),ti=async e=>e.show(["-s","--format=%s"]),ni=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),oi="datadog-git-plugin",ri=e=>{const{options:t,context:n}=e,o=n.getLogger(oi),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t=[Xr(e),ei(e),ti(e),ni(e),Zr(e),Yr(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,d,c,p,l,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:d,date:c},committer:{name:p,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new Gr(s)}})(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)));n.git=t,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:oi,enforce:"pre",buildRoot(e){if(U(t))try{r.resume();const t=yn(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}`)}}}]},ii="datadog-injection-plugin",si=/^https?:\/\//,ai=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],ui=t.bold.yellow,di=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(hn(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(si)?await(async(e,t=5e3)=>{let n;return Promise.race([L({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await di(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},pi=(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`},li=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||we.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)},fi=e=>e instanceof Error&&"code"in e,mi=e=>ai.includes(e),gi=(e,t,n)=>{e.warn(`"${ui(t)}" files are not supported (${ui(n)}).`)},hi=i.promises,yi=(e,t,n)=>({setup(o){const{onStart:s,onResolve:u,onLoad:d,onEnd:p,esbuild:l,initialOptions:f}=o,m=[],g=`${t.bundler.name}.${we.MIDDLE}.${x}.js`,h=i.realpathSync(c.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 Dr(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await fe(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:ii}))),d({filter:b,namespace:ii},(async()=>({contents:pi(n,{position:we.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),p((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=pi(n,{position:we.BEFORE}),i=pi(n,{position:we.AFTER}),s=pi(n,{position:we.BEFORE,onAllChunks:!0}),u=pi(n,{position:we.AFTER,onAllChunks:!0});if(!(r||i||s||u))return;const d=[];for(const[n,c]of Object.entries(o.metafile.outputs)){const o=c.entryPoint&&m.some((e=>e.resolved.endsWith(c.entryPoint))),p=o?r:s,f=o?i:u;if(!p&&!f)continue;const g=hn(t.buildRoot,n),{base:h,ext:y}=a.parse(g);mi(y)?d.push((async()=>{try{const e=await hi.readFile(g,"utf-8"),t=await l.transform(e,{loader:"default",banner:p,footer:f});await hi.writeFile(g,t.code)}catch(t){if(!fi(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${g}: ${t}`)}})()):gi(e,y,h)}await Promise.all(d)}))}}),bi=x,wi="?inject-proxy",vi=(e,t)=>({banner(n){const o=pi(t,{position:we.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=a.parse(n.fileName);return mi(i)?o:(gi(e,i,r),"")},async resolveId(e,n,o){if(B(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&pi(t,{position:we.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}${wi}`}return null},load(e){if(B(e))return pi(t,{position:we.MIDDLE});if(e.endsWith(wi)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(bi)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=pi(t,{position:we.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=a.parse(n.fileName);return mi(i)?o:(gi(e,i,r),"")}}),$i=(e,t,n,o,r)=>s=>{const u=new WeakMap,d=e.sources.ConcatSource,c=n.bundler.name,p=a.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${c}.${we.MIDDLE}.${x}.js`);me(p,"");s.hooks.shutdown.tap(ii,(()=>{var e;e=p,i.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await li(t,o,r,n.buildRoot)};s.hooks.beforeRun.tapPromise(ii,l),s.hooks.watchRun.tapPromise(ii,l),s.hooks.compilation.tap(ii,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:ii,stage:o},(()=>{const e=pi(r,{position:we.BEFORE}),o=pi(r,{position:we.AFTER}),i=pi(r,{position:we.BEFORE,onAllChunks:!0}),s=pi(r,{position:we.AFTER,onAllChunks:!0});for(const r of n.chunks){let c=e,p=o;if(r.canBeInitial()||(c=i,p=s),""!==c||""!==p)for(const e of r.files){const{base:o,ext:r}=a.parse(e);mi(r)?n.updateAsset(e,(e=>{const t=u.get(e);if(!t||t.banner!==c||t.footer!==p){const t=new d(c,"\n",e,"\n",p);return u.set(e,{source:t,banner:c,footer:p}),t}return t.source})):gi(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},ki=e=>{const{bundler:t,context:n}=e,o=n.getLogger(ii),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++G}`,e)};const s={name:ii,enforce:"post",esbuild:yi(o,n,i),webpack:$i(t,o,n,r,i),rspack:$i(t,o,n,r,i),rollup:vi(o,i),vite:{...vi(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>pi(i,{position:we.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:pi(i,{position:we.MIDDLE})})}:s.buildStart=async()=>{await li(o,r,i,n.buildRoot)},[s]},xi="datadog-true-end-plugin",Ei=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=()=>{t.hook("syncTrueEnd")},r=async()=>{o(),await n()},i=e=>{e.hooks.shutdown.tapPromise(xi,r)},s={async writeBundle(){},async closeBundle(){await r()}};return[{name:xi,enforce:"post",webpack:i,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:s,rollup:s,rspack:i}]},Si={[Mo]:or},Ii=t.bold.red;var Di="3.1.8-dev.1";const ji=(({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: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: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=j);const a=process.env.BUILD_PLUGINS_ENV||"production",u=S.includes(a)?a:"development",d=t.rspackVersion||t.version||t.VERSION,c=r.framework,p={bundler:{name:c,version:d},env:u,metadata:s.metadata||{},packageName:`@datadog/${c}-plugin`,version:n},l={errors:[],logs:[],queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:ee(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:z(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",Er],["async-queue",Ir],["build-report",zr],["bundler-report",Hr],["custom-hooks",Jr],["git",ri],["injection",ki],["true-end",Ei]),s.customPlugins&&h.push(["custom",s.customPlugins]);const y=[["apps",se,Tn],["error-tracking",_n,Qn],["live-debugger",Xn,Po],["metrics",Mo,rr],["output",ir,pr],["rum",lr,kr]];for(const[e,t,n]of y)ie(s,t,m)&&h.push([e,n]);for(const[e,n]of h)f.plugins.push(...oe(f,n,e)({bundler:t,context:f,options:s,data:p,stores:l}));return(e=>{const t=[];for(const n of M){const o=C(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>A(e))).join(" and "),i=A(`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: ${Ii(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),g.end(),f.plugins}))})({bundler:v,version:Di}).esbuild,Pi=Di,Ai=Si;exports.datadogEsbuildPlugin=ji,exports.helpers=Ai,exports.version=Pi;
|
|
2
2
|
//# sourceMappingURL=index.js.map
|