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