@datadog/esbuild-plugin 3.1.3-dev.2 → 3.1.4
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/apps-runtime.mjs +1 -0
- package/dist/src/index.d.ts +0 -2
- package/dist/src/index.js +1 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/index.mjs +2 -2
- package/package.json +2 -3
|
@@ -0,0 +1 @@
|
|
|
1
|
+
class e extends Error{constructor(e,t,n){super(e),this.functionName=t,this.statusCode=n,this.name="BackendFunctionError"}}const t=async(t,n)=>{const r={functionName:t,args:n};let o,s;try{o=await fetch("/__dd/executeAction",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)})}catch(n){throw new e(`Network error while executing backend function "${t}": ${n instanceof Error?n.message:String(n)}`,t)}if(!o.ok){let n=`Backend function "${t}" failed with status ${o.status}`;try{const e=await o.text();e&&(n+=`: ${e}`)}catch{}throw new e(n,t,o.status)}try{s=await o.json()}catch(n){throw new e(`Failed to parse response from backend function "${t}": ${n instanceof Error?n.message:String(n)}`,t,o.status)}if(!s.success)throw new e(`Backend function "${t}" returned an error: ${s.error}`,t,o.status);return s.result.data};let n=0;const r=(t,r)=>{const o="undefined"!=typeof crypto&&crypto.randomUUID?crypto.randomUUID():(n+=1,`req-${Date.now()}-${n}`);return new Promise(((n,s)=>{let a;function i(){window.removeEventListener("message",c),clearTimeout(a)}function c(r){if(!function(e,t){return null!==e&&"object"==typeof e&&"type"in e&&"app-builder:run-query:response"===e.type&&"requestId"in e&&e.requestId===t}(r.data,o))return;i();const a=r.data;a.success?n(a.result.data):s(new e(a.error??`Backend function "${t}" failed`,t))}window.addEventListener("message",c),a=setTimeout((()=>{i(),s(new e(`Backend function "${t}" timed out waiting for response`,t))}),12e4),window.parent.postMessage({type:"app-builder:run-query",requestId:o,queryName:t,args:r},"*")}))};function o(){return function(){try{return"undefined"!=typeof window&&window.parent!==window}catch{return!0}}()?r:t}globalThis.DD_APPS_RUNTIME={executeBackendFunction:async function(e,t){return o()(e,t)}};
|
package/dist/src/index.d.ts
CHANGED
package/dist/src/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";var e=require("unplugin"),t=require("chalk"),n=require("async-retry"),o=require("stream"),r=require("zlib"),s=require("buffer"),i=require("fs/promises"),a=require("fs"),u=require("json-stream-stringify"),c=require("path"),d=require("jszip"),p=require("os"),l=require("glob"),f=require("crypto"),m=require("pretty-bytes"),h=require("p-queue"),g=require("perf_hooks"),y=require("@datadog/js-instrumentation-wasm"),b=require("simple-git"),w=require("esbuild");const $=t.bold.green,v=t.bold.yellow,k=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],S=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],E=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},x="__datadog-helper-file",D=new RegExp(x),P=["development","production","test"],j="datadog-build-plugins",C=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),R=async e=>{const{getForm:t,defaultHeaders:n={},zip:s=!0}=e,i=await t(),a=new Request("fake://url",{method:"POST",body:i}),u=o.Readable.fromWeb(a.body);return{data:s?u.pipe(r.createGzip()):u,headers:{"Content-Encoding":s?"gzip":"multipart/form-data",...n,...Object.fromEntries(a.headers.entries())}}},A=[400,401,403,404,405,409,413],O=e=>{const{auth:t,url:o,method:r="GET",getData:s,type:i="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 s){const{data:t,headers:o}=await s();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=await a.json(),n=e?.errors?.map((e=>e.title&&e.detail?`${e.title}: ${e.detail}`:e.title?e.title:e.detail?`detail: ${e.detail}`:"")).filter((e=>e.length>0)).join("\n");n&&(t+=`\n${n}`)}catch{}if(A.includes(a.status))return e(new Error(t)),{};throw new Error(t)}try{let e;return e="json"===i?await a.json():await a.text(),e}catch(t){return e(t),{}}}),a)},T=e=>({message:t,context:n})=>O({retries:2,minTimeout:100,url:"https://browser-http-intake.logs.datadoghq.com/v1/input/pub44d5f4eb86e1392037b7501f7adc540e",method:"POST",type:"json",getData:async()=>{const o={ddsource:e.packageName||j,message:t,service:"build-plugins",team:"language-foundations",env:e.env,version:e.version,bundler:{name:e.bundler.name,version:e.bundler.version},metadata:e.metadata,...n};return{data:JSON.stringify(o),headers:{"Content-Type":"application/json"}}}}),M=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),N=e=>e.includes(x),_=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},I=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},F=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(),s=n.getUTCSeconds(),i=n.getUTCMilliseconds(),a=`${t?`${t}d `:""}${o?`${o}h `:""}${r?`${r}m `:""}${s?`${s}s`:""}`.trim();return`${a}${!a||i?` ${i}ms`:""}`.trim()},z=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),r=Math.min(10,Math.floor(o/2)),s=o-r;return`${e.slice(0,r)}${n}${e.slice(-s)}`},L=(e="")=>{try{if(!e||e.startsWith("git@"))return e;const t=new URL(e),n="/"===t.pathname?"":t.pathname;return`${t.protocol?`${t.protocol}//`:""}${t.host}${n}`}catch{return e}},q=e=>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 K=0;const B={debug:0,info:1,warn:2,error:3,none:4},U=e=>e.split(">").map(M).join(">"),H=(e,n,o,r)=>{const s=U(e);return(i,a="debug",{forward:u,context:c}={})=>{let d=t.dim,p=console.log;"error"===a?(d=t.red,p=console.error):"warn"===a?(d=t.yellow,p=console.warn):"info"===a&&(d=t.cyan,p=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${s}]`,f="string"==typeof i?i:JSON.stringify(i,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=T(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){H(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}B[a]>=B[r]&&p(`${d(l)} ${f}`)}},W=(e,n,o)=>(r,s={})=>{const{level:i="debug",start:a=!0,log:u=!0,tags:c=[]}=s,d={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${i}`],logLevel:i,total:0};n.push(d);const p=()=>d.spans.filter((e=>!e.end)),l=n=>{p().length||(!d.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),d.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const s=p();if(s?.length){s.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of s)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),l(e)}return{timer:d,resume:l,end:e=>{f(e,!1);const n=d.spans.reduce(((e,t)=>e+(t.end-t.start)),0);d.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(F(n))}`,i)},pause:f,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=p();for(const n of t)n.tags.push(...e)}else d.tags.push(...e)}}},J=(e,t,n="warn")=>o=>{const r=H(o,e,t,n);return{getLogger:r=>J(e,t,n)(`${U(o)}>${r}`),time:W(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)}},V=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],G=(e,t,n,o)=>{const r=n=>function(...r){const s=o.time(`${e} | ${t}`,{log:!1,tags:["type:hook",`hook:${t}`]}),i=n.apply(this,r);return i instanceof Promise?i.finally((()=>{s.end()})):(s.end(),i)};return"object"==typeof n&&null!==n&&"handler"in n?{...n,handler:r(n.handler)}:r(n)},Y=(e,t,n)=>{const o=e.getLogger(j);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),s=t(e).map((e=>((e,t)=>{const n={...e},o=M(e.name);for(const r of V){const s=e[r];s&&(n[r]=G(o,r,s,t))}return n})(e,o))),i=s.map((e=>`plugin:${e.name}`));return r.tag(i),r.end(),s}},Q=async e=>i.rm(e,{force:!0,maxRetries:3,recursive:!0}),X=async e=>i.mkdir(e,{recursive:!0}),Z=(e,t)=>{var n;n=c.dirname(e),a.mkdirSync(n,{recursive:!0}),a.writeFileSync(e,t,{encoding:"utf-8"})},ee=e=>a.readFileSync(e,{encoding:"utf-8"}),te=e=>{try{return a.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},ne=async(e,t)=>{if("function"==typeof a.openAsBlob){const n=await a.openAsBlob(e,{type:t.contentType});return new s.File([n],t.filename)}{const n=o.Readable.toWeb(a.createReadStream(e)),r=await new Response(n).blob();return new s.File([r],t.filename,{type:t.contentType})}},oe=async e=>{const t={empty:!1,exists:!0};try{const{size:n}=await i.stat(e);0===n&&(t.empty=!0)}catch(e){if("ENOENT"!==e.code)throw e;t.exists=!1}return t},re="apps",se="datadog-apps-plugin",ie="api/unstable/app-builder-code/apps",ae="datadog-apps-assets.zip",ue=async(e,t)=>{const n=(await Promise.all(e.map((e=>l.glob(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),s=o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o}}));return s},ce=[".ts",".js",".tsx",".jsx"];const de=(e,t)=>N(t)?x:t.startsWith(e)||c.isAbsolute(t)?t:c.resolve(e,t),pe=(e,t)=>{let n,o=de(process.cwd(),e);for(;!n;){const e=c.resolve(o,t);if(te(e)&&(n=e),o=o.split(c.sep).slice(0,-1).join(c.sep),[c.sep,""].includes(o))break}return n},le=(e,t)=>{const n=[...e].map((e=>de(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},fe=t.bold.red,me=t.bold.yellow,he=e=>{const t=pe(e,"package.json");if(t)try{const e=ee(t);return JSON.parse(e)}catch(e){return}},ge=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=he(e);o||t.warn(me("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(fe("Unable to determine the app name to compute the app identifier."));const s=((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=L(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);s||t.error(fe("Unable to determine the git remote to compute the app identifier."));const i=n?.identifier||((e,t)=>{if(!e||!t)return;const n=`${e}:${t}`;return f.createHash("md5").update(n).digest("hex")})(s,r);return i&&r||t.error(fe("Unable to compute the app identifier.")),{identifier:i,name:r}},ye=t.green.bold,be=t.yellow.bold,we=t.cyan.bold,$e=t.bold,ve=(e,t={},n)=>async()=>{const o=await ne(e,{contentType:"application/zip",filename:ae});return R({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ae);const t=S("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},ke=async(e,t,n)=>{const r=[],s=[];if(!t.apiKey||!t.appKey)return r.push(new Error("Missing authentication token, need both app and api keys.")),{errors:r,warnings:s};if(!t.identifier)return r.push(new Error("No app identifier provided")),{errors:r,warnings:s};const i=(a=t.site,u=t.identifier,S("APPS_INTAKE_URL")||`https://api.${a}/${ie}/${u}/upload`);var a,u;const c=C({bundler:t.bundlerName,plugin:"apps",version:t.version}),d=q({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),p=`an archive of:\n - ${ye(e.assets.length.toString())} files\n - ${ye(m(e.size))}\n\nWith the configuration:\n${d}`;if(t.dryRun)return n.error(`\n${we("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:r,warnings:s};try{const r=await O({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:ve(e.archivePath,c,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${be(`${t}/5`)}): ${e.message}`;s.push(o),n.warn(o)}});if(n.debug(`Uploaded ${p}\n`),r.version_id&&r.application_id&&r.app_builder_id){const{version_id:e,application_id:o,app_builder_id:s}=r,i=`https://api.${t.site}/api/unstable/app-builder-code/apps/serve/${o}/v/${e}/index.html`,a=`https://app.${t.site}/app-builder/apps/${s}`;n.info(`Your application is available at:\n${$e("Standalone :")}\n ${we(i)}\n\n${$e("AppBuilder :")}\n ${we(a)}`)}const a=S("APPS_VERSION_NAME")?.trim();if(a){const e=((e,t)=>`https://api.${e}/${ie}/${t}/release/live`)(t.site,t.identifier);await O({auth:{apiKey:t.apiKey,appKey:t.appKey},url:e,method:"PUT",type:"json",getData:async()=>({data:o.Readable.from(JSON.stringify({version_id:a})),headers:{"Content-Type":"application/json",...c}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${be(`${t}/5`)}): ${e.message}`;s.push(o),n.warn(o)}}),n.info(`Released version ${$e(a)} to live.`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));r.push(t)}return{errors:r,warnings:s}};function Se(e){try{return require.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}const Ee="import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';",xe=" 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 De(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),Se(n)&&o.push(Ee),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(xe),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 Pe(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function je(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:[Pe("dd-backend-resolve",t)]}}async function Ce(e,t,n,o,r){const s=`virtual:dd-backend-dev:${t.name}`,i=function(e,t,n,o){const r=[];return r.push(`import { ${e} } from ${JSON.stringify(t)};`),Se(o??process.cwd())&&r.push(Ee),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(xe),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.entryPath,n,o);r.debug(`Bundling backend function "${t.name}" from ${t.entryPath}`);const a=je(o,{[s]:i}),u=await e({...a,build:{...a.build,write:!1,rollupOptions:{...a.build.rollupOptions,input:s,output:a.build.rollupOptions.output}}}),c=Array.isArray(u)?u[0]:u;if(!("output"in c))throw new Error(`Unexpected vite.build result for "${t.name}"`);const d="chunk"===c.output[0].type?c.output[0].code:"";return r.debug(`Bundled "${t.name}" (${d.length} bytes)`),d}async function Re(e,t,n,o){const r=`https://${n.site}/api/v2/app-builder/queries/preview-async`;o.debug(`Calling Datadog API: ${r}`);const s=JSON.stringify({data:{type:"queries",attributes:{query:{id:f.randomUUID(),name:t,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e}},onlyTriggerManually:!0}},template_params:{}}}}),i=await O({url:r,auth:n,method:"POST",type:"json",getData:()=>({data:s,headers:{"Content-Type":"application/json"}})}),a=i.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 s=await O({url:o,auth:t,type:"json"});if(s.errors?.length){const e=s.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const i=s.data?.attributes;if(n.debug(`Long-poll response, done: ${i?.done}`),i?.done)return i.outputs}throw new Error("Query execution timed out")}(a,n,o)}function Ae(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class Oe extends Error{constructor(e,t){super(t),this.statusCode=e}}async function Te(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 Oe(400,"Missing or invalid functionName");const s=t.get(o);if(!s)throw new Oe(404,`Backend function "${o}" not found`);return{functionName:o,code:await n(s,r)}}function Me(e,t,n,o,r){const s=new Map(t.map((e=>[e.name,e]))),i=(t,n)=>Ce(e,t,n,o,r);t.length>0&&r.info(`Dev server middleware active for ${t.length} backend function(s): ${t.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,t,n)=>{if("POST"===e.method)if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await Te(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){Ae(t,e instanceof Oe?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,t,s,i).catch((()=>{Ae(t,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!a)return void Ae(t,403,"Auth credentials not configured. Set DD_API_KEY and DD_APP_KEY to enable remote execution.");(async function(e,t,n,o,r,s){try{const{functionName:i,code:a}=await Te(e,n,o);s.debug(`Executing action: ${i} with args`);const u=await Re(a,i,r,s);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:u}))}catch(e){const n=e instanceof Oe?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";s.debug(`Error handling executeAction: ${o}`),Ae(t,n,o)}})(e,t,s,i,a,r).catch((()=>{Ae(t,500,"Unexpected error")}))}else n();else n()}}const Ne=({viteBuild:e,buildRoot:t,functions:n,backendOutputs:o,handleUpload:r,log:s,auth:a})=>({async closeBundle(){let a;n.length>0&&(a=await async function(e,t,n,o,r){const s=await i.mkdtemp(c.join(p.tmpdir(),"dd-apps-backend-"));r.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const i of t){const t=`\0dd-backend:${i.name}`,a=De(i.name,i.entryPath,o),u=je(o,{[t]:a}),d=await e({...u,build:{...u.build,write:!0,outDir:s,emptyOutDir:!1,rollupOptions:{...u.build.rollupOptions,input:{[i.name]:t},output:{...u.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),p=Array.isArray(d)?d[0]:d;if("output"in p)for(const e of p.output){if("chunk"!==e.type||!e.isEntry)continue;const t=c.resolve(s,e.fileName);n.set(i.name,t),r.debug(`Backend function "${i.name}" output: ${t}`)}}return s}(e,n,o,t,s));try{await r()}finally{a&&await Q(a)}},configureServer(o){o.middlewares.use(Me(e,n,a,t,s))}}),_e=t.yellow.bold,Ie=t.red.bold,Fe=({options:e,context:t,bundler:n})=>{const o=t.getLogger(se);let r;const s=(e=>{const t=e[re]||{};return{enable:t.enable??!!e[re],include:t.include||[],dryRun:t.dryRun??!S("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim(),backendDir:t.backendDir?.trim()||"backend"}})(e);if(!s.enable)return[];const u=function(e,t){let n;try{n=a.readdirSync(e)}catch(n){if("ENOENT"===n.code)return t.debug(`No backend directory found at ${e}`),[];throw n}const o=[];for(const t of n){const n=c.join(e,t),r=a.statSync(n);if(r.isDirectory())for(const e of ce){const r=c.join(n,`index${e}`);try{a.statSync(r),o.push({name:t,entryPath:r});break}catch{}}else if(r.isFile()){const e=c.extname(t);if(ce.includes(e)){const r=c.basename(t,e);o.push({name:r,entryPath:n})}}}return t.debug(`Discovered ${o.length} backend function(s): ${o.map((e=>e.name)).join(", ")}`),o}(c.resolve(t.buildRoot,s.backendDir),o),l=new Map,f=u.length>0,m=[];return m.push({name:se,enforce:"post",vite:Ne({viteBuild:n.build,buildRoot:t.buildRoot,functions:u,backendOutputs:l,handleUpload:async()=>{const e=o.time("handle assets");let n;try{const e=o.time("resolve identifier"),{name:r,identifier:u}=ge(t.buildRoot,o,{url:t.git?.remote,name:s.name,identifier:s.identifier});if(!u||!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");e.end();const m=c.relative(t.buildRoot,t.bundler.outDir),h=[...s.include,`${m}/**/*`],g=await ue(h,t.buildRoot);if(!g.length)return void o.debug("No assets to upload.");const y=new Set(l.values()),b=(f?g.filter((e=>!y.has(e.absolutePath))):g).map((e=>({...e,relativePath:c.join("frontend",e.relativePath)})));if(f)for(const[e,t]of l)b.push({absolutePath:t,relativePath:`backend/${e}.js`});const w=o.time("archive assets"),$=await(async e=>{const t=await i.mkdtemp(c.join(p.tmpdir(),"dd-apps-")),n=c.join(t,ae),o=new d;for(const t of e)o.file(t.relativePath,a.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=a.createWriteStream(n),s=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});s.on("error",t),r.on("error",t),r.on("close",e),s.pipe(r)}));const{size:r}=await i.stat(n);return{archivePath:n,size:r,assets:e}})(b);w.end(),n=c.dirname($.archivePath);const v=o.time("upload assets"),{errors:k,warnings:S}=await ke($,{apiKey:t.auth.apiKey,appKey:t.auth.appKey,bundlerName:t.bundler.name,dryRun:s.dryRun,identifier:u,name:r,site:t.auth.site,version:t.version},o);if(v.end(),S.length>0&&o.warn(`${_e("Warnings while uploading assets:")}\n - ${S.join("\n - ")}`),k.length>0){const e=k.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){r=e,o.error(`${Ie("Failed to upload assets:")}\n${e?.message||e}`)}if(n&&await Q(n),e.end(),r)throw r},log:o,auth:t.auth})}),m},ze="errorTracking",Le="datadog-error-tracking-plugin",qe=(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$/,""),s=c.relative(n,r),i=((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,s);return{minifiedFilePath:r,minifiedUrl:i,relativePath:s}},Ke=/[/]+|[\\]+/g,Be=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Ue=(e,t)=>{const n=e.replace(Be,"").split(Ke),o=t.replace(Be,"").split(Ke),r=n.join("/");let s="";for(let e=0;e<o.length;e+=1){const t=o.slice(-e).join("/");r.startsWith(t)&&(s=t)}return s},He=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([oe(e.minifiedFilePath),oe(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Ue(e.relativePath,t)}})(e,n),s=[],i=[],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=>{i.push(`${c.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:o.hash,repository_url:o.remote}],version:1})})}catch(t){i.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&s.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||s.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&s.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||s.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&i.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:a,errors:s,warnings:i}},We=t.green.bold,Je=t.yellow.bold,Ve=t.red.bold,Ge=(e,t={})=>async()=>R({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await ne(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}),Ye=async(e,t,n,o)=>{const r=[],s=[];if(!n.apiKey)return r.push({error:new Error("No authentication token provided")}),{errors:r,warnings:s};if(0===e.length)return s.push("No sourcemaps to upload"),{errors:r,warnings:s};const i=o.time("Queue uploads"),a=new(h.default?h.default:h)({concurrency:t.maxConcurrency}),u=(c=n.site,S("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const d=C({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),p=q({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),l=`\nUploading ${We(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(l);const f=[];for(const i of e){const e={sourcemap:i.content.get("source_map")?.path.replace(n.outDir,"."),file:i.content.get("minified_file")?.path.replace(n.outDir,".")};f.push(a.add((async()=>{try{await O({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:Ge(i,d),onRetry:(t,n)=>{const r=`Failed to upload ${Je(e.sourcemap)} | ${Je(e.file)}:\n ${t.message}\nRetrying ${n}/5`;s.push(r),o.debug(r)}})}catch(n){if(r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}return i.end(),o.debug(`Queued ${We(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:s,errors:r}},Qe=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=>({...qe(e.minifiedPathPrefix,t.outDir,n),sourcemapFilePath:n,minifiedPathPrefix:e.minifiedPathPrefix})))})(e.sourcemaps,{outDir:t.outDir,outputs:t.outputs});o.end();const s=n.time("send sourcemaps");await(async(e,t,n,o)=>{const r=Date.now(),s=t.minifiedPathPrefix,i={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=>He(e,i,s,n.git))));a.end();const c=u.map((e=>e.errors)).flat(),d=u.map((e=>e.warnings)).flat();if(d.length>0&&o.warn(`Warnings while preparing payloads:\n - ${d.join("\n - ")}`),c.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${c.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const p=o.time("Upload sourcemaps"),{errors:l,warnings:f}=await Ye(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 ${We(`${e.length-l.length}/${e.length}`)} sourcemaps in ${We(F(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?`${Ve(e.file)} | ${Ve(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),s.end()},Xe=e=>{const n=t.bold.red,o=e[ze]||{},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},Ze=({options:e,context:t})=>{const n=t.getLogger(Le),o=n.time("validate options"),r=((e,t)=>{const n=[],o=Xe(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Le}.`);const r={enable:!!e[ze],...e[ze],sourcemaps:void 0};return o.config&&(r.sourcemaps=o.config),r})(e,n);if(o.end(),!r.enable)return[];let s,i,a=!1;const u=async()=>{if(!r.sourcemaps||a)return;a=!0;const e=n.time("sourcemaps process");await Qe(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:s,outDir:t.bundler.outDir,outputs:i?.outputs||[],site:t.auth.site,version:t.version},n),e.end()};return[{name:Le,enforce:"post",async git(e){s=e,i&&await u()},async buildReport(t){i=t,!s&&I(e)||await u()},async asyncTrueEnd(){a||await u()}}]};var et=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(et||{});const tt="liveDebugger",nt="datadog-live-debugger-plugin";function ot(e){return"function"==typeof e?e:e.default}function rt(e,t,n,o,r){const s=c.relative(t,e).replace(/\\/g,"/"),i=st(n,r);if(i)return`${s};${i}`;const a=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${s};<anonymous>@${a}:${o}`}function st(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)?ut(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=it(e.object,t),o=at(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)?ut(o.key,t):null}function it(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=it(e.object,t),o=at(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function at(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function ut(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 ct(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function dt(e,t,n,o){const r=[];for(const t of e.params)for(const e of pt(t,o))"this"!==e&&r.push(e);if(n&&o.isBlockStatement(e.body)){const t=new Set(e.params.flatMap((e=>pt(e,o)))),n="id"in e&&o.isIdentifier(e.id)?e.id.name:"";for(const s of e.body.body)if(o.isVariableDeclaration(s))for(const e of s.declarations)for(const s of pt(e.id,o))t.has(s)||s===n||r.push(s)}return r.length>25?r.slice(0,25):r}function pt(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:pt(e.argument,t):t.isAssignmentPattern(e)?pt(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?pt(e.argument,t):pt(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?pt(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const lt=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let ft,mt,ht,gt,yt=!1;function bt(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 lt.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=lt.find((t=>e.message.includes(t))),n=t??lt.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 ${lt.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const wt=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function $t(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:s,namedOnly:i}=e;let a=0,u=0,c=0,d=0,p=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:1,skippedUnsupportedCount:d,totalFunctions:p};if(!wt.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p};yt||(ft=bt("@babel/parser").parse,mt=ot(bt("@babel/traverse")),ht=bt("@babel/types"),gt=ot(bt("magic-string")),yt=!0);const l=ft(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let h=0;if(mt(l,{Function(e){if(p++,!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,ht))return void d++;if(r&&function(e,t,n){let o=e;for(;o;){if(ct(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return ct(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",ht))return void c++;if(s&&!s.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,ht)))return void d++;if(i&&!st(e,ht))return void d++;let t=0;if(!st(e,ht)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=rt(n,o,e,t,ht);try{const t=e.node,n=h++,o=`$dd_p${n}`,r=dt(t,0,!1,ht),s=dt(t,0,!0,ht),i=ht.isArrowFunctionExpression(t)&&!ht.isBlockStatement(t.body),a=[],c=i||!ht.isBlockStatement(t.body)||!St(t.body.body,ht);let d;if(!i&&ht.isBlockStatement(t.body)&&kt(t.body.body,a,ht),!i&&ht.isBlockStatement(t.body)&&t.body.directives.length>0){d=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:i,needsTrailingReturn:c,bodyParenStart:i&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:d,functionId:l,probeVarName:o,probeIdx:String(n),entryVars:r,exitVars:s,returns:a}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p};const g=new gt(t);for(let e=f.length-1;e>=0;e--)vt(g,t,f[e]);return{code:g.toString(),map:g.generateMap({source:n,hires:!1}),failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:p}}function vt(e,t,n){const{probeVarName:o,probeIdx:r,functionId:s,entryVars:i,exitVars:a,returns:u,bodyStart:c,bodyEnd:d,functionEnd:p,isExpressionBody:l,bodyParenStart:f,directivesEnd:m}=n,h=`$dd_e${r}`,g=`$dd_l${r}`,y=`$dd_rv${r}`,b=i.join(", "),w=a.join(", "),$=b===w,v=$?h:g,k=`const ${o} = $dd_probes('${s}');`,S=`const ${h} = () => ({${b}});`,E=$?"":`const ${g} = () => ({${w}});`,x=`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=d;e<p;e++)if(")"===t[e]){n=e;break}-1!==n&&(e.remove(f,f+1),e.remove(n,n+1))}const n=["{",k,S,E,"try {",x,`const ${y} = `].filter(Boolean).join("\n"),r=[";",`if (${o}) $dd_return(${o}, ${y}, this, ${h}(), ${v}());`,`return ${y};`,`} ${D}`,"}"].join("\n");e.appendLeft(c,n),e.appendLeft(d,r)}else{const t=["",k,S,"try {",E,`let ${y};`,x].filter(Boolean).join("\n"),r=[""];n.needsTrailingReturn&&r.push(`if (${o}) $dd_return(${o}, undefined, this, ${h}(), ${v}());`),r.push(`} ${D}`,"");const s=r.join("\n"),i=m??c+1;e.appendLeft(i,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(d-1,s)}}function kt(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))kt(o.body,t,n);else if(n.isIfStatement(o))kt([o.consequent],t,n),o.alternate&&kt([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))kt([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)kt(e.consequent,t,n);else n.isTryStatement(o)?(kt(o.block.body,t,n),o.handler&&kt(o.handler.body.body,t,n),o.finalizer&&kt(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&kt([o.body],t,n)}function St(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 St(e,t)&&St(o,t)}return!1}const Et=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],xt=t.bold.red,Dt=Number(process.env.DD_LD_LIMIT)||1/0,Pt=(e,t)=>{const n=t.getLogger(nt);let o=0,r=0,s=0,i=0,a=0,u=0,c=0,d=0;return{name:nt,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(p,l){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?l.includes(e):e.test(l))))return{code:p}}for(const t of e.exclude){if("string"==typeof t?l.includes(t):t.test(l))return{code:p}}if(d>=Dt)return{code:p};try{const n=$t({code:p,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});return o+=n.instrumentedCount,c+=n.totalFunctions,r+=n.failedCount,s+=n.skippedByCommentCount,i+=n.skippedFileCount,a+=n.skippedUnsupportedCount,n.totalFunctions>0&&d++,0===n.instrumentedCount?{code:p}:(u++,{code:n.code,map:n.map})}catch(e){return n.error(`Instrumentation Error in ${l}: ${e}`,{forward:!0}),{code:p}}}},buildEnd:()=>{c>0&&n.info(`Live Debugger: ${o}/${c} functions instrumented across ${u}/${d} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:s,skippedFileCount:i,skippedUnsupportedCount:a,totalFilesWithFunctions:d,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},jt=({options:e,context:t})=>{const n=((e,t)=>{const n=e[tt]||{},o=[],r=e.errorTracking?.sourcemaps?.releaseVersion;if(void 0!==n.enable&&"boolean"!=typeof n.enable&&o.push(`${xt("enable")} must be a boolean`),void 0!==n.version&&"string"!=typeof n.version&&o.push(`${xt("version")} must be a string`),n.version&&r&&n.version!==r&&o.push(`${xt("version")} must match ${xt("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(`${xt("include")} patterns must be strings or RegExp`);break}}else o.push(`${xt("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(`${xt("exclude")} patterns must be strings or RegExp`);break}}else o.push(`${xt("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&o.push(`${xt("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Et.includes(e)){o.push(`${xt("functionTypes")} contains invalid value "${e}". Valid values: ${Et.join(", ")}`);break}}else o.push(`${xt("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&o.push(`${xt("namedOnly")} must be a boolean`),o.length)throw t.error(`\n - ${o.join("\n - ")}`),new Error(`Invalid configuration for ${nt}.`);return{enable:n.enable??!!e[tt],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(nt));return n.enable?(t.inject({type:"code",position:et.BEFORE,injectIntoAllChunks:!0,value:"if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}"}),[Pt(n,t)]):[]},Ct=[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}],Rt="metrics",At="datadog-metrics-plugin",Ot=e=>Math.floor((e||Date.now())/1e3),Tt=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),Mt=(e="")=>e.endsWith("/")?e:`${e}/`,Nt=(e,t)=>{let n=e;return e.split(Mt(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},_t=(e,t)=>e.split("!").pop().replace(Mt(t),"./"),It=(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)),_t(o||"no-name",n)},Ft=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),zt=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Lt=t.bold.red,qt=t.bold.cyan,Kt=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},Bt=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Kt("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:F(e.duration)}))),top:!0};n.sort(Kt("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Ut=(e,t,n)=>{const o=[];var r;n&&(o.push(...Bt("Loader",n.loaders)),o.push(...Bt("Tapable",n.tapables)),o.push(...Bt("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},s=new Set,i=_(e.build),a=new Map,u=new Map,c=new Map;for(const e of i.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)c.has(n)||c.set(n,new Set),c.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(c.has(e.filepath)){const t=c.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),c.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=c.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;s.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!s.size)return[t,n,o];const d=Array.from(s);return d.sort(Kt((e=>e.dependents.size))),t.values=d.map((e=>({name:e.name,value:e.dependents.size.toString()}))),d.sort(Kt((e=>e.dependencies.size))),n.values=d.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),d.sort(Kt("size")),o.values=d.map((e=>({name:e.name,value:m(e.size)}))),d.sort(Kt("aggregatedSize")),r.values=d.map((e=>({name:e.name,value:m(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(Kt((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Kt((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Kt((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,s=e.build.errors.length,i=e.build.entries?e.build.entries.length:0;return e.build.start&&t.values.push({name:"Overhead duration",value:F(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:F(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:F(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:i.toString()},{name:"Number of warnings",value:r.toString()},{name:"Number of errors",value:s.toString()}),[t]})(e));const s=(e=>{let t="";for(const t of e){t.top&&t.values.length>=5&&(t.values=t.values.slice(0,5),t.name=`Top 5 ${t.name}`);for(const e of t.values)e.name=z(e.name,60)}const n=Math.max(...e.map((e=>e.name.length))),o=Math.max(...e.flatMap((e=>e.values.map((e=>e.name.length))))),r=Math.max(...e.flatMap((e=>e.values.map((e=>e.value.length))))),s=Math.max(n+4,o+r+4);for(const n of e){if(0===n.values.length)continue;const e=s-(n.name.length+4);t+=`\n== ${n.name} ${"=".repeat(e)}=\n`;for(const e of n.values){const n=r-e.value.length;t+=` [${Lt(e.value)}] ${" ".repeat(n)}${qt(e.name)}\n`}}return t})(o);t.info(s)},Ht="api/v1/series",Wt=t.bold.green,Jt=["onStart","onLoad","onResolve","onEnd"],Vt=new Map,Gt=new Map,Yt=new Map,Qt=(e,t,n)=>{const o=Object.assign({},e);for(const r of Jt)o[r]=async(o,s)=>{const i=Gt.get(t)||{name:t,increment:0,duration:0,events:{}};i.events[r]=i.events[r]||{name:r,values:[]};const a="onLoad"===r;return(0,e[r])(o,(async(...e)=>{const o=_t(e[0].path,n),u=Yt.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=g.performance.now();try{return await s(...e)}finally{const n=g.performance.now(),s=n-c,d={start:c,end:n,duration:s,context:zt(e)};if(i.events[r].values.push(d),i.duration+=s,i.increment+=1,Gt.set(t,i),u.events[r].values.push(d),u.duration+=s,u.increment+=1,Yt.set(o,u),a){const e=Vt.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(d),e.duration+=s,e.increment+=1,Vt.set(t,e)}}}))};return o},Xt=(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 s=Qt(r,o.name,t);await n({...s,initialOptions:{...s.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:s,modules:i}={plugins:Gt,modules:Yt,loaders:Vt};o.end(),await e.asyncHook("timings",{tapables:r,loaders:s,modules:i})}))}});class Zt{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=It(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Ft))(e);o.length||o.push("no-loader"),this.started[n]={module:Nt(n),timings:{start:g.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=It(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=g.performance.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},s=n.loaders.join(",");r.events[s]=r.events[s]||{name:s,values:[]},r.events[s].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 en{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,r,s){const i=this.timings.get(t)||{name:t,duration:0,increment:0,events:{}};i.events[n]||(i.events[n]={name:n,values:[]}),i.events[n].values.push({start:r,end:s,duration:s-r,context:o,type:e}),i.duration+=s-r,i.increment+=1,this.timings.set(t,i)}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 s=g.performance.now(),i=t.apply(this,r),a=()=>{this.saveResult(e,n,o,zt(r),s,g.performance.now())};return i.then(a,a),i}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const s=g.performance.now(),i=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,zt(r),s,g.performance.now()),i(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const s=g.performance.now(),i=t.apply(this,r);return this.saveResult(e,n,o,zt(r),s,g.performance.now()),i}}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,s)=>{const i="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${i}`;if(this.monitoredTaps[u])return n.call(o,r,s);this.monitoredTaps[u]=!0;const c=this.getTapPatch(e,s,i,t);return n.call(o,r,c)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(At)||(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 tn=e=>async t=>{const n=e.getLogger(At),o={name:At},r=new en(e.buildRoot),s=new Zt(e.buildRoot),i=n.time("parse compiler hooks");r.throughHooks(t),i.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=>{s.startModule(t,e)})),e.hooks.succeedModule.tap(o,(t=>{s.doneModule(t,e)})),e.hooks.failedModule&&e.hooks.failedModule.tap(o,(t=>{s.doneModule(t,e)}))})),t.hooks.afterEmit.tapPromise(o,(async()=>{const{timings:t}=r.getResults(),{loaders:n,modules:o}=s.getResults();await e.asyncHook("timings",{tapables:t,loaders:n,modules:o})}))},nn={filters:Ct},on=({options:e,context:t})=>{const n=t.getLogger(At);let o=0;const r=((e,t)=>{const n=e[Rt],o=Ot(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enable:!!e[Rt],enableDefaultPrefix:!0,enableTracing:!1,filters:Ct,tags:[],...e[Rt],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[];if(!r.enable)return s;const i={name:At,enforce:"pre",esbuild:Xt(t,n),webpack:tn(t),rspack:tn(t)},a=n.time("build",{start:!1}),u=r.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let c,d;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"),s=r.timestamp,i=n.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],s=e.entries||[],i=e.warnings.length,a=e.errors.length,u=e.duration,c=new Map,d=new Map,p=new Map;for(const e of s){for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");p.has(n)||p.set(n,[]),p.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,s.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,i]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`entryName:${e}`))),d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");p.has(r)&&o.push(...p.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of s){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})(d,s);i.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 s of Object.values(o.events)){let i=0;r+=s.values.length;for(const t of s.values){const n=t.end-t.start;i+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,i]],tags:[`pluginName:${o.name}`,`hookName:${s.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,s.values.length]],tags:[`pluginName:${o.name}`,`hookName:${s.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(c?.tapables,s);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})(c?.loaders,s);l.end();const m=((e,t,n,o,r)=>{const s=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}s.add(Tt(e,o,r))}const i=Array.from(s).filter((e=>e.toSend)).length;return s.add(Tt({metric:"metrics.count",type:"count",points:[[t,i+1]],tags:[],toSend:!0},o,r)),s})(new Set([...a,...p,...f]),s,r.filters,r.tags,r.prefix);await t.asyncHook("metrics",m),e.end();const h=n.time("outputing report");Ut(t,n,c),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 s=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: ${Wt(`https://api.${t.site}/${Ht}`)}\n\nMetrics:\n - ${s.join("\n - ")}`),O({method:"POST",url:`https://api.${t.site}/${Ht}?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[Rt]?.timestamp||(r.timestamp=Ot(t.build.start))},buildEnd(){a.end(),o=Date.now()},async timings(e){c=e,d&&await p()},async buildReport(e){d=e,!c&&u||await p()}};return r.enableTracing&&s.push(i),s.push(l),s},rn="output",sn="datadog-output-plugin",an=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,un=e=>{const t=void 0===e;return{build:an("build",e?.build??t),bundler:an("bundler",e?.bundler??t),dependencies:an("dependencies",e?.dependencies??t),errors:an("errors",e?.errors??t),logs:an("logs",e?.logs??t),metrics:an("metrics",e?.metrics??t),timings:an("timings",e?.timings??t),warnings:an("warnings",e?.warnings??t)}},cn=(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}))}))},dn=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},pn=({options:e,context:t})=>{const n=(e=>({enable:!!e[rn],path:"./",...e[rn],files:un(e[rn]?.files)}))(e),o=t.getLogger(sn);if(!n.enable)return[];const r=(e,r)=>{const s=n.files[e];if(!r||!1===s)return;t.queue((async()=>{const e=o.time(`output ${s}`),i=((e,t,n)=>{const o=c.isAbsolute(t)?t:c.resolve(e,t);return c.resolve(o,n)})(t.bundler.outDir,n.path,s);let d;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await X(c.dirname(e));const n=a.createWriteStream(e),o=new u.JsonStreamStringify(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(i,e)}catch(e){d=e}d?o.error(`Failed writing ${s}: ${d}`):o.debug(`Wrote "./${c.relative(t.buildRoot,i)}"`),e.end()})())};return[{name:sn,buildReport(e){const t=o.time("serialize report"),n=_(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:cn(o,(e=>{r("bundler",e)})),rollup:dn((e=>{r("bundler",e)})),vite:dn((e=>{r("bundler",e)})),webpack:cn(o,(e=>{r("bundler",e)}))}]},ln="rum",fn="datadog-rum-plugin",mn=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")});`,hn="datadog-rum-privacy-plugin";const gn=(e,t)=>{const n=t.getLogger(hn),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,s=0;return{name:hn,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?.()),i=y.instrument({id:t,code:e,map:n},o);return 0===i.privacyDictionarySize?{code:e}:(r+=i.privacyDictionarySize,s++,i)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${r} entries across ${s} files`,{forward:!0,context:{dictionaryEntryCount:r,fileCount:s}})}}},yn=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,bn=(e,t)=>{const n=e.sdk;if(n.clientToken)return yn(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 O({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 yn({...e,sdk:{clientToken:o,...n}})}},wn=e=>{const n=t.bold.red,o=e[ln]||{},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 s={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={...s,...o.sdk},r},$n=e=>{const t=e[ln]||{},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},vn=e=>{const n=t.bold.red,o=e[ln]||{},r={errors:[]};if(!o.sourceCodeContext)return r;const s=o.sourceCodeContext;return s?.service&&"string"==typeof s.service||r.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),r.config=s,r},kn=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=wn(e),r=$n(e),s=vn(e);if(n.push(...o.errors),n.push(...r.errors),n.push(...s.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${fn}.`);const i={enable:!!e[ln],...e[ln],sdk:void 0,privacy:void 0,sourceCodeContext:void 0};return o.config&&(i.sdk=o.config),r.config&&(i.privacy=r.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(i.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),s.config&&(i.sourceCodeContext=s.config),i})(e,t.getLogger(fn)),o=[];if(!n.enable)return o;if(n.sourceCodeContext&&t.inject({type:"code",position:et.BEFORE,injectIntoAllChunks:!0,value:mn(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:et.MIDDLE,value:c.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:et.MIDDLE,value:bn(n,t)})),n.privacy){t.inject({type:"file",position:et.BEFORE,value:c.join(__dirname,"./privacy-helpers.js")});const e=gn(n.privacy,t);o.push(e)}return o},Sn="datadog-analytics-plugin",En=({context:e})=>{const t=e.getLogger(Sn);return[{name:Sn,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}`)}})())}}]},xn="datadog-async-queue-plugin",Dn=e=>{const{context:t,stores:n}=e,o=t.getLogger(xn),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:xn,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Pn=async(e,t,n)=>{const o=[],r=e.initialOptions.entryPoints,s=[],i=[];if(Array.isArray(r))for(const e of r){const t=e&&"object"==typeof e?e.in:e;s.push({path:t})}else r&&"object"==typeof r&&s.push(...Object.entries(r).map((([e,t])=>({name:e,path:t}))));const a=s.flatMap((e=>{return(t=e.path,t.includes("*")?l.glob.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const s=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});s.errors.length&&i.push(...s.errors.map((e=>e.text))),s.path&&o.push({name:n.name,resolved:s.path,original:n.path})}));for(const e of i)n.error(e);return await Promise.all(a),o},jn=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Cn=/(\?|%3F|\|)+/gi,Rn=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=Tn(e),jn.lastIndex=0,jn.exec(t)?.[1]||"unknown");var t},An=["unknown","commonjsHelpers.js",`vite${c.sep}preload-helper.js`],On=(e,t,n)=>{const o=new Set;for(const n of e){const e=Tn(n);N(n)||e===t||An.includes(e)||o.add(e)}return o},Tn=e=>e.split("!").pop().split(Cn).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Mn=(e,t)=>N(t)?x:"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(Cn).shift().replace(/^((\.\.?)?[/\\])+/g,""),Nn=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[de(t,e),n]))),_n=(e,t)=>({setup(n){const o=new Map;let r=[];const s=t.time("build report",{start:!1});n.onStart((async()=>{o.clear(),r=[],s.resume();const i=t.time("process entries");r.push(...await Pn(n,e,t));for(const t of r){const n=Mn(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}i.end(),s.pause()})),n.onEnd((async n=>{s.resume();const r=t.time("collecting errors and warnings"),i=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={},h={},g=t.time("indexing metafile data"),y=Nn(n.metafile.inputs,a),b=Nn(n.metafile.outputs,a);g.end();const w=e=>{if(!N(e))return e;const t=y[de(a,e)];if(!t)return e;const n=t.imports.find((e=>!N(e.path)));return n?n.path:e},$=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(N(e))continue;const n=de(a,e),o={name:Mn(i,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Rn(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=de(a,e),s=Mn(i,n),u=[];for(const e of Object.keys(r.inputs)){if(N(e))continue;const n=m[de(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${s}`)}if(r.entryPoint&&!u.length){const e=m[de(a,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${s}`);continue}u.push(e)}const c={name:s,filepath:n,inputs:u,size:r.bytes,type:Rn(n)};if(h[n]=c,"map"===c.type&&l.push(c),d.push(c),!r.entryPoint)continue;const f=m[de(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)}}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 S={inputs:{report:m,meta:y},outputs:{report:h,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,x=e=>!N(e)&&!e.match(E),D=(e,n,o={})=>{if(!x(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 s=n.meta[e];if(!s)return t.debug(`Could not find metafile's ${e}`),o;if(!s.imports||!s.imports.length)return o;for(const t of s.imports){const s=t.path.match(/^\.\.?\//),d=s?c.dirname(e):a,p=de(d,t.path);if(t.external){if(x(t.path)){const e=s?p:t.path,n=S.inputs.report[e]||{filepath:e,name:Mn(i,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),S.inputs.report[e]=n,o[n.filepath]=n}}else D(p,n,o)}return o},P=t.time("looping through entries");for(const e of p){const t={},n={};for(const n of e.inputs)D(n.filepath,S.inputs,t);for(const t of e.outputs)D(t.filepath,S.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=S.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!x(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?c.dirname(e.filepath):a,s=de(r,o.path);let i;if(o.external){const e=n?s:o.path;i=S.inputs.report[e]}else i=S.inputs.report[s];i?(e.dependencies.add(i),i.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,s.end(),await e.asyncHook("buildReport",e.build)}))}}),In=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),s=t.time("filling inputs and outputs",{start:!1}),i=t.time("completing dependencies and dependents",{start:!1}),u=t.time("filling dependencies and dependents",{start:!1}),c=t.time("filling sourcemaps inputs",{start:!1}),d=new Map,p=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),d.clear(),p.clear(),l.clear()},onLog(t,n){"warn"===t&&e.build.warnings.push(n.message||n.toString())},renderError(t){t&&e.build.errors.push(t.message)},moduleParsed(e){n.resume();const t=Tn(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=On(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),s=On(new Set([...e.dynamicImporters,...e.importers]),t);for(const e of s)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?de(e.buildRoot,n.dir):e.bundler.outDir,g=new Set,y=new Set,b=new Map;i.resume();for(const[e,{dependencies:t,dependents:n}]of f){for(const n of t){const t=Tn(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=Tn(t),o=f.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),f.set(n,o))}}i.end(),s.resume();for(const[e,n]of Object.entries(m)){const o=de(h,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),s=p.get(o)||{name:e,filepath:o,inputs:[],size:r,type:Rn(e)};if("map"===s.type&&y.add(s),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(Tn(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=a.statSync(e).size}catch(e){n=t.renderedLength}const o=d.get(e)||{name:Mn(h,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Rn(e)};s.inputs.push(o),d.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=Tn(e);if(!f.has(n)){b.set(de(h,n),s);continue}if(d.has(n)){t.debug(`Input report already there for ${n} from ${s.name}.`);continue}const o=d.get(n)||{name:Mn(h,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};s.inputs.push(o),d.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...s,name:n.name,size:0,outputs:[s]}),p.set(s.filepath,s)}s.end();for(const[e,n]of b){const o=p.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of d){const o=f.get(e);if(o){for(const e of o.dependencies){const o=d.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Mn(h,e)} of ${n.name}`)}for(const e of o.dependents){const o=d.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Mn(h,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){c.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=p.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}c.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Mn(h,e),r=p.get(e);if(!r)return d.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const s=m[Mn(h,e)];if(!s)return t.debug(`Could not find asset for ${o}`),n;const i=[];"imports"in s&&i.push(...s.imports),"dynamicImports"in s&&i.push(...s.dynamicImports);for(const e of i)w(de(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}":"${Mn(h,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(d.values()),e.build.outputs=Array.from(p.values()),e.build.entries=Array.from(l.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},Fn=(e,t,n)=>o=>{let r=[],s=[],i=[];const a=new Map,u=new Map,c=new Map,d=new Map,p=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||N(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=Tn(e);t.add(n),n.startsWith("external ")&&t.add(h(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(d.has(e)){const n=d.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else d.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=Tn(t.request);if(d.has(n))return d.get(n);if(e.context){const t=de(Tn(e.context),n);if(d.has(t))return d.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],s=[],i=[],a.clear(),u.clear(),d.clear(),l.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),s=n.time("indexing modules");for(const e of t)g(e);s.end();const i=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Mn(e.bundler.outDir,t),s=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 i=l.get(t)||{dependents:new Set,dependencies:new Set};for(const e of s){const n=l.get(e)||{dependencies:new Set,dependents:new Set};n.dependents.add(t),i.dependencies.add(e),l.set(e,n)}l.set(t,i);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:Rn(t)};r.push(u),a.set(t,u),w(n)&&a.set(h(t),u)}i.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=l.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,d=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>de(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"===Rn(e))continue;const t=c.get(e)||new Set;for(const e of n)t.add(e);c.set(e,t)}}h.end();const y=n.time("building outputs");for(const t of d){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:de(e.bundler.outDir,t.name),type:Rn(t.name)};if(u.set(o.filepath,o),s.push(o),"map"===o.type){p.push(o);continue}const r=c.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of p){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),$=(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,s=new Map;let a=0;const c=$(r),d=Array.from(c).flatMap(l),p=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"===Rn(e)));for(const e of d){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)s.has(e.filepath)||s.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:p?de(e.bundler.outDir,p):"unknown",size:a,inputs:Array.from(s.values()),outputs:Array.from(t.values()),type:p?Rn(p):"unknown"};i.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=s,e.build.entries=i,f.end(),await e.asyncHook("buildReport",e.build)}))},zn="datadog-build-report-plugin",Ln=e=>{const{context:t}=e,n=t.getLogger(zn);return[{name:zn,enforce:"post",esbuild:_n(t,n),rspack:Fn(t,zn,n),webpack:Fn(t,zn,n),vite:In(t,n),rollup:In(t,n)}]},qn="datadog-bundler-report-plugin",Kn=(e,t)=>t?c.isAbsolute(t)?t:c.resolve(e,t):"",Bn=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)},Un=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Kn(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Hn=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Bn(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=le(r,process.cwd())),e.bundler.outDir=Kn(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Wn=e=>{const{context:t}=e,n=t.getLogger(qn);return[{name:qn,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Kn(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Kn(t.buildRoot,c.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Un(t),rspack:Un(t),vite:Hn(t),rollup:{options(e){let n;if("output"in e){const t=Bn(e.output);n=le(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=de(process.cwd(),n);const e=le([n,...o],process.cwd());t.buildRoot=e===c.sep?process.cwd():e}else t.buildRoot=le(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=Bn(e);le(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.")}}}]},Jn="datadog-custom-hooks-plugin",Vn=e=>{const{context:t}=e,n=t.getLogger(Jn),o=e=>(o,...r)=>{const s=n.time(`execution | ${o}`,{tags:["type:custom-hook",`hook:${o}`]}),i=[],a=[];for(const n of t.plugins){if(!(o in n))continue;const t=n[o];if("function"==typeof t)try{const s=t(...r);s instanceof Promise&&(e||i.push(`Plugin "${n.name}" returned a promise on the non async hook "${o}".`),a.push(s))}catch(e){i.push(`Plugin "${n.name}" errored on hook "${o}". [${e}]`)}else i.push(`Plugin "${n.name}" has an invalid hook type for "${o}". [${typeof t}]`)}if(i.length>0){for(const e of i)n.error(e);throw new Error("Some plugins errored during the hook execution.")}return Promise.all(a).finally((()=>s.end()))};return t.hook=o(!1),t.asyncHook=o(!0),[{name:Jn,enforce:"pre"}]};class Gn{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=ee(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 s=this.matchSources(r);if(0!==s.length)return s;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 Yn=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await Qn(e);for(const e of t)if(e.name===n)return L(e.refs.push);return L(t[0].refs.push)},Qn=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},Xn=async e=>e.revparse("HEAD"),Zn=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),eo=async e=>e.branch(),to=async e=>e.show(["-s","--format=%s"]),no=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),oo="datadog-git-plugin",ro=e=>{const{options:t,context:n}=e,o=n.getLogger(oo),r=o.time("get git information",{start:!1}),s=async e=>{try{const t=await(async e=>{const t=[Xn(e),eo(e),to(e),no(e),Zn(e),Yn(e)],[n,o,r,s,i,a]=await Promise.all(t),[u,c,d,p,l,f]=s.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:c,date:d},committer:{name:p,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new Gn(i)}})(await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=b.simpleGit(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return b.simpleGit(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:oo,enforce:"pre",buildRoot(e){if(I(t))try{r.resume();const t=pe(e,".git");if(!t)return o.warn("No .git directory found, skipping git plugin."),void r.end();n.queue(s(t))}catch(e){o.error(`Could not get git information: ${e.message}`)}}}]},so="datadog-injection-plugin",io=/^https?:\/\//,ao=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],uo=t.bold.yellow,co=async(e,t=process.cwd())=>(e=>i.readFile(e,{encoding:"utf-8"}))(de(t,e)),po=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(io)?await(async(e,t=5e3)=>{let n;return Promise.race([O({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await co(r,n);else{if("code"!==e.type)throw new Error(`Invalid item type "${e.type}", only accepts "code" or "file".`);o=r}}catch(s){const i=`${e.type} - ${z(r)}`;e.fallback?(t.debug(`Fallback for "${i}": ${s.toString()}`),o=await po(e.fallback,t,n)):t.warn(`Failed "${i}": ${s.toString()}`)}return o},lo=(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`},fo=async(e,t,n,o=process.cwd())=>{const r=await(async(e,t,n=process.cwd())=>{const o=new Map;for(const[r,s]of e.entries()){const e=await po(s,t,n);if(e){const t=s.position||et.BEFORE;o.set(r,{value:e,injectIntoAllChunks:"injectIntoAllChunks"in s&&s.injectIntoAllChunks,position:t})}}return o})(t,e,o);for(const e of r.values())n.push(e)},mo=e=>e instanceof Error&&"code"in e,ho=e=>ao.includes(e),go=(e,t,n)=>{e.warn(`"${uo(t)}" files are not supported (${uo(n)}).`)},yo=a.promises,bo=(e,t,n)=>({setup(o){const{onStart:r,onResolve:s,onLoad:u,onEnd:d,esbuild:l,initialOptions:f}=o,m=[],h=`${t.bundler.name}.${et.MIDDLE}.${x}.js`,g=a.realpathSync(p.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 Pn(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await X(c.dirname(e)),await i.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),s({filter:b},(async e=>({path:e.path,namespace:so}))),u({filter:b,namespace:so},(async()=>({contents:lo(n,{position:et.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),d((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=lo(n,{position:et.BEFORE}),s=lo(n,{position:et.AFTER}),i=lo(n,{position:et.BEFORE,onAllChunks:!0}),a=lo(n,{position:et.AFTER,onAllChunks:!0});if(!(r||s||i||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))),p=o?r:i,f=o?s:a;if(!p&&!f)continue;const h=de(t.buildRoot,n),{base:g,ext:y}=c.parse(h);ho(y)?u.push((async()=>{try{const e=await yo.readFile(h,"utf-8"),t=await l.transform(e,{loader:"default",banner:p,footer:f});await yo.writeFile(h,t.code)}catch(t){if(!mo(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${h}: ${t}`)}})()):go(e,y,g)}await Promise.all(u)}))}}),wo=x,$o="?inject-proxy",vo=(e,t)=>({banner(n){const o=lo(t,{position:et.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:s}=c.parse(n.fileName);return ho(s)?o:(go(e,s,r),"")},async resolveId(e,n,o){if(N(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&lo(t,{position:et.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}${$o}`}return null},load(e){if(N(e))return lo(t,{position:et.MIDDLE});if(e.endsWith($o)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(wo)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=lo(t,{position:et.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:s}=c.parse(n.fileName);return ho(s)?o:(go(e,s,r),"")}}),ko=(e,t,n,o,r)=>s=>{const i=new WeakMap,u=e.sources.ConcatSource,d=n.bundler.name,p=c.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${d}.${et.MIDDLE}.${x}.js`);Z(p,"");s.hooks.shutdown.tap(so,(()=>{var e;e=p,a.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await fo(t,o,r,n.buildRoot)};s.hooks.beforeRun.tapPromise(so,l),s.hooks.watchRun.tapPromise(so,l),s.hooks.compilation.tap(so,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:so,stage:o},(()=>{const e=lo(r,{position:et.BEFORE}),o=lo(r,{position:et.AFTER}),s=lo(r,{position:et.BEFORE,onAllChunks:!0}),a=lo(r,{position:et.AFTER,onAllChunks:!0});for(const r of n.chunks){let d=e,p=o;if(r.canBeInitial()||(d=s,p=a),""!==d||""!==p)for(const e of r.files){const{base:o,ext:r}=c.parse(e);ho(r)?n.updateAsset(e,(e=>{const t=i.get(e);if(!t||t.banner!==d||t.footer!==p){const t=new u(d,"\n",e,"\n",p);return i.set(e,{source:t,banner:d,footer:p}),t}return t.source})):go(t,r,o)}}}))}));const f=(e=>{const n={import:[p]},o=e=>{for(const[n,o]of Object.entries(e))"object"==typeof o?(o.import=o.import||[],o.import.unshift(p)):"string"==typeof o?e[n]=[p,o]:Array.isArray(o)?o.unshift(p):t.error("Invalid entry type: "+typeof o)};return e?"function"==typeof e?async()=>{const t=await e();return o(t),t}:"object"!=typeof e?"string"==typeof e?[n,e]:(t.error("Invalid entry type: "+typeof e),e):(o(e),e):{ddHelper:n}})(s.options.entry);s.options.entry=f},So=e=>{const{bundler:t,context:n}=e,o=n.getLogger(so),r=new Map,s=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++K}`,e)};const i={name:so,enforce:"post",esbuild:bo(o,n,s),webpack:ko(t,o,n,r,s),rspack:ko(t,o,n,r,s),rollup:vo(o,s),vite:{...vo(o,s),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>lo(s,{position:et.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)?i.load={filter:{id:D},handler:()=>({code:lo(s,{position:et.MIDDLE})})}:i.buildStart=async()=>{await fo(o,r,s,n.buildRoot)},[i]},Eo="datadog-true-end-plugin",xo=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=()=>{t.hook("syncTrueEnd")},r=async()=>{o(),await n()},s=e=>{e.hooks.shutdown.tapPromise(Eo,r)},i={async writeBundle(){},async closeBundle(){await r()}};return[{name:Eo,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:i,rollup:i,rspack:s}]},Do={[Rt]:nn},Po=t.bold.red;var jo="3.1.3-dev.2";const Co=(({bundler:t,version:n})=>{const o=Date.now();return e.createUnplugin(((e,r)=>{const s=Date.now(),i=((e={})=>{const t={site:S("SITE")||e.auth?.site||"datadoghq.com"};return Object.defineProperty(t,"apiKey",{value:S("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(t,"appKey",{value:S("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:t}})(e);"esbuild"===r.framework&&(r.esbuildHostName=j);const a=process.env.BUILD_PLUGINS_ENV||"production",u=P.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,d=r.framework,p={bundler:{name:d,version:c},env:u,metadata:i.metadata||{},packageName:`@datadog/${d}-plugin`,version:n},l={errors:[],logs:[],queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),s={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{auth:t.auth,pluginNames:[],bundler:{...s.bundler,outDir:r},build:s,buildRoot:r,env:n.env,getLogger:J(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:T(n),start:e,version:n.version}})({start:o,options:i,data:p,stores:l}),m=f.getLogger("factory"),h=m.time("Plugins initialization",{start:s});f.pluginNames.push(j);const g=[];g.push(["analytics",En],["async-queue",Dn],["build-report",Ln],["bundler-report",Wn],["custom-hooks",Vn],["git",ro],["injection",So],["true-end",xo]),i.customPlugins&&g.push(["custom",i.customPlugins]),g.push(["apps",Fe],["error-tracking",Ze],["live-debugger",jt],["metrics",on],["output",pn],["rum",kn]);for(const[e,n]of g)f.plugins.push(...Y(f,n,e)({bundler:t,context:f,options:i,data:p,stores:l}));return(e=>{const t=[];for(const n of k){const o=E(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>v(e))).join(" and "),s=v(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${s}`),t.push(`${r} (using ${s})`)}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: ${Po(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),h.end(),f.plugins}))})({bundler:w,version:jo}).esbuild,Ro=jo,Ao=Do;exports.datadogEsbuildPlugin=Co,exports.helpers=Ao,exports.version=Ro;
|
|
1
|
+
"use strict";var e=require("unplugin"),t=require("chalk"),n=require("async-retry"),o=require("stream"),r=require("zlib"),i=require("buffer"),s=require("fs/promises"),a=require("fs"),u=require("json-stream-stringify"),c=require("path"),p=require("jszip"),d=require("os"),l=require("glob"),f=require("crypto"),m=require("pretty-bytes"),h=require("p-queue"),g=require("perf_hooks"),y=require("@datadog/js-instrumentation-wasm"),b=require("simple-git"),w=require("esbuild");const $=t.bold.green,v=t.bold.yellow,k=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],x=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],S=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},E="__datadog-helper-file",D=new RegExp(E),P=["development","production","test"],j="datadog-build-plugins",C=e=>{if(null===e||"object"!=typeof e)return"";const t="title"in e&&"string"==typeof e.title?e.title:void 0,n="detail"in e&&"string"==typeof e.detail?e.detail:void 0;return t&&n?`${t}: ${n}`:t||(n?`detail: ${n}`:"")},R=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),A=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.Readable.fromWeb(a.body);return{data:i?u.pipe(r.createGzip()):u,headers:{"Content-Encoding":i?"gzip":"multipart/form-data",...n,...Object.fromEntries(a.headers.entries())}}},O=[400,401,403,404,405,409,413],T=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(C).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=C(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(O.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)},M=e=>({message:t,context:n})=>T({retries:2,minTimeout:100,url:"https://browser-http-intake.logs.datadoghq.com/v1/input/pub44d5f4eb86e1392037b7501f7adc540e",method:"POST",type:"json",getData:async()=>{const o={ddsource:e.packageName||j,message:t,service:"build-plugins",team:"language-foundations",env:e.env,version:e.version,bundler:{name:e.bundler.name,version:e.bundler.version},metadata:e.metadata,...n};return{data:JSON.stringify(o),headers:{"Content-Type":"application/json"}}}}),N=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),_=e=>e.includes(E),I=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},F=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()},L=(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}},B=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 K=0;const U={debug:0,info:1,warn:2,error:3,none:4},H=e=>e.split(">").map(N).join(">"),W=(e,n,o,r)=>{const i=H(e);return(s,a="debug",{forward:u,context:c}={})=>{let p=t.dim,d=console.log;"error"===a?(p=t.red,d=console.error):"warn"===a?(p=t.yellow,d=console.warn):"info"===a&&(p=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=M(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){W(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}U[a]>=U[r]&&d(`${p(l)} ${f}`)}},J=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:c=[]}=i,p={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(p);const d=()=>p.spans.filter((e=>!e.end)),l=n=>{d().length||(!p.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),p.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:p,resume:l,end:e=>{f(e,!1);const n=p.spans.reduce(((e,t)=>e+(t.end-t.start)),0);p.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=d();for(const n of t)n.tags.push(...e)}else p.tags.push(...e)}}},V=(e,t,n="warn")=>o=>{const r=W(o,e,t,n);return{getLogger:r=>V(e,t,n)(`${H(o)}>${r}`),time:J(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)}},G=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],Y=(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)},Q=(e,t,n)=>{const o=e.getLogger(j);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=N(e.name);for(const r of G){const i=e[r];i&&(n[r]=Y(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},X=async e=>s.rm(e,{force:!0,maxRetries:3,recursive:!0}),Z=async e=>s.mkdir(e,{recursive:!0}),ee=(e,t)=>{var n;n=c.dirname(e),a.mkdirSync(n,{recursive:!0}),a.writeFileSync(e,t,{encoding:"utf-8"})},te=e=>a.readFileSync(e,{encoding:"utf-8"}),ne=e=>{try{return a.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},oe=async(e,t)=>{if("function"==typeof a.openAsBlob){const n=await a.openAsBlob(e,{type:t.contentType});return new i.File([n],t.filename)}{const n=o.Readable.toWeb(a.createReadStream(e)),r=await new Response(n).blob();return new i.File([r],t.filename,{type:t.contentType})}},re=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 ie=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(ie||{});const se="apps",ae="datadog-apps-plugin",ue="api/unstable/app-builder-code/apps",ce="datadog-apps-assets.zip",pe=/\.backend\.(ts|tsx|js|jsx)$/,de=async(e,t)=>{const n=(await Promise.all(e.map((e=>l.glob(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 le(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(...he(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&&ge(e.local.name,n,t),o.push(e.exported.name)}}}return o}const fe=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function me(e){return null==e||fe.has(e.type)}function he(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 ge(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 ye(e){const t=e.relativePath.split(c.sep).join("/");return`${f.createHash("sha256").update(t).digest("hex")}.${e.name}`}function be(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 we=(e,t)=>_(t)?E:t.startsWith(e)||c.isAbsolute(t)?t:c.resolve(e,t),$e=(e,t)=>{let n,o=we(process.cwd(),e);for(;!n;){const e=c.resolve(o,t);if(ne(e)&&(n=e),o=o.split(c.sep).slice(0,-1).join(c.sep),[c.sep,""].includes(o))break}return n},ve=(e,t)=>{const n=[...e].map((e=>we(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},ke=t.bold.red,xe=t.bold.yellow,Se=e=>{const t=$e(e,"package.json");if(t)try{const e=te(t);return JSON.parse(e)}catch(e){return}},Ee=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=Se(e);o||t.warn(xe("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(ke("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(ke("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 f.createHash("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(ke("Unable to compute the app identifier.")),{identifier:s,name:r}},De=t.green.bold,Pe=t.yellow.bold,je=t.cyan.bold,Ce=t.bold,Re=(e,t={},n)=>async()=>{const o=await oe(e,{contentType:"application/zip",filename:ce});return A({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ce);const t=x("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},Ae=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,x("APPS_INTAKE_URL")||`https://api.${a}/${ue}/${u}/upload`);var a,u;const c=R({bundler:t.bundlerName,plugin:"apps",version:t.version}),p=B({identifier:t.identifier,intakeUrl:s,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),d=`an archive of:\n - ${De(e.assets.length.toString())} files\n - ${De(m(e.size))}\n\nWith the configuration:\n${p}`;if(t.dryRun)return n.error(`\n${je("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${d}`),{errors:r,warnings:i};try{const r=await T({auth:{apiKey:t.apiKey,appKey:t.appKey},url:s,method:"POST",type:"json",getData:Re(e.archivePath,c,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Pe(`${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${Ce("Standalone :")}\n ${je(s)}\n\n${Ce("AppBuilder :")}\n ${je(a)}`)}const a=x("APPS_VERSION_NAME")?.trim();if(a){const e=((e,t)=>`https://api.${e}/${ue}/${t}/release/live`)(t.site,t.identifier);await T({auth:{apiKey:t.apiKey,appKey:t.appKey},url:e,method:"PUT",type:"json",getData:async()=>({data:o.Readable.from(JSON.stringify({version_id:a})),headers:{"Content-Type":"application/json",...c}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${Pe(`${t}/5`)}): ${e.message}`;i.push(o),n.warn(o)}}),n.info(`Released version ${Ce(a)} to live.`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));r.push(t)}return{errors:r,warnings:i}};function Oe(e){try{return require.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}const Te="import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';",Me=" 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 Ne(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),Oe(n)&&o.push(Te),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(Me),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 _e(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function Ie(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:[_e("dd-backend-resolve",t)]}}function Fe(e){return`${e.relativePath}/${e.name}`}async function ze(e,t,n,o,r){const i=Fe(t),s=`virtual:dd-backend-dev:${i}`,a=function(e,t,n,o){const r=[];return r.push(`import { ${e} } from ${JSON.stringify(t)};`),Oe(o??process.cwd())&&r.push(Te),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(Me),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=Ie(o,{[s]:a}),c=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:s,output:u.build.rollupOptions.output}}}),p=Array.isArray(c)?c[0]:c;if(!("output"in p))throw new Error(`Unexpected vite.build result for "${i}"`);const d="chunk"===p.output[0].type?p.output[0].code:"";return r.debug(`Bundled "${i}" (${d.length} bytes)`),d}async function Le(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:f.randomUUID(),name:t,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e}},onlyTriggerManually:!0}},template_params:{}}}}),s=await T({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 T({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 Be extends Error{constructor(e,t){super(t),this.statusCode=e}}async function Ke(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 Be(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new Be(404,`Backend function "${o}" not found`);const s=await n(i,r);return{displayName:Fe(i),code:s}}function Ue(e,t,n,o,r){const i=(t,n)=>ze(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=>[ye(e),e]))));var u;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await Ke(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){qe(t,e instanceof Be?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 Ke(e,n,o);i.debug(`Executing action: ${s} with args`);const u=await Le(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 Be?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 He=({viteBuild:e,buildRoot:t,getBackendFunctions:n,handleUpload:o,log:r,auth:i})=>({async closeBundle(){let i,a=new Map;const u=n();if(u.length>0){const n=await async function(e,t,n,o){const r=await s.mkdtemp(c.join(d.tmpdir(),"dd-apps-backend-")),i=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const s of t){const t=ye(s),a=`\0dd-backend:${t}`,u=Ne(s.name,s.absolutePath,n),p=Ie(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,a=n.outputs}try{await o(a)}finally{i&&await X(i)}},configureServer(o){o.middlewares.use(Ue(e,n,i,t,r))}});const We=t.yellow.bold,Je=t.red.bold;const Ve=({options:e,context:t,bundler:n})=>{const o=t.getLogger(ae);let r;const i=(e=>{const t=e[se]||{};return{enable:t.enable??!!e[se],include:t.include||[],dryRun:t.dryRun??!x("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:ie.MIDDLE,value:c.join(__dirname,"./apps-runtime.mjs")});const{setBackendFunctions:u,getBackendFunctions:l}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return[{name:ae,enforce:"post",transform:{filter:{id:{include:[pe],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,n){const r=le(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?`),u(n,[]),{code:"",map:null};const{functions:i,proxyCode:s}=function(e,t,n){const o=c.relative(n,t).replace(pe,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t};r.push(e),i.push({exportName:n,queryName:ye(e)})}return{functions:r,proxyCode:be(i)}}(r,n,t.buildRoot);return u(n,i),o.debug(`Generated proxy for ${n} with ${i.length} export(s)`),{code:s,map:null}}},vite:He({viteBuild:n.build,buildRoot:t.buildRoot,getBackendFunctions:l,handleUpload:async e=>{const n=o.time("handle assets");let u;try{const n=o.time("resolve identifier"),{name:r,identifier:l}=Ee(t.buildRoot,o,{url:t.git?.remote,name:i.name,identifier:i.identifier});if(!l||!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 de(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(d.tmpdir(),"dd-apps-")),n=c.join(t,ce),o=new p;for(const t of e)o.file(t.relativePath,a.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=a.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(),u=c.dirname(w.archivePath);const $=o.time("upload assets"),{errors:v,warnings:k}=await Ae(w,{apiKey:t.auth.apiKey,appKey:t.auth.appKey,bundlerName:t.bundler.name,dryRun:i.dryRun,identifier:l,name:r,site:t.auth.site,version:t.version},o);if($.end(),k.length>0&&o.warn(`${We("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(`${Je("Failed to upload assets:")}\n${e?.message||e}`)}if(u&&await X(u),n.end(),r)throw r},log:o,auth:t.auth})}]},Ge="errorTracking",Ye="datadog-error-tracking-plugin",Qe=(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}},Xe=/[/]+|[\\]+/g,Ze=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,et=(e,t)=>{const n=e.replace(Ze,"").split(Xe),o=t.replace(Ze,"").split(Xe),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},tt=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([re(e.minifiedFilePath),re(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:et(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}},nt=t.green.bold,ot=t.yellow.bold,rt=t.red.bold,it=(e,t={})=>async()=>A({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await oe(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}),st=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(h.default?h.default:h)({concurrency:t.maxConcurrency}),u=(c=n.site,x("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const p=R({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),d=B({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(p,null,2)}`}),l=`\nUploading ${nt(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 T({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:it(s,p),onRetry:(t,n)=>{const r=`Failed to upload ${ot(e.sourcemap)} | ${ot(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 ${nt(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:i,errors:r}},at=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=>({...Qe(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=>tt(e,s,i,n.git))));a.end();const c=u.map((e=>e.errors)).flat(),p=u.map((e=>e.warnings)).flat();if(p.length>0&&o.warn(`Warnings while preparing payloads:\n - ${p.join("\n - ")}`),c.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${c.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const d=o.time("Upload sourcemaps"),{errors:l,warnings:f}=await st(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 ${nt(`${e.length-l.length}/${e.length}`)} sourcemaps in ${nt(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?`${rt(e.file)} | ${rt(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()},ut=e=>{const n=t.bold.red,o=e[Ge]||{},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},ct=({options:e,context:t})=>{const n=t.getLogger(Ye),o=n.time("validate options"),r=((e,t)=>{const n=[],o=ut(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Ye}.`);const r={enable:!!e[Ge],...e[Ge],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 at(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:Ye,enforce:"post",async git(e){i=e,s&&await u()},async buildReport(t){s=t,!i&&F(e)||await u()},async asyncTrueEnd(){a||await u()}}]},pt="liveDebugger",dt="datadog-live-debugger-plugin";function lt(e){return"function"==typeof e?e:e.default}function ft(e,t,n,o,r){const i=c.relative(t,e).replace(/\\/g,"/"),s=mt(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 mt(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)?yt(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=ht(e.object,t),o=gt(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)?yt(o.key,t):null}function ht(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=ht(e.object,t),o=gt(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function gt(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function yt(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 bt(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function wt(e,t,n,o){const r=[];for(const t of e.params)for(const e of $t(t,o))"this"!==e&&r.push(e);if(n&&o.isBlockStatement(e.body)){const t=new Set(e.params.flatMap((e=>$t(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 $t(e.id,o))t.has(i)||i===n||r.push(i)}return r.length>25?r.slice(0,25):r}function $t(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:$t(e.argument,t):t.isAssignmentPattern(e)?$t(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?$t(e.argument,t):$t(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?$t(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const vt=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let kt,xt,St,Et,Dt=!1;function Pt(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 vt.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=vt.find((t=>e.message.includes(t))),n=t??vt.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 ${vt.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const jt=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function Ct(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,c=0,p=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:c,skippedFileCount:1,skippedUnsupportedCount:p,totalFunctions:d};if(!jt.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:p,totalFunctions:d};Dt||(kt=Pt("@babel/parser").parse,xt=lt(Pt("@babel/traverse")),St=Pt("@babel/types"),Et=lt(Pt("magic-string")),Dt=!0);const l=kt(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let h=0;if(xt(l,{Function(e){if(d++,!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,St))return void p++;if(r&&function(e,t,n){let o=e;for(;o;){if(bt(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return bt(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",St))return void c++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,St)))return void p++;if(s&&!mt(e,St))return void p++;let t=0;if(!mt(e,St)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=ft(n,o,e,t,St);try{const t=e.node,n=h++,o=`$dd_p${n}`,r=wt(t,0,!1,St),i=wt(t,0,!0,St),s=St.isArrowFunctionExpression(t)&&!St.isBlockStatement(t.body),a=[],c=s||!St.isBlockStatement(t.body)||!Ot(t.body.body,St);let p;if(!s&&St.isBlockStatement(t.body)&&At(t.body.body,a,St),!s&&St.isBlockStatement(t.body)&&t.body.directives.length>0){p=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,needsTrailingReturn:c,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:p,functionId:l,probeVarName:o,probeIdx:String(n),entryVars:r,exitVars:i,returns:a}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:p,totalFunctions:d};const g=new Et(t);for(let e=f.length-1;e>=0;e--)Rt(g,t,f[e]);return{code:g.toString(),map:g.generateMap({source:n,hires:!1}),failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:p,totalFunctions:d}}function Rt(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,exitVars:a,returns:u,bodyStart:c,bodyEnd:p,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=p;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(c,n),e.appendLeft(p,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??c+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(p-1,i)}}function At(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))At(o.body,t,n);else if(n.isIfStatement(o))At([o.consequent],t,n),o.alternate&&At([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))At([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)At(e.consequent,t,n);else n.isTryStatement(o)?(At(o.block.body,t,n),o.handler&&At(o.handler.body.body,t,n),o.finalizer&&At(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&At([o.body],t,n)}function Ot(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 Ot(e,t)&&Ot(o,t)}return!1}const Tt=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Mt=t.bold.red,Nt=Number(process.env.DD_LD_LIMIT)||1/0,_t=(e,t)=>{const n=t.getLogger(dt);let o=0,r=0,i=0,s=0,a=0,u=0,c=0,p=0;return{name:dt,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(p>=Nt)return{code:d};try{const n=Ct({code:d,filePath:l,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});return o+=n.instrumentedCount,c+=n.totalFunctions,r+=n.failedCount,i+=n.skippedByCommentCount,s+=n.skippedFileCount,a+=n.skippedUnsupportedCount,n.totalFunctions>0&&p++,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:()=>{c>0&&n.info(`Live Debugger: ${o}/${c} functions instrumented across ${u}/${p} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:p,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},It=({options:e,context:t})=>{const n=((e,t)=>{const n=e[pt]||{},o=[],r=e.errorTracking?.sourcemaps?.releaseVersion;if(void 0!==n.enable&&"boolean"!=typeof n.enable&&o.push(`${Mt("enable")} must be a boolean`),void 0!==n.version&&"string"!=typeof n.version&&o.push(`${Mt("version")} must be a string`),n.version&&r&&n.version!==r&&o.push(`${Mt("version")} must match ${Mt("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(`${Mt("include")} patterns must be strings or RegExp`);break}}else o.push(`${Mt("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(`${Mt("exclude")} patterns must be strings or RegExp`);break}}else o.push(`${Mt("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&o.push(`${Mt("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Tt.includes(e)){o.push(`${Mt("functionTypes")} contains invalid value "${e}". Valid values: ${Tt.join(", ")}`);break}}else o.push(`${Mt("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&o.push(`${Mt("namedOnly")} must be a boolean`),o.length)throw t.error(`\n - ${o.join("\n - ")}`),new Error(`Invalid configuration for ${dt}.`);return{enable:n.enable??!!e[pt],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(dt));return n.enable?(t.inject({type:"code",position:ie.BEFORE,injectIntoAllChunks:!0,value:"if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}"}),[_t(n,t)]):[]},Ft=[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}],zt="metrics",Lt="datadog-metrics-plugin",qt=e=>Math.floor((e||Date.now())/1e3),Bt=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),Kt=(e="")=>e.endsWith("/")?e:`${e}/`,Ut=(e,t)=>{let n=e;return e.split(Kt(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},Ht=(e,t)=>e.split("!").pop().replace(Kt(t),"./"),Wt=(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)),Ht(o||"no-name",n)},Jt=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),Vt=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Gt=t.bold.red,Yt=t.bold.cyan,Qt=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},Xt=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Qt("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:z(e.duration)}))),top:!0};n.sort(Qt("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Zt=(e,t,n)=>{const o=[];var r;n&&(o.push(...Xt("Loader",n.loaders)),o.push(...Xt("Tapable",n.tapables)),o.push(...Xt("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=I(e.build),a=new Map,u=new Map,c=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)c.has(n)||c.set(n,new Set),c.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(c.has(e.filepath)){const t=c.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),c.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=c.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const p=Array.from(i);return p.sort(Qt((e=>e.dependents.size))),t.values=p.map((e=>({name:e.name,value:e.dependents.size.toString()}))),p.sort(Qt((e=>e.dependencies.size))),n.values=p.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),p.sort(Qt("size")),o.values=p.map((e=>({name:e.name,value:m(e.size)}))),p.sort(Qt("aggregatedSize")),r.values=p.map((e=>({name:e.name,value:m(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(Qt((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Qt((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Qt((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=L(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+=` [${Gt(e.value)}] ${" ".repeat(n)}${Yt(e.name)}\n`}}return t})(o);t.info(i)},en="api/v1/series",tn=t.bold.green,nn=["onStart","onLoad","onResolve","onEnd"],on=new Map,rn=new Map,sn=new Map,an=(e,t,n)=>{const o=Object.assign({},e);for(const r of nn)o[r]=async(o,i)=>{const s=rn.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=Ht(e[0].path,n),u=sn.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=g.performance.now();try{return await i(...e)}finally{const n=g.performance.now(),i=n-c,p={start:c,end:n,duration:i,context:Vt(e)};if(s.events[r].values.push(p),s.duration+=i,s.increment+=1,rn.set(t,s),u.events[r].values.push(p),u.duration+=i,u.increment+=1,sn.set(o,u),a){const e=on.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(p),e.duration+=i,e.increment+=1,on.set(t,e)}}}))};return o},un=(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=an(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:rn,modules:sn,loaders:on};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class cn{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Wt(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Jt))(e);o.length||o.push("no-loader"),this.started[n]={module:Ut(n),timings:{start:g.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Wt(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=g.performance.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},i=n.loaders.join(",");r.events[i]=r.events[i]||{name:i,values:[]},r.events[i].values.push(n.timings),r.increment+=1,r.duration+=o,t.set(n.module,r);for(const t of n.loaders){const n=e.get(t)||{name:t,increment:0,duration:0,events:{}};n.increment+=1,n.duration+=o,e.set(t,n)}}return{loaders:e,modules:t}}}class pn{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=g.performance.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,Vt(r),i,g.performance.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=g.performance.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,Vt(r),i,g.performance.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=g.performance.now(),s=t.apply(this,r);return this.saveResult(e,n,o,Vt(r),i,g.performance.now()),s}}getTapPatch(e,t,n,o){switch(e){case"promise":return this.getPromiseTapPatch(e,t,n,o);case"async":return this.getAsyncTapPatch(e,t,n,o);default:return this.getDefaultTapPatch(e,t,n,o)}}newTap(e,t,n,o){return(r,i)=>{const s="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${s}`;if(this.monitoredTaps[u])return n.call(o,r,i);this.monitoredTaps[u]=!0;const c=this.getTapPatch(e,i,s,t);return n.call(o,r,c)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(Lt)||(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 dn=e=>async t=>{const n=e.getLogger(Lt),o={name:Lt},r=new pn(e.buildRoot),i=new cn(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})}))},ln={filters:Ft},fn=({options:e,context:t})=>{const n=t.getLogger(Lt);let o=0;const r=((e,t)=>{const n=e[zt],o=qt(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enable:!!e[zt],enableDefaultPrefix:!0,enableTracing:!1,filters:Ft,tags:[],...e[zt],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),i=[];if(!r.enable)return i;const s={name:Lt,enforce:"pre",esbuild:un(t,n),webpack:dn(t),rspack:dn(t)},a=n.time("build",{start:!1}),u=r.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let c,p;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,c=new Map,p=new Map,d=new Map;for(const e of i){for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");d.has(n)||d.set(n,[]),d.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)p.has(t.filepath)||p.set(t.filepath,[]),p.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`entryName:${e}`))),p.has(e.filepath)&&o.push(...p.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})(p,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})(c?.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})(c?.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(Bt(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Bt({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");Zt(t,n,c),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: ${tn(`https://api.${t.site}/${en}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),T({method:"POST",url:`https://api.${t.site}/${en}?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[zt]?.timestamp||(r.timestamp=qt(t.build.start))},buildEnd(){a.end(),o=Date.now()},async timings(e){c=e,p&&await d()},async buildReport(e){p=e,!c&&u||await d()}};return r.enableTracing&&i.push(s),i.push(l),i},mn="output",hn="datadog-output-plugin",gn=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,yn=e=>{const t=void 0===e;return{build:gn("build",e?.build??t),bundler:gn("bundler",e?.bundler??t),dependencies:gn("dependencies",e?.dependencies??t),errors:gn("errors",e?.errors??t),logs:gn("logs",e?.logs??t),metrics:gn("metrics",e?.metrics??t),timings:gn("timings",e?.timings??t),warnings:gn("warnings",e?.warnings??t)}},bn=(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}))}))},wn=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},$n=({options:e,context:t})=>{const n=(e=>({enable:!!e[mn],path:"./",...e[mn],files:yn(e[mn]?.files)}))(e),o=t.getLogger(hn);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 p;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await Z(c.dirname(e));const n=a.createWriteStream(e),o=new u.JsonStreamStringify(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(s,e)}catch(e){p=e}p?o.error(`Failed writing ${i}: ${p}`):o.debug(`Wrote "./${c.relative(t.buildRoot,s)}"`),e.end()})())};return[{name:hn,buildReport(e){const t=o.time("serialize report"),n=I(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:bn(o,(e=>{r("bundler",e)})),rollup:wn((e=>{r("bundler",e)})),vite:wn((e=>{r("bundler",e)})),webpack:bn(o,(e=>{r("bundler",e)}))}]},vn="rum",kn="datadog-rum-plugin",xn=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")});`,Sn="datadog-rum-privacy-plugin";const En=(e,t)=>{const n=t.getLogger(Sn),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:Sn,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=y.instrument({id:t,code:e,map:n},o);return 0===s.privacyDictionarySize?{code:e}:(r+=s.privacyDictionarySize,i++,s)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${r} entries across ${i} files`,{forward:!0,context:{dictionaryEntryCount:r,fileCount:i}})}}},Dn=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Pn=(e,t)=>{const n=e.sdk;if(n.clientToken)return Dn(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 T({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 Dn({...e,sdk:{clientToken:o,...n}})}},jn=e=>{const n=t.bold.red,o=e[vn]||{},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},Cn=e=>{const t=e[vn]||{},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},Rn=e=>{const n=t.bold.red,o=e[vn]||{},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},An=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=jn(e),r=Cn(e),i=Rn(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 ${kn}.`);const s={enable:!!e[vn],...e[vn],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(kn)),o=[];if(!n.enable)return o;if(n.sourceCodeContext&&t.inject({type:"code",position:ie.BEFORE,injectIntoAllChunks:!0,value:xn(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:ie.MIDDLE,value:c.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:ie.MIDDLE,value:Pn(n,t)})),n.privacy){t.inject({type:"file",position:ie.BEFORE,value:c.join(__dirname,"./privacy-helpers.js")});const e=En(n.privacy,t);o.push(e)}return o},On="datadog-analytics-plugin",Tn=({context:e})=>{const t=e.getLogger(On);return[{name:On,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}`)}})())}}]},Mn="datadog-async-queue-plugin",Nn=e=>{const{context:t,stores:n}=e,o=t.getLogger(Mn),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:Mn,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},_n=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("*")?l.glob.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const i=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});i.errors.length&&s.push(...i.errors.map((e=>e.text))),i.path&&o.push({name:n.name,resolved:i.path,original:n.path})}));for(const e of s)n.error(e);return await Promise.all(a),o},In=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Fn=/(\?|%3F|\|)+/gi,zn=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=Bn(e),In.lastIndex=0,In.exec(t)?.[1]||"unknown");var t},Ln=["unknown","commonjsHelpers.js",`vite${c.sep}preload-helper.js`],qn=(e,t,n)=>{const o=new Set;for(const n of e){const e=Bn(n);_(n)||e===t||Ln.includes(e)||o.add(e)}return o},Bn=e=>e.split("!").pop().split(Fn).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Kn=(e,t)=>_(t)?E:"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(Fn).shift().replace(/^((\.\.?)?[/\\])+/g,""),Un=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[we(t,e),n]))),Hn=(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 _n(n,e,t));for(const t of r){const n=Kn(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=Un(n.metafile.inputs,a),b=Un(n.metafile.outputs,a);g.end();const w=e=>{if(!_(e))return e;const t=y[we(a,e)];if(!t)return e;const n=t.imports.find((e=>!_(e.path)));return n?n.path:e},$=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(_(e))continue;const n=we(a,e),o={name:Kn(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:zn(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=we(a,e),i=Kn(s,n),u=[];for(const e of Object.keys(r.inputs)){if(_(e))continue;const n=m[we(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!u.length){const e=m[we(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:zn(n)};if(h[n]=c,"map"===c.type&&l.push(c),p.push(c),!r.entryPoint)continue;const f=m[we(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=>!_(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=we(p,t.path);if(t.external){if(E(t.path)){const e=i?d:t.path,n=x.inputs.report[e]||{filepath:e,name:Kn(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=we(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)}))}}),Wn=(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}),u=t.time("filling dependencies and dependents",{start:!1}),c=t.time("filling sourcemaps inputs",{start:!1}),p=new Map,d=new Map,l=new Map,f=new Map;return{buildStart(){f.clear(),p.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=Bn(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?we(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=Bn(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=Bn(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=we(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:zn(e)};if("map"===i.type&&y.add(i),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(Bn(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=a.statSync(e).size}catch(e){n=t.renderedLength}const o=p.get(e)||{name:Kn(h,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:zn(e)};i.inputs.push(o),p.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=Bn(e);if(!f.has(n)){b.set(we(h,n),i);continue}if(p.has(n)){t.debug(`Input report already there for ${n} from ${i.name}.`);continue}const o=p.get(n)||{name:Kn(h,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};i.inputs.push(o),p.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}.`)}u.resume();for(const[e,n]of p){const o=f.get(e);if(o){for(const e of o.dependencies){const o=p.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Kn(h,e)} of ${n.name}`)}for(const e of o.dependents){const o=p.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Kn(h,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){c.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=d.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}c.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Kn(h,e),r=d.get(e);if(!r)return p.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[Kn(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(we(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}":"${Kn(h,e.filepath)}" already reported.`),l.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(p.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)}}},Jn=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,c=new Map,p=new Map,d=[],l=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||_(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=Bn(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(p.has(e)){const n=p.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else p.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=Bn(t.request);if(p.has(n))return p.get(n);if(e.context){const t=we(Bn(e.context),n);if(p.has(t))return p.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(),p.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=Kn(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:zn(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,p=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>we(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"===zn(e))continue;const t=c.get(e)||new Set;for(const e of n)t.add(e);c.set(e,t)}}h.end();const y=n.time("building outputs");for(const t of p){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:we(e.bundler.outDir,t.name),type:zn(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){d.push(o);continue}const r=c.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of 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 c=$(r),p=Array.from(c).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"===zn(e)));for(const e of p){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?we(e.bundler.outDir,d):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:d?zn(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)}))},Vn="datadog-build-report-plugin",Gn=e=>{const{context:t}=e,n=t.getLogger(Vn);return[{name:Vn,enforce:"post",esbuild:Hn(t,n),rspack:Jn(t,Vn,n),webpack:Jn(t,Vn,n),vite:Wn(t,n),rollup:Wn(t,n)}]},Yn="datadog-bundler-report-plugin",Qn=(e,t)=>t?c.isAbsolute(t)?t:c.resolve(e,t):"",Xn=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)},Zn=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Qn(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},eo=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Xn(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=ve(r,process.cwd())),e.bundler.outDir=Qn(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),to=e=>{const{context:t}=e,n=t.getLogger(Yn);return[{name:Yn,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Qn(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Qn(t.buildRoot,c.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Zn(t),rspack:Zn(t),vite:eo(t),rollup:{options(e){let n;if("output"in e){const t=Xn(e.output);n=ve(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=we(process.cwd(),n);const e=ve([n,...o],process.cwd());t.buildRoot=e===c.sep?process.cwd():e}else t.buildRoot=ve(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=Xn(e);ve(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.")}}}]},no="datadog-custom-hooks-plugin",oo=e=>{const{context:t}=e,n=t.getLogger(no),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:no,enforce:"pre"}]};class ro{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=te(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 io=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await so(e);for(const e of t)if(e.name===n)return q(e.refs.push);return q(t[0].refs.push)},so=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},ao=async e=>e.revparse("HEAD"),uo=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),co=async e=>e.branch(),po=async e=>e.show(["-s","--format=%s"]),lo=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),fo="datadog-git-plugin",mo=e=>{const{options:t,context:n}=e,o=n.getLogger(fo),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t=[ao(e),co(e),po(e),lo(e),uo(e),io(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,c,p,d,l,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:c,date:p},committer:{name:d,email:l,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new ro(s)}})(await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=b.simpleGit(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return b.simpleGit(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:fo,enforce:"pre",buildRoot(e){if(F(t))try{r.resume();const t=$e(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}`)}}}]},ho="datadog-injection-plugin",go=/^https?:\/\//,yo=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],bo=t.bold.yellow,wo=async(e,t=process.cwd())=>(e=>s.readFile(e,{encoding:"utf-8"}))(we(t,e)),$o=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(go)?await(async(e,t=5e3)=>{let n;return Promise.race([T({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await wo(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} - ${L(r)}`;e.fallback?(t.debug(`Fallback for "${s}": ${i.toString()}`),o=await $o(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},vo=(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`},ko=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 $o(i,t,n);if(e){const t=i.position||ie.BEFORE;o.set(r,{value:e,injectIntoAllChunks:"injectIntoAllChunks"in i&&i.injectIntoAllChunks,position:t})}}return o})(t,e,o);for(const e of r.values())n.push(e)},xo=e=>e instanceof Error&&"code"in e,So=e=>yo.includes(e),Eo=(e,t,n)=>{e.warn(`"${bo(t)}" files are not supported (${bo(n)}).`)},Do=a.promises,Po=(e,t,n)=>({setup(o){const{onStart:r,onResolve:i,onLoad:u,onEnd:p,esbuild:l,initialOptions:f}=o,m=[],h=`${t.bundler.name}.${ie.MIDDLE}.${E}.js`,g=a.realpathSync(d.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 _n(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await Z(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:ho}))),u({filter:b,namespace:ho},(async()=>({contents:vo(n,{position:ie.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),p((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=vo(n,{position:ie.BEFORE}),i=vo(n,{position:ie.AFTER}),s=vo(n,{position:ie.BEFORE,onAllChunks:!0}),a=vo(n,{position:ie.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))),d=o?r:s,f=o?i:a;if(!d&&!f)continue;const h=we(t.buildRoot,n),{base:g,ext:y}=c.parse(h);So(y)?u.push((async()=>{try{const e=await Do.readFile(h,"utf-8"),t=await l.transform(e,{loader:"default",banner:d,footer:f});await Do.writeFile(h,t.code)}catch(t){if(!xo(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${h}: ${t}`)}})()):Eo(e,y,g)}await Promise.all(u)}))}}),jo=E,Co="?inject-proxy",Ro=(e,t)=>({banner(n){const o=vo(t,{position:ie.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=c.parse(n.fileName);return So(i)?o:(Eo(e,i,r),"")},async resolveId(e,n,o){if(_(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&vo(t,{position:ie.MIDDLE})){if(e.endsWith(".html"))return null;const t=await this.resolve(e,n,o);if(!t||t.external)return t;return(await this.load(t)).moduleSideEffects=!0,`${t.id}${Co}`}return null},load(e){if(_(e))return vo(t,{position:ie.MIDDLE});if(e.endsWith(Co)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(jo)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=vo(t,{position:ie.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=c.parse(n.fileName);return So(i)?o:(Eo(e,i,r),"")}}),Ao=(e,t,n,o,r)=>i=>{const s=new WeakMap,u=e.sources.ConcatSource,p=n.bundler.name,d=c.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${p}.${ie.MIDDLE}.${E}.js`);ee(d,"");i.hooks.shutdown.tap(ho,(()=>{var e;e=d,a.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await ko(t,o,r,n.buildRoot)};i.hooks.beforeRun.tapPromise(ho,l),i.hooks.watchRun.tapPromise(ho,l),i.hooks.compilation.tap(ho,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:ho,stage:o},(()=>{const e=vo(r,{position:ie.BEFORE}),o=vo(r,{position:ie.AFTER}),i=vo(r,{position:ie.BEFORE,onAllChunks:!0}),a=vo(r,{position:ie.AFTER,onAllChunks:!0});for(const r of n.chunks){let p=e,d=o;if(r.canBeInitial()||(p=i,d=a),""!==p||""!==d)for(const e of r.files){const{base:o,ext:r}=c.parse(e);So(r)?n.updateAsset(e,(e=>{const t=s.get(e);if(!t||t.banner!==p||t.footer!==d){const t=new u(p,"\n",e,"\n",d);return s.set(e,{source:t,banner:p,footer:d}),t}return t.source})):Eo(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},Oo=e=>{const{bundler:t,context:n}=e,o=n.getLogger(ho),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++K}`,e)};const s={name:ho,enforce:"post",esbuild:Po(o,n,i),webpack:Ao(t,o,n,r,i),rspack:Ao(t,o,n,r,i),rollup:Ro(o,i),vite:{...Ro(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>vo(i,{position:ie.MIDDLE})?[{tag:"script",attrs:{type:"module",src:"/@id/__datadog-helper-file"},injectTo:"head-prepend"}]:[]}}};var a;return a=n.bundler.name,["rspack","webpack"].includes(a)?s.load={filter:{id:D},handler:()=>({code:vo(i,{position:ie.MIDDLE})})}:s.buildStart=async()=>{await ko(o,r,i,n.buildRoot)},[s]},To="datadog-true-end-plugin",Mo=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(To,r)},s={async writeBundle(){},async closeBundle(){await r()}};return[{name:To,enforce:"post",webpack:i,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:s,rollup:s,rspack:i}]},No={[zt]:ln},_o=t.bold.red;var Io="3.1.4";const Fo=(({bundler:t,version:n})=>{const o=Date.now();return e.createUnplugin(((e,r)=>{const i=Date.now(),s=((e={})=>{const t={site:x("SITE")||e.auth?.site||"datadoghq.com"};return Object.defineProperty(t,"apiKey",{value:x("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(t,"appKey",{value:x("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:t}})(e);"esbuild"===r.framework&&(r.esbuildHostName=j);const a=process.env.BUILD_PLUGINS_ENV||"production",u=P.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,p=r.framework,d={bundler:{name:p,version:c},env:u,metadata:s.metadata||{},packageName:`@datadog/${p}-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:V(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:M(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(j);const g=[];g.push(["analytics",Tn],["async-queue",Nn],["build-report",Gn],["bundler-report",to],["custom-hooks",oo],["git",mo],["injection",Oo],["true-end",Mo]),s.customPlugins&&g.push(["custom",s.customPlugins]),g.push(["apps",Ve],["error-tracking",ct],["live-debugger",It],["metrics",fn],["output",$n],["rum",An]);for(const[e,n]of g)f.plugins.push(...Q(f,n,e)({bundler:t,context:f,options:s,data:d,stores:l}));return(e=>{const t=[];for(const n of k){const o=S(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>v(e))).join(" and "),i=v(`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: ${_o(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),h.end(),f.plugins}))})({bundler:w,version:Io}).esbuild,zo=Io,Lo=No;exports.datadogEsbuildPlugin=Fo,exports.helpers=Lo,exports.version=zo;
|
|
2
2
|
//# sourceMappingURL=index.js.map
|