@datadog/esbuild-plugin 3.2.0 → 3.2.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.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 +1 -1
package/dist/src/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{createUnplugin as e}from"unplugin";import t from"chalk";import n from"async-retry";import{File as o}from"buffer";import r,{mkdtemp as i}from"fs/promises";import s from"fs";import{JsonStreamStringify as a}from"json-stream-stringify";import u from"path";import{Readable as d}from"stream";import{createHash as c,randomUUID as p}from"crypto";import l,{tmpdir as f}from"os";import*as m from"eslint-scope";import g from"jszip";import{glob as h}from"glob";import y from"pretty-bytes";import b from"p-queue";import w from"@jridgewell/remapping";import{performance as v}from"perf_hooks";import{instrument as $}from"@datadog/js-instrumentation-wasm";import{simpleGit as k}from"simple-git";import x from"esbuild";import E from"node:url";import S from"node:path";import I from"node:module";const D=E.fileURLToPath(import.meta.url),j=S.dirname(D),P=I.createRequire(import.meta.url),M="__datadog-helper-file",A=new RegExp(M),C=["development","production","test"],N=["datadoghq.com","us3.datadoghq.com","us5.datadoghq.com","datadoghq.eu","ddog-gov.com","us2.ddog-gov.com","ap1.datadoghq.com","ap2.datadoghq.com","datad0g.com"],T=N[0],O="datadog-build-plugins",R=t.bold.green,_=t.bold.yellow,F=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],z=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],L=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},B=(e,t,n)=>{if(void 0!==e)return(e=>N.some((t=>t===e)))(e)?e:void n.push(`${t} "${e}" is not a supported Datadog site. See the site parameters in https://docs.datadoghq.com/getting_started/site/.`)},K=e=>{if(null===e||"object"!=typeof e)return"";const t="title"in e&&"string"==typeof e.title?e.title:void 0,n="detail"in e&&"string"==typeof e.detail?e.detail:void 0;return t&&n?`${t}: ${n}`:t||(n?`detail: ${n}`:"")},q=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),U=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())}}},V=[400,401,403,404,405,409,413],H=e=>{const{auth:t,url:o,method:r="GET",getData:i,type:s="text"}=e,a={retries:0===e.retries?0:e.retries||5,onRetry:e.onRetry,maxTimeout:e.maxTimeout,minTimeout:e.minTimeout};return n((async(e,n)=>{let a;try{const e={method:r,duplex:"half"};let n={"X-Datadog-Origin":"build-plugins"};if(t?.apiKey&&(n["DD-API-KEY"]=t.apiKey),t?.appKey&&(n["DD-APPLICATION-KEY"]=t.appKey),"function"==typeof i){const{data:t,headers:o}=await i();e.body=t,n={...n,...o}}a=await fetch(o,{...e,headers:n})}catch(t){return e(t),{}}if(!a.ok){let t=`HTTP ${a.status} ${a.statusText}`;try{const e=(e=>{try{const t=JSON.parse(e);if(null!==t&&"object"==typeof t)if("errors"in t&&Array.isArray(t.errors)){const e=t.errors.map(K).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=K(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(V.includes(a.status))return e(new Error(t)),{};throw new Error(t)}try{let e;return e="json"===s?await a.json():await a.text(),e}catch(t){return e(t),{}}}),a)},W=e=>({message:t,context:n})=>H({retries:2,minTimeout:100,url:"https://browser-http-intake.logs.datadoghq.com/v1/input/pub44d5f4eb86e1392037b7501f7adc540e",method:"POST",type:"json",getData:async()=>{const o={ddsource:e.packageName||O,message:t,service:"build-plugins",team:"language-foundations",env:e.env,version:e.version,bundler:{name:e.bundler.name,version:e.bundler.version},metadata:e.metadata,...n};return{data:JSON.stringify(o),headers:{"Content-Type":"application/json"}}}}),J=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),G=e=>e.includes(M),Y=e=>{const t={bundler:e.bundler,errors:e.errors,metadata:e.metadata,warnings:e.warnings,logs:e.logs,timings:e.timings,start:e.start,end:e.end,duration:e.duration,writeDuration:e.writeDuration,entries:[],inputs:[],outputs:[]};for(const n of e.entries||[]){const e={...n,inputs:[],outputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),n.outputs&&(e.outputs=n.outputs.map((e=>e.filepath))),t.entries.push(e)}for(const n of e.inputs||[]){const e={...n,dependencies:[],dependents:[]};if(n.dependencies)for(const t of n.dependencies)e.dependencies.push(t.filepath);if(n.dependents)for(const t of n.dependents)e.dependents.push(t.filepath);t.inputs.push(e)}for(const n of e.outputs||[]){const e={...n,inputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),t.outputs.push(e)}return t},Q=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},Z=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()},X=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),r=Math.min(10,Math.floor(o/2)),i=o-r;return`${e.slice(0,r)}${n}${e.slice(-i)}`},ee=(e="")=>{try{if(!e||e.startsWith("git@"))return e;const t=new URL(e),n="/"===t.pathname?"":t.pathname;return`${t.protocol?`${t.protocol}//`:""}${t.host}${n}`}catch{return e}},te=e=>e.trim().toLowerCase().replace(/[^a-z0-9_:./-]+/g,"_").replace(/^_+|_+$/g,"")||"unknown",ne=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 oe=0;const re={debug:0,info:1,warn:2,error:3,none:4},ie=e=>e.split(">").map(J).join(">"),se=(e,n,o,r)=>{const i=ie(e);return(s,a="debug",{forward:u,context:d}={})=>{let c=t.dim,p=console.log;"error"===a?(c=t.red,p=console.error):"warn"===a?(c=t.yellow,p=console.warn):"info"===a&&(c=t.cyan,p=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=W(n);await t({message:f,context:{plugin:e,status:a,...d}})}catch(t){se(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}re[a]>=re[r]&&p(`${c(l)} ${f}`)}},ae=(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(Z(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)}}},ue=(e,t,n="warn")=>o=>{const r=se(o,e,t,n);return{getLogger:r=>ue(e,t,n)(`${ie(o)}>${r}`),time:ae(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)}},de=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],ce=(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)},pe=(e,t,n)=>{const o=e.getLogger(O);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=J(e.name);for(const r of de){const i=e[r];i&&(n[r]=ce(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},le=new Set,fe=(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&&(le.has(t)||(le.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},me="apps",ge="datadog-apps-plugin",he="api/unstable/app-builder-code/apps",ye="datadog-apps-assets.zip",be=/\.backend\.(ts|tsx|js|jsx)$/,we=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],ve=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),$e=async e=>r.mkdir(e,{recursive:!0}),ke=(e,t)=>{var n;n=u.dirname(e),s.mkdirSync(n,{recursive:!0}),s.writeFileSync(e,t,{encoding:"utf-8"})},xe=e=>s.readFileSync(e,{encoding:"utf-8"}),Ee=e=>{try{return s.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},Se=async(e,t)=>{if("function"==typeof s.openAsBlob){const n=await s.openAsBlob(e,{type:t.contentType});return new o([n],t.filename)}{const n=d.toWeb(s.createReadStream(e)),r=await new Response(n).blob();return new o([r],t.filename,{type:t.contentType})}},Ie=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 De=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(De||{});function je(e,t){if(!function(e){return"Program"===e.type}(e))throw new Error(`Expected a Program node from this.parse() for ${t}, got ${e.type}`);return e}function Pe(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function Me(e){return"type"===e.importKind||"type"===e.exportKind}function Ae(e,t){return function(e,t){const n=je(e,t),o=function(e){const t=new Map;for(const n of e.body)if("FunctionDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"function"});else if("ClassDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"class"});else if("VariableDeclaration"===n.type)for(const e of n.declarations)"Identifier"===e.id.type&&t.set(e.id.name,{kind:"variable",init:e.init});else if("ImportDeclaration"===n.type)for(const e of n.specifiers)t.set(e.local.name,{kind:"import"});return t}(n),r=[];for(const e of n.body){if("ExportDefaultDeclaration"===e.type)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);if("ExportAllDeclaration"===e.type)throw new Error(`"export *" is not supported in .backend.ts files. Use explicit named exports instead: ${t}`);if("ExportNamedDeclaration"!==e.type)continue;e.declaration&&r.push(...Te(e.declaration,t).map((e=>({kind:"local",name:e,localName:e}))));const n="string"==typeof e.source?.value?e.source.value:null;for(const i of e.specifiers){if("Identifier"!==i.exported.type)continue;if("default"===i.exported.name)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);const e="Identifier"===i.local.type?i.local.name:"string"==typeof i.local.value?i.local.value:null;e&&(n?r.push({kind:"re-export",name:i.exported.name,localName:e,source:n}):("Identifier"===i.local.type&&Oe(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const Ce=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function Ne(e){return null==e||Ce.has(e.type)}function Te(e,t){if("FunctionDeclaration"===e.type&&e.id)return[e.id.name];if("ClassDeclaration"===e.type)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${t}`);if("VariableDeclaration"===e.type)return e.declarations.flatMap((e=>{if("Identifier"!==e.id.type)throw new Error(`Destructured exports are not supported in backend files. Use individual named exports instead: ${t}`);if(Ne(e.init))throw new Error(`Non-function export "${e.id.name}" in backend file ${t}. Only function exports are supported — use "export function ${e.id.name}(…) { }" instead.`);return[e.id.name]}));throw new Error(`Unsupported export declaration type "${e.type}" in backend file ${t}. Only function and variable exports are allowed.`)}function Oe(e,t,n){const o=t.get(e);if(o){if("class"===o.kind)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${n}`);if("variable"===o.kind&&Ne(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function Re(e){const t=e.relativePath.split(u.sep).join("/");return`${c("sha256").update(t).digest("hex")}.${e.name}`}function _e(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 Fe(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return P.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}(n)&&o.push("import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';"),o.push(""),o.push('/** @param {import("./context.types").Context} $ */'),o.push("export async function main($) {"),o.push(" globalThis.$ = $;"),o.push(""),o.push(" // Register the $.Actions-based implementation for executeAction"),o.push(" if (typeof setExecuteActionImplementation === 'function') {\n setExecuteActionImplementation(async (actionId, request) => {\n const actionPath = actionId.replace(/^com\\.datadoghq\\./, '');\n const pathParts = actionPath.split('.');\n let actionFn = $.Actions;\n for (const part of pathParts) {\n if (!actionFn) throw new Error('Action not found: ' + actionId);\n actionFn = actionFn[part];\n }\n if (typeof actionFn !== 'function') throw new Error('Action is not a function: ' + actionId);\n return actionFn(request);\n });\n }"),o.push(""),o.push(" const args = $.backendFunctionArgs ?? [];"),o.push(` const result = await ${e}(...args);`),o.push(" return result;"),o.push("}"),o.join("\n")}function ze(e,t,n){const o={state:t},r=e=>{n._?.(e,o),function(e,t){return t[e.type]}(e,n)?.(e,o);for(const t of Object.keys(e))"type"!==t&&i(e[t])},i=e=>{if(Array.isArray(e))for(const t of e)Le(t)&&r(t);else Le(e)&&r(e)};r(e)}function Le(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function Be(e){ze(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=m.analyze(e,{ecmaVersion:2022,ignoreEval:!0,sourceType:"module"}),n=new Map;for(const e of t.scopes)for(const t of e.references)n.set(t.identifier,t);return{scopeManager:t,referencesByIdentifier:n,moduleScope:Ve(t)}}function Ke(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function qe(e){return e.defs.some((e=>"ImportBinding"===e.type))}function Ue(e,t){return t.moduleScope.set.get(e)}function Ve(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function He(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:We(e,t)},r=[];return ze(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 tt(n,"action-catalog call aliases");if(Qe(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw tt(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!Je(o,t.scopeAnalysis))return!1;if(e.optional||Ye(o))throw tt(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function We(e,t){const n=new Set;return ze(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 Xe(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&Je(e.init,t))return Xe(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?[]:et(e.value))).map((e=>e.name));return Xe(e,t,n)}(e,t))n.add(o)},AssignmentExpression(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.left.type&&"Identifier"===e.right.type&&Qe(e.right,t.actionFunctions,t))return Ze([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&Je(e.right,t))return Ze([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?[]:et(e.value)));return Ze(n,t)}(e,t))n.add(o)}}),n}function Je(e,t){const n=Ge(e);return!!n&&Qe(n,t.actionNamespaces,t)}function Ge(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?Ge(e.object):void 0}function Ye(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&Ye(e.object)}function Qe(e,t,n){return function(e,t,n){const o=Ke(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function Ze(e,t){return e.flatMap((e=>{const n=Ke(e,t.moduleScope);return n?[n]:[]}))}function Xe(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function et(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?et(e.argument):et(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?et(e):[]));case"RestElement":return et(e.argument);case"AssignmentPattern":return et(e.left);case"MemberExpression":return[]}}function tt(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const nt="@datadog/action-catalog";function ot(e,t,n){const o=e.get(t);if(!o)return ct(t,[],n.name);const r=Ke(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?pt(t,[],n.name):st({modules:e,visitedExports:new Set},t,r,[]):pt(t,[],n.name)}function rt(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 ut(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?ut(t.id,r,n):rt(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return st(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=rt(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||!it(r,s)){if(r)return at(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 it(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function st(e,t,n,o){const r=e.modules.get(t);if(!r)return ct(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return dt(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 dt(t,r,n);return rt(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 at(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 ut(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 dt(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 ct(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 pt(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 lt(e,t,n){const o=xt(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=ot(e.modules,t,n);if("unsupported"===o.kind)return Ct(o,n.name);if(!o.binding.expression)return Nt(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return Dt(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return lt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=ft(e,t,n);if("unsupported"===o.kind)return o;return lt(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 ft(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=mt(e,t,n.object);return"unsupported"===o.kind?o:function(e,t,n){let o;for(const r of t.properties){if("SpreadElement"===r.type)return At(e);if(r.computed)return It(e);if(kt(r)===n){if(o)return jt(e,n);if("init"!==r.kind)return St(e,n);if(!gt(r))return Mt(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 mt(e,t,n){if("Super"===n.type)return Pt(t,n.type);const o=xt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=ft(e,t,o);return"unsupported"===n.kind?n:mt(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return Pt(t,o.type);const r=ot(e.modules,t,o);if("unsupported"===r.kind)return Ct(r,o.name);if(!r.binding.expression)return Nt(r.moduleId,r.variable.name);if(e.mutatedImportedObjectVariables.has(r.variable))return function(e,t){return{kind:"unsupported",moduleId:e,reason:"imported-object-mutation",variableName:t,message:`Imported object '${t}' from module '${e}' is mutated in the module graph.`}}(r.moduleId,r.variable.name);if(e.seenVariables.has(r.variable))return Dt(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return mt(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function gt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function ht(e){const t=new Set;for(const n of e.values())ze(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){bt(e.left,t)},UpdateExpression(e,{state:t}){bt(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&bt(e.argument,t)},ForInStatement(e,{state:t}){yt(e.left,t)},ForOfStatement(e,{state:t}){yt(e.left,t)}});return t}function yt(e,t){"VariableDeclaration"!==e.type&&bt(e,t)}function bt(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&bt(e.left,t):bt(e.argument,t);else for(const n of e.elements)n&&bt(n,t);else for(const n of e.properties)bt("RestElement"===n.type?n.argument:n.value,t);else{const n=$t(e);n&&wt(n,t)}else wt(e,t)}function wt(e,t){const n=vt(t,e,new Set);n&&t.mutatedVariables.add(n)}function vt(e,t,n){const o=Ke(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),qe(o)){const n=ot(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=xt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return $t(t);return}(r);return i?vt(e,i,n):void 0}function $t(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?$t(e.object):void 0}function kt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function xt(e){let t=e;for(;Et(t);)t=t.expression;return t}function Et(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function St(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 It(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function Dt(e,t){return{kind:"unsupported",moduleId:e,reason:"cycle",variableName:t,message:`Resolving variable '${t}' in module '${e}' would cycle through static string values.`}}function jt(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function Pt(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 Mt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unsupported-object-property-value",propertyName:t,valueType:n,message:`Static object property '${t}' in module '${e}' has unsupported value type '${n}'.`}}function At(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function Ct(e,t){return{kind:"unsupported",moduleId:e.moduleId,reason:"static-definition-unsupported",variableName:t,definition:e,message:`Variable '${t}' could not be resolved to a static definition: ${e.message}`}}function Nt(e,t){return{kind:"unsupported",moduleId:e,reason:"uninitialized-const",variableName:t,message:`Const variable '${t}' in module '${e}' does not have an initializer.`}}const Tt=new Set(["node_modules",".yarn"]);function Ot(e,t,n,o=[]){if(!Xt(e,t))return null;const r=je(n,e),i=Be(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&&Pe(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:Rt(r,i,s),exportsByName:_t(r,i,s),starExports:Lt(r,s),topLevelBindingsByVariable:Bt(r,i)}}function Rt(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!Pe(r.source))continue;const e=Yt(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:Jt(n.imported),resolvedId:e}))}}return o}function _t(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&zt(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):Ft(r,t,n,o);return o}function Ft(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&&Pe(e.source)){const t=Yt(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=Jt(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:Jt(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=Jt(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=Ue(Jt(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function zt(e,t,n){const o=Gt(e);o&&Pe(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Yt(t,e.source.value)})}function Lt(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||Gt(e)||!Pe(e.source)?[]:[{resolvedId:Yt(t,e.source.value)}]))}function Bt(e,t){const n=new Map;for(const o of e.body)Kt(o,t,n);return function(e,t,n){ze(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){Vt(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){Vt(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Vt(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){Ut(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){Ut(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function Kt(e,t,n){if("VariableDeclaration"===e.type)return void qt(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void qt(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 qt(e,t,n){for(const o of e.declarations){const r=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const e of r)n.set(e,{kind:"unsupported",reason:"binding pattern"});continue}const[i]=r;i&&("const"===e.kind?n.set(i,{kind:"const",expression:o.init??null}):n.set(i,{kind:"mutable",declarationKind:e.kind}))}}function Ut(e,t,n){"VariableDeclaration"!==e.type&&Vt(e,t,n)}function Vt(e,t,n){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&Vt(e.left,t,n):Vt(e.argument,t,n);else for(const o of e.elements)o&&Vt(o,t,n);else for(const o of e.properties)Vt("RestElement"===o.type?o.argument:o.value,t,n);else{const o=Wt(e);o&&Ht(o,t,n,"mutated object binding")}else Ht(e,t,n,"reassigned binding")}function Ht(e,t,n,o){const r=Ke(e,t);if(!r||qe(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function Wt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?Wt(e.object):void 0}function Jt(e){return"Identifier"===e.type?e.name:String(e.value)}function Gt(e){const t=e.exported;return t?Jt(t):void 0}function Yt(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function Qt(e){const t=[];return ze(e,t,{ImportExpression(e,{state:t}){const n=function(e){return tn(e.source,"non-literal dynamic import")}(e);Zt(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 tn(e.arguments[0],"non-literal dynamic import")}(e);Zt(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||!Pe(t)||nn(t.value)})(e)&&t.push({specifier:en(e),kind:"require"})}}),t}function Zt(e){return"non-literal dynamic import"===e||nn(e)}function Xt(e,t){if(!we.some((t=>e.endsWith(t))))return!1;const n=u.relative(u.resolve(t),e);return!n.startsWith("..")&&!u.isAbsolute(n)&&!n.split(u.sep).some((e=>Tt.has(e)))}function en(e){return tn(e.arguments[0],"local require")}function tn(e,t){return Pe(e)?e.value:t}function nn(e){return e.startsWith(".")||e.startsWith("/")}function on(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function rn(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 on(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw on(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Xt(i,n)){if(!t.has(i))throw on(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===nt||o.startsWith(`${nt}/`))&&!Me(r))for(const e of r.specifiers)Me(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)qe(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 He(e.ast,r,e.id)){const r=sn(n,t,e);r&&o.add(r)}})),[...o].sort()}function sn(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw dn(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 dn(t,"spread object arguments");if(o.computed)throw dn(t,"computed object property keys");if(un(o)){if(n)throw dn(t,"multiple connectionId properties");if("init"!==o.kind)throw dn(t,"accessor connectionId properties");if(!an(o))throw dn(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return lt({modules:e,mutatedImportedObjectVariables:ht(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 an(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function un(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 dn(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const cn=/^(?:\0|virtual:)/;function pn(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=ln(n.id);if(r=o,cn.test(r))return;var r;const i=Ot(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(ln));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function ln(e){return e.split("?")[0]}function fn(e,t){const n=pn(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>rn(e,n.getModuleRecords(),t)}}function mn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function gn(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:[...we,".json"]},plugins:[mn("dd-backend-resolve",t),...n]}}function hn(e){return`${e.relativePath}/${e.name}`}async function yn(e,t,n,o){const r=hn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return Fe(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=fn(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=gn(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 bn(e,t,n,o,r){const i=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,s=hn(t);r.debug(`Calling Datadog API: ${i}`);const a=JSON.stringify({data:{type:"queries",attributes:{query:{id:p(),name:s,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e,allowedConnectionIds:t.allowedConnectionIds,context:{backendFunctionArgs:n}}},onlyTriggerManually:!0}},template_params:{}}}}),u=await H({url:i,auth:o,method:"POST",type:"json",getData:()=>({data:a,headers:{"Content-Type":"application/json"}})}),d=u.data?.id;if(!d)throw new Error("No receipt ID returned from Datadog API");return r.debug(`Query execution started with receipt: ${d}`),async function(e,t,n){const o=`https://api.${t.site}/api/v2/app-builder/queries/execution-long-polling/${e}`,r=10;for(let e=0;e<r;e++){n.debug(`Long-poll attempt ${e+1}/${r}...`);const i=await H({url:o,auth:t,type:"json"});if(i.errors?.length){const e=i.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const s=i.data?.attributes;if(n.debug(`Long-poll response, done: ${s?.done}`),s?.done){if(!s.outputs)throw new Error("Query execution completed without outputs");return s.outputs}}throw new Error("Query execution timed out")}(d,o,r)}function wn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class vn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function $n(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 vn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new vn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function kn(e,t,n,o,r){const i=t=>yn(e,t,o,r),s=t();s.length>0&&r.info(`Dev server middleware active for ${s.length} backend function(s): ${s.map((e=>e.name)).join(", ")}`);const a=n.apiKey&&n.appKey?{apiKey:n.apiKey,appKey:n.appKey,site:n.site}:void 0;return a||r.warn("Auth credentials not configured. The /__dd/executeAction endpoint will be unavailable. Set DD_API_KEY and DD_APP_KEY to enable remote execution."),(e,n,o)=>{if("POST"!==e.method)return void o();const s=(u=t(),new Map(u.map((e=>[Re(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await $n(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){wn(t,e instanceof vn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,n,s,i).catch((()=>{wn(n,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void wn(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 $n(e,n,o),d=hn(s);i.debug(`Executing action: ${d} with args`);const c=await bn(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 vn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";i.debug(`Error handling executeAction: ${o}`),wn(t,n,o)}})(e,n,s,i,a,r).catch((()=>{wn(n,500,"Unexpected error")}))}else o()}}const xn=async(e,t)=>{const n=(await Promise.all(e.map((e=>h(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>u.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(u.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(u.sep);if(!e.every((e=>e.startsWith(`${r}${u.sep}`))))break;n=r}return n})(o),i=o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o.split(u.sep).join("/")}}));return i},En=(e,t)=>G(t)?M:t.startsWith(e)||u.isAbsolute(t)?t:u.resolve(e,t),Sn=(e,t)=>{let n,o=En(process.cwd(),e);for(;!n;){const e=u.resolve(o,t);if(Ee(e)&&(n=e),o=o.split(u.sep).slice(0,-1).join(u.sep),[u.sep,""].includes(o))break}return n},In=(e,t)=>{const n=[...e].map((e=>En(t||process.cwd(),e).split(u.sep))),o=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<o;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(u.sep)||u.sep},Dn=t.bold.red,jn=t.bold.yellow,Pn=e=>{const t=Sn(e,"package.json");if(t)try{const e=xe(t);return JSON.parse(e)}catch(e){return}},Mn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=Pn(e);o||t.warn(jn("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(Dn("Unable to determine the app name to compute the app identifier."));const i=((e,t)=>{const n=e||(e=>{if(e&&e.repository)return"string"==typeof e.repository?e.repository:"url"in e.repository?e.repository.url:void 0})(t);if(!n)return;const o=ee(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(Dn("Unable to determine the git remote to compute the app identifier."));const s=n?.identifier||((e,t)=>{if(!e||!t)return;const n=`${e}:${t}`;return c("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(Dn("Unable to compute the app identifier.")),{identifier:s,name:r}},An=t.green.bold,Cn=t.yellow.bold,Nn=t.cyan.bold,Tn=t.bold,On=(e,t={},n)=>async()=>{const o=await Se(e,{contentType:"application/zip",filename:ye});return U({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ye);const t=z("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},Rn=async(e,t,n)=>{const o=[],r=[];if(!t.apiKey||!t.appKey)return o.push(new Error("Missing authentication token, need both app and api keys.")),{errors:o,warnings:r};if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:r};const i=(s=t.site,a=t.identifier,z("APPS_INTAKE_URL")||`https://api.${s}/${he}/${a}/upload`);var s,a;const u=q({bundler:t.bundlerName,plugin:"apps",version:t.version}),c=ne({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(u,null,2)}`}),p=`an archive of:\n - ${An(e.assets.length.toString())} files\n - ${An(y(e.size))}\n\nWith the configuration:\n${c}`;if(t.dryRun)return n.error(`\n${Nn("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:On(e.archivePath,u,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Cn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}});if(n.debug(`Uploaded ${p}\n`),o.app_builder_id){const e=`https://app.${t.site}/app-builder/apps/${o.app_builder_id}`;n.info(`Your application is available at:\n ${Nn(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${he}/${t}/release/live`)(t.site,t.identifier);await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:e,method:"PUT",type:"json",getData:async()=>({data:d.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...u}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${Cn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${Tn(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}},_n=t.yellow.bold,Fn=t.red.bold,zn="manifest.json";async function Ln(e){const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-manifest-")),n=u.join(t,zn);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[Re(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await ve(t),e}return{manifestAsset:{absolutePath:n,relativePath:zn},cleanup:()=>ve(t)}}const Bn=async({backendOutputs:e,backendFunctions:t,context:n,options:o})=>{const i=n.getLogger(ge),{auth:a,buildRoot:d,bundler:{name:c,outDir:p},git:f,version:m}=n,h=i.time("handle assets");let y,b,w;try{const n=i.time("resolve identifier"),{name:h,identifier:w}=Mn(d,i,{url:f?.remote,name:o.name,identifier:o.identifier});if(!w||!h)throw new Error("Missing apps identification.\nEither:\n - pass an 'options.apps.identifier' and 'options.apps.name' to your plugin's configuration.\n - have a 'name' and a 'repository' in your 'package.json'.\n - have a valid remote url on your git project.\n");n.end();const v=u.relative(d,p),$=[...o.include,`${v}/**/*`],k=await xn($,d);if(!k.length)return void i.debug("No assets to upload.");const x=new Set(e.values()),E=k.filter((e=>!x.has(e.absolutePath))).map((e=>({...e,relativePath:`frontend/${e.relativePath}`})));for(const[t,n]of e)E.push({absolutePath:n,relativePath:`backend/${t}.js`});const{manifestAsset:S,cleanup:I}=await Ln(t);b=I,E.push(S);const D=i.time("archive assets"),j=await(async e=>{const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-")),n=u.join(t,ye),o=new g;for(const t of e)o.file(t.relativePath,s.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=s.createWriteStream(n),i=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});i.on("error",t),r.on("error",t),r.on("close",e),i.pipe(r)}));const{size:i}=await r.stat(n);return{archivePath:n,size:i,assets:e}})(E);D.end(),y=u.dirname(j.archivePath);const P=i.time("upload assets"),{errors:M,warnings:A}=await Rn(j,{apiKey:a.apiKey,appKey:a.appKey,bundlerName:c,dryRun:o.dryRun,identifier:w,name:h,site:a.site,version:m},i);if(P.end(),A.length>0&&i.warn(`${_n("Warnings while uploading assets:")}\n - ${A.join("\n - ")}`),M.length>0){const e=M.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){w=e,i.error(`${Fn("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await ve(y),b&&await b(),h.end(),w)throw w};const Kn=u.join(j,"./apps-runtime.mjs"),qn=({bundler:e,context:t,options:n})=>{const o=t.getLogger(ge),{auth:r,buildRoot:s}=t;t.inject({type:"file",position:De.MIDDLE,value:Kn});const{setBackendFunctions:a,getBackendFunctions:d}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[be],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=Ae(this.parse(e),t);if(0===n.length)return o.warn(`Backend file ${t} has no exported functions. Did you forget to add a named export?`),a(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=u.relative(n,t).replace(be,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:Re(e)})}return{functions:r,proxyCode:_e(i)}}(n,t,s);return a(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let r,a=new Map,c=d();if(c.length>0){const t=await async function(e,t,n,o){const r=await i(u.join(f(),"dd-apps-backend-")),s=new Map,a=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const i of t){const t=Re(i),d=`\0dd-backend:${t}`,c=Fe(i.name,i.absolutePath,n),p=fn(i.absolutePath,n),l=gn(n,{[d]:c},[p.plugin]),f=await e({...l,build:{...l.build,write:!0,outDir:r,emptyOutDir:!1,rollupOptions:{...l.build.rollupOptions,input:{[t]:d},output:{...l.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=u.resolve(r,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}a.set(i.absolutePath,p.getAllowedConnectionIds())}return{outDir:r,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:a.get(e.absolutePath)})))}}(e.build,c,s,o);r=t.outDir,a=t.outputs,c=t.functions}try{await Bn({backendOutputs:a,backendFunctions:c,context:t,options:n})}finally{r&&await ve(r)}},configureServer(t){t.middlewares.use(kn(e.build,d,r,s,o))}}},Un=({options:e,context:t,bundler:n})=>{const o=t.getLogger(ge),r=(e=>{const t=e[me]||{};return{include:t.include||[],dryRun:t.dryRun??!z("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:ge,enforce:"post",vite:qn({bundler:n,context:t,options:r})}]},Vn="errorTracking",Hn="datadog-error-tracking-plugin",Wn=(e,n,o)=>{if(".map"!==u.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=u.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return u.join(e,t);try{const n=e.replace(/\/*$/,"/"),o=new URL(n),r=t.replace(/^[\\/]*/,"");return new URL(r,o).href}catch{return`${e}${t}`}})(e,i);return{minifiedFilePath:r,minifiedUrl:s,relativePath:i}},Jn=/[/]+|[\\]+/g,Gn=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Yn=(e,t)=>{const n=e.replace(Gn,"").split(Jn),o=t.replace(Gn,"").split(Jn),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([Ie(e.minifiedFilePath),Ie(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Yn(e.relativePath,t)}})(e,n),i=[],s=[],a=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(o)try{a.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${u.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:o.hash,repository_url:o.remote}],version:1})})}catch(t){s.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&s.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:a,errors:i,warnings:s}},Zn=e=>{const t=e.message.match(/HTTP (\d{3})/);return t?`status_code:${t[1]}`:"status_code:unknown"},Xn=e=>{const t=Zn(e);return"status_code:unknown"!==t?`error_type:http_${t.replace("status_code:","")}`:`error_type:${te(e.name||"unknown")}`},eo=(e,t,n)=>{const o=((e,t)=>`${e}|${t.join("|")}`)(t,n),r=e.metrics.get(o);r?r.value++:e.metrics.set(o,{name:t,value:1,tags:n})},to=(e,t,n)=>{eo(e,"retry",[...e.baseTags,`attempt:${n}`,Zn(t),Xn(t)])},no=(e,t)=>{eo(e,"failure",[...e.baseTags,Zn(t),Xn(t)])},oo=(e,t)=>{if(!t.sendMetrics)return;if(!e.metrics.size)return;const n=(e=>{const t=Math.floor(Date.now()/1e3);return Array.from(e.metrics.values()).map((e=>({metric:`sourcemaps.upload.${e.name}`,type:"count",points:[[t,e.value]],tags:e.tags})))})(e);for(const e of n)t.addMetric(e)},ro=t.green.bold,io=t.yellow.bold,so=t.red.bold,ao=(e,t={})=>async()=>U({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await Se(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}),uo=async(e,t,n,o)=>{const r=[],i=[];if(!n.apiKey)return r.push({error:new Error("No authentication token provided")}),{errors:r,warnings:i};if(0===e.length)return i.push("No sourcemaps to upload"),{errors:r,warnings:i};const s=o.time("Queue uploads"),a=new(b.default?b.default:b)({concurrency:t.maxConcurrency}),u=(d=n.site,z("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${d}/api/v2/srcmap`);var d;const c=q({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=(e=>({metrics:new Map,baseTags:[`service:${e.service}`]}))(t),l=ne({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),f=`\nUploading ${ro(e.length.toString())} sourcemaps with configuration:\n${l}`;o.debug(f);const m=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};m.push(a.add((async()=>{try{await H({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:ao(s,c),onRetry:(t,n)=>{to(p,t,n);const r=`Failed to upload ${io(e.sourcemap)} | ${io(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(no(p,n),r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}s.end(),o.debug(`Queued ${ro(e.length.toString())} uploads.`);try{await Promise.all(m),await a.onIdle()}finally{oo(p,n)}return{warnings:i,errors:r}},co=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=>({...Wn(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 uo(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site,sendMetrics:n.sendMetrics,addMetric:n.addMetric},o);if(p.end(),o.debug(`Done uploading ${ro(`${e.length-l.length}/${e.length}`)} sourcemaps in ${ro(Z(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?`${so(e.file)} | ${so(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{addMetric:t.addMetric,apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,sendMetrics:t.sendMetrics,site:t.site,version:t.version},n),i.end()},po=e=>{const n=t.bold.red,o=e[Vn]||{},r={errors:[]};if(o.sourcemaps){const t=o.sourcemaps,i=t.releaseVersion||e.metadata?.version;i||r.errors.push(`${n("sourcemaps.releaseVersion")} is required (set it directly or via ${n("metadata.version")}).`),t.releaseVersion&&e.metadata?.version&&t.releaseVersion!==e.metadata.version&&r.errors.push(`${n("sourcemaps.releaseVersion")} must match ${n("metadata.version")} when both are configured.`),t.service||r.errors.push(`${n("sourcemaps.service")} is required.`),t.minifiedPathPrefix||r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} is required.`),t.minifiedPathPrefix&&!(e=>{let t;try{t=new URL(e).host}catch{}return!(!t&&!e.startsWith("/"))})(t.minifiedPathPrefix)&&r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} must be a valid URL or start with '/'.`),i&&(r.config={bailOnError:!1,dryRun:!1,maxConcurrency:20,...t,releaseVersion:i})}return r},lo=({options:e,context:t})=>{const n=t.getLogger(Hn),o=n.time("validate options"),r=((e,t)=>{const n=[],o=po(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Hn}.`);return{...e[Vn],sourcemaps:o.config}})(e,n);o.end();const i=fe(e,"metrics",n);let s,a,u=!1;const d=async()=>{if(!r.sourcemaps||u)return;u=!0;const e=n.time("sourcemaps process");await co(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:s,addMetric:t.addMetric,outDir:t.bundler.outDir,outputs:a?.outputs||[],sendMetrics:i,site:t.auth.site,version:t.version},n),e.end()};return[{name:Hn,enforce:"post",async git(e){s=e,a&&await d()},async buildReport(t){a=t,!s&&Q(e)||await d()},async asyncTrueEnd(){u||await d()}}]},fo="liveDebugger",mo="datadog-live-debugger-plugin",go="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",ho="__DD_LIVE_DEBUGGER_BUILD__",yo=e=>void 0===e?go:`${go};if(typeof globalThis.${ho}==='undefined'){globalThis.${ho}={version:${JSON.stringify(e)}}}`;function bo(e){return"function"==typeof e?e:e.default}function wo(e,t,n,o,r){const i=u.relative(t,e).replace(/\\/g,"/"),s=vo(n,r);if(s)return`${i};${s}`;const a=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${a}:${o}`}function vo(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)?xo(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=$o(e.object,t),o=ko(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)?xo(o.key,t):null}function $o(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=$o(e.object,t),o=ko(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function ko(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function xo(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 Eo(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function So(e,t){const n=[];if(t.isBlockStatement(e.body)){const o=e.params.flatMap((e=>Ao(e,t))),r=new Set(o),i="id"in e&&t.isIdentifier(e.id)?e.id.name:"";for(const o of e.body.body)if(t.isVariableDeclaration(o)){const e=o.end;if(null==e)continue;for(const s of o.declarations)for(const o of Ao(s.id,t))r.has(o)||o===i||n.push({name:o,declarationEnd:e,temporalDeadZones:[]})}}const o=n.length>25?n.slice(0,25):n;if(t.isBlockStatement(e.body)){const n=o.map((({name:e})=>e)),r=new Set(n),i=function(e,t,n){const o=new Map;for(const r of e.body)Io(r,t,o,n);return o}(e.body,r,t);for(const e of o)e.temporalDeadZones=i.get(e.name)??[]}return o}function Io(e,t,n,o){o.isFunctionDeclaration(e)||o.isClassDeclaration(e)||(o.isBlockStatement(e)?Do(e,t,n,o):o.isIfStatement(e)?(Io(e.consequent,t,n,o),e.alternate&&Io(e.alternate,t,n,o)):o.isForStatement(e)||o.isForInStatement(e)||o.isForOfStatement(e)||o.isWhileStatement(e)||o.isDoWhileStatement(e)?Io(e.body,t,n,o):o.isSwitchStatement(e)?function(e,t,n,o){for(const r of e.cases){jo(r.consequent,e.start,t,n,o);for(const e of r.consequent)Io(e,t,n,o)}}(e,t,n,o):o.isTryStatement(e)?(Do(e.block,t,n,o),e.handler&&Do(e.handler.body,t,n,o),e.finalizer&&Do(e.finalizer,t,n,o)):(o.isLabeledStatement(e)||o.isWithStatement(e))&&Io(e.body,t,n,o))}function Do(e,t,n,o){jo(e.body,e.start,t,n,o);for(const r of e.body)Io(r,t,n,o)}function jo(e,t,n,o,r){if(null!=t)for(const i of e)r.isVariableDeclaration(i)&&"var"!==i.kind?Po(i,t,n,o,r):r.isClassDeclaration(i)&&i.id&&Mo(i.id.name,t,i.end,n,o)}function Po(e,t,n,o,r){for(const i of e.declarations)for(const s of Ao(i.id,r))Mo(s,t,e.end,n,o)}function Mo(e,t,n,o,r){if(null==n||!o.has(e))return;const i=r.get(e)??[];i.push({start:t,end:n}),r.set(e,i)}function Ao(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:Ao(e.argument,t):t.isAssignmentPattern(e)?Ao(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?Ao(e.argument,t):Ao(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?Ao(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const Co=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let No,To,Oo,Ro,_o=!1;function Fo(e){try{return function(e){switch(e){case"@babel/parser":return P("@babel/parser");case"@babel/traverse":return P("@babel/traverse");case"@babel/types":return P("@babel/types");case"magic-string":return P("magic-string");default:throw new Error(`Unknown peer dependency: ${e}`)}}(e)}catch(e){throw function(e){if(!function(e){if(!(e instanceof Error))return!1;const t=e.code;if("MODULE_NOT_FOUND"!==t&&"ERR_MODULE_NOT_FOUND"!==t)return!1;return Co.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=Co.find((t=>e.message.includes(t))),n=t??Co.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 ${Co.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const zo=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function Lo(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(!zo.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};_o||(No=Fo("@babel/parser").parse,To=bo(Fo("@babel/traverse")),Oo=Fo("@babel/types"),Ro=bo(Fo("magic-string")),_o=!0);const l=No(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let g=0;if(To(l,{Function(e){if(p++,!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,Oo))return void c++;if(r&&function(e,t,n){let o=e;for(;o;){if(Eo(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return Eo(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",Oo))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,Oo)))return void c++;if(s&&!vo(e,Oo))return void c++;let t=0;if(!vo(e,Oo)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=wo(n,o,e,t,Oo);try{const t=e.node,n=g++,o=`$dd_p${n}`,r=function(e,t){const n=[];for(const o of e.params)for(const e of Ao(o,t))"this"!==e&&n.push(e);return n.length>25?n.slice(0,25):n}(t,Oo),i=So(t,Oo),s=Oo.isArrowFunctionExpression(t)&&!Oo.isBlockStatement(t.body),a=s&&Oo.isSequenceExpression(t.body),d=[],c=s||!Oo.isBlockStatement(t.body)||!Uo(t.body.body,Oo);let p;if(!s&&Oo.isBlockStatement(t.body)&&qo(t.body.body,d,Oo),!s&&Oo.isBlockStatement(t.body)&&t.body.directives.length>0){p=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,hasSequenceExpressionBody:a,needsTrailingReturn:c,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:p,functionId:l,probeVarName:o,probeIdx:String(n),entryVars:r,localVars:i,returns:d}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:d,skippedFileCount:0,skippedUnsupportedCount:c,totalFunctions:p};const h=new Ro(t);for(let e=f.length-1;e>=0;e--)Bo(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 Bo(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,localVars:a,returns:u,bodyStart:d,bodyEnd:c,functionEnd:p,isExpressionBody:l,hasSequenceExpressionBody:f,bodyParenStart:m,directivesEnd:g}=n,h=`$dd_e${r}`,y=`$dd_rv${r}`,b=s.join(", "),w=""!==b,v=w?`, ${h}()`:"",$=`const ${o} = $dd_probes('${i}');`,k=w?`const ${h} = () => ({${b}});`:"",x=`if (${o}) $dd_entry(${o}, this${v});`,E=`catch(e) { if (${o}) $dd_throw(${o}, e, this${v}); throw e; }`;if(l){if(null!=m){const n=function(e,t,n){const o=[];for(let r=t;r<n;r++)"("===e[r]&&o.push(r);return o}(t,m,d),o=function(e,t,n){const o=[];for(let r=n-1;r>=t;r--)")"===e[r]&&o.push(r);return o}(t,c,p),r=Math.min(n.length,o.length);for(let t=0;t<r;t++){const r=n[t],i=o[t];e.remove(r,r+1),e.remove(i,i+1)}}const n=["{",$,k,"try {",x,`const ${y} = `].filter(Boolean).join("\n"),r=[f?");":";",`if (${o}) $dd_return(${o}, ${y}, this${Ko(h,w,a,c)});`,`return ${y};`,`} ${E}`,"}"].join("\n");if(c-d>=2){const o=f?`${n}(${t[d]}`:n+t[d];e.update(d,d+1,o),e.update(c-1,c,t[c-1]+r)}else e.update(d,c,n+t.slice(d,c)+r)}else{const r=[$,k,"try {",`let ${y};`,x].filter(Boolean).join("\n");for(const t of u){const n=Ko(h,w,a,t.start);null!=t.argStart&&null!=t.argEnd?(e.appendLeft(t.argStart,`(${y} = `),e.appendLeft(t.argEnd,`, ${o} ? $dd_return(${o}, ${y}, this${n}) : ${y})`)):e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, this${n}); `)}if(null!=g){const n=g-1;e.update(n,g,`${t[n]}\n${r}`)}else e.update(d,d+1,`${t[d]}${r}`);const i=Ko(h,w,a,c),s=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, this${i});\n`:""}} ${E}\n`;e.update(c-1,c,`${s}${t[c-1]}`)}}function Ko(e,t,n,o){const r=function(e,t){const n=e.filter((({declarationEnd:e,temporalDeadZones:n})=>e<=t&&!function(e,t){return e.some((({start:e,end:n})=>e<=t&&t<n))}(n,t))).map((({name:e})=>e));if(0===n.length)return;return`{${n.join(", ")}}`}(n,o);return t&&r?`, ${e}(), ${r}`:t?`, ${e}()`:r?`, undefined, ${r}`:""}function qo(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))qo(o.body,t,n);else if(n.isIfStatement(o))qo([o.consequent],t,n),o.alternate&&qo([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))qo([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)qo(e.consequent,t,n);else n.isTryStatement(o)?(qo(o.block.body,t,n),o.handler&&qo(o.handler.body.body,t,n),o.finalizer&&qo(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&qo([o.body],t,n)}function Uo(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 Uo(e,t)&&Uo(o,t)}return!1}const Vo=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Ho=t.bold.red,Wo=Number(process.env.DD_LD_LIMIT)||1/0,Jo=(e,t)=>{const n=t.getLogger(mo);let o=0,r=0,i=0,s=0,a=0,u=0,d=0,c=0;return{name:mo,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>=Wo)return{code:p};try{const f=Lo({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,d+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&c++,0===f.instrumentedCount)return{code:p};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),g=f.map&&m?function(e,t,n,o){try{return w(e,((e,n)=>1===n.depth?t:null))}catch(t){return o.error(`Failed to compose source map for ${n}: ${t}`,{forward:!0}),e}}(f.map,m,l,n):f.map;return{code:f.code,map:g}}catch(e){return n.error(`Instrumentation Error in ${l}: ${e}`,{forward:!0}),{code:p}}}},buildEnd:()=>{d>0&&n.info(`Live Debugger: ${o}/${d} functions instrumented across ${u}/${c} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:c,instrumentedCount:o,totalFunctions:d,transformedFileCount:u}})}}},Go=({options:e,context:t})=>{const n=((e,t)=>{const n=e[fo]||{},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(`${Ho("include")} patterns must be strings or RegExp`);break}}else r.push(`${Ho("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(`${Ho("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Ho("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Ho("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Vo.includes(e)){r.push(`${Ho("functionTypes")} contains invalid value "${e}". Valid values: ${Vo.join(", ")}`);break}}else r.push(`${Ho("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Ho("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${mo}.`);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(mo));return t.inject({type:"code",position:De.BEFORE,injectIntoAllChunks:!0,value:yo(n.version)}),[Jo(n,t)]};const Yo=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/^sourcemaps\.upload\.(failure|retry)$/.test(e.metric)&&(t.count=0),/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],Qo="metrics",Zo="datadog-metrics-plugin",Xo=e=>Math.floor((e||Date.now())/1e3),er=(e,t)=>{const n=[`bundler:${te(e.bundler.name)}`,`plugin_version:${te(e.version)}`,`site:${te(e.auth.site)}`];return e.build.metadata.name&&n.push(`build_name:${te(e.build.metadata.name)}`),e.build.metadata.version&&n.push(`build_version:${te(e.build.metadata.version)}`),[...n,...t]},tr=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),nr=(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(tr(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(tr({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i},or=(e="")=>e.endsWith("/")?e:`${e}/`,rr=(e,t)=>{let n=e;return e.split(or(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},ir=(e,t)=>e.split("!").pop().replace(or(t),"./"),sr=(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)),ir(o||"no-name",n)},ar=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),ur=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),dr=t.bold.red,cr=t.bold.cyan,pr=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},lr=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(pr("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:Z(e.duration)}))),top:!0};n.sort(pr("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},fr=(e,t,n)=>{const o=[];var r;n&&(o.push(...lr("Loader",n.loaders)),o.push(...lr("Tapable",n.tapables)),o.push(...lr("Module",n.modules))),o.push(...(e=>{const t={name:"Module total dependents",values:[],top:!0},n={name:"Module total dependencies",values:[],top:!0},o={name:"Module size",values:[],top:!0},r={name:"Module aggregated size",values:[],top:!0},i=new Set,s=Y(e.build),a=new Map,u=new Map,d=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)d.has(n)||d.set(n,new Set),d.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(d.has(e.filepath)){const t=d.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),d.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=d.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const c=Array.from(i);return c.sort(pr((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort(pr((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort(pr("size")),o.values=c.map((e=>({name:e.name,value:y(e.size)}))),c.sort(pr("aggregatedSize")),r.values=c.map((e=>({name:e.name,value:y(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(pr((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(pr((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(pr((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:Z(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:Z(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:Z(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=X(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+=` [${dr(e.value)}] ${" ".repeat(n)}${cr(e.name)}\n`}}return t})(o);t.info(i)},mr="api/v1/series",gr=t.bold.green,hr=(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: ${gr(`https://api.${t.site}/${mr}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),H({method:"POST",url:`https://api.${t.site}/${mr}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))},yr=["onStart","onLoad","onResolve","onEnd"],br=new Map,wr=new Map,vr=new Map,$r=(e,t,n)=>{const o=Object.assign({},e);for(const r of yr)o[r]=async(o,i)=>{const s=wr.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=ir(e[0].path,n),u=vr.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const d=v.now();try{return await i(...e)}finally{const n=v.now(),i=n-d,c={start:d,end:n,duration:i,context:ur(e)};if(s.events[r].values.push(c),s.duration+=i,s.increment+=1,wr.set(t,s),u.events[r].values.push(c),u.duration+=i,u.increment+=1,vr.set(o,u),a){const e=br.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,br.set(t,e)}}}))};return o},kr=(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=$r(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:wr,modules:vr,loaders:br};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class xr{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=sr(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(ar))(e);o.length||o.push("no-loader"),this.started[n]={module:rr(n),timings:{start:v.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=sr(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=v.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},i=n.loaders.join(",");r.events[i]=r.events[i]||{name:i,values:[]},r.events[i].values.push(n.timings),r.increment+=1,r.duration+=o,t.set(n.module,r);for(const t of n.loaders){const n=e.get(t)||{name:t,increment:0,duration:0,events:{}};n.increment+=1,n.duration+=o,e.set(t,n)}}return{loaders:e,modules:t}}}class Er{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,r,i){const s=this.timings.get(t)||{name:t,duration:0,increment:0,events:{}};s.events[n]||(s.events[n]={name:n,values:[]}),s.events[n].values.push({start:r,end:i,duration:i-r,context:o,type:e}),s.duration+=i-r,s.increment+=1,this.timings.set(t,s)}getResults(){const e=this.timings;for(const[t,n]of this.timings){const o=n;o.duration=Object.values(n.events).map((e=>e.values.reduce(((e,t)=>e+t.end-t.start),0))).reduce(((e,t)=>e+t),0),e.set(t,o)}return{monitoredTaps:this.monitoredTaps,tapables:this.tapables,hooks:this.hooks,timings:e}}getPromiseTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,ur(r),i,v.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,ur(r),i,v.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r);return this.saveResult(e,n,o,ur(r),i,v.now()),s}}getTapPatch(e,t,n,o){switch(e){case"promise":return this.getPromiseTapPatch(e,t,n,o);case"async":return this.getAsyncTapPatch(e,t,n,o);default:return this.getDefaultTapPatch(e,t,n,o)}}newTap(e,t,n,o){return(r,i)=>{const s="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${s}`;if(this.monitoredTaps[u])return n.call(o,r,i);this.monitoredTaps[u]=!0;const d=this.getTapPatch(e,i,s,t);return n.call(o,r,d)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(Zo)||(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 Sr=e=>async t=>{const n=e.getLogger(Zo),o={name:Zo},r=new Er(e.buildRoot),i=new xr(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})}))},Ir={filters:Yo},Dr=({options:e,context:t,stores:n})=>{const o=t.getLogger(Zo);let r=0;((e,t)=>{e.addMetric=e=>{t.metrics.add(e)}})(t,n);const i=((e,t)=>{const n=e[Qo],o=Xo(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enableDefaultPrefix:!0,enableTracing:!1,filters:Yo,tags:[],...e[Qo],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[],a={name:Zo,enforce:"pre",esbuild:kr(t,o),webpack:Sr(t),rspack:Sr(t)},u=o.time("build",{start:!1}),d=i.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let c,p;const l=async()=>{if(!n.metrics.size)return;const e=o.time("aggregating collected metrics"),r=(()=>{const e=new Set(n.metrics);n.metrics.clear();const o=er(t,i.tags);return nr(e,i.timestamp,i.filters,o,i.prefix)})();await t.asyncHook("metrics",r),e.end();const s=o.time("sending collected metrics to Datadog");await hr(r,{apiKey:t.auth.apiKey,site:t.auth.site},o),s.end()},f=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-r;const e=o.time("aggregating metrics"),n=i.timestamp,s=o.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,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})(p,n);s.end();const u=o.time("aggregate plugins metrics"),d=((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})(c?.tapables,n);u.end();const l=o.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(c?.loaders,n);l.end();const m=new Set([...a,...d,...f]),g=er(t,i.tags),h=nr(m,n,i.filters,g,i.prefix);await t.asyncHook("metrics",h),e.end();const y=o.time("outputing report");fr(t,o,c),y.end();const b=o.time("sending metrics to Datadog");await hr(h,{apiKey:t.auth.apiKey,site:t.auth.site},o),b.end()},m={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){u.resume(),t.build.start=t.build.start||Date.now(),e[Qo]?.timestamp||(i.timestamp=Xo(t.build.start))},buildEnd(){u.end(),r=Date.now()},async timings(e){c=e,p&&await f()},async buildReport(e){p=e,!c&&d||await f()},async flush(){await l()}};return i.enableTracing&&s.push(a),s.push(m),s},jr="output",Pr="datadog-output-plugin",Mr=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,Ar=e=>{const t=void 0===e;return{build:Mr("build",e?.build??t),bundler:Mr("bundler",e?.bundler??t),dependencies:Mr("dependencies",e?.dependencies??t),errors:Mr("errors",e?.errors??t),logs:Mr("logs",e?.logs??t),metrics:Mr("metrics",e?.metrics??t),timings:Mr("timings",e?.timings??t),warnings:Mr("warnings",e?.warnings??t)}},Cr=(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}))}))},Nr=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},Tr=({options:e,context:t})=>{const n=t.getLogger(Pr),o=(e=>({path:"./",...e[jr],files:Ar(e[jr]?.files)}))(e),r=(e,r)=>{const i=o.files[e];if(!r||!1===i)return;t.queue((async()=>{const e=n.time(`output ${i}`),d=((e,t,n)=>{const o=u.isAbsolute(t)?t:u.resolve(e,t);return u.resolve(o,n)})(t.bundler.outDir,o.path,i);let c;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await $e(u.dirname(e));const n=s.createWriteStream(e),o=new a(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(d,e)}catch(e){c=e}c?n.error(`Failed writing ${i}: ${c}`):n.debug(`Wrote "./${u.relative(t.buildRoot,d)}"`),e.end()})())};return[{name:Pr,buildReport(e){const t=n.time("serialize report"),o=Y(e);t.end(),r("build",{bundler:o.bundler,metadata:o.metadata,start:o.start,end:o.end,duration:o.duration,writeDuration:o.writeDuration,entries:o.entries,outputs:o.outputs}),r("logs",o.logs),r("timings",o.timings),r("dependencies",o.inputs),r("errors",o.errors),r("warnings",o.warnings)},metrics(e){r("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{r("bundler",e.metafile)}))}},rspack:Cr(n,(e=>{r("bundler",e)})),rollup:Nr((e=>{r("bundler",e)})),vite:Nr((e=>{r("bundler",e)})),webpack:Cr(n,(e=>{r("bundler",e)}))}]},Or="rum",Rr="datadog-rum-plugin",_r=e=>`(function(c,n){try{if(typeof window==='undefined')return;var w=window,m=w[n]=w[n]||{},s=new Error().stack;s&&(m[s]=c)}catch(e){}})(${JSON.stringify(e)},${JSON.stringify("DD_SOURCE_CODE_CONTEXT")});`,Fr="datadog-rum-privacy-plugin";const zr=(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=$({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}})}}},Lr=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Br=(e,t)=>{const n=e.sdk;if(n.clientToken)return Lr(e);if(!t.auth.apiKey||!t.auth.appKey)throw new Error('Missing "auth.apiKey" and/or "auth.appKey" to fetch "rum.sdk.clientToken".');return async()=>{let o;try{const e=await H({url:`https://api.${t.auth.site}/api/v2/rum/applications/${n.applicationId}`,type:"json",auth:t.auth});o=e.data?.attributes?.client_token}catch(e){throw new Error(`Could not fetch the clientToken: ${e.message}`)}if(!o)throw new Error("Missing clientToken in the API response.");return Lr({...e,sdk:{clientToken:o,...n}})}},Kr=e=>{const n=t.bold.red,o=e[Or]||{},r={errors:[]};if(!o.sdk)return r;o.sdk.applicationId||r.errors.push(`Missing ${n("applicationId")} in the SDK configuration.`),e.auth.apiKey&&e.auth.appKey||o.sdk.clientToken||r.errors.push(`Missing ${n('"auth.apiKey"')} and/or ${n('"auth.appKey"')} to fetch missing client token.`);const i={applicationId:"unknown_application_id",allowUntrustedEvents:!1,compressIntakeRequests:!1,defaultPrivacyLevel:"mask",enablePrivacyForActionName:!1,sessionReplaySampleRate:0,sessionSampleRate:100,silentMultipleInit:!1,site:e.auth.site||"datadoghq.com",startSessionReplayRecordingManually:!1,storeContextsAcrossPages:!1,telemetrySampleRate:20,traceSampleRate:100,trackingConsent:"granted",trackLongTasks:!1,trackResources:!1,trackUserInteractions:!1,trackViewsManually:!1};return r.config={...i,...o.sdk},r},qr=e=>{const t=e[Or]||{},n={errors:[]};if(t.privacy){const e={exclude:[/\/node_modules\//,/\.preval\./,/^[!@#$%^&*()=+~`-]/],include:[/\.(?:c|m)?(?:j|t)sx?$/],addToDictionaryFunctionName:"$",helperCodeExpression:"/*__PURE__*/((q='$DD_A_Q',g=globalThis)=>(g[q]=g[q]||[],(v=>(g[q].push(v),v))))()"};n.config={...e,...t.privacy}}return n},Ur=e=>{const n=t.bold.red,o=e[Or]||{},r={errors:[]};if(!o.sourceCodeContext)return r;const i=o.sourceCodeContext;return i?.service&&"string"==typeof i.service||r.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),r.config={...i,version:i.version||e.metadata?.version},r},Vr=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=Kr(e),r=qr(e),i=Ur(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 ${Rr}.`);const s={...e[Or],sdk:void 0,privacy:void 0,sourceCodeContext:void 0};return o.config&&(s.sdk=o.config),r.config&&(s.privacy=r.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(s.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),i.config&&(s.sourceCodeContext=i.config),s})(e,t.getLogger(Rr)),o=[];if(n.sourceCodeContext&&t.inject({type:"code",position:De.BEFORE,injectIntoAllChunks:!0,value:_r(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:De.MIDDLE,value:u.join(j,"./rum-browser-sdk.js")}),t.inject({type:"code",position:De.MIDDLE,value:Br(n,t)})),n.privacy){t.inject({type:"file",position:De.BEFORE,value:u.join(j,"./privacy-helpers.js")});const e=zr(n.privacy,t);o.push(e)}return o},Hr="datadog-analytics-plugin",Wr=({context:e})=>{const t=e.getLogger(Hr);return[{name:Hr,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}`)}})())}}]},Jr="datadog-async-queue-plugin",Gr=e=>{const{context:t,stores:n}=e,o=t.getLogger(Jr),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:Jr,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Yr=async(e,t,n)=>{const o=[],r=e.initialOptions.entryPoints,i=[],s=[];if(Array.isArray(r))for(const e of r){const t=e&&"object"==typeof e?e.in:e;i.push({path:t})}else r&&"object"==typeof r&&i.push(...Object.entries(r).map((([e,t])=>({name:e,path:t}))));const a=i.flatMap((e=>{return(t=e.path,t.includes("*")?h.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const i=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});i.errors.length&&s.push(...i.errors.map((e=>e.text))),i.path&&o.push({name:n.name,resolved:i.path,original:n.path})}));for(const e of s)n.error(e);return await Promise.all(a),o},Qr=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Zr=/(\?|%3F|\|)+/gi,Xr=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=ni(e),Qr.lastIndex=0,Qr.exec(t)?.[1]||"unknown");var t},ei=["unknown","commonjsHelpers.js",`vite${u.sep}preload-helper.js`],ti=(e,t,n)=>{const o=new Set;for(const n of e){const e=ni(n);G(n)||e===t||ei.includes(e)||o.add(e)}return o},ni=e=>e.split("!").pop().split(Zr).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),oi=(e,t)=>G(t)?M:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(u.sep),o=e.split(u.sep).filter(((e,t)=>e===n[t])).join(u.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(Zr).shift().replace(/^((\.\.?)?[/\\])+/g,""),ri=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[En(t,e),n]))),ii=(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 Yr(n,e,t));for(const t of r){const n=oi(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}s.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),s=e.bundler.outDir,a=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const d=[],c=[],p=[],l=[],f=[],m={},g={},h=t.time("indexing metafile data"),y=ri(n.metafile.inputs,a),b=ri(n.metafile.outputs,a);h.end();const w=e=>{if(!G(e))return e;const t=y[En(a,e)];if(!t)return e;const n=t.imports.find((e=>!G(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(G(e))continue;const n=En(a,e),o={name:oi(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Xr(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=En(a,e),i=oi(s,n),u=[];for(const e of Object.keys(r.inputs)){if(G(e))continue;const n=m[En(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!u.length){const e=m[En(a,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}u.push(e)}const d={name:i,filepath:n,inputs:u,size:r.bytes,type:Xr(n)};if(g[n]=d,"map"===d.type&&l.push(d),c.push(d),!r.entryPoint)continue;const f=m[En(a,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...d,name:o.get(f.name)||f.name,outputs:[d],size:d.size};p.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of l){const n=g[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:g,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!G(e)&&!e.match(E),I=(e,n,o={})=>{if(!S(e))return o;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),o;if(o[r.filepath])return o;o[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),o;if(!i.imports||!i.imports.length)return o;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),c=i?u.dirname(e):a,p=En(c,t.path);if(t.external){if(S(t.path)){const e=i?p:t.path,n=x.inputs.report[e]||{filepath:e,name:oi(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),d.includes(n)||d.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(p,n,o)}return o},D=t.time("looping through entries");for(const e of p){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const j=t.time("aggregate dependencies and dependents");for(const e of d){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?u.dirname(e.filepath):a,i=En(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)}))}}),si=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),i=t.time("filling inputs and outputs",{start:!1}),a=t.time("completing dependencies and dependents",{start:!1}),u=t.time("filling dependencies and dependents",{start:!1}),d=t.time("filling sourcemaps inputs",{start:!1}),c=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),c.clear(),p.clear(),l.clear()},onLog(t,n){"warn"===t&&e.build.warnings.push(n.message||n.toString())},renderError(t){t&&e.build.errors.push(t.message)},moduleParsed(e){n.resume();const t=ni(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=ti(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=ti(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?En(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=ni(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=ni(t),o=f.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),f.set(n,o))}}a.end(),i.resume();for(const[e,n]of Object.entries(m)){const o=En(g,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),i=p.get(o)||{name:e,filepath:o,inputs:[],size:r,type:Xr(e)};if("map"===i.type&&y.add(i),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(ni(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=s.statSync(e).size}catch(e){n=t.renderedLength}const o=c.get(e)||{name:oi(g,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Xr(e)};i.inputs.push(o),c.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=ni(e);if(!f.has(n)){b.set(En(g,n),i);continue}if(c.has(n)){t.debug(`Input report already there for ${n} from ${i.name}.`);continue}const o=c.get(n)||{name:oi(g,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};i.inputs.push(o),c.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&h.add({...i,name:n.name,size:0,outputs:[i]}),p.set(i.filepath,i)}i.end();for(const[e,n]of b){const o=p.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of c){const o=f.get(e);if(o){for(const e of o.dependencies){const o=c.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${oi(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 ${oi(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=oi(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[oi(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(En(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}":"${oi(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)}}},ai=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,d=new Map,c=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||G(e)),g=e=>e.replace(/(^external[^"]+"|"$)/g,""),h=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=ni(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=ni(t.request);if(c.has(n))return c.get(n);if(e.context){const t=En(ni(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=oi(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:Xr(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=>En(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"===Xr(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:En(e.bundler.outDir,t.name),type:Xr(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"===Xr(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?En(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:p?Xr(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)}))},ui="datadog-build-report-plugin",di=e=>{const{context:t}=e,n=t.getLogger(ui);return[{name:ui,enforce:"post",esbuild:ii(t,n),rspack:ai(t,ui,n),webpack:ai(t,ui,n),vite:si(t,n),rollup:si(t,n)}]},ci="datadog-bundler-report-plugin",pi=(e,t)=>t?u.isAbsolute(t)?t:u.resolve(e,t):"",li=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?u.dirname(e.file):void 0)).filter(Boolean)},fi=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=pi(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},mi=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=li(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=In(r,process.cwd())),e.bundler.outDir=pi(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),gi=e=>{const{context:t}=e,n=t.getLogger(ci);return[{name:ci,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=pi(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=pi(t.buildRoot,u.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:fi(t),rspack:fi(t),vite:mi(t),rollup:{options(e){let n;if("output"in e){const t=li(e.output);n=In(t,process.cwd())}const o=(e=>{const t=new Set;if(e.input){const n=Array.isArray(e.input)?e.input:"object"==typeof e.input?Object.values(e.input):[e.input];for(const e of n){if("string"!=typeof e)throw new Error("Invalid input type");t.add(u.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=En(process.cwd(),n);const e=In([n,...o],process.cwd());t.buildRoot=e===u.sep?process.cwd():e}else t.buildRoot=In(o,process.cwd()),t.bundler.outDir=u.resolve(process.cwd(),"dist");t.hook("buildRoot",t.buildRoot)},buildStart(e){t.bundler.rawConfig=e},renderStart(e){t.bundler.rawConfig.outputs=t.bundler.rawConfig.outputs||[],t.bundler.rawConfig.outputs.push(e),t.hook("bundlerReport",t.bundler);const o=li(e);In(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.")}}}]},hi="datadog-custom-hooks-plugin",yi=e=>{const{context:t}=e,n=t.getLogger(hi),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:hi,enforce:"pre"}]};class bi{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=xe(e),o=JSON.parse(n);if(!o.sources)return void t("Missing 'sources' field in sourcemap.");const r=o.sources;if(0===r.length)return void t("Empty 'sources' field in sourcemap.");const i=this.matchSources(r);if(0!==i.length)return i;t(`${r.map(this.displaySource).join(", ")} not in the tracked files.`)}matchSources(e){let t=[];const n=new Set;for(const o of e){const e=this.getFilename(o);if(n.has(e))continue;n.add(e);const r=this.trackedFilenames.get(e);r&&(t=t.concat(r))}return t}rawTrackedFilesList(){let e=[];return this.trackedFilenames.forEach((t=>{e=e.concat(t)})),e}getFilename(e){let t=e.lastIndexOf("/");-1===t?t=0:t++;let n=e.lastIndexOf("?");return(-1===n||n<=t)&&(n=e.length),e.substring(t,n)}}const wi=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await vi(e);for(const e of t)if(e.name===n)return ee(e.refs.push);return ee(t[0].refs.push)},vi=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},$i=async e=>e.revparse("HEAD"),ki=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),xi=async e=>e.branch(),Ei=async e=>e.show(["-s","--format=%s"]),Si=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),Ii="datadog-git-plugin",Di=e=>{const{options:t,context:n}=e,o=n.getLogger(Ii),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=k(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return k(t)})(u.dirname(e));if(0===(await t.getRemotes(!0)).length)return o.warn("No git remotes available, skipping git plugin. This is expected for a repository that has not been pushed yet."),void r.end();const i=await(async e=>{const t=[$i(e),xi(e),Ei(e),Si(e),ki(e),wi(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 bi(s)}})(t);n.git=i,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:Ii,enforce:"pre",buildRoot(e){if(Q(t))try{r.resume();const t=Sn(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}`)}}}]},ji="datadog-injection-plugin",Pi=/^https?:\/\//,Mi=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],Ai=t.bold.yellow,Ci=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(En(t,e)),Ni=async(e,t,n=process.cwd())=>{let o;const r=await(async e=>"function"==typeof e.value?e.value():e.value)(e);try{if("file"===e.type)o=r.match(Pi)?await(async(e,t=5e3)=>{let n;return Promise.race([H({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await Ci(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} - ${X(r)}`;e.fallback?(t.debug(`Fallback for "${s}": ${i.toString()}`),o=await Ni(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},Ti=(e,t)=>{const n=e.filter((e=>e.position===t.position&&(!t.onAllChunks||e.injectIntoAllChunks)));if(0===n.length)return"";return`// begin injection by Datadog build plugins\n${n.map((e=>`(() => {${e.value}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},Oi=async(e,t,n,o=process.cwd())=>{const r=await(async(e,t,n=process.cwd())=>{const o=new Map;for(const[r,i]of e.entries()){const e=await Ni(i,t,n);if(e){const t=i.position||De.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)},Ri=e=>e instanceof Error&&"code"in e,_i=e=>Mi.includes(e),Fi=(e,t,n)=>{e.warn(`"${Ai(t)}" files are not supported (${Ai(n)}).`)},zi=s.promises,Li=(e,t,n)=>({setup(o){const{onStart:i,onResolve:a,onLoad:d,onEnd:c,esbuild:p,initialOptions:f}=o,m=[],g=`${t.bundler.name}.${De.MIDDLE}.${M}.js`,h=s.realpathSync(l.tmpdir()),y=u.resolve(h,g),b=new RegExp(`${g}$`),w=f.inject;f.inject=w?[...w]:[],f.inject.push(y),i((async()=>{m.push(...await Yr(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await $e(u.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),a({filter:b},(async e=>({path:e.path,namespace:ji}))),d({filter:b,namespace:ji},(async()=>({contents:Ti(n,{position:De.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),c((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=Ti(n,{position:De.BEFORE}),i=Ti(n,{position:De.AFTER}),s=Ti(n,{position:De.BEFORE,onAllChunks:!0}),a=Ti(n,{position:De.AFTER,onAllChunks:!0});if(!(r||i||s||a))return;const d=[];for(const[n,c]of Object.entries(o.metafile.outputs)){const o=c.entryPoint&&m.some((e=>e.resolved.endsWith(c.entryPoint))),l=o?r:s,f=o?i:a;if(!l&&!f)continue;const g=En(t.buildRoot,n),{base:h,ext:y}=u.parse(g);_i(y)?d.push((async()=>{try{const e=await zi.readFile(g,"utf-8"),t=await p.transform(e,{loader:"default",banner:l,footer:f});await zi.writeFile(g,t.code)}catch(t){if(!Ri(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${g}: ${t}`)}})()):Fi(e,y,h)}await Promise.all(d)}))}}),Bi=M,Ki="?inject-proxy",qi=(e,t)=>({banner(n){const o=Ti(t,{position:De.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return _i(i)?o:(Fi(e,i,r),"")},async resolveId(e,n,o){if(G(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&Ti(t,{position:De.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}${Ki}`}return null},load(e){if(G(e))return Ti(t,{position:De.MIDDLE});if(e.endsWith(Ki)){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=Ti(t,{position:De.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return _i(i)?o:(Fi(e,i,r),"")}}),Ui=(e,t,n,o,r)=>i=>{const a=new WeakMap,d=e.sources.ConcatSource,c=n.bundler.name,p=u.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${c}.${De.MIDDLE}.${M}.js`);ke(p,"");i.hooks.shutdown.tap(ji,(()=>{var e;e=p,s.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await Oi(t,o,r,n.buildRoot)};i.hooks.beforeRun.tapPromise(ji,l),i.hooks.watchRun.tapPromise(ji,l),i.hooks.compilation.tap(ji,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:ji,stage:o},(()=>{const e=Ti(r,{position:De.BEFORE}),o=Ti(r,{position:De.AFTER}),i=Ti(r,{position:De.BEFORE,onAllChunks:!0}),s=Ti(r,{position:De.AFTER,onAllChunks:!0});for(const r of n.chunks){let c=e,p=o;if(r.canBeInitial()||(c=i,p=s),""!==c||""!==p)for(const e of r.files){const{base:o,ext:r}=u.parse(e);_i(r)?n.updateAsset(e,(e=>{const t=a.get(e);if(!t||t.banner!==c||t.footer!==p){const t=new d(c,"\n",e,"\n",p);return a.set(e,{source:t,banner:c,footer:p}),t}return t.source})):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}})(i.options.entry);i.options.entry=f},Vi=e=>{const{bundler:t,context:n}=e,o=n.getLogger(ji),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++oe}`,e)};const s={name:ji,enforce:"post",esbuild:Li(o,n,i),webpack:Ui(t,o,n,r,i),rspack:Ui(t,o,n,r,i),rollup:qi(o,i),vite:{...qi(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>Ti(i,{position:De.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:A},handler:()=>({code:Ti(i,{position:De.MIDDLE})})}:s.buildStart=async()=>{await Oi(o,r,i,n.buildRoot)},[s]},Hi="datadog-true-end-plugin",Wi=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=async()=>{await t.asyncHook("flush")},r=()=>{t.hook("syncTrueEnd")},i=async()=>{r(),await n(),await o()},s=e=>{e.hooks.shutdown.tapPromise(Hi,i)},a={async writeBundle(){},async closeBundle(){await i()}};return[{name:Hi,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n(),await o()})),e.onDispose((()=>{r()}))}},vite:a,rollup:a,rspack:s}]},Ji={[Qo]:Ir},Gi=t.bold.red;var Yi="3.2.0";const Qi=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,r)=>{const i=Date.now(),s=((e={})=>{const t=(e=>{const t=[];return void 0===e||void 0!==e.version&&"string"!=typeof e.version&&t.push("metadata.version must be a string"),t})(e.metadata),n=z("SITE"),o={site:B(n,"DATADOG_SITE/DD_SITE",t)??B(e.auth?.site,"auth.site",t)??T};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:z("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:z("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=O);const a=process.env.BUILD_PLUGINS_ENV||"production",u=C.includes(a)?a:"development",d=t.rspackVersion||t.version||t.VERSION,c=r.framework,p={bundler:{name:c,version:d},env:u,metadata:s.metadata||{},packageName:`@datadog/${c}-plugin`,version:n},l={errors:[],logs:[],metrics:new Set,queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{addMetric:()=>{throw new Error("AddMetric function called before it was initialized.")},auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:ue(n,o,t.logLevel),asyncHook:()=>{throw new Error("AsyncHook function called before it was initialized.")},hook:()=>{throw new Error("Hook function called before it was initialized.")},inject:()=>{throw new Error("Inject function called before it was initialized.")},plugins:[],queue:()=>{throw new Error("Queue function called before it was initialized.")},sendLog:W(n),start:e,version:n.version}})({start:o,options:s,data:p,stores:l}),m=f.getLogger("factory"),g=m.time("Plugins initialization",{start:i});f.pluginNames.push(O);const h=[];h.push(["analytics",Wr],["async-queue",Gr],["build-report",di],["bundler-report",gi],["custom-hooks",yi],["git",Di],["injection",Vi],["true-end",Wi]),s.customPlugins&&h.push(["custom",s.customPlugins]);const y=[["apps",me,Un],["error-tracking",Vn,lo],["live-debugger",fo,Go],["metrics",Qo,Dr],["output",jr,Tr],["rum",Or,Vr]];for(const[e,t,n]of y)fe(s,t,m)&&h.push([e,n]);for(const[e,n]of h)f.plugins.push(...pe(f,n,e)({bundler:t,context:f,options:s,data:p,stores:l}));return(e=>{const t=[];for(const n of F){const o=L(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>_(e))).join(" and "),i=_(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>R(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: ${Gi(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),g.end(),f.plugins}))})({bundler:x,version:Yi}).esbuild,Zi=Yi,Xi=Ji;export{Qi as datadogEsbuildPlugin,Xi as helpers,Zi as version};
|
|
1
|
+
import{createUnplugin as e}from"unplugin";import t from"chalk";import n from"async-retry";import{File as o}from"buffer";import r,{mkdtemp as i}from"fs/promises";import s from"fs";import{JsonStreamStringify as a}from"json-stream-stringify";import u from"path";import{Readable as c}from"stream";import{createHash as d,randomUUID as p}from"crypto";import l,{tmpdir as f}from"os";import*as m from"eslint-scope";import g from"jszip";import{glob as h}from"glob";import y from"pretty-bytes";import b from"p-queue";import w from"@jridgewell/remapping";import{performance as v}from"perf_hooks";import{instrument as $}from"@datadog/js-instrumentation-wasm";import{simpleGit as k}from"simple-git";import x from"esbuild";import E from"node:url";import S from"node:path";import I from"node:module";const D=E.fileURLToPath(import.meta.url),j=S.dirname(D),P=I.createRequire(import.meta.url),M="__datadog-helper-file",A=new RegExp(M),C=["development","production","test"],N=["datadoghq.com","us3.datadoghq.com","us5.datadoghq.com","datadoghq.eu","ddog-gov.com","us2.ddog-gov.com","ap1.datadoghq.com","ap2.datadoghq.com","datad0g.com"],T=N[0],O="datadog-build-plugins",R=t.bold.green,_=t.bold.yellow,F=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],L=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],z=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},B=(e,t,n)=>{if(void 0!==e)return(e=>N.some((t=>t===e)))(e)?e:void n.push(`${t} "${e}" is not a supported Datadog site. See the site parameters in https://docs.datadoghq.com/getting_started/site/.`)},K=e=>{if(null===e||"object"!=typeof e)return"";const t="title"in e&&"string"==typeof e.title?e.title:void 0,n="detail"in e&&"string"==typeof e.detail?e.detail:void 0;return t&&n?`${t}: ${n}`:t||(n?`detail: ${n}`:"")},q=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),U=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())}}},V=[400,401,403,404,405,409,413],H=e=>{const{auth:t,url:o,method:r="GET",getData:i,type:s="text"}=e,a={retries:0===e.retries?0:e.retries||5,onRetry:e.onRetry,maxTimeout:e.maxTimeout,minTimeout:e.minTimeout};return n((async(e,n)=>{let a;try{const e={method:r,duplex:"half"};let n={"X-Datadog-Origin":"build-plugins"};if(t?.apiKey&&(n["DD-API-KEY"]=t.apiKey),t?.appKey&&(n["DD-APPLICATION-KEY"]=t.appKey),"function"==typeof i){const{data:t,headers:o}=await i();e.body=t,n={...n,...o}}a=await fetch(o,{...e,headers:n})}catch(t){return e(t),{}}if(!a.ok){let t=`HTTP ${a.status} ${a.statusText}`;try{const e=(e=>{try{const t=JSON.parse(e);if(null!==t&&"object"==typeof t)if("errors"in t&&Array.isArray(t.errors)){const e=t.errors.map(K).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=K(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(V.includes(a.status))return e(new Error(t)),{};throw new Error(t)}try{let e;return e="json"===s?await a.json():await a.text(),e}catch(t){return e(t),{}}}),a)},W=e=>({message:t,context:n})=>H({retries:2,minTimeout:100,url:"https://browser-http-intake.logs.datadoghq.com/v1/input/pub44d5f4eb86e1392037b7501f7adc540e",method:"POST",type:"json",getData:async()=>{const o={ddsource:e.packageName||O,message:t,service:"build-plugins",team:"language-foundations",env:e.env,version:e.version,bundler:{name:e.bundler.name,version:e.bundler.version},metadata:e.metadata,...n};return{data:JSON.stringify(o),headers:{"Content-Type":"application/json"}}}}),J=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),G=e=>e.includes(M),Y=e=>{const t={bundler:e.bundler,errors:e.errors,metadata:e.metadata,warnings:e.warnings,logs:e.logs,timings:e.timings,start:e.start,end:e.end,duration:e.duration,writeDuration:e.writeDuration,entries:[],inputs:[],outputs:[]};for(const n of e.entries||[]){const e={...n,inputs:[],outputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),n.outputs&&(e.outputs=n.outputs.map((e=>e.filepath))),t.entries.push(e)}for(const n of e.inputs||[]){const e={...n,dependencies:[],dependents:[]};if(n.dependencies)for(const t of n.dependencies)e.dependencies.push(t.filepath);if(n.dependents)for(const t of n.dependents)e.dependents.push(t.filepath);t.inputs.push(e)}for(const n of e.outputs||[]){const e={...n,inputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),t.outputs.push(e)}return t},Q=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},Z=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()},X=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),r=Math.min(10,Math.floor(o/2)),i=o-r;return`${e.slice(0,r)}${n}${e.slice(-i)}`},ee=(e="")=>{try{if(!e||e.startsWith("git@"))return e;const t=new URL(e),n="/"===t.pathname?"":t.pathname;return`${t.protocol?`${t.protocol}//`:""}${t.host}${n}`}catch{return e}},te=e=>e.trim().toLowerCase().replace(/[^a-z0-9_:./-]+/g,"_").replace(/^_+|_+$/g,"")||"unknown",ne=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 oe=0;const re={debug:0,info:1,warn:2,error:3,none:4},ie=e=>e.split(">").map(J).join(">"),se=(e,n,o,r)=>{const i=ie(e);return(s,a="debug",{forward:u,context:c}={})=>{let d=t.dim,p=console.log;"error"===a?(d=t.red,p=console.error):"warn"===a?(d=t.yellow,p=console.warn):"info"===a&&(d=t.cyan,p=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=W(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){se(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}re[a]>=re[r]&&p(`${d(l)} ${f}`)}},ae=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:c=[]}=i,d={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(d);const p=()=>d.spans.filter((e=>!e.end)),l=n=>{p().length||(!d.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),d.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=p();if(i?.length){i.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of i)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),l(e)}return{timer:d,resume:l,end:e=>{f(e,!1);const n=d.spans.reduce(((e,t)=>e+(t.end-t.start)),0);d.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(Z(n))}`,s)},pause:f,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=p();for(const n of t)n.tags.push(...e)}else d.tags.push(...e)}}},ue=(e,t,n="warn")=>o=>{const r=se(o,e,t,n);return{getLogger:r=>ue(e,t,n)(`${ie(o)}>${r}`),time:ae(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)}},ce=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],de=(e,t,n,o)=>{const r=n=>function(...r){const i=o.time(`${e} | ${t}`,{log:!1,tags:["type:hook",`hook:${t}`]}),s=n.apply(this,r);return s instanceof Promise?s.finally((()=>{i.end()})):(i.end(),s)};return"object"==typeof n&&null!==n&&"handler"in n?{...n,handler:r(n.handler)}:r(n)},pe=(e,t,n)=>{const o=e.getLogger(O);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=J(e.name);for(const r of ce){const i=e[r];i&&(n[r]=de(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},le=new Set,fe=(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&&(le.has(t)||(le.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},me="apps",ge="datadog-apps-plugin",he="api/unstable/app-builder-code/apps",ye="datadog-apps-assets.zip",be=/\.backend\.(ts|tsx|js|jsx)$/,we=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],ve=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),$e=async e=>r.mkdir(e,{recursive:!0}),ke=(e,t)=>{var n;n=u.dirname(e),s.mkdirSync(n,{recursive:!0}),s.writeFileSync(e,t,{encoding:"utf-8"})},xe=e=>s.readFileSync(e,{encoding:"utf-8"}),Ee=e=>{try{return s.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},Se=async(e,t)=>{if("function"==typeof s.openAsBlob){const n=await s.openAsBlob(e,{type:t.contentType});return new o([n],t.filename)}{const n=c.toWeb(s.createReadStream(e)),r=await new Response(n).blob();return new o([r],t.filename,{type:t.contentType})}},Ie=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 De=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(De||{});function je(e,t){if(!function(e){return"Program"===e.type}(e))throw new Error(`Expected a Program node from this.parse() for ${t}, got ${e.type}`);return e}function Pe(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function Me(e){return"type"===e.importKind||"type"===e.exportKind}function Ae(e,t){return function(e,t){const n=je(e,t),o=function(e){const t=new Map;for(const n of e.body)if("FunctionDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"function"});else if("ClassDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"class"});else if("VariableDeclaration"===n.type)for(const e of n.declarations)"Identifier"===e.id.type&&t.set(e.id.name,{kind:"variable",init:e.init});else if("ImportDeclaration"===n.type)for(const e of n.specifiers)t.set(e.local.name,{kind:"import"});return t}(n),r=[];for(const e of n.body){if("ExportDefaultDeclaration"===e.type)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);if("ExportAllDeclaration"===e.type)throw new Error(`"export *" is not supported in .backend.ts files. Use explicit named exports instead: ${t}`);if("ExportNamedDeclaration"!==e.type)continue;e.declaration&&r.push(...Te(e.declaration,t).map((e=>({kind:"local",name:e,localName:e}))));const n="string"==typeof e.source?.value?e.source.value:null;for(const i of e.specifiers){if("Identifier"!==i.exported.type)continue;if("default"===i.exported.name)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);const e="Identifier"===i.local.type?i.local.name:"string"==typeof i.local.value?i.local.value:null;e&&(n?r.push({kind:"re-export",name:i.exported.name,localName:e,source:n}):("Identifier"===i.local.type&&Oe(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const Ce=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function Ne(e){return null==e||Ce.has(e.type)}function Te(e,t){if("FunctionDeclaration"===e.type&&e.id)return[e.id.name];if("ClassDeclaration"===e.type)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${t}`);if("VariableDeclaration"===e.type)return e.declarations.flatMap((e=>{if("Identifier"!==e.id.type)throw new Error(`Destructured exports are not supported in backend files. Use individual named exports instead: ${t}`);if(Ne(e.init))throw new Error(`Non-function export "${e.id.name}" in backend file ${t}. Only function exports are supported — use "export function ${e.id.name}(…) { }" instead.`);return[e.id.name]}));throw new Error(`Unsupported export declaration type "${e.type}" in backend file ${t}. Only function and variable exports are allowed.`)}function Oe(e,t,n){const o=t.get(e);if(o){if("class"===o.kind)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${n}`);if("variable"===o.kind&&Ne(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function Re(e){const t=e.relativePath.split(u.sep).join("/");return`${d("sha256").update(t).digest("hex")}.${e.name}`}function _e(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 Fe(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return P.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}(n)&&o.push("import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';"),o.push(""),o.push('/** @param {import("./context.types").Context} $ */'),o.push("export async function main($) {"),o.push(" globalThis.$ = $;"),o.push(""),o.push(" // Register the $.Actions-based implementation for executeAction"),o.push(" if (typeof setExecuteActionImplementation === 'function') {\n setExecuteActionImplementation(async (actionId, request) => {\n const actionPath = actionId.replace(/^com\\.datadoghq\\./, '');\n const pathParts = actionPath.split('.');\n let actionFn = $.Actions;\n for (const part of pathParts) {\n if (!actionFn) throw new Error('Action not found: ' + actionId);\n actionFn = actionFn[part];\n }\n if (typeof actionFn !== 'function') throw new Error('Action is not a function: ' + actionId);\n return actionFn(request);\n });\n }"),o.push(""),o.push(" const args = $.backendFunctionArgs ?? [];"),o.push(` const result = await ${e}(...args);`),o.push(" return result;"),o.push("}"),o.join("\n")}function Le(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)ze(t)&&r(t);else ze(e)&&r(e)};r(e)}function ze(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function Be(e){Le(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=m.analyze(e,{ecmaVersion:2022,ignoreEval:!0,sourceType:"module"}),n=new Map;for(const e of t.scopes)for(const t of e.references)n.set(t.identifier,t);return{scopeManager:t,referencesByIdentifier:n,moduleScope:Ve(t)}}function Ke(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function qe(e){return e.defs.some((e=>"ImportBinding"===e.type))}function Ue(e,t){return t.moduleScope.set.get(e)}function Ve(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function He(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:We(e,t)},r=[];return Le(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 tt(n,"action-catalog call aliases");if(Qe(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw tt(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!Je(o,t.scopeAnalysis))return!1;if(e.optional||Ye(o))throw tt(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function We(e,t){const n=new Set;return Le(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 Xe(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&Je(e.init,t))return Xe(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?[]:et(e.value))).map((e=>e.name));return Xe(e,t,n)}(e,t))n.add(o)},AssignmentExpression(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.left.type&&"Identifier"===e.right.type&&Qe(e.right,t.actionFunctions,t))return Ze([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&Je(e.right,t))return Ze([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?[]:et(e.value)));return Ze(n,t)}(e,t))n.add(o)}}),n}function Je(e,t){const n=Ge(e);return!!n&&Qe(n,t.actionNamespaces,t)}function Ge(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?Ge(e.object):void 0}function Ye(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&Ye(e.object)}function Qe(e,t,n){return function(e,t,n){const o=Ke(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function Ze(e,t){return e.flatMap((e=>{const n=Ke(e,t.moduleScope);return n?[n]:[]}))}function Xe(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function et(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?et(e.argument):et(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?et(e):[]));case"RestElement":return et(e.argument);case"AssignmentPattern":return et(e.left);case"MemberExpression":return[]}}function tt(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const nt="@datadog/action-catalog";function ot(e,t,n){const o=e.get(t);if(!o)return dt(t,[],n.name);const r=Ke(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?pt(t,[],n.name):st({modules:e,visitedExports:new Set},t,r,[]):pt(t,[],n.name)}function rt(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 ut(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?ut(t.id,r,n):rt(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return st(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=rt(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||!it(r,s)){if(r)return at(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 it(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function st(e,t,n,o){const r=e.modules.get(t);if(!r)return dt(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return ct(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 ct(t,r,n);return rt(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 at(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 ut(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 ct(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported default import.`,hops:t}}function dt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"variable",variableName:n,message:`Module '${e}' was not collected while resolving variable '${n}'.`,hops:t}}function pt(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 lt(e,t,n){const o=xt(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=ot(e.modules,t,n);if("unsupported"===o.kind)return Ct(o,n.name);if(!o.binding.expression)return Nt(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return Dt(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return lt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=ft(e,t,n);if("unsupported"===o.kind)return o;return lt(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 ft(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=mt(e,t,n.object);return"unsupported"===o.kind?o:function(e,t,n){let o;for(const r of t.properties){if("SpreadElement"===r.type)return At(e);if(r.computed)return It(e);if(kt(r)===n){if(o)return jt(e,n);if("init"!==r.kind)return St(e,n);if(!gt(r))return Mt(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 mt(e,t,n){if("Super"===n.type)return Pt(t,n.type);const o=xt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=ft(e,t,o);return"unsupported"===n.kind?n:mt(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return Pt(t,o.type);const r=ot(e.modules,t,o);if("unsupported"===r.kind)return Ct(r,o.name);if(!r.binding.expression)return Nt(r.moduleId,r.variable.name);if(e.mutatedImportedObjectVariables.has(r.variable))return function(e,t){return{kind:"unsupported",moduleId:e,reason:"imported-object-mutation",variableName:t,message:`Imported object '${t}' from module '${e}' is mutated in the module graph.`}}(r.moduleId,r.variable.name);if(e.seenVariables.has(r.variable))return Dt(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return mt(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function gt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function ht(e){const t=new Set;for(const n of e.values())Le(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){bt(e.left,t)},UpdateExpression(e,{state:t}){bt(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&bt(e.argument,t)},ForInStatement(e,{state:t}){yt(e.left,t)},ForOfStatement(e,{state:t}){yt(e.left,t)}});return t}function yt(e,t){"VariableDeclaration"!==e.type&&bt(e,t)}function bt(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&bt(e.left,t):bt(e.argument,t);else for(const n of e.elements)n&&bt(n,t);else for(const n of e.properties)bt("RestElement"===n.type?n.argument:n.value,t);else{const n=$t(e);n&&wt(n,t)}else wt(e,t)}function wt(e,t){const n=vt(t,e,new Set);n&&t.mutatedVariables.add(n)}function vt(e,t,n){const o=Ke(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),qe(o)){const n=ot(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=xt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return $t(t);return}(r);return i?vt(e,i,n):void 0}function $t(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?$t(e.object):void 0}function kt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function xt(e){let t=e;for(;Et(t);)t=t.expression;return t}function Et(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function St(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 It(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function Dt(e,t){return{kind:"unsupported",moduleId:e,reason:"cycle",variableName:t,message:`Resolving variable '${t}' in module '${e}' would cycle through static string values.`}}function jt(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function Pt(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 Mt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unsupported-object-property-value",propertyName:t,valueType:n,message:`Static object property '${t}' in module '${e}' has unsupported value type '${n}'.`}}function At(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function Ct(e,t){return{kind:"unsupported",moduleId:e.moduleId,reason:"static-definition-unsupported",variableName:t,definition:e,message:`Variable '${t}' could not be resolved to a static definition: ${e.message}`}}function Nt(e,t){return{kind:"unsupported",moduleId:e,reason:"uninitialized-const",variableName:t,message:`Const variable '${t}' in module '${e}' does not have an initializer.`}}const Tt=new Set(["node_modules",".yarn"]);function Ot(e,t,n,o=[]){if(!Xt(e,t))return null;const r=je(n,e),i=Be(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&&Pe(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:Rt(r,i,s),exportsByName:_t(r,i,s),starExports:zt(r,s),topLevelBindingsByVariable:Bt(r,i)}}function Rt(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!Pe(r.source))continue;const e=Yt(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:Jt(n.imported),resolvedId:e}))}}return o}function _t(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&Lt(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):Ft(r,t,n,o);return o}function Ft(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&&Pe(e.source)){const t=Yt(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=Jt(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:Jt(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=Jt(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=Ue(Jt(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function Lt(e,t,n){const o=Gt(e);o&&Pe(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Yt(t,e.source.value)})}function zt(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||Gt(e)||!Pe(e.source)?[]:[{resolvedId:Yt(t,e.source.value)}]))}function Bt(e,t){const n=new Map;for(const o of e.body)Kt(o,t,n);return function(e,t,n){Le(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){Vt(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){Vt(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Vt(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){Ut(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){Ut(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function Kt(e,t,n){if("VariableDeclaration"===e.type)return void qt(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void qt(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 qt(e,t,n){for(const o of e.declarations){const r=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const e of r)n.set(e,{kind:"unsupported",reason:"binding pattern"});continue}const[i]=r;i&&("const"===e.kind?n.set(i,{kind:"const",expression:o.init??null}):n.set(i,{kind:"mutable",declarationKind:e.kind}))}}function Ut(e,t,n){"VariableDeclaration"!==e.type&&Vt(e,t,n)}function Vt(e,t,n){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&Vt(e.left,t,n):Vt(e.argument,t,n);else for(const o of e.elements)o&&Vt(o,t,n);else for(const o of e.properties)Vt("RestElement"===o.type?o.argument:o.value,t,n);else{const o=Wt(e);o&&Ht(o,t,n,"mutated object binding")}else Ht(e,t,n,"reassigned binding")}function Ht(e,t,n,o){const r=Ke(e,t);if(!r||qe(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function Wt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?Wt(e.object):void 0}function Jt(e){return"Identifier"===e.type?e.name:String(e.value)}function Gt(e){const t=e.exported;return t?Jt(t):void 0}function Yt(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function Qt(e){const t=[];return Le(e,t,{ImportExpression(e,{state:t}){const n=function(e){return tn(e.source,"non-literal dynamic import")}(e);Zt(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 tn(e.arguments[0],"non-literal dynamic import")}(e);Zt(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||!Pe(t)||nn(t.value)})(e)&&t.push({specifier:en(e),kind:"require"})}}),t}function Zt(e){return"non-literal dynamic import"===e||nn(e)}function Xt(e,t){if(!we.some((t=>e.endsWith(t))))return!1;const n=u.relative(u.resolve(t),e);return!n.startsWith("..")&&!u.isAbsolute(n)&&!n.split(u.sep).some((e=>Tt.has(e)))}function en(e){return tn(e.arguments[0],"local require")}function tn(e,t){return Pe(e)?e.value:t}function nn(e){return e.startsWith(".")||e.startsWith("/")}function on(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function rn(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 on(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw on(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Xt(i,n)){if(!t.has(i))throw on(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===nt||o.startsWith(`${nt}/`))&&!Me(r))for(const e of r.specifiers)Me(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)qe(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 He(e.ast,r,e.id)){const r=sn(n,t,e);r&&o.add(r)}})),[...o].sort()}function sn(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw cn(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 cn(t,"spread object arguments");if(o.computed)throw cn(t,"computed object property keys");if(un(o)){if(n)throw cn(t,"multiple connectionId properties");if("init"!==o.kind)throw cn(t,"accessor connectionId properties");if(!an(o))throw cn(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return lt({modules:e,mutatedImportedObjectVariables:ht(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 an(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function un(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 cn(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const dn=/^(?:\0|virtual:)/;function pn(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=ln(n.id);if(r=o,dn.test(r))return;var r;const i=Ot(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(ln));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function ln(e){return e.split("?")[0]}function fn(e,t){const n=pn(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>rn(e,n.getModuleRecords(),t)}}function mn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function gn(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:[...we,".json"]},plugins:[mn("dd-backend-resolve",t),...n]}}function hn(e){return`${e.relativePath}/${e.name}`}async function yn(e,t,n,o){const r=hn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return Fe(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=fn(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=gn(n,{[i]:s},[a.plugin]),c=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),d=Array.isArray(c)?c[0]:c;if(!("output"in d))throw new Error(`Unexpected vite.build result for "${r}"`);const p="chunk"===d.output[0].type?d.output[0].code:"",l={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${p.length} bytes)`),{func:l,code:p}}async function bn(e,t,n,o,r){const i=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,s=hn(t);r.debug(`Calling Datadog API: ${i}`);const a=JSON.stringify({data:{type:"queries",attributes:{query:{id:p(),name:s,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e,allowedConnectionIds:t.allowedConnectionIds,context:{backendFunctionArgs:n}}},onlyTriggerManually:!0}},template_params:{}}}}),u=await H({url:i,auth:o,method:"POST",type:"json",getData:()=>({data:a,headers:{"Content-Type":"application/json"}})}),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 H({url:o,auth:t,type:"json"});if(i.errors?.length){const e=i.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const s=i.data?.attributes;if(n.debug(`Long-poll response, done: ${s?.done}`),s?.done){if(!s.outputs)throw new Error("Query execution completed without outputs");return s.outputs}}throw new Error("Query execution timed out")}(c,o,r)}function wn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class vn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function $n(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 vn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new vn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function kn(e,t,n,o,r){const i=t=>yn(e,t,o,r),s=t();s.length>0&&r.info(`Dev server middleware active for ${s.length} backend function(s): ${s.map((e=>e.name)).join(", ")}`);const a=n.apiKey&&n.appKey?{apiKey:n.apiKey,appKey:n.appKey,site:n.site}:void 0;return a||r.warn("Auth credentials not configured. The /__dd/executeAction endpoint will be unavailable. Set DD_API_KEY and DD_APP_KEY to enable remote execution."),(e,n,o)=>{if("POST"!==e.method)return void o();const s=(u=t(),new Map(u.map((e=>[Re(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await $n(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){wn(t,e instanceof vn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,n,s,i).catch((()=>{wn(n,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void wn(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 $n(e,n,o),c=hn(s);i.debug(`Executing action: ${c} with args`);const d=await bn(a,s,u,r,i);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:d}))}catch(e){const n=e instanceof vn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";i.debug(`Error handling executeAction: ${o}`),wn(t,n,o)}})(e,n,s,i,a,r).catch((()=>{wn(n,500,"Unexpected error")}))}else o()}}const xn=async(e,t)=>{const n=(await Promise.all(e.map((e=>h(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>u.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(u.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(u.sep);if(!e.every((e=>e.startsWith(`${r}${u.sep}`))))break;n=r}return n})(o),i=o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o.split(u.sep).join("/")}}));return i},En=(e,t)=>G(t)?M:t.startsWith(e)||u.isAbsolute(t)?t:u.resolve(e,t),Sn=(e,t)=>{let n,o=En(process.cwd(),e);for(;!n;){const e=u.resolve(o,t);if(Ee(e)&&(n=e),o=o.split(u.sep).slice(0,-1).join(u.sep),[u.sep,""].includes(o))break}return n},In=(e,t)=>{const n=[...e].map((e=>En(t||process.cwd(),e).split(u.sep))),o=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<o;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(u.sep)||u.sep},Dn=t.bold.red,jn=t.bold.yellow,Pn=e=>{const t=Sn(e,"package.json");if(t)try{const e=xe(t);return JSON.parse(e)}catch(e){return}},Mn=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=Pn(e);o||t.warn(jn("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(Dn("Unable to determine the app name to compute the app identifier."));const i=((e,t)=>{const n=e||(e=>{if(e&&e.repository)return"string"==typeof e.repository?e.repository:"url"in e.repository?e.repository.url:void 0})(t);if(!n)return;const o=ee(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(Dn("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("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(Dn("Unable to compute the app identifier.")),{identifier:s,name:r}},An=t.green.bold,Cn=t.yellow.bold,Nn=t.cyan.bold,Tn=t.bold,On=(e,t={},n)=>async()=>{const o=await Se(e,{contentType:"application/zip",filename:ye});return U({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ye);const t=L("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},Rn=async(e,t,n)=>{const o=[],r=[];if(!t.apiKey||!t.appKey)return o.push(new Error("Missing authentication token, need both app and api keys.")),{errors:o,warnings:r};if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:r};const i=(s=t.site,a=t.identifier,L("APPS_INTAKE_URL")||`https://api.${s}/${he}/${a}/upload`);var s,a;const u=q({bundler:t.bundlerName,plugin:"apps",version:t.version}),d=ne({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(u,null,2)}`}),p=`an archive of:\n - ${An(e.assets.length.toString())} files\n - ${An(y(e.size))}\n\nWith the configuration:\n${d}`;if(t.dryRun)return n.error(`\n${Nn("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:On(e.archivePath,u,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Cn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}});if(n.debug(`Uploaded ${p}\n`),o.app_builder_id){const e=`https://app.${t.site}/app-builder/apps/${o.app_builder_id}`;n.info(`Your application is available at:\n ${Nn(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${he}/${t}/release/live`)(t.site,t.identifier);await H({auth:{apiKey:t.apiKey,appKey:t.appKey},url:e,method:"PUT",type:"json",getData:async()=>({data:c.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...u}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${Cn(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${Tn(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}},_n=t.yellow.bold,Fn=t.red.bold,Ln="manifest.json";async function zn(e){const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-manifest-")),n=u.join(t,Ln);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[Re(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await ve(t),e}return{manifestAsset:{absolutePath:n,relativePath:Ln},cleanup:()=>ve(t)}}const Bn=async({backendOutputs:e,backendFunctions:t,context:n,options:o})=>{const i=n.getLogger(ge),{auth:a,buildRoot:c,bundler:{name:d,outDir:p},git:f,version:m}=n,h=i.time("handle assets");let y,b,w;try{const n=i.time("resolve identifier"),{name:h,identifier:w}=Mn(c,i,{url:f?.remote,name:o.name,identifier:o.identifier});if(!w||!h)throw new Error("Missing apps identification.\nEither:\n - pass an 'options.apps.identifier' and 'options.apps.name' to your plugin's configuration.\n - have a 'name' and a 'repository' in your 'package.json'.\n - have a valid remote url on your git project.\n");n.end();const v=u.relative(c,p),$=[...o.include,`${v}/**/*`],k=await xn($,c);if(!k.length)return void i.debug("No assets to upload.");const x=new Set(e.values()),E=k.filter((e=>!x.has(e.absolutePath))).map((e=>({...e,relativePath:`frontend/${e.relativePath}`})));for(const[t,n]of e)E.push({absolutePath:n,relativePath:`backend/${t}.js`});const{manifestAsset:S,cleanup:I}=await zn(t);b=I,E.push(S);const D=i.time("archive assets"),j=await(async e=>{const t=await r.mkdtemp(u.join(l.tmpdir(),"dd-apps-")),n=u.join(t,ye),o=new g;for(const t of e)o.file(t.relativePath,s.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=s.createWriteStream(n),i=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});i.on("error",t),r.on("error",t),r.on("close",e),i.pipe(r)}));const{size:i}=await r.stat(n);return{archivePath:n,size:i,assets:e}})(E);D.end(),y=u.dirname(j.archivePath);const P=i.time("upload assets"),{errors:M,warnings:A}=await Rn(j,{apiKey:a.apiKey,appKey:a.appKey,bundlerName:d,dryRun:o.dryRun,identifier:w,name:h,site:a.site,version:m},i);if(P.end(),A.length>0&&i.warn(`${_n("Warnings while uploading assets:")}\n - ${A.join("\n - ")}`),M.length>0){const e=M.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){w=e,i.error(`${Fn("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await ve(y),b&&await b(),h.end(),w)throw w};const Kn=u.join(j,"./apps-runtime.mjs"),qn=({bundler:e,context:t,options:n})=>{const o=t.getLogger(ge),{auth:r,buildRoot:s}=t;t.inject({type:"file",position:De.MIDDLE,value:Kn});const{setBackendFunctions:a,getBackendFunctions:c}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[be],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=Ae(this.parse(e),t);if(0===n.length)return o.warn(`Backend file ${t} has no exported functions. Did you forget to add a named export?`),a(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=u.relative(n,t).replace(be,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:Re(e)})}return{functions:r,proxyCode:_e(i)}}(n,t,s);return a(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let r,a=new Map,d=c();if(d.length>0){const t=await async function(e,t,n,o){const r=await i(u.join(f(),"dd-apps-backend-")),s=new Map,a=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const i of t){const t=Re(i),c=`\0dd-backend:${t}`,d=Fe(i.name,i.absolutePath,n),p=fn(i.absolutePath,n),l=gn(n,{[c]:d},[p.plugin]),f=await e({...l,build:{...l.build,write:!0,outDir:r,emptyOutDir:!1,rollupOptions:{...l.build.rollupOptions,input:{[t]:c},output:{...l.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=u.resolve(r,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}a.set(i.absolutePath,p.getAllowedConnectionIds())}return{outDir:r,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:a.get(e.absolutePath)})))}}(e.build,d,s,o);r=t.outDir,a=t.outputs,d=t.functions}try{await Bn({backendOutputs:a,backendFunctions:d,context:t,options:n})}finally{r&&await ve(r)}},configureServer(t){t.middlewares.use(kn(e.build,c,r,s,o))}}},Un=({options:e,context:t,bundler:n})=>{const o=t.getLogger(ge),r=(e=>{const t=e[me]||{};return{include:t.include||[],dryRun:t.dryRun??!L("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim()}})(e);return"vite"!==t.bundler.name?(o.warn(`The apps plugin only supports Vite; skipping under '${t.bundler.name}'.`),[]):[{name:ge,enforce:"post",vite:qn({bundler:n,context:t,options:r})}]},Vn="errorTracking",Hn="datadog-error-tracking-plugin",Wn=(e,n,o)=>{if(".map"!==u.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=u.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return u.join(e,t);try{const n=e.replace(/\/*$/,"/"),o=new URL(n),r=t.replace(/^[\\/]*/,"");return new URL(r,o).href}catch{return`${e}${t}`}})(e,i);return{minifiedFilePath:r,minifiedUrl:s,relativePath:i}},Jn=/[/]+|[\\]+/g,Gn=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Yn=(e,t)=>{const n=e.replace(Gn,"").split(Jn),o=t.replace(Gn,"").split(Jn),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([Ie(e.minifiedFilePath),Ie(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Yn(e.relativePath,t)}})(e,n),i=[],s=[],a=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(o)try{a.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${u.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:o.hash,repository_url:o.remote}],version:1})})}catch(t){s.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&s.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:a,errors:i,warnings:s}},Zn=e=>{const t=e.message.match(/HTTP (\d{3})/);return t?`status_code:${t[1]}`:"status_code:unknown"},Xn=e=>{const t=Zn(e);return"status_code:unknown"!==t?`error_type:http_${t.replace("status_code:","")}`:`error_type:${te(e.name||"unknown")}`},eo=(e,t,n)=>{const o=((e,t)=>`${e}|${t.join("|")}`)(t,n),r=e.metrics.get(o);r?r.value++:e.metrics.set(o,{name:t,value:1,tags:n})},to=(e,t,n)=>{eo(e,"retry",[...e.baseTags,`attempt:${n}`,Zn(t),Xn(t)])},no=(e,t)=>{eo(e,"failure",[...e.baseTags,Zn(t),Xn(t)])},oo=(e,t)=>{if(!t.sendMetrics)return;if(!e.metrics.size)return;const n=(e=>{const t=Math.floor(Date.now()/1e3);return Array.from(e.metrics.values()).map((e=>({metric:`sourcemaps.upload.${e.name}`,type:"count",points:[[t,e.value]],tags:e.tags})))})(e);for(const e of n)t.addMetric(e)},ro=t.green.bold,io=t.yellow.bold,so=t.red.bold,ao=(e,t={})=>async()=>U({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await Se(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}),uo=async(e,t,n,o)=>{const r=[],i=[];if(!n.apiKey)return r.push({error:new Error("No authentication token provided")}),{errors:r,warnings:i};if(0===e.length)return i.push("No sourcemaps to upload"),{errors:r,warnings:i};const s=o.time("Queue uploads"),a=new(b.default?b.default:b)({concurrency:t.maxConcurrency}),u=(c=n.site,L("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const d=q({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=(e=>({metrics:new Map,baseTags:[`service:${e.service}`]}))(t),l=ne({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),f=`\nUploading ${ro(e.length.toString())} sourcemaps with configuration:\n${l}`;o.debug(f);const m=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};m.push(a.add((async()=>{try{await H({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:ao(s,d),onRetry:(t,n)=>{to(p,t,n);const r=`Failed to upload ${io(e.sourcemap)} | ${io(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(no(p,n),r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}s.end(),o.debug(`Queued ${ro(e.length.toString())} uploads.`);try{await Promise.all(m),await a.onIdle()}finally{oo(p,n)}return{warnings:i,errors:r}},co=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=>({...Wn(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 c=u.map((e=>e.errors)).flat(),d=u.map((e=>e.warnings)).flat();if(d.length>0&&o.warn(`Warnings while preparing payloads:\n - ${d.join("\n - ")}`),c.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${c.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const p=o.time("Upload sourcemaps"),{errors:l,warnings:f}=await uo(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site,sendMetrics:n.sendMetrics,addMetric:n.addMetric},o);if(p.end(),o.debug(`Done uploading ${ro(`${e.length-l.length}/${e.length}`)} sourcemaps in ${ro(Z(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?`${so(e.file)} | ${so(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{addMetric:t.addMetric,apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,sendMetrics:t.sendMetrics,site:t.site,version:t.version},n),i.end()},po=e=>{const n=t.bold.red,o=e[Vn]||{},r={errors:[]};if(o.sourcemaps){const t=o.sourcemaps,i=t.releaseVersion||e.metadata?.version;i||r.errors.push(`${n("sourcemaps.releaseVersion")} is required (set it directly or via ${n("metadata.version")}).`),t.releaseVersion&&e.metadata?.version&&t.releaseVersion!==e.metadata.version&&r.errors.push(`${n("sourcemaps.releaseVersion")} must match ${n("metadata.version")} when both are configured.`),t.service||r.errors.push(`${n("sourcemaps.service")} is required.`),t.minifiedPathPrefix||r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} is required.`),t.minifiedPathPrefix&&!(e=>{let t;try{t=new URL(e).host}catch{}return!(!t&&!e.startsWith("/"))})(t.minifiedPathPrefix)&&r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} must be a valid URL or start with '/'.`),i&&(r.config={bailOnError:!1,dryRun:!1,maxConcurrency:20,...t,releaseVersion:i})}return r},lo=({options:e,context:t})=>{const n=t.getLogger(Hn),o=n.time("validate options"),r=((e,t)=>{const n=[],o=po(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Hn}.`);return{...e[Vn],sourcemaps:o.config}})(e,n);o.end();const i=fe(e,"metrics",n);let s,a,u=!1;const c=async()=>{if(!r.sourcemaps||u)return;u=!0;const e=n.time("sourcemaps process");await co(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:s,addMetric:t.addMetric,outDir:t.bundler.outDir,outputs:a?.outputs||[],sendMetrics:i,site:t.auth.site,version:t.version},n),e.end()};return[{name:Hn,enforce:"post",async git(e){s=e,a&&await c()},async buildReport(t){a=t,!s&&Q(e)||await c()},async asyncTrueEnd(){u||await c()}}]},fo="liveDebugger",mo="datadog-live-debugger-plugin",go="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",ho="__DD_LIVE_DEBUGGER_BUILD__",yo=e=>void 0===e?go:`${go};if(typeof globalThis.${ho}==='undefined'){globalThis.${ho}={version:${JSON.stringify(e)}}}`;function bo(e){return"function"==typeof e?e:e.default}function wo(e,t,n,o,r){const i=u.relative(t,e).replace(/\\/g,"/"),s=vo(n,r);if(s)return`${i};${s}`;const a=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${a}:${o}`}function vo(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)?xo(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=$o(e.object,t),o=ko(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)?xo(o.key,t):null}function $o(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=$o(e.object,t),o=ko(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function ko(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function xo(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 Eo(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function So(e,t){const n=[];if(t.isBlockStatement(e.body)){const o=e.params.flatMap((e=>Ao(e,t))),r=new Set(o),i="id"in e&&t.isIdentifier(e.id)?e.id.name:"";for(const o of e.body.body)if(t.isVariableDeclaration(o)){const e=o.end;if(null==e)continue;for(const s of o.declarations)for(const o of Ao(s.id,t))r.has(o)||o===i||n.push({name:o,declarationEnd:e,temporalDeadZones:[]})}}const o=n.length>25?n.slice(0,25):n;if(t.isBlockStatement(e.body)){const n=o.map((({name:e})=>e)),r=new Set(n),i=function(e,t,n){const o=new Map;for(const r of e.body)Io(r,t,o,n);return o}(e.body,r,t);for(const e of o)e.temporalDeadZones=i.get(e.name)??[]}return o}function Io(e,t,n,o){o.isFunctionDeclaration(e)||o.isClassDeclaration(e)||(o.isBlockStatement(e)?Do(e,t,n,o):o.isIfStatement(e)?(Io(e.consequent,t,n,o),e.alternate&&Io(e.alternate,t,n,o)):o.isForStatement(e)||o.isForInStatement(e)||o.isForOfStatement(e)||o.isWhileStatement(e)||o.isDoWhileStatement(e)?Io(e.body,t,n,o):o.isSwitchStatement(e)?function(e,t,n,o){for(const r of e.cases){jo(r.consequent,e.start,t,n,o);for(const e of r.consequent)Io(e,t,n,o)}}(e,t,n,o):o.isTryStatement(e)?(Do(e.block,t,n,o),e.handler&&Do(e.handler.body,t,n,o),e.finalizer&&Do(e.finalizer,t,n,o)):(o.isLabeledStatement(e)||o.isWithStatement(e))&&Io(e.body,t,n,o))}function Do(e,t,n,o){jo(e.body,e.start,t,n,o);for(const r of e.body)Io(r,t,n,o)}function jo(e,t,n,o,r){if(null!=t)for(const i of e)r.isVariableDeclaration(i)&&"var"!==i.kind?Po(i,t,n,o,r):r.isClassDeclaration(i)&&i.id&&Mo(i.id.name,t,i.end,n,o)}function Po(e,t,n,o,r){for(const i of e.declarations)for(const s of Ao(i.id,r))Mo(s,t,e.end,n,o)}function Mo(e,t,n,o,r){if(null==n||!o.has(e))return;const i=r.get(e)??[];i.push({start:t,end:n}),r.set(e,i)}function Ao(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:Ao(e.argument,t):t.isAssignmentPattern(e)?Ao(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?Ao(e.argument,t):Ao(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?Ao(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const Co=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let No,To,Oo,Ro,_o=!1;function Fo(e){try{return function(e){switch(e){case"@babel/parser":return P("@babel/parser");case"@babel/traverse":return P("@babel/traverse");case"@babel/types":return P("@babel/types");case"magic-string":return P("magic-string");default:throw new Error(`Unknown peer dependency: ${e}`)}}(e)}catch(e){throw function(e){if(!function(e){if(!(e instanceof Error))return!1;const t=e.code;if("MODULE_NOT_FOUND"!==t&&"ERR_MODULE_NOT_FOUND"!==t)return!1;return Co.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=Co.find((t=>e.message.includes(t))),n=t??Co.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 ${Co.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const Lo=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function zo(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,c=0,d=0,p=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:1,skippedUnsupportedCount:d,totalFunctions:p};if(!Lo.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p};_o||(No=Fo("@babel/parser").parse,To=bo(Fo("@babel/traverse")),Oo=Fo("@babel/types"),Ro=bo(Fo("magic-string")),_o=!0);const l=No(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map,g=new Set,h=new Map,y=new Map;let b=0;if(To(l,{Function(e){p++;const t=function(e,t){if(t.isClassMethod(e.node)&&"constructor"===e.node.kind&&Wo(e,t))return e.node;return}(e,Oo);if(t&&(m.set(t,t.body.start),h.set(t,function(e,t){const n=[];for(const o of e)qo(o,n,t);return n}(t.body.body,Oo))),!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,Oo))return void d++;if(r&&function(e,t,n){let o=e;for(;o;){if(Eo(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return Eo(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",Oo))return void c++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,Oo)))return void d++;if(s&&!vo(e,Oo))return void d++;let l=0;if(!vo(e,Oo)){const t=e.parentPath?.node;t&&(l=y.get(t)||0,y.set(t,l+1))}const w=wo(n,o,e,l,Oo);try{const t=e.node,n=b++,o=`$dd_p${n}`,r=function(e,t){const n=[];for(const o of e.params)for(const e of Ao(o,t))"this"!==e&&n.push(e);return n.length>25?n.slice(0,25):n}(t,Oo),i=So(t,Oo),s=Oo.isArrowFunctionExpression(t)&&!Oo.isBlockStatement(t.body),a=s&&Oo.isSequenceExpression(t.body),c=function(e,t){if(t.isFunction(e.node)&&!t.isArrowFunctionExpression(e.node))return;let n=e.parentPath;for(;n;){const e=n.node;if(t.isClassMethod(e)&&"constructor"===e.kind){if(!Wo(n,t))return;return{node:e,parent:n.parent,parentPath:n.parentPath}}if(t.isFunction(e)){if(t.isArrowFunctionExpression(e)){n=n.parentPath;continue}return}n=n.parentPath}return}(e,Oo),d=null!=c;c&&(g.add(c.node),m.set(c.node,c.node.body.start));const p=[],l=s||!Oo.isBlockStatement(t.body)||!Yo(t.body.body,Oo);let h;if(!s&&Oo.isBlockStatement(t.body)&&Go(t.body.body,p,Oo),!s&&Oo.isBlockStatement(t.body)&&t.body.directives.length>0){h=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,hasSequenceExpressionBody:a,aliasesExpressionBodySuperCall:d&&s&&Ho(t.body,Oo),needsTrailingReturn:l,useThisAlias:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:h,functionId:w,probeVarName:o,probeIdx:String(n),entryVars:r,localVars:i,returns:p}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p};const w=new Ro(t),v=function(e){const t=new Set;for(const n of e)n.aliasesExpressionBodySuperCall&&t.add(Vo({start:n.bodyStart,end:n.bodyEnd}));return t}(f),$=function(e,t,n,o){const r=[];for(const i of e){const e=t.get(i);null!=e&&r.push({bodyStart:e,superCalls:(n.get(i)??[]).filter((e=>!o.has(Vo(e))))})}return r}(g,m,h,v);for(let e=f.length-1;e>=0;e--)Bo(w,t,f[e]);for(const e of $)Ko(w,t,e);return{code:w.toString(),map:w.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p}}function Bo(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,localVars:a,returns:u,bodyStart:c,bodyEnd:d,functionEnd:p,isExpressionBody:l,hasSequenceExpressionBody:f,aliasesExpressionBodySuperCall:m,useThisAlias:g,bodyParenStart:h,directivesEnd:y}=n,b=`$dd_e${r}`,w=`$dd_rv${r}`,v=g?"$dd_t":"this",$=s.join(", "),k=""!==$,x=k?`, ${b}()`:"";const E=`const ${o} = $dd_probes('${i.replace(/['\\\n\r\u2028\u2029]/g,(e=>{switch(e){case"'":return"\\'";case"\\":return"\\\\";case"\n":return"\\n";case"\r":return"\\r";case"\u2028":return"\\u2028";case"\u2029":return"\\u2029";default:return e}}))}');`,S=k?`const ${b} = () => ({${$}});`:"",I=`if (${o}) $dd_entry(${o}, ${v}${x});`,D=`catch(e) { if (${o}) $dd_throw(${o}, e, ${v}${x}); throw e; }`;if(l){if(null!=h){const n=function(e,t,n){const o=[];for(let r=t;r<n;r++)"("===e[r]&&o.push(r);return o}(t,h,c),o=function(e,t,n){const o=[];for(let r=n-1;r>=t;r--)")"===e[r]&&o.push(r);return o}(t,d,p),r=Math.min(n.length,o.length);for(let t=0;t<r;t++){const r=n[t],i=o[t];e.remove(r,r+1),e.remove(i,i+1)}}const n=["{",E,S,"try {",I,m?`const ${w} = ($dd_t = `:`const ${w} = `].filter(Boolean).join("\n");let r=f?");":";";m&&(r=f?"));":");");const i=[r,`if (${o}) $dd_return(${o}, ${w}, ${v}${Jo(b,k,a,d)});`,`return ${w};`,`} ${D}`,"}"].join("\n");if(d-c>=2){const o=f?`${n}(${t[c]}`:n+t[c];e.update(c,c+1,o),e.update(d-1,d,t[d-1]+i)}else e.update(c,d,n+t.slice(c,d)+i)}else{const r=[E,S,"try {",`let ${w};`,I].filter(Boolean).join("\n");for(const t of u){const n=Jo(b,k,a,t.start);if(null!=t.argStart&&null!=t.argEnd){const r=t.hasSequenceExpressionArgument?`(${w} = (`:`(${w} = `,i=t.hasSequenceExpressionArgument?")":"";e.appendLeft(t.argStart,r),e.appendLeft(t.argEnd,`${i}, ${o} ? $dd_return(${o}, ${w}, ${v}${n}) : ${w})`)}else e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, ${v}${n}); `)}if(null!=y){const n=y-1;e.update(n,y,`${t[n]}\n${r}`)}else e.update(c,c+1,`${t[c]}${r}`);const i=Jo(b,k,a,d),s=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, ${v}${i});\n`:""}} ${D}\n`;e.update(d-1,d,`${s}${t[d-1]}`)}}function Ko(e,t,n){e.update(n.bodyStart,n.bodyStart+1,`${t[n.bodyStart]}let $dd_t;`);for(const t of n.superCalls)e.appendLeft(t.start,"($dd_t = "),e.appendLeft(t.end,")")}function qo(e,t,n){Ho(e,n)&&t.push({start:e.start,end:e.end});const o=Object.values(e);for(const e of o)if(Array.isArray(e))for(const o of e)Uo(o,t,n);else Uo(e,t,n)}function Uo(e,t,n){n.isNode(e)&&(n.isFunction(e)&&!n.isArrowFunctionExpression(e)||qo(e,t,n))}function Vo(e){return`${e.start}:${e.end}`}function Ho(e,t){return t.isCallExpression(e)&&t.isSuper(e.callee)}function Wo(e,t){const n=e.parentPath?.parentPath;if(!n)return!1;const o=n.node;return(t.isClassDeclaration(o)||t.isClassExpression(o))&&null!=o.superClass}function Jo(e,t,n,o){const r=function(e,t){const n=e.filter((({declarationEnd:e,temporalDeadZones:n})=>e<=t&&!function(e,t){return e.some((({start:e,end:n})=>e<=t&&t<n))}(n,t))).map((({name:e})=>e));if(0===n.length)return;return`{${n.join(", ")}}`}(n,o);return t&&r?`, ${e}(), ${r}`:t?`, ${e}()`:r?`, undefined, ${r}`:""}function Go(e,t,n){for(const o of e)if(n.isReturnStatement(o))t.push({start:o.start,end:o.end,argStart:o.argument?.start??void 0,argEnd:o.argument?.end??void 0,hasSequenceExpressionArgument:n.isSequenceExpression(o.argument)});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))Go(o.body,t,n);else if(n.isIfStatement(o))Go([o.consequent],t,n),o.alternate&&Go([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))Go([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)Go(e.consequent,t,n);else n.isTryStatement(o)?(Go(o.block.body,t,n),o.handler&&Go(o.handler.body.body,t,n),o.finalizer&&Go(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&Go([o.body],t,n)}function Yo(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 Yo(e,t)&&Yo(o,t)}return!1}const Qo=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Zo=t.bold.red,Xo=Number(process.env.DD_LD_LIMIT)||1/0,er=(e,t)=>{const n=t.getLogger(mo);let o=0,r=0,i=0,s=0,a=0,u=0,c=0,d=0;return{name:mo,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(p,l){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?l.includes(e):e.test(l))))return{code:p}}for(const t of e.exclude){if("string"==typeof t?l.includes(t):t.test(l))return{code:p}}if(d>=Xo)return{code:p};try{const f=zo({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,c+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&d++,0===f.instrumentedCount)return{code:p};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),g=f.map&&m?function(e,t,n,o){try{return w(e,((e,n)=>1===n.depth?t:null))}catch(t){return o.error(`Failed to compose source map for ${n}: ${t}`,{forward:!0}),e}}(f.map,m,l,n):f.map;return{code:f.code,map:g}}catch(e){return n.error(`Instrumentation Error in ${l}: ${e}`,{forward:!0}),{code:p}}}},buildEnd:()=>{c>0&&n.info(`Live Debugger: ${o}/${c} functions instrumented across ${u}/${d} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:d,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},tr=({options:e,context:t})=>{const n=((e,t)=>{const n=e[fo]||{},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(`${Zo("include")} patterns must be strings or RegExp`);break}}else r.push(`${Zo("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(`${Zo("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Zo("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Zo("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Qo.includes(e)){r.push(`${Zo("functionTypes")} contains invalid value "${e}". Valid values: ${Qo.join(", ")}`);break}}else r.push(`${Zo("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Zo("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${mo}.`);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(mo));return t.inject({type:"code",position:De.BEFORE,injectIntoAllChunks:!0,value:yo(n.version)}),[er(n,t)]};const nr=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/^sourcemaps\.upload\.(failure|retry)$/.test(e.metric)&&(t.count=0),/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],or="metrics",rr="datadog-metrics-plugin",ir=e=>Math.floor((e||Date.now())/1e3),sr=(e,t)=>{const n=[`bundler:${te(e.bundler.name)}`,`plugin_version:${te(e.version)}`,`site:${te(e.auth.site)}`];return e.build.metadata.name&&n.push(`build_name:${te(e.build.metadata.name)}`),e.build.metadata.version&&n.push(`build_version:${te(e.build.metadata.version)}`),[...n,...t]},ar=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),ur=(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(ar(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(ar({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i},cr=(e="")=>e.endsWith("/")?e:`${e}/`,dr=(e,t)=>{let n=e;return e.split(cr(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},pr=(e,t)=>e.split("!").pop().replace(cr(t),"./"),lr=(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)),pr(o||"no-name",n)},fr=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),mr=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),gr=t.bold.red,hr=t.bold.cyan,yr=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},br=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(yr("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:Z(e.duration)}))),top:!0};n.sort(yr("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},wr=(e,t,n)=>{const o=[];var r;n&&(o.push(...br("Loader",n.loaders)),o.push(...br("Tapable",n.tapables)),o.push(...br("Module",n.modules))),o.push(...(e=>{const t={name:"Module total dependents",values:[],top:!0},n={name:"Module total dependencies",values:[],top:!0},o={name:"Module size",values:[],top:!0},r={name:"Module aggregated size",values:[],top:!0},i=new Set,s=Y(e.build),a=new Map,u=new Map,c=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)c.has(n)||c.set(n,new Set),c.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(c.has(e.filepath)){const t=c.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),c.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=c.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const d=Array.from(i);return d.sort(yr((e=>e.dependents.size))),t.values=d.map((e=>({name:e.name,value:e.dependents.size.toString()}))),d.sort(yr((e=>e.dependencies.size))),n.values=d.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),d.sort(yr("size")),o.values=d.map((e=>({name:e.name,value:y(e.size)}))),d.sort(yr("aggregatedSize")),r.values=d.map((e=>({name:e.name,value:y(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(yr((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(yr((e=>e.size))).map((e=>({name:e.name,value:y(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(yr((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:Z(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:Z(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:Z(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=X(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+=` [${gr(e.value)}] ${" ".repeat(n)}${hr(e.name)}\n`}}return t})(o);t.info(i)},vr="api/v1/series",$r=t.bold.green,kr=(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: ${$r(`https://api.${t.site}/${vr}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),H({method:"POST",url:`https://api.${t.site}/${vr}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))},xr=["onStart","onLoad","onResolve","onEnd"],Er=new Map,Sr=new Map,Ir=new Map,Dr=(e,t,n)=>{const o=Object.assign({},e);for(const r of xr)o[r]=async(o,i)=>{const s=Sr.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=pr(e[0].path,n),u=Ir.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=v.now();try{return await i(...e)}finally{const n=v.now(),i=n-c,d={start:c,end:n,duration:i,context:mr(e)};if(s.events[r].values.push(d),s.duration+=i,s.increment+=1,Sr.set(t,s),u.events[r].values.push(d),u.duration+=i,u.increment+=1,Ir.set(o,u),a){const e=Er.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(d),e.duration+=i,e.increment+=1,Er.set(t,e)}}}))};return o},jr=(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=Dr(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:Sr,modules:Ir,loaders:Er};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class Pr{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=lr(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(fr))(e);o.length||o.push("no-loader"),this.started[n]={module:dr(n),timings:{start:v.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=lr(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=v.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},i=n.loaders.join(",");r.events[i]=r.events[i]||{name:i,values:[]},r.events[i].values.push(n.timings),r.increment+=1,r.duration+=o,t.set(n.module,r);for(const t of n.loaders){const n=e.get(t)||{name:t,increment:0,duration:0,events:{}};n.increment+=1,n.duration+=o,e.set(t,n)}}return{loaders:e,modules:t}}}class Mr{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,r,i){const s=this.timings.get(t)||{name:t,duration:0,increment:0,events:{}};s.events[n]||(s.events[n]={name:n,values:[]}),s.events[n].values.push({start:r,end:i,duration:i-r,context:o,type:e}),s.duration+=i-r,s.increment+=1,this.timings.set(t,s)}getResults(){const e=this.timings;for(const[t,n]of this.timings){const o=n;o.duration=Object.values(n.events).map((e=>e.values.reduce(((e,t)=>e+t.end-t.start),0))).reduce(((e,t)=>e+t),0),e.set(t,o)}return{monitoredTaps:this.monitoredTaps,tapables:this.tapables,hooks:this.hooks,timings:e}}getPromiseTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,mr(r),i,v.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,mr(r),i,v.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=v.now(),s=t.apply(this,r);return this.saveResult(e,n,o,mr(r),i,v.now()),s}}getTapPatch(e,t,n,o){switch(e){case"promise":return this.getPromiseTapPatch(e,t,n,o);case"async":return this.getAsyncTapPatch(e,t,n,o);default:return this.getDefaultTapPatch(e,t,n,o)}}newTap(e,t,n,o){return(r,i)=>{const s="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${s}`;if(this.monitoredTaps[u])return n.call(o,r,i);this.monitoredTaps[u]=!0;const c=this.getTapPatch(e,i,s,t);return n.call(o,r,c)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(rr)||(this.hooks[e]||(this.hooks[e]=[]),this.hooks[e].includes(t)||(this.hooks[e].push(t),this.replaceTaps(t,n)))}patchHooks(e){const t=e.constructor.name,n=Object.keys(e.hooks).filter((e=>!this.ignoredHooks.includes(e)&&!this.hooks[t]?.includes(e)));for(const o of n)this.patchHook(t,o,e.hooks[o])}checkNewHooks(){for(const e of this.tapables)this.patchHooks(e)}throughHooks(e){this.tapables.includes(e)||this.tapables.push(e),this.patchHooks(e)}}const Ar=e=>async t=>{const n=e.getLogger(rr),o={name:rr},r=new Mr(e.buildRoot),i=new Pr(e.buildRoot),s=n.time("parse compiler hooks");r.throughHooks(t),s.end(),t.hooks.thisCompilation.tap(o,(e=>{const t=n.time("parse compilation hooks");r.throughHooks(e),t.end(),e.hooks.buildModule.tap(o,(t=>{i.startModule(t,e)})),e.hooks.succeedModule.tap(o,(t=>{i.doneModule(t,e)})),e.hooks.failedModule&&e.hooks.failedModule.tap(o,(t=>{i.doneModule(t,e)}))})),t.hooks.afterEmit.tapPromise(o,(async()=>{const{timings:t}=r.getResults(),{loaders:n,modules:o}=i.getResults();await e.asyncHook("timings",{tapables:t,loaders:n,modules:o})}))},Cr={filters:nr},Nr=({options:e,context:t,stores:n})=>{const o=t.getLogger(rr);let r=0;((e,t)=>{e.addMetric=e=>{t.metrics.add(e)}})(t,n);const i=((e,t)=>{const n=e[or],o=ir(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enableDefaultPrefix:!0,enableTracing:!1,filters:nr,tags:[],...e[or],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[],a={name:rr,enforce:"pre",esbuild:jr(t,o),webpack:Ar(t),rspack:Ar(t)},u=o.time("build",{start:!1}),c=i.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,p;const l=async()=>{if(!n.metrics.size)return;const e=o.time("aggregating collected metrics"),r=(()=>{const e=new Set(n.metrics);n.metrics.clear();const o=sr(t,i.tags);return ur(e,i.timestamp,i.filters,o,i.prefix)})();await t.asyncHook("metrics",r),e.end();const s=o.time("sending collected metrics to Datadog");await kr(r,{apiKey:t.auth.apiKey,site:t.auth.site},o),s.end()},f=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-r;const e=o.time("aggregating metrics"),n=i.timestamp,s=o.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,c=new Map,d=new Map,p=new Map;for(const e of i){for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");p.has(n)||p.set(n,[]),p.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`entryName:${e}`))),d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");p.has(r)&&o.push(...p.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of i){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(p,n);s.end();const u=o.time("aggregate plugins metrics"),c=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"plugins.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values()){let e=0,r=0;for(const i of Object.values(o.events)){let s=0;r+=i.values.length;for(const t of i.values){const n=t.end-t.start;s+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,s]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,i.values.length]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(d?.tapables,n);u.end();const l=o.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(d?.loaders,n);l.end();const m=new Set([...a,...c,...f]),g=sr(t,i.tags),h=ur(m,n,i.filters,g,i.prefix);await t.asyncHook("metrics",h),e.end();const y=o.time("outputing report");wr(t,o,d),y.end();const b=o.time("sending metrics to Datadog");await kr(h,{apiKey:t.auth.apiKey,site:t.auth.site},o),b.end()},m={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){u.resume(),t.build.start=t.build.start||Date.now(),e[or]?.timestamp||(i.timestamp=ir(t.build.start))},buildEnd(){u.end(),r=Date.now()},async timings(e){d=e,p&&await f()},async buildReport(e){p=e,!d&&c||await f()},async flush(){await l()}};return i.enableTracing&&s.push(a),s.push(m),s},Tr="output",Or="datadog-output-plugin",Rr=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,_r=e=>{const t=void 0===e;return{build:Rr("build",e?.build??t),bundler:Rr("bundler",e?.bundler??t),dependencies:Rr("dependencies",e?.dependencies??t),errors:Rr("errors",e?.errors??t),logs:Rr("logs",e?.logs??t),metrics:Rr("metrics",e?.metrics??t),timings:Rr("timings",e?.timings??t),warnings:Rr("warnings",e?.warnings??t)}},Fr=(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}))}))},Lr=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},zr=({options:e,context:t})=>{const n=t.getLogger(Or),o=(e=>({path:"./",...e[Tr],files:_r(e[Tr]?.files)}))(e),r=(e,r)=>{const i=o.files[e];if(!r||!1===i)return;t.queue((async()=>{const e=n.time(`output ${i}`),c=((e,t,n)=>{const o=u.isAbsolute(t)?t:u.resolve(e,t);return u.resolve(o,n)})(t.bundler.outDir,o.path,i);let d;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await $e(u.dirname(e));const n=s.createWriteStream(e),o=new a(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(c,e)}catch(e){d=e}d?n.error(`Failed writing ${i}: ${d}`):n.debug(`Wrote "./${u.relative(t.buildRoot,c)}"`),e.end()})())};return[{name:Or,buildReport(e){const t=n.time("serialize report"),o=Y(e);t.end(),r("build",{bundler:o.bundler,metadata:o.metadata,start:o.start,end:o.end,duration:o.duration,writeDuration:o.writeDuration,entries:o.entries,outputs:o.outputs}),r("logs",o.logs),r("timings",o.timings),r("dependencies",o.inputs),r("errors",o.errors),r("warnings",o.warnings)},metrics(e){r("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{r("bundler",e.metafile)}))}},rspack:Fr(n,(e=>{r("bundler",e)})),rollup:Lr((e=>{r("bundler",e)})),vite:Lr((e=>{r("bundler",e)})),webpack:Fr(n,(e=>{r("bundler",e)}))}]},Br="rum",Kr="datadog-rum-plugin",qr=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")});`,Ur="datadog-rum-privacy-plugin";const Vr=(e,t)=>{const n=t.getLogger(Ur),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:Ur,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(e,t){try{const n=function(e){if("rspack"===e?.framework||"webpack"===e?.framework)switch(typeof e.inputSourceMap){case"undefined":return;case"string":return e.inputSourceMap;default:return JSON.stringify(e.inputSourceMap)}}(this.getNativeBuildContext?.()),s=$({id:t,code:e,map:n},o);return 0===s.privacyDictionarySize?{code:e}:(r+=s.privacyDictionarySize,i++,s)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${r} entries across ${i} files`,{forward:!0,context:{dictionaryEntryCount:r,fileCount:i}})}}},Hr=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Wr=(e,t)=>{const n=e.sdk;if(n.clientToken)return Hr(e);if(!t.auth.apiKey||!t.auth.appKey)throw new Error('Missing "auth.apiKey" and/or "auth.appKey" to fetch "rum.sdk.clientToken".');return async()=>{let o;try{const e=await H({url:`https://api.${t.auth.site}/api/v2/rum/applications/${n.applicationId}`,type:"json",auth:t.auth});o=e.data?.attributes?.client_token}catch(e){throw new Error(`Could not fetch the clientToken: ${e.message}`)}if(!o)throw new Error("Missing clientToken in the API response.");return Hr({...e,sdk:{clientToken:o,...n}})}},Jr=e=>{const n=t.bold.red,o=e[Br]||{},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},Gr=e=>{const t=e[Br]||{},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},Yr=e=>{const n=t.bold.red,o=e[Br]||{},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},Qr=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=Jr(e),r=Gr(e),i=Yr(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 ${Kr}.`);const s={...e[Br],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(Kr)),o=[];if(n.sourceCodeContext&&t.inject({type:"code",position:De.BEFORE,injectIntoAllChunks:!0,value:qr(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:De.MIDDLE,value:u.join(j,"./rum-browser-sdk.js")}),t.inject({type:"code",position:De.MIDDLE,value:Wr(n,t)})),n.privacy){t.inject({type:"file",position:De.BEFORE,value:u.join(j,"./privacy-helpers.js")});const e=Vr(n.privacy,t);o.push(e)}return o},Zr="datadog-analytics-plugin",Xr=({context:e})=>{const t=e.getLogger(Zr);return[{name:Zr,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}`)}})())}}]},ei="datadog-async-queue-plugin",ti=e=>{const{context:t,stores:n}=e,o=t.getLogger(ei),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:ei,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},ni=async(e,t,n)=>{const o=[],r=e.initialOptions.entryPoints,i=[],s=[];if(Array.isArray(r))for(const e of r){const t=e&&"object"==typeof e?e.in:e;i.push({path:t})}else r&&"object"==typeof r&&i.push(...Object.entries(r).map((([e,t])=>({name:e,path:t}))));const a=i.flatMap((e=>{return(t=e.path,t.includes("*")?h.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const i=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});i.errors.length&&s.push(...i.errors.map((e=>e.text))),i.path&&o.push({name:n.name,resolved:i.path,original:n.path})}));for(const e of s)n.error(e);return await Promise.all(a),o},oi=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,ri=/(\?|%3F|\|)+/gi,ii=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=ui(e),oi.lastIndex=0,oi.exec(t)?.[1]||"unknown");var t},si=["unknown","commonjsHelpers.js",`vite${u.sep}preload-helper.js`],ai=(e,t,n)=>{const o=new Set;for(const n of e){const e=ui(n);G(n)||e===t||si.includes(e)||o.add(e)}return o},ui=e=>e.split("!").pop().split(ri).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),ci=(e,t)=>G(t)?M:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(u.sep),o=e.split(u.sep).filter(((e,t)=>e===n[t])).join(u.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(ri).shift().replace(/^((\.\.?)?[/\\])+/g,""),di=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[En(t,e),n]))),pi=(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 ni(n,e,t));for(const t of r){const n=ci(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}s.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),s=e.bundler.outDir,a=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const c=[],d=[],p=[],l=[],f=[],m={},g={},h=t.time("indexing metafile data"),y=di(n.metafile.inputs,a),b=di(n.metafile.outputs,a);h.end();const w=e=>{if(!G(e))return e;const t=y[En(a,e)];if(!t)return e;const n=t.imports.find((e=>!G(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(G(e))continue;const n=En(a,e),o={name:ci(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:ii(e)};m[n]=o,c.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=En(a,e),i=ci(s,n),u=[];for(const e of Object.keys(r.inputs)){if(G(e))continue;const n=m[En(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!u.length){const e=m[En(a,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}u.push(e)}const c={name:i,filepath:n,inputs:u,size:r.bytes,type:ii(n)};if(g[n]=c,"map"===c.type&&l.push(c),d.push(c),!r.entryPoint)continue;const f=m[En(a,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...c,name:o.get(f.name)||f.name,outputs:[c],size:c.size};p.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of l){const n=g[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:g,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!G(e)&&!e.match(E),I=(e,n,o={})=>{if(!S(e))return o;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),o;if(o[r.filepath])return o;o[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),o;if(!i.imports||!i.imports.length)return o;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),d=i?u.dirname(e):a,p=En(d,t.path);if(t.external){if(S(t.path)){const e=i?p:t.path,n=x.inputs.report[e]||{filepath:e,name:ci(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),c.includes(n)||c.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(p,n,o)}return o},D=t.time("looping through entries");for(const e of p){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const j=t.time("aggregate dependencies and dependents");for(const e of c){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?u.dirname(e.filepath):a,i=En(r,o.path);let s;if(o.external){const e=n?i:o.path;s=x.inputs.report[e]}else s=x.inputs.report[i];s?(e.dependencies.add(s),s.dependents.add(e)):t.debug(`Could not find input file of ${o.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}j.end(),e.build.outputs=d,e.build.inputs=c,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),li=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),i=t.time("filling inputs and outputs",{start:!1}),a=t.time("completing dependencies and dependents",{start:!1}),u=t.time("filling dependencies and dependents",{start:!1}),c=t.time("filling sourcemaps inputs",{start:!1}),d=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),d.clear(),p.clear(),l.clear()},onLog(t,n){"warn"===t&&e.build.warnings.push(n.message||n.toString())},renderError(t){t&&e.build.errors.push(t.message)},moduleParsed(e){n.resume();const t=ui(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=ai(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=ai(new Set([...e.dynamicImporters,...e.importers]),t);for(const e of i)o.dependents.add(e);for(const e of r)o.dependencies.add(e);f.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,m){o.resume();const g=n.dir?En(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=ui(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=ui(t),o=f.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),f.set(n,o))}}a.end(),i.resume();for(const[e,n]of Object.entries(m)){const o=En(g,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),i=p.get(o)||{name:e,filepath:o,inputs:[],size:r,type:ii(e)};if("map"===i.type&&y.add(i),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(ui(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=s.statSync(e).size}catch(e){n=t.renderedLength}const o=d.get(e)||{name:ci(g,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:ii(e)};i.inputs.push(o),d.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=ui(e);if(!f.has(n)){b.set(En(g,n),i);continue}if(d.has(n)){t.debug(`Input report already there for ${n} from ${i.name}.`);continue}const o=d.get(n)||{name:ci(g,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};i.inputs.push(o),d.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&h.add({...i,name:n.name,size:0,outputs:[i]}),p.set(i.filepath,i)}i.end();for(const[e,n]of b){const o=p.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of d){const o=f.get(e);if(o){for(const e of o.dependencies){const o=d.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${ci(g,e)} of ${n.name}`)}for(const e of o.dependents){const o=d.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${ci(g,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){c.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=p.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}c.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=ci(g,e),r=p.get(e);if(!r)return d.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[ci(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(En(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}":"${ci(g,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(d.values()),e.build.outputs=Array.from(p.values()),e.build.entries=Array.from(l.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},fi=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,c=new Map,d=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||G(e)),g=e=>e.replace(/(^external[^"]+"|"$)/g,""),h=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=ui(e);t.add(n),n.startsWith("external ")&&t.add(g(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(d.has(e)){const n=d.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else d.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=ui(t.request);if(d.has(n))return d.get(n);if(e.context){const t=En(ui(e.context),n);if(d.has(t))return d.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],i=[],s=[],a.clear(),u.clear(),d.clear(),l.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),i=n.time("indexing modules");for(const e of t)h(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=ci(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:ii(t)};r.push(u),a.set(t,u),w(n)&&a.set(g(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=l.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,d=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>En(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"===ii(e))continue;const t=c.get(e)||new Set;for(const e of n)t.add(e);c.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of d){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:En(e.bundler.outDir,t.name),type:ii(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){p.push(o);continue}const r=c.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of p){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return new Set;t.add(e);const n=new Set(e.chunks);for(const o of e.childrenIterable||[]){const e=v(o,t);for(const t of e)n.add(t)}return n};for(const[o,r]of t.entrypoints){const t=new Map,i=new Map;let a=0;const c=v(r),d=Array.from(c).flatMap(l),p=r.chunks.filter((e=>h.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===ii(e)));for(const e of d){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)i.has(e.filepath)||i.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:p?En(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:p?ii(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)}))},mi="datadog-build-report-plugin",gi=e=>{const{context:t}=e,n=t.getLogger(mi);return[{name:mi,enforce:"post",esbuild:pi(t,n),rspack:fi(t,mi,n),webpack:fi(t,mi,n),vite:li(t,n),rollup:li(t,n)}]},hi="datadog-bundler-report-plugin",yi=(e,t)=>t?u.isAbsolute(t)?t:u.resolve(e,t):"",bi=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?u.dirname(e.file):void 0)).filter(Boolean)},wi=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=yi(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},vi=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=bi(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=In(r,process.cwd())),e.bundler.outDir=yi(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),$i=e=>{const{context:t}=e,n=t.getLogger(hi);return[{name:hi,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=yi(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=yi(t.buildRoot,u.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:wi(t),rspack:wi(t),vite:vi(t),rollup:{options(e){let n;if("output"in e){const t=bi(e.output);n=In(t,process.cwd())}const o=(e=>{const t=new Set;if(e.input){const n=Array.isArray(e.input)?e.input:"object"==typeof e.input?Object.values(e.input):[e.input];for(const e of n){if("string"!=typeof e)throw new Error("Invalid input type");t.add(u.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=En(process.cwd(),n);const e=In([n,...o],process.cwd());t.buildRoot=e===u.sep?process.cwd():e}else t.buildRoot=In(o,process.cwd()),t.bundler.outDir=u.resolve(process.cwd(),"dist");t.hook("buildRoot",t.buildRoot)},buildStart(e){t.bundler.rawConfig=e},renderStart(e){t.bundler.rawConfig.outputs=t.bundler.rawConfig.outputs||[],t.bundler.rawConfig.outputs.push(e),t.hook("bundlerReport",t.bundler);const o=bi(e);In(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.")}}}]},ki="datadog-custom-hooks-plugin",xi=e=>{const{context:t}=e,n=t.getLogger(ki),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:ki,enforce:"pre"}]};class Ei{constructor(e){this.trackedFilenames=new Map;for(const t of e){const e=this.getFilename(t),n=this.trackedFilenames.get(e);n?n.push(t):this.trackedFilenames.set(e,new Array(t))}}displaySource(e){return e.length<=40?e:`[...]${e.slice(-35)}`}matchSourcemap(e,t){const n=xe(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 Si=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await Ii(e);for(const e of t)if(e.name===n)return ee(e.refs.push);return ee(t[0].refs.push)},Ii=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},Di=async e=>e.revparse("HEAD"),ji=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),Pi=async e=>e.branch(),Mi=async e=>e.show(["-s","--format=%s"]),Ai=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),Ci="datadog-git-plugin",Ni=e=>{const{options:t,context:n}=e,o=n.getLogger(Ci),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=k(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return k(t)})(u.dirname(e));if(0===(await t.getRemotes(!0)).length)return o.warn("No git remotes available, skipping git plugin. This is expected for a repository that has not been pushed yet."),void r.end();const i=await(async e=>{const t=[Di(e),Pi(e),Mi(e),Ai(e),ji(e),Si(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,c,d,p,l,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:c,date:d},committer:{name:p,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new Ei(s)}})(t);n.git=i,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:Ci,enforce:"pre",buildRoot(e){if(Q(t))try{r.resume();const t=Sn(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}`)}}}]},Ti="datadog-injection-plugin",Oi=/^https?:\/\//,Ri=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],_i=t.bold.yellow,Fi=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(En(t,e)),Li=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(Oi)?await(async(e,t=5e3)=>{let n;return Promise.race([H({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await Fi(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} - ${X(r)}`;e.fallback?(t.debug(`Fallback for "${s}": ${i.toString()}`),o=await Li(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},zi=(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`},Bi=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 Li(i,t,n);if(e){const t=i.position||De.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)},Ki=e=>e instanceof Error&&"code"in e,qi=e=>Ri.includes(e),Ui=(e,t,n)=>{e.warn(`"${_i(t)}" files are not supported (${_i(n)}).`)},Vi=s.promises,Hi=(e,t,n)=>({setup(o){const{onStart:i,onResolve:a,onLoad:c,onEnd:d,esbuild:p,initialOptions:f}=o,m=[],g=`${t.bundler.name}.${De.MIDDLE}.${M}.js`,h=s.realpathSync(l.tmpdir()),y=u.resolve(h,g),b=new RegExp(`${g}$`),w=f.inject;f.inject=w?[...w]:[],f.inject.push(y),i((async()=>{m.push(...await ni(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await $e(u.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),a({filter:b},(async e=>({path:e.path,namespace:Ti}))),c({filter:b,namespace:Ti},(async()=>({contents:zi(n,{position:De.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),d((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=zi(n,{position:De.BEFORE}),i=zi(n,{position:De.AFTER}),s=zi(n,{position:De.BEFORE,onAllChunks:!0}),a=zi(n,{position:De.AFTER,onAllChunks:!0});if(!(r||i||s||a))return;const c=[];for(const[n,d]of Object.entries(o.metafile.outputs)){const o=d.entryPoint&&m.some((e=>e.resolved.endsWith(d.entryPoint))),l=o?r:s,f=o?i:a;if(!l&&!f)continue;const g=En(t.buildRoot,n),{base:h,ext:y}=u.parse(g);qi(y)?c.push((async()=>{try{const e=await Vi.readFile(g,"utf-8"),t=await p.transform(e,{loader:"default",banner:l,footer:f});await Vi.writeFile(g,t.code)}catch(t){if(!Ki(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${g}: ${t}`)}})()):Ui(e,y,h)}await Promise.all(c)}))}}),Wi=M,Ji="?inject-proxy",Gi=(e,t)=>({banner(n){const o=zi(t,{position:De.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return qi(i)?o:(Ui(e,i,r),"")},async resolveId(e,n,o){if(G(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&zi(t,{position:De.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}${Ji}`}return null},load(e){if(G(e))return zi(t,{position:De.MIDDLE});if(e.endsWith(Ji)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(Wi)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=zi(t,{position:De.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return qi(i)?o:(Ui(e,i,r),"")}}),Yi=(e,t,n,o,r)=>i=>{const a=new WeakMap,c=e.sources.ConcatSource,d=n.bundler.name,p=u.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${d}.${De.MIDDLE}.${M}.js`);ke(p,"");i.hooks.shutdown.tap(Ti,(()=>{var e;e=p,s.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await Bi(t,o,r,n.buildRoot)};i.hooks.beforeRun.tapPromise(Ti,l),i.hooks.watchRun.tapPromise(Ti,l),i.hooks.compilation.tap(Ti,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:Ti,stage:o},(()=>{const e=zi(r,{position:De.BEFORE}),o=zi(r,{position:De.AFTER}),i=zi(r,{position:De.BEFORE,onAllChunks:!0}),s=zi(r,{position:De.AFTER,onAllChunks:!0});for(const r of n.chunks){let d=e,p=o;if(r.canBeInitial()||(d=i,p=s),""!==d||""!==p)for(const e of r.files){const{base:o,ext:r}=u.parse(e);qi(r)?n.updateAsset(e,(e=>{const t=a.get(e);if(!t||t.banner!==d||t.footer!==p){const t=new c(d,"\n",e,"\n",p);return a.set(e,{source:t,banner:d,footer:p}),t}return t.source})):Ui(t,r,o)}}}))}));const f=(e=>{const n={import:[p]},o=e=>{for(const[n,o]of Object.entries(e))"object"==typeof o?(o.import=o.import||[],o.import.unshift(p)):"string"==typeof o?e[n]=[p,o]:Array.isArray(o)?o.unshift(p):t.error("Invalid entry type: "+typeof o)};return e?"function"==typeof e?async()=>{const t=await e();return o(t),t}:"object"!=typeof e?"string"==typeof e?[n,e]:(t.error("Invalid entry type: "+typeof e),e):(o(e),e):{ddHelper:n}})(i.options.entry);i.options.entry=f},Qi=e=>{const{bundler:t,context:n}=e,o=n.getLogger(Ti),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++oe}`,e)};const s={name:Ti,enforce:"post",esbuild:Hi(o,n,i),webpack:Yi(t,o,n,r,i),rspack:Yi(t,o,n,r,i),rollup:Gi(o,i),vite:{...Gi(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>zi(i,{position:De.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:A},handler:()=>({code:zi(i,{position:De.MIDDLE})})}:s.buildStart=async()=>{await Bi(o,r,i,n.buildRoot)},[s]},Zi="datadog-true-end-plugin",Xi=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=async()=>{await t.asyncHook("flush")},r=()=>{t.hook("syncTrueEnd")},i=async()=>{r(),await n(),await o()},s=e=>{e.hooks.shutdown.tapPromise(Zi,i)},a={async writeBundle(){},async closeBundle(){await i()}};return[{name:Zi,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n(),await o()})),e.onDispose((()=>{r()}))}},vite:a,rollup:a,rspack:s}]},es={[or]:Cr},ts=t.bold.red;var ns="3.2.1";const os=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,r)=>{const i=Date.now(),s=((e={})=>{const t=(e=>{const t=[];return void 0===e||void 0!==e.version&&"string"!=typeof e.version&&t.push("metadata.version must be a string"),t})(e.metadata),n=L("SITE"),o={site:B(n,"DATADOG_SITE/DD_SITE",t)??B(e.auth?.site,"auth.site",t)??T};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:L("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:L("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=O);const a=process.env.BUILD_PLUGINS_ENV||"production",u=C.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,d=r.framework,p={bundler:{name:d,version:c},env:u,metadata:s.metadata||{},packageName:`@datadog/${d}-plugin`,version:n},l={errors:[],logs:[],metrics:new Set,queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{addMetric:()=>{throw new Error("AddMetric function called before it was initialized.")},auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:ue(n,o,t.logLevel),asyncHook:()=>{throw new Error("AsyncHook function called before it was initialized.")},hook:()=>{throw new Error("Hook function called before it was initialized.")},inject:()=>{throw new Error("Inject function called before it was initialized.")},plugins:[],queue:()=>{throw new Error("Queue function called before it was initialized.")},sendLog:W(n),start:e,version:n.version}})({start:o,options:s,data:p,stores:l}),m=f.getLogger("factory"),g=m.time("Plugins initialization",{start:i});f.pluginNames.push(O);const h=[];h.push(["analytics",Xr],["async-queue",ti],["build-report",gi],["bundler-report",$i],["custom-hooks",xi],["git",Ni],["injection",Qi],["true-end",Xi]),s.customPlugins&&h.push(["custom",s.customPlugins]);const y=[["apps",me,Un],["error-tracking",Vn,lo],["live-debugger",fo,tr],["metrics",or,Nr],["output",Tr,zr],["rum",Br,Qr]];for(const[e,t,n]of y)fe(s,t,m)&&h.push([e,n]);for(const[e,n]of h)f.plugins.push(...pe(f,n,e)({bundler:t,context:f,options:s,data:p,stores:l}));return(e=>{const t=[];for(const n of F){const o=z(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>_(e))).join(" and "),i=_(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>R(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: ${ts(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),g.end(),f.plugins}))})({bundler:x,version:ns}).esbuild,rs=ns,is=es;export{os as datadogEsbuildPlugin,is as helpers,rs as version};
|
|
2
2
|
//# sourceMappingURL=index.mjs.map
|