@datadog/webpack-plugin 3.1.0 → 3.1.2-dev.0

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.
@@ -18,11 +18,13 @@ type AppsOptions = {
18
18
  dryRun?: boolean;
19
19
  identifier?: string;
20
20
  name?: string;
21
+ /** Source directory (relative to project root) to scan for backend function files. */
22
+ backendDir?: string;
21
23
  };
22
24
 
23
- declare const CONFIG_KEY$4: "apps";
25
+ declare const CONFIG_KEY$5: "apps";
24
26
 
25
- type types$4 = {
27
+ type types$5 = {
26
28
  AppsOptions: AppsOptions;
27
29
  };
28
30
 
@@ -40,12 +42,29 @@ type ErrorTrackingOptions = {
40
42
  sourcemaps?: SourcemapsOptions;
41
43
  };
42
44
 
43
- declare const CONFIG_KEY$3: "errorTracking";
45
+ declare const CONFIG_KEY$4: "errorTracking";
44
46
 
45
- type types$3 = {
47
+ type types$4 = {
46
48
  ErrorTrackingOptions: ErrorTrackingOptions;
47
49
  };
48
50
 
51
+ declare const VALID_FUNCTION_KINDS: readonly ["functionDeclaration", "functionExpression", "arrowFunction", "objectMethod", "classMethod", "classPrivateMethod"];
52
+ type FunctionKind = (typeof VALID_FUNCTION_KINDS)[number];
53
+ type LiveDebuggerOptions = {
54
+ enable?: boolean;
55
+ include?: (string | RegExp)[];
56
+ exclude?: (string | RegExp)[];
57
+ honorSkipComments?: boolean;
58
+ functionTypes?: FunctionKind[];
59
+ namedOnly?: boolean;
60
+ };
61
+
62
+ declare const CONFIG_KEY$3: "liveDebugger";
63
+
64
+ type types$3 = {
65
+ LiveDebuggerOptions: LiveDebuggerOptions;
66
+ };
67
+
49
68
  type Filter = (metric: Metric) => Metric | null;
50
69
  type MetricsOptions = {
51
70
  enable?: boolean;
@@ -318,8 +337,9 @@ interface BaseOptions {
318
337
  logLevel?: LogLevel;
319
338
  }
320
339
  interface Options extends BaseOptions {
321
- [CONFIG_KEY$4]?: AppsOptions;
322
- [CONFIG_KEY$3]?: ErrorTrackingOptions;
340
+ [CONFIG_KEY$5]?: AppsOptions;
341
+ [CONFIG_KEY$4]?: ErrorTrackingOptions;
342
+ [CONFIG_KEY$3]?: LiveDebuggerOptions;
323
343
  [CONFIG_KEY$2]?: MetricsOptions;
324
344
  [CONFIG_KEY$1]?: OutputOptions;
325
345
  [CONFIG_KEY]?: RumOptions;
@@ -387,4 +407,4 @@ declare const helpers: {
387
407
  };
388
408
  };
389
409
 
390
- export { type types$4 as AppsTypes, type types$3 as ErrorTrackingTypes, type types$2 as MetricsTypes, type types$1 as OutputTypes, type types as RumTypes, type WebpackPluginOptions, datadogWebpackPlugin, helpers, version };
410
+ export { type types$5 as AppsTypes, type types$4 as ErrorTrackingTypes, type types$3 as LiveDebuggerTypes, type types$2 as MetricsTypes, type types$1 as OutputTypes, type types as RumTypes, type WebpackPluginOptions, datadogWebpackPlugin, helpers, version };
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"),s=require("zlib"),r=require("buffer"),i=require("fs/promises"),a=require("fs"),u=require("json-stream-stringify"),p=require("path"),c=require("jszip"),l=require("os"),d=require("glob"),m=require("crypto"),f=require("pretty-bytes"),h=require("p-queue"),g=require("perf_hooks"),y=require("@datadog/js-instrumentation-wasm"),b=require("simple-git"),w=require("webpack");const v=t.bold.green,$=t.bold.yellow,k=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","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},D="__datadog-helper-file",x=new RegExp(D),R=["development","production","test"],P="datadog-build-plugins",j=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),T=async e=>{const{getForm:t,defaultHeaders:n={},zip:r=!0}=e,i=await t(),a=new Request("fake://url",{method:"POST",body:i}),u=o.Readable.fromWeb(a.body);return{data:r?u.pipe(s.createGzip()):u,headers:{"Content-Encoding":r?"gzip":"multipart/form-data",...n,...Object.fromEntries(a.headers.entries())}}},M=[400,403,413],O=e=>{const{auth:t,url:o,method:s="GET",getData:r,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:s,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 r){const{data:t,headers:o}=await r();e.body=t,n={...n,...o}}a=await fetch(o,{...e,headers:n})}catch(t){return e(t),{}}if(!a.ok){const t=`HTTP ${a.status} ${a.statusText}`;if(M.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)},A=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||P,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,""),C=e=>e.includes(D),z=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},_=e=>{const t=Math.floor(e/1e3/60/60/24),n=new Date(e-24*t*60*60*1e3),o=n.getUTCHours(),s=n.getUTCMinutes(),r=n.getUTCSeconds(),i=n.getUTCMilliseconds(),a=`${t?`${t}d `:""}${o?`${o}h `:""}${s?`${s}m `:""}${r?`${r}s`:""}`.trim();return`${a}${!a||i?` ${i}ms`:""}`.trim()},F=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),s=Math.min(10,Math.floor(o/2)),r=o-s;return`${e.slice(0,s)}${n}${e.slice(-r)}`},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 H={debug:0,info:1,warn:2,error:3,none:4},U=e=>e.split(">").map(N).join(">"),W=(e,n,o,s)=>{const r=U(e);return(i,a="debug",{forward:u,context:p}={})=>{let c=t.dim,l=console.log;"error"===a?(c=t.red,l=console.error):"warn"===a?(c=t.yellow,l=console.warn):"info"===a&&(c=t.cyan,l=console.log);const d=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${r}]`,m="string"==typeof i?i:JSON.stringify(i,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:m,time:Date.now()}),"error"===a&&o.errors.push(m),"warn"===a&&o.warnings.push(m),u){const t=async()=>{try{const t=A(n);await t({message:m,context:{plugin:e,status:a,...p}})}catch(t){W(e,n,o,s)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}H[a]>=H[s]&&l(`${c(d)} ${m}`)}},B=(e,n,o)=>(s,r={})=>{const{level:i="debug",start:a=!0,log:u=!0,tags:p=[]}=r,c={pluginName:e,label:s,spans:[],tags:[...p,`plugin:${e}`,`level:${i}`],logLevel:i,total:0};n.push(c);const l=()=>c.spans.filter((e=>!e.end)),d=n=>{l().length||(!c.spans.length&&u&&o(t.dim(`[${t.cyan(s)}] : start`),"debug"),c.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},m=(e,n=!0)=>{const r=l();if(r?.length){r.length>1&&o(`Timer ${t.cyan(s)} has more than one ongoing span.`,"debug");for(const t of r)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(s)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),d(e)}return{timer:c,resume:d,end:e=>{m(e,!1);const n=c.spans.reduce(((e,t)=>e+(t.end-t.start)),0);c.total=n,u&&o(`[${t.cyan(s)}] : ${t.cyan(_(n))}`,i)},pause:m,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=l();for(const n of t)n.tags.push(...e)}else c.tags.push(...e)}}},G=(e,t,n="warn")=>o=>{const s=W(o,e,t,n);return{getLogger:s=>G(e,t,n)(`${U(o)}>${s}`),time:B(o,t.timings,s),error:(e,t)=>s(e,"error",t),warn:(e,t)=>s(e,"warn",t),info:(e,t)=>s(e,"info",t),debug:(e,t)=>s(e,"debug",t)}},J=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],V=(e,t,n,o)=>{const s=n=>function(...s){const r=o.time(`${e} | ${t}`,{log:!1,tags:["type:hook",`hook:${t}`]}),i=n.apply(this,s);return i instanceof Promise?i.finally((()=>{r.end()})):(r.end(),i)};return"object"==typeof n&&null!==n&&"handler"in n?{...n,handler:s(n.handler)}:s(n)},Y=(e,t,n)=>{const o=e.getLogger(P);return e=>{const s=o.time(`hook | init ${n}`,{log:!1}),r=t(e).map((e=>((e,t)=>{const n={...e},o=N(e.name);for(const s of J){const r=e[s];r&&(n[s]=V(o,s,r,t))}return n})(e,o))),i=r.map((e=>`plugin:${e.name}`));return s.tag(i),s.end(),r}},Q=async e=>i.mkdir(e,{recursive:!0}),X=(e,t)=>{var n;n=p.dirname(e),a.mkdirSync(n,{recursive:!0}),a.writeFileSync(e,t,{encoding:"utf-8"})},Z=e=>a.readFileSync(e,{encoding:"utf-8"}),ee=e=>{try{return a.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},te=async(e,t)=>{if("function"==typeof a.openAsBlob){const n=await a.openAsBlob(e,{type:t.contentType});return new r.File([n],t.filename)}{const n=o.Readable.toWeb(a.createReadStream(e)),s=await new Response(n).blob();return new r.File([s],t.filename,{type:t.contentType})}},ne=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},oe="apps",se="datadog-apps-plugin",re="datadog-apps-assets.zip",ie=async(e,t)=>{const n=(await Promise.all(e.map((e=>d.glob(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>p.relative(t,e))),s=(e=>{if(0===e.length)return"";const t=e[0].split(p.sep);let n="";for(let o=0;o<t.length-1;o++){const s=t.slice(0,o+1).join(p.sep);if(!e.every((e=>e.startsWith(`${s}${p.sep}`))))break;n=s}return n})(o),r=o.map(((e,t)=>{const o=s?e.slice(s.length+1):e;return{absolutePath:n[t],relativePath:o}}));return r},ae=(e,t)=>C(t)?D:t.startsWith(e)||p.isAbsolute(t)?t:p.resolve(e,t),ue=(e,t)=>{let n,o=ae(process.cwd(),e);for(;!n;){const e=p.resolve(o,t);if(ee(e)&&(n=e),o=o.split(p.sep).slice(0,-1).join(p.sep),[p.sep,""].includes(o))break}return n},pe=(e,t)=>{const n=[...e].map((e=>ae(t||process.cwd(),e).split(p.sep))),o=n.length?Math.min(...n.map((e=>e.length))):0,s=[];for(let e=0;e<o;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;s.push(t)}return s.length>0&&s.join(p.sep)||p.sep},ce=t.bold.red,le=t.bold.yellow,de=e=>{const t=ue(e,"package.json");if(t)try{const e=Z(t);return JSON.parse(e)}catch(e){return}},me=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=de(e);o||t.warn(le("No package.json found to infer the app name."));const s=n?.name||o?.name?.trim();s||t.error(ce("Unable to determine the app name to compute the app identifier."));const r=((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);r||t.error(ce("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 m.createHash("md5").update(n).digest("hex")})(r,s);return i&&s||t.error(ce("Unable to compute the app identifier.")),{identifier:i,name:s}},fe=t.green.bold,he=t.yellow.bold,ge=t.cyan.bold,ye=t.bold,be=(e,t={},n)=>async()=>{const o=await te(e,{contentType:"application/zip",filename:re});return T({getForm:()=>{const e=new FormData;return e.append("name",n),e.append("bundle",o,re),e},defaultHeaders:t,zip:!1})},we=async(e,t,n)=>{const o=[],s=[];if(!t.apiKey||!t.appKey)return o.push(new Error("Missing authentication token, need both app and api keys.")),{errors:o,warnings:s};if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:s};const r=(i=t.site,a=t.identifier,S("APPS_INTAKE_URL")||`https://api.${i}/api/unstable/app-builder-code/apps/${a}/upload`);var i,a;const u=j({bundler:t.bundlerName,plugin:"apps",version:t.version}),p=q({identifier:t.identifier,intakeUrl:r,defaultHeaders:`\n${JSON.stringify(u,null,2)}`}),c=`an archive of:\n - ${fe(e.assets.length.toString())} files\n - ${fe(f(e.size))}\n\nWith the configuration:\n${p}`;if(t.dryRun)return n.error(`\n${ge("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${c}`),{errors:o,warnings:s};try{const o=await O({auth:{apiKey:t.apiKey,appKey:t.appKey},url:r,method:"POST",type:"json",getData:be(e.archivePath,u,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${he(`${t}/5`)}): ${e.message}`;s.push(o),n.warn(o)}});if(n.debug(`Uploaded ${c}\n`),o.version_id&&o.application_id&&o.app_builder_id){const{version_id:e,application_id:s,app_builder_id:r}=o,i=`https://api.${t.site}/api/unstable/app-builder-code/apps/serve/${s}/v/${e}/index.html`,a=`https://app.${t.site}/app-builder/apps/${r}`;n.info(`Your application is available at:\n${ye("Standalone :")}\n ${ge(i)}\n\n${ye("AppBuilder :")}\n ${ge(a)}`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));o.push(t)}return{errors:o,warnings:s}},ve=t.yellow.bold,$e=t.red.bold,ke=({options:e,context:t})=>{const n=t.getLogger(se);let o;const s=(e=>{const t=e[oe]||{};return{enable:t.enable??!!e[oe],include:t.include||[],dryRun:t.dryRun??!1,identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim()}})(e);if(!s.enable)return[];const r=async()=>{const e=n.time("handle assets");let r;try{const e=n.time("resolve identifier"),{name:o,identifier:u}=me(t.buildRoot,n,{url:t.git?.remote,name:s.name,identifier:s.identifier});if(!u||!o)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 d=p.relative(t.buildRoot,t.bundler.outDir),m=[...s.include,`${d}/**/*`],f=await ie(m,t.buildRoot);if(!f.length)return void n.debug("No assets to upload.");const h=n.time("archive assets"),g=await(async e=>{const t=await i.mkdtemp(p.join(l.tmpdir(),"dd-apps-")),n=p.join(t,re),o=new c;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 s=a.createWriteStream(n),r=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});r.on("error",t),s.on("error",t),s.on("close",e),r.pipe(s)}));const{size:s}=await i.stat(n);return{archivePath:n,size:s,assets:e}})(f);h.end(),r=p.dirname(g.archivePath);const y=n.time("upload assets"),{errors:b,warnings:w}=await we(g,{apiKey:t.auth.apiKey,appKey:t.auth.appKey,bundlerName:t.bundler.name,dryRun:s.dryRun,identifier:u,name:o,site:t.auth.site,version:t.version},n);if(y.end(),w.length>0&&n.warn(`${ve("Warnings while uploading assets:")}\n - ${w.join("\n - ")}`),b.length>0){const e=b.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){o=e,n.error(`${$e("Failed to upload assets:")}\n${e?.message||e}`)}if(r&&await(async e=>i.rm(e,{force:!0,maxRetries:3,recursive:!0}))(r),e.end(),o)throw o};return[{name:se,enforce:"post",async asyncTrueEnd(){await r()}}]},Se="errorTracking",Ee="datadog-error-tracking-plugin",De=(e,n,o)=>{if(".map"!==p.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const s=o.replace(/\.map$/,""),r=p.relative(n,s),i=((e,t)=>{if(e.startsWith("/"))return p.join(e,t);try{const n=e.replace(/\/*$/,"/"),o=new URL(n),s=t.replace(/^[\\/]*/,"");return new URL(s,o).href}catch{return`${e}${t}`}})(e,r);return{minifiedFilePath:s,minifiedUrl:i,relativePath:r}},xe=/[/]+|[\\]+/g,Re=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Pe=(e,t)=>{const n=e.replace(Re,"").split(xe),o=t.replace(Re,"").split(xe),s=n.join("/");let r="";for(let e=0;e<o.length;e+=1){const t=o.slice(-e).join("/");s.startsWith(t)&&(r=t)}return r},je=async(e,t,n,o)=>{const s=await(async(e,t)=>{const[n,o]=await Promise.all([ne(e.minifiedFilePath),ne(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Pe(e.relativePath,t)}})(e,n),r=[],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(`${p.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 s.file.empty&&r.push(`Minified file is empty: ${e.minifiedFilePath}`),s.file.exists||r.push(`Minified file not found: ${e.minifiedFilePath}`),s.sourcemap.empty&&r.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),s.sourcemap.exists||r.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),s.repeatedPrefix&&i.push(`The minified file path contains a repeated pattern with the minified path prefix: ${s.repeatedPrefix}`),{content:a,errors:r,warnings:i}},Te=t.green.bold,Me=t.yellow.bold,Oe=t.red.bold,Ae=(e,t={})=>async()=>T({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await te(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}),Ne=async(e,t,n,o)=>{const s=[],r=[];if(!n.apiKey)return s.push({error:new Error("No authentication token provided")}),{errors:s,warnings:r};if(0===e.length)return r.push("No sourcemaps to upload"),{errors:s,warnings:r};const i=o.time("Queue uploads"),a=new(h.default?h.default:h)({concurrency:t.maxConcurrency}),u=(p=n.site,S("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${p}/api/v2/srcmap`);var p;const c=j({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),l=q({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),d=`\nUploading ${Te(e.length.toString())} sourcemaps with configuration:\n${l}`;o.debug(d);const m=[];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,".")};m.push(a.add((async()=>{try{await O({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:Ae(i,c),onRetry:(t,n)=>{const s=`Failed to upload ${Me(e.sourcemap)} | ${Me(e.file)}:\n ${t.message}\nRetrying ${n}/5`;r.push(s),o.debug(s)}})}catch(n){if(s.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}return i.end(),o.debug(`Queued ${Te(e.length.toString())} uploads.`),await Promise.all(m),await a.onIdle(),{warnings:r,errors:s}},Ce=async(e,t,n)=>{const o=n.time("get sourcemaps files"),s=((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=>({...De(e.minifiedPathPrefix,t.outDir,n),sourcemapFilePath:n,minifiedPathPrefix:e.minifiedPathPrefix})))})(e.sourcemaps,{outDir:t.outDir,outputs:t.outputs});o.end();const r=n.time("send sourcemaps");await(async(e,t,n,o)=>{const s=Date.now(),r=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=>je(e,i,r,n.git))));a.end();const p=u.map((e=>e.errors)).flat(),c=u.map((e=>e.warnings)).flat();if(c.length>0&&o.warn(`Warnings while preparing payloads:\n - ${c.join("\n - ")}`),p.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${p.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const l=o.time("Upload sourcemaps"),{errors:d,warnings:m}=await Ne(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site},o);if(l.end(),o.debug(`Done uploading ${Te(`${e.length-d.length}/${e.length}`)} sourcemaps in ${Te(_(Date.now()-s))}.`),d.length>0){const e=`Failed to upload some sourcemaps:\n - ${d.map((({metadata:e,error:t})=>{const n=t.cause||t.stack||t.message;return e?`${Oe(e.file)} | ${Oe(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}m.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${m.join("\n - ")}`)})(s,e.sourcemaps,{apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,site:t.site,version:t.version},n),r.end()},ze=e=>{const n=t.bold.red,o=e[Se]||{},s={errors:[]};if(o.sourcemaps){o.sourcemaps.releaseVersion||s.errors.push(`${n("sourcemaps.releaseVersion")} is required.`),o.sourcemaps.service||s.errors.push(`${n("sourcemaps.service")} is required.`),o.sourcemaps.minifiedPathPrefix||s.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)||s.errors.push(`${n("sourcemaps.minifiedPathPrefix")} must be a valid URL or start with '/'.`));const e={bailOnError:!1,dryRun:!1,maxConcurrency:20,...o.sourcemaps};s.config=e}return s},Ie=({options:e,context:t})=>{const n=t.getLogger(Ee),o=n.time("validate options"),s=((e,t)=>{const n=[],o=ze(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Ee}.`);const s={enable:!!e[Se],...e[Se],sourcemaps:void 0};return o.config&&(s.sourcemaps=o.config),s})(e,n);if(o.end(),!s.enable)return[];let r,i,a=!1;const u=async()=>{if(!s.sourcemaps||a)return;a=!0;const e=n.time("sourcemaps process");await Ce(s,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:r,outDir:t.bundler.outDir,outputs:i?.outputs||[],site:t.auth.site,version:t.version},n),e.end()};return[{name:Ee,enforce:"post",async git(e){r=e,i&&await u()},async buildReport(t){i=t,!r&&I(e)||await u()},async asyncTrueEnd(){a||await u()}}]},_e=[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}],Fe="metrics",Le="datadog-metrics-plugin",qe=e=>Math.floor((e||Date.now())/1e3),Ke=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),He=(e="")=>e.endsWith("/")?e:`${e}/`,Ue=(e,t)=>{let n=e;return e.split(He(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},We=(e,t)=>e.split("!").pop().replace(He(t),"./"),Be=(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)),We(o||"no-name",n)},Ge=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),Je=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Ve=t.bold.red,Ye=t.bold.cyan,Qe=e=>(t,n)=>{let o,s;return"function"==typeof e?(o=e(t),s=e(n)):(o=t[e],s=n[e]),o>s?-1:o<s?1:0},Xe=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Qe("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:_(e.duration)}))),top:!0};n.sort(Qe("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Ze=(e,t,n)=>{const o=[];var s;n&&(o.push(...Xe("Loader",n.loaders)),o.push(...Xe("Tapable",n.tapables)),o.push(...Xe("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},s={name:"Module aggregated size",values:[],top:!0},r=new Set,i=z(e.build),a=new Map,u=new Map,p=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)p.has(n)||p.set(n,new Set),p.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(p.has(e.filepath)){const t=p.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),p.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=p.get(e)||new Set;let s=t.size;for(const e of n)s+=a.get(e)?.size||0;r.add({name:t.name,size:t.size,aggregatedSize:s,dependents:o,dependencies:n})}if(!r.size)return[t,n,o];const c=Array.from(r);return c.sort(Qe((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort(Qe((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort(Qe("size")),o.values=c.map((e=>({name:e.name,value:f(e.size)}))),c.sort(Qe("aggregatedSize")),s.values=c.map((e=>({name:e.name,value:f(e.aggregatedSize||e.size)}))),[t,n,o,s]})(e)),o.push(...(s=e,[{name:"Asset size",values:(s.build.outputs||[]).filter((e=>"map"!==e.type)).sort(Qe((e=>e.size))).map((e=>({name:e.name,value:f(e.size)}))),top:!0},{name:"Entry aggregated size",values:(s.build.entries||[]).sort(Qe((e=>e.size))).map((e=>({name:e.name,value:f(e.size)}))),top:!0},{name:"Entry number of modules",values:(s.build.entries||[]).sort(Qe((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,s=e.build.warnings.length,r=e.build.errors.length,i=e.build.entries?e.build.entries.length:0;return e.build.start&&t.values.push({name:"Overhead duration",value:_(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:_(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:_(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:s.toString()},{name:"Number of errors",value:r.toString()}),[t]})(e));const r=(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=F(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))))),s=Math.max(...e.flatMap((e=>e.values.map((e=>e.value.length))))),r=Math.max(n+4,o+s+4);for(const n of e){if(0===n.values.length)continue;const e=r-(n.name.length+4);t+=`\n== ${n.name} ${"=".repeat(e)}=\n`;for(const e of n.values){const n=s-e.value.length;t+=` [${Ve(e.value)}] ${" ".repeat(n)}${Ye(e.name)}\n`}}return t})(o);t.info(r)},et="api/v1/series",tt=t.bold.green,nt=["onStart","onLoad","onResolve","onEnd"],ot=new Map,st=new Map,rt=new Map,it=(e,t,n)=>{const o=Object.assign({},e);for(const s of nt)o[s]=async(o,r)=>{const i=st.get(t)||{name:t,increment:0,duration:0,events:{}};i.events[s]=i.events[s]||{name:s,values:[]};const a="onLoad"===s;return(0,e[s])(o,(async(...e)=>{const o=We(e[0].path,n),u=rt.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[s]=u.events[s]||{name:s,values:[]};const p=g.performance.now();try{return await r(...e)}finally{const n=g.performance.now(),r=n-p,c={start:p,end:n,duration:r,context:Je(e)};if(i.events[s].values.push(c),i.duration+=r,i.increment+=1,st.set(t,i),u.events[s].values.push(c),u.duration+=r,u.increment+=1,rt.set(o,u),a){const e=ot.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[s]=e.events[s]||{name:s,values:[]},e.events[s].values.push(c),e.duration+=r,e.increment+=1,ot.set(t,e)}}}))};return o},at=(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 s=>{const r=it(s,o.name,t);await n({...r,initialOptions:{...r.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:s,loaders:r,modules:i}={plugins:st,modules:rt,loaders:ot};o.end(),await e.asyncHook("timings",{tapables:s,loaders:r,modules:i})}))}});class ut{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Be(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Ge))(e);o.length||o.push("no-loader"),this.started[n]={module:Ue(n),timings:{start:g.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Be(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,s=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},r=n.loaders.join(",");s.events[r]=s.events[r]||{name:r,values:[]},s.events[r].values.push(n.timings),s.increment+=1,s.duration+=o,t.set(n.module,s);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 pt{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,s,r){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:s,end:r,duration:r-s,context:o,type:e}),i.duration+=r-s,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(...s)=>{this.checkNewHooks();const r=g.performance.now(),i=t.apply(this,s),a=()=>{this.saveResult(e,n,o,Je(s),r,g.performance.now())};return i.then(a,a),i}}getAsyncTapPatch(e,t,n,o){return(...s)=>{this.checkNewHooks();const r=g.performance.now(),i=s.pop();return t.apply(this,[...s,(...t)=>(this.saveResult(e,n,o,Je(s),r,g.performance.now()),i(...t))])}}getDefaultTapPatch(e,t,n,o){return(...s)=>{this.checkNewHooks();const r=g.performance.now(),i=t.apply(this,s);return this.saveResult(e,n,o,Je(s),r,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(s,r)=>{const i="string"==typeof(a=s)?a:a.name;var a;const u=`${t}-${i}`;if(this.monitoredTaps[u])return n.call(o,s,r);this.monitoredTaps[u]=!0;const p=this.getTapPatch(e,r,i,t);return n.call(o,s,p)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(Le)||(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 ct=e=>async t=>{const n=e.getLogger(Le),o={name:Le},s=new pt(e.buildRoot),r=new ut(e.buildRoot),i=n.time("parse compiler hooks");s.throughHooks(t),i.end(),t.hooks.thisCompilation.tap(o,(e=>{const t=n.time("parse compilation hooks");s.throughHooks(e),t.end(),e.hooks.buildModule.tap(o,(t=>{r.startModule(t,e)})),e.hooks.succeedModule.tap(o,(t=>{r.doneModule(t,e)})),e.hooks.failedModule&&e.hooks.failedModule.tap(o,(t=>{r.doneModule(t,e)}))})),t.hooks.afterEmit.tapPromise(o,(async()=>{const{timings:t}=s.getResults(),{loaders:n,modules:o}=r.getResults();await e.asyncHook("timings",{tapables:t,loaders:n,modules:o})}))},lt={filters:_e},dt=({options:e,context:t})=>{const n=t.getLogger(Le);let o=0;const s=((e,t)=>{const n=e[Fe],o=qe(n?.timestamp);let s=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(s+=s?`.${n.prefix}`:n.prefix),{enable:!!e[Fe],enableDefaultPrefix:!0,enableTracing:!1,filters:_e,tags:[],...e[Fe],timestamp:o,prefix:s.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),r=[];if(!s.enable)return r;const i={name:Le,enforce:"pre",esbuild:at(t,n),webpack:ct(t),rspack:ct(t)},a=n.time("build",{start:!1}),u=s.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let p,c;const l=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"),r=s.timestamp,i=n.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],s=e.outputs||[],r=e.entries||[],i=e.warnings.length,a=e.errors.length,u=e.duration,p=new Map,c=new Map,l=new Map;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);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");l.has(n)||l.set(n,[]),l.get(n).push(e.name)}}for(const e of s)for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,s.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,r.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}`];p.has(e.filepath)&&o.push(...p.get(e.filepath).map((e=>`entryName:${e}`))),c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of s){const o=[`assetName:${e.name}`,`assetType:${e.type}`],s=e.filepath.replace(/\.map$/,"");l.has(s)&&o.push(...l.get(s).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 r){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(c,r);i.end();const u=n.time("aggregate plugins metrics"),l=((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,s=0;for(const r of Object.values(o.events)){let i=0;s+=r.values.length;for(const t of r.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:${r.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,r.values.length]],tags:[`pluginName:${o.name}`,`hookName:${r.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,s]],tags:[`pluginName:${o.name}`]})}return n})(p?.tapables,r);u.end();const d=n.time("aggregate loaders metrics"),m=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(p?.loaders,r);d.end();const f=((e,t,n,o,s)=>{const r=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}r.add(Ke(e,o,s))}const i=Array.from(r).filter((e=>e.toSend)).length;return r.add(Ke({metric:"metrics.count",type:"count",points:[[t,i+1]],tags:[],toSend:!0},o,s)),r})(new Set([...a,...l,...m]),r,s.filters,s.tags,s.prefix);await t.asyncHook("metrics",f),e.end();const h=n.time("outputing report");Ze(t,n,p),h.end();const g=n.time("sending metrics to Datadog");await((e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.debug("No metrics to send.");const o=Array.from(e).filter((e=>e.toSend)).map((e=>({...e,toSend:void 0}))),s=new Map;for(const e of o)s.has(e.metric)||s.set(e.metric,0),s.set(e.metric,s.get(e.metric)+1);const r=Array.from(s.entries()).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>`${e} - ${t}`));return n.debug(`\nSending ${o.length} metrics with configuration:\n - intake: ${tt(`https://api.${t.site}/${et}`)}\n\nMetrics:\n - ${r.join("\n - ")}`),O({method:"POST",url:`https://api.${t.site}/${et}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))})(f,{apiKey:t.auth.apiKey,site:t.auth.site},n),g.end()},d={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){a.resume(),t.build.start=t.build.start||Date.now(),e[Fe]?.timestamp||(s.timestamp=qe(t.build.start))},buildEnd(){a.end(),o=Date.now()},async timings(e){p=e,c&&await l()},async buildReport(e){c=e,!p&&u||await l()}};return s.enableTracing&&r.push(i),r.push(d),r},mt="output",ft="datadog-output-plugin",ht=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,gt=e=>{const t=void 0===e;return{build:ht("build",e?.build??t),bundler:ht("bundler",e?.bundler??t),dependencies:ht("dependencies",e?.dependencies??t),errors:ht("errors",e?.errors??t),logs:ht("logs",e?.logs??t),metrics:ht("metrics",e?.metrics??t),timings:ht("timings",e?.timings??t),warnings:ht("warnings",e?.warnings??t)}},yt=(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}))}))},bt=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},wt=({options:e,context:t})=>{const n=(e=>({enable:!!e[mt],path:"./",...e[mt],files:gt(e[mt]?.files)}))(e),o=t.getLogger(ft);if(!n.enable)return[];const s=(e,s)=>{const r=n.files[e];if(!s||!1===r)return;t.queue((async()=>{const e=o.time(`output ${r}`),i=((e,t,n)=>{const o=p.isAbsolute(t)?t:p.resolve(e,t);return p.resolve(o,n)})(t.bundler.outDir,n.path,r);let c;try{const e="function"==typeof s?await s():s;await(async(e,t)=>{await Q(p.dirname(e));const n=a.createWriteStream(e),o=new u.JsonStreamStringify(t,void 0,2),s=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),s})(i,e)}catch(e){c=e}c?o.error(`Failed writing ${r}: ${c}`):o.debug(`Wrote "./${p.relative(t.buildRoot,i)}"`),e.end()})())};return[{name:ft,buildReport(e){const t=o.time("serialize report"),n=z(e);t.end(),s("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}),s("logs",n.logs),s("timings",n.timings),s("dependencies",n.inputs),s("errors",n.errors),s("warnings",n.warnings)},metrics(e){s("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{s("bundler",e.metafile)}))}},rspack:yt(o,(e=>{s("bundler",e)})),rollup:bt((e=>{s("bundler",e)})),vite:bt((e=>{s("bundler",e)})),webpack:yt(o,(e=>{s("bundler",e)}))}]};var vt=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(vt||{});const $t="rum",kt="datadog-rum-plugin",St=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")});`,Et="datadog-rum-privacy-plugin";const Dt=(e,t)=>{const n=t.getLogger(Et),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 s=0,r=0;return{name:Et,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}:(s+=i.privacyDictionarySize,r++,i)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${s} entries across ${r} files`,{forward:!0,context:{dictionaryEntryCount:s,fileCount:r}})}}},xt=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Rt=(e,t)=>{const n=e.sdk;if(n.clientToken)return xt(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 xt({...e,sdk:{clientToken:o,...n}})}},Pt=e=>{const n=t.bold.red,o=e[$t]||{},s={errors:[]};if(!o.sdk)return s;o.sdk.applicationId||s.errors.push(`Missing ${n("applicationId")} in the SDK configuration.`),e.auth.apiKey&&e.auth.appKey||o.sdk.clientToken||s.errors.push(`Missing ${n('"auth.apiKey"')} and/or ${n('"auth.appKey"')} to fetch missing client token.`);const r={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 s.config={...r,...o.sdk},s},jt=e=>{const t=e[$t]||{},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},Tt=e=>{const n=t.bold.red,o=e[$t]||{},s={errors:[]};if(!o.sourceCodeContext)return s;const r=o.sourceCodeContext;return r?.service&&"string"==typeof r.service||s.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),s.config=r,s},Mt=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=Pt(e),s=jt(e),r=Tt(e);if(n.push(...o.errors),n.push(...s.errors),n.push(...r.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${kt}.`);const i={enable:!!e[$t],...e[$t],sdk:void 0,privacy:void 0,sourceCodeContext:void 0};return o.config&&(i.sdk=o.config),s.config&&(i.privacy=s.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(i.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),r.config&&(i.sourceCodeContext=r.config),i})(e,t.getLogger(kt)),o=[];if(!n.enable)return o;if(n.sourceCodeContext&&t.inject({type:"code",position:vt.BEFORE,injectIntoAllChunks:!0,value:St(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:vt.MIDDLE,value:p.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:vt.MIDDLE,value:Rt(n,t)})),n.privacy){t.inject({type:"file",position:vt.BEFORE,value:p.join(__dirname,"./privacy-helpers.js")});const e=Dt(n.privacy,t);o.push(e)}return o},Ot="datadog-analytics-plugin",At=({context:e})=>{const t=e.getLogger(Ot);return[{name:Ot,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}`)}})())}}]},Nt="datadog-async-queue-plugin",Ct=e=>{const{context:t,stores:n}=e,o=t.getLogger(Nt),s=[];return t.queue=e=>{const t=e.catch((e=>{s.push(e.message||e.toString())}));n.queue.push(t)},[{name:Nt,asyncTrueEnd:async()=>{await Promise.all(n.queue),s.length>0&&o.error(`Error occurred while processing async queue:\n ${s.join("\n ")}`)}}]},zt=async(e,t,n)=>{const o=[],s=e.initialOptions.entryPoints,r=[],i=[];if(Array.isArray(s))for(const e of s){const t=e&&"object"==typeof e?e.in:e;r.push({path:t})}else s&&"object"==typeof s&&r.push(...Object.entries(s).map((([e,t])=>({name:e,path:t}))));const a=r.flatMap((e=>{return(t=e.path,t.includes("*")?d.glob.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,s])=>{const r=await e.resolve(s,{kind:"entry-point",resolveDir:t.buildRoot});r.errors.length&&i.push(...r.errors.map((e=>e.text))),r.path&&o.push({name:n.name,resolved:r.path,original:n.path})}));for(const e of i)n.error(e);return await Promise.all(a),o},It=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,_t=/(\?|%3F|\|)+/gi,Ft=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=Kt(e),It.lastIndex=0,It.exec(t)?.[1]||"unknown");var t},Lt=["unknown","commonjsHelpers.js",`vite${p.sep}preload-helper.js`],qt=(e,t,n)=>{const o=new Set;for(const n of e){const e=Kt(n);C(n)||e===t||Lt.includes(e)||o.add(e)}return o},Kt=e=>e.split("!").pop().split(_t).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Ht=(e,t)=>C(t)?D:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(p.sep),o=e.split(p.sep).filter(((e,t)=>e===n[t])).join(p.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(_t).shift().replace(/^((\.\.?)?[/\\])+/g,""),Ut=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[ae(t,e),n]))),Wt=(e,t)=>({setup(n){const o=new Map;let s=[];const r=t.time("build report",{start:!1});n.onStart((async()=>{o.clear(),s=[],r.resume();const i=t.time("process entries");s.push(...await zt(n,e,t));for(const t of s){const n=Ht(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}i.end(),r.pause()})),n.onEnd((async n=>{r.resume();const s=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(s.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const u=[],c=[],l=[],d=[],m=[],f={},h={},g=t.time("indexing metafile data"),y=Ut(n.metafile.inputs,a),b=Ut(n.metafile.outputs,a);g.end();const w=e=>{if(!C(e))return e;const t=y[ae(a,e)];if(!t)return e;const n=t.imports.find((e=>!C(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(C(e))continue;const n=ae(a,e),o={name:Ht(i,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Ft(e)};f[n]=o,u.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,s]of Object.entries(n.metafile.outputs)){const n=ae(a,e),r=Ht(i,n),u=[];for(const e of Object.keys(s.inputs)){if(C(e))continue;const n=f[ae(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${r}`)}if(s.entryPoint&&!u.length){const e=f[ae(a,s.entryPoint)];if(!e){t.debug(`Input ${s.entryPoint} not found for output ${r}`);continue}u.push(e)}const p={name:r,filepath:n,inputs:u,size:s.bytes,type:Ft(n)};if(h[n]=p,"map"===p.type&&d.push(p),c.push(p),!s.entryPoint)continue;const m=f[ae(a,w(s.entryPoint))];if(m){if(!o.get(m.name))continue;const e={...p,name:o.get(m.name)||m.name,outputs:[p],size:p.size};l.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of d){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:f,meta:y},outputs:{report:h,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,D=e=>!C(e)&&!e.match(E),x=(e,n,o={})=>{if(!D(e))return o;const s=n.report[e];if(!s)return t.debug(`Could not find report's ${e}`),o;if(o[s.filepath])return o;o[s.filepath]=s;const r=n.meta[e];if(!r)return t.debug(`Could not find metafile's ${e}`),o;if(!r.imports||!r.imports.length)return o;for(const t of r.imports){const r=t.path.match(/^\.\.?\//),c=r?p.dirname(e):a,l=ae(c,t.path);if(t.external){if(D(t.path)){const e=r?l:t.path,n=S.inputs.report[e]||{filepath:e,name:Ht(i,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in s&&(n.dependents.add(s),s.dependencies.add(n)),"inputs"in s&&!s.inputs.includes(n)&&s.inputs.push(n),u.includes(n)||u.push(n),S.inputs.report[e]=n,o[n.filepath]=n}}else x(l,n,o)}return o},R=t.time("looping through entries");for(const e of l){const t={},n={};for(const n of e.inputs)x(n.filepath,S.inputs,t);for(const t of e.outputs)x(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),m.push(e)}R.end();const P=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(!D(o.path))continue;const n=o.path.match(/^\.?\.\//),s=n?p.dirname(e.filepath):a,r=ae(s,o.path);let i;if(o.external){const e=n?r:o.path;i=S.inputs.report[e]}else i=S.inputs.report[r];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}`)}P.end(),e.build.outputs=c,e.build.inputs=u,e.build.entries=m,r.end(),await e.asyncHook("buildReport",e.build)}))}}),Bt=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),s=t.time("filling entries",{start:!1}),r=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}),p=t.time("filling sourcemaps inputs",{start:!1}),c=new Map,l=new Map,d=new Map,m=new Map;return{buildStart(){m.clear(),c.clear(),l.clear(),d.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=Kt(e.id),o=m.get(t)||{dependencies:new Set,dependents:new Set},s=qt(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),r=qt(new Set([...e.dynamicImporters,...e.importers]),t);for(const e of r)o.dependents.add(e);for(const e of s)o.dependencies.add(e);m.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,f){o.resume();const h=n.dir?ae(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 m){for(const n of t){const t=Kt(n),o=m.get(t)||{dependencies:new Set,dependents:new Set};o.dependents.has(e)||(o.dependents.add(e),m.set(t,o))}for(const t of n){const n=Kt(t),o=m.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),m.set(n,o))}}i.end(),r.resume();for(const[e,n]of Object.entries(f)){const o=ae(h,e),s="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),r=l.get(o)||{name:e,filepath:o,inputs:[],size:s,type:Ft(e)};if("map"===r.type&&y.add(r),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(Kt(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=a.statSync(e).size}catch(e){n=t.renderedLength}const o=c.get(e)||{name:Ht(h,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Ft(e)};r.inputs.push(o),c.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=Kt(e);if(!m.has(n)){b.set(ae(h,n),r);continue}if(c.has(n)){t.debug(`Input report already there for ${n} from ${r.name}.`);continue}const o=c.get(n)||{name:Ht(h,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};r.inputs.push(o),c.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...r,name:n.name,size:0,outputs:[r]}),l.set(r.filepath,r)}r.end();for(const[e,n]of b){const o=l.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of c){const o=m.get(e);if(o){for(const e of o.dependencies){const o=c.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Ht(h,e)} of ${n.name}`)}for(const e of o.dependents){const o=c.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Ht(h,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){p.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=l.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}p.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Ht(h,e),s=l.get(e);if(!s)return c.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,s);const r=f[Ht(h,e)];if(!r)return t.debug(`Could not find asset for ${o}`),n;const i=[];"imports"in r&&i.push(...r.imports),"dynamicImports"in r&&i.push(...r.dynamicImports);for(const e of i)w(ae(h,e),n);return n};s.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),d.has(e.filepath)&&t.debug(`Entry "${e.name}":"${Ht(h,e.filepath)}" already reported.`),d.set(e.filepath,e)}s.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(c.values()),e.build.outputs=Array.from(l.values()),e.build.entries=Array.from(d.values()),s.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},Gt=(e,t,n)=>o=>{let s=[],r=[],i=[];const a=new Map,u=new Map,p=new Map,c=new Map,l=[],d=new Map,m=n.time("build report",{start:!1}),f=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||C(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=Kt(e);t.add(n),n.startsWith("external ")&&t.add(h(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(c.has(e)){const n=c.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else c.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=Kt(t.request);if(c.has(n))return c.get(n);if(e.context){const t=ae(Kt(e.context),n);if(c.has(t))return c.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{s=[],r=[],i=[],a.clear(),u.clear(),c.clear(),d.clear(),o.hooks.finishModules.tap(t,(t=>{m.resume();const o=n.time("dependency graph"),r=n.time("indexing modules");for(const e of t)g(e);r.end();const i=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Ht(e.bundler.outDir,t),r=new Set(y(n).map((e=>{const o=b(n,e);if(!o?.identifier())return!1;const s=o.identifier();return!!f(s)&&(s!==t&&(w(o)?h(s):s))})).filter(Boolean));if(!f(t))continue;const i=d.get(t)||{dependents:new Set,dependencies:new Set};for(const e of r){const n=d.get(e)||{dependencies:new Set,dependents:new Set};n.dependents.add(t),i.dependencies.add(e),d.set(e,n)}d.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:Ft(t)};s.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 s){const t=d.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(),m.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{m.resume();const o=t.chunks,c=t.getAssets(),d=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>ae(e.bundler.outDir,t))),h=n.time("indexing chunks"),g=t.chunkGraph;for(const e of o){const t=d(e),n=(g?.getChunkModules(e)||[]).flatMap((e=>"modules"in e&&Array.isArray(e.modules)?e.modules.map((e=>e.identifier())):e.identifier())).filter(f);for(const e of t){if("map"===Ft(e))continue;const t=p.get(e)||new Set;for(const e of n)t.add(e);p.set(e,t)}}h.end();const y=n.time("building outputs");for(const t of c){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:ae(e.bundler.outDir,t.name),type:Ft(t.name)};if(u.set(o.filepath,o),r.push(o),"map"===o.type){l.push(o);continue}const s=p.get(o.filepath);if(s)for(const e of s){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of l){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return[];t.add(e);const n=[...e.chunks];for(const o of e.childrenIterable||[])n.push(...v(o,t));return n};for(const[o,s]of t.entrypoints){const t=new Map,r=new Map;let a=0;const p=v(s).flatMap(d),c=s.chunks.filter((e=>g.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||s.name&&e.includes(s.name))).find((e=>"js"===Ft(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)r.has(e.filepath)||r.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const l={name:o,filepath:c?ae(e.bundler.outDir,c):"unknown",size:a,inputs:Array.from(r.values()),outputs:Array.from(t.values()),type:c?Ft(c):"unknown"};i.push(l)}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=s,e.build.outputs=r,e.build.entries=i,m.end(),await e.asyncHook("buildReport",e.build)}))},Jt="datadog-build-report-plugin",Vt=e=>{const{context:t}=e,n=t.getLogger(Jt);return[{name:Jt,enforce:"post",esbuild:Wt(t,n),rspack:Gt(t,Jt,n),webpack:Gt(t,Jt,n),vite:Bt(t,n),rollup:Bt(t,n)}]},Yt="datadog-bundler-report-plugin",Qt=(e,t)=>t?p.isAbsolute(t)?t:p.resolve(e,t):"",Xt=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?p.dirname(e.file):void 0)).filter(Boolean)},Zt=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Qt(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},en=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,s=Xt(o);e.buildRoot=t.root??process.cwd(),o&&s.length&&(n=pe(s,process.cwd())),e.bundler.outDir=Qt(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),tn=e=>{const{context:t}=e,n=t.getLogger(Yt);return[{name:Yt,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Qt(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Qt(t.buildRoot,p.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Zt(t),rspack:Zt(t),vite:en(t),rollup:{options(e){let n;if("output"in e){const t=Xt(e.output);n=pe(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(p.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=ae(process.cwd(),n);const e=pe([n,...o],process.cwd());t.buildRoot=e===p.sep?process.cwd():e}else t.buildRoot=pe(o,process.cwd()),t.bundler.outDir=p.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=Xt(e);pe(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.")}}}]},nn="datadog-custom-hooks-plugin",on=e=>{const{context:t}=e,n=t.getLogger(nn),o=e=>(o,...s)=>{const r=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 r=t(...s);r instanceof Promise&&(e||i.push(`Plugin "${n.name}" returned a promise on the non async hook "${o}".`),a.push(r))}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((()=>r.end()))};return t.hook=o(!1),t.asyncHook=o(!0),[{name:nn,enforce:"pre"}]};class sn{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=Z(e),o=JSON.parse(n);if(!o.sources)return void t("Missing 'sources' field in sourcemap.");const s=o.sources;if(0===s.length)return void t("Empty 'sources' field in sourcemap.");const r=this.matchSources(s);if(0!==r.length)return r;t(`${s.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 s=this.trackedFilenames.get(e);s&&(t=t.concat(s))}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 rn=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await an(e);for(const e of t)if(e.name===n)return L(e.refs.push);return L(t[0].refs.push)},an=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},un=async e=>e.revparse("HEAD"),pn=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),cn=async e=>e.branch(),ln=async e=>e.show(["-s","--format=%s"]),dn=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),mn="datadog-git-plugin",fn=e=>{const{options:t,context:n}=e,o=n.getLogger(mn),s=o.time("get git information",{start:!1}),r=async e=>{try{const t=await(async e=>{const t=[un(e),cn(e),ln(e),dn(e),pn(e),rn(e)],[n,o,s,r,i,a]=await Promise.all(t),[u,p,c,l,d,m]=r.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:p,date:c},committer:{name:l,email:d,date:m},message:s.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new sn(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)})(p.dirname(e)));n.git=t,s.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:mn,enforce:"pre",buildRoot(e){if(I(t))try{s.resume();const t=ue(e,".git");if(!t)return o.warn("No .git directory found, skipping git plugin."),void s.end();n.queue(r(t))}catch(e){o.error(`Could not get git information: ${e.message}`)}}}]},hn="datadog-injection-plugin",gn=/^https?:\/\//,yn=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],bn=t.bold.yellow,wn=async(e,t=process.cwd())=>(e=>i.readFile(e,{encoding:"utf-8"}))(ae(t,e)),vn=async(e,t,n=process.cwd())=>{let o;const s=await(async e=>"function"==typeof e.value?e.value():e.value)(e);try{if("file"===e.type)o=s.match(gn)?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)}))])})(s):await wn(s,n);else{if("code"!==e.type)throw new Error(`Invalid item type "${e.type}", only accepts "code" or "file".`);o=s}}catch(r){const i=`${e.type} - ${F(s)}`;e.fallback?(t.debug(`Fallback for "${i}": ${r.toString()}`),o=await vn(e.fallback,t,n)):t.warn(`Failed "${i}": ${r.toString()}`)}return o},$n=(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`},kn=async(e,t,n,o=process.cwd())=>{const s=await(async(e,t,n=process.cwd())=>{const o=new Map;for(const[s,r]of e.entries()){const e=await vn(r,t,n);if(e){const t=r.position||vt.BEFORE;o.set(s,{value:e,injectIntoAllChunks:"injectIntoAllChunks"in r&&r.injectIntoAllChunks,position:t})}}return o})(t,e,o);for(const e of s.values())n.push(e)},Sn=e=>e instanceof Error&&"code"in e,En=e=>yn.includes(e),Dn=(e,t,n)=>{e.warn(`"${bn(t)}" files are not supported (${bn(n)}).`)},xn=a.promises,Rn=(e,t,n)=>({setup(o){const{onStart:s,onResolve:r,onLoad:u,onEnd:c,esbuild:d,initialOptions:m}=o,f=[],h=`${t.bundler.name}.${vt.MIDDLE}.${D}.js`,g=a.realpathSync(l.tmpdir()),y=p.resolve(g,h),b=new RegExp(`${h}$`),w=m.inject;m.inject=w?[...w]:[],m.inject.push(y),s((async()=>{f.push(...await zt(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await Q(p.dirname(e)),await i.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),r({filter:b},(async e=>({path:e.path,namespace:hn}))),u({filter:b,namespace:hn},(async()=>({contents:$n(n,{position:vt.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),c((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const s=$n(n,{position:vt.BEFORE}),r=$n(n,{position:vt.AFTER}),i=$n(n,{position:vt.BEFORE,onAllChunks:!0}),a=$n(n,{position:vt.AFTER,onAllChunks:!0});if(!(s||r||i||a))return;const u=[];for(const[n,c]of Object.entries(o.metafile.outputs)){const o=c.entryPoint&&f.some((e=>e.resolved.endsWith(c.entryPoint))),l=o?s:i,m=o?r:a;if(!l&&!m)continue;const h=ae(t.buildRoot,n),{base:g,ext:y}=p.parse(h);En(y)?u.push((async()=>{try{const e=await xn.readFile(h,"utf-8"),t=await d.transform(e,{loader:"default",banner:l,footer:m});await xn.writeFile(h,t.code)}catch(t){if(!Sn(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${h}: ${t}`)}})()):Dn(e,y,g)}await Promise.all(u)}))}}),Pn=D,jn="?inject-proxy",Tn=(e,t)=>({banner(n){const o=$n(t,{position:vt.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:s,ext:r}=p.parse(n.fileName);return En(r)?o:(Dn(e,r,s),"")},async resolveId(e,n,o){if(C(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&$n(t,{position:vt.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}${jn}`}return null},load(e){if(C(e))return $n(t,{position:vt.MIDDLE});if(e.endsWith(jn)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(Pn)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=$n(t,{position:vt.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:s,ext:r}=p.parse(n.fileName);return En(r)?o:(Dn(e,r,s),"")}}),Mn=(e,t,n,o,s)=>r=>{const i=new WeakMap,u=e.sources.ConcatSource,c=n.bundler.name,l=p.resolve(n.bundler.outDir,`${c}.${vt.MIDDLE}.${D}.js`);X(l,"");r.hooks.shutdown.tap(hn,(()=>{var e;e=l,a.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const d=async()=>{await kn(t,o,s,n.buildRoot)};r.hooks.beforeRun.tapPromise(hn,d),r.hooks.watchRun.tapPromise(hn,d),r.hooks.compilation.tap(hn,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:hn,stage:o},(()=>{const e=$n(s,{position:vt.BEFORE}),o=$n(s,{position:vt.AFTER}),r=$n(s,{position:vt.BEFORE,onAllChunks:!0}),a=$n(s,{position:vt.AFTER,onAllChunks:!0});for(const s of n.chunks){let c=e,l=o;if(s.canBeInitial()||(c=r,l=a),""!==c||""!==l)for(const e of s.files){const{base:o,ext:s}=p.parse(e);En(s)?n.updateAsset(e,(e=>{const t=i.get(e);if(!t||t.banner!==c||t.footer!==l){const t=new u(c,"\n",e,"\n",l);return i.set(e,{source:t,banner:c,footer:l}),t}return t.source})):Dn(t,s,o)}}}))}));const m=(e=>{const n={import:[l]},o=e=>{for(const[n,o]of Object.entries(e))"object"==typeof o?(o.import=o.import||[],o.import.unshift(l)):"string"==typeof o?e[n]=[l,o]:Array.isArray(o)?o.unshift(l):t.error("Invalid entry type: "+typeof o)};return e?"function"==typeof e?async()=>{const t=await e();return o(t),t}:"object"!=typeof e?"string"==typeof e?[n,e]:(t.error("Invalid entry type: "+typeof e),e):(o(e),e):{ddHelper:n}})(r.options.entry);r.options.entry=m},On=e=>{const{bundler:t,context:n}=e,o=n.getLogger(hn),s=new Map,r=[];n.inject=e=>{s.set(`${Date.now()}.${performance.now()}.${++K}`,e)};const i={name:hn,enforce:"post",esbuild:Rn(o,n,r),webpack:Mn(t,o,n,s,r),rspack:Mn(t,o,n,s,r),rollup:Tn(o,r),vite:{...Tn(o,r),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>$n(r,{position:vt.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:x},handler:()=>({code:$n(r,{position:vt.MIDDLE})})}:i.buildStart=async()=>{await kn(o,s,r,n.buildRoot)},[i]},An="datadog-true-end-plugin",Nn=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=()=>{t.hook("syncTrueEnd")},s=async()=>{o(),await n()},r=e=>{e.hooks.shutdown.tapPromise(An,s)},i={async writeBundle(){},async closeBundle(){await s()}};return[{name:An,enforce:"post",webpack:r,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:i,rollup:i,rspack:r}]},Cn={[Fe]:lt},zn=t.bold.red;var In="3.1.0";const _n=(({bundler:t,version:n})=>{const o=Date.now();return e.createUnplugin(((e,s)=>{const r=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"===s.framework&&(s.esbuildHostName=P);const a=process.env.BUILD_PLUGINS_ENV||"production",u=R.includes(a)?a:"development",p=t.rspackVersion||t.version||t.VERSION,c=s.framework,l={bundler:{name:c,version:p},env:u,metadata:i.metadata||{},packageName:`@datadog/${c}-plugin`,version:n},d={errors:[],logs:[],queue:[],timings:[],warnings:[]},m=(({start:e,options:t,data:n,stores:o})=>{const s=process.cwd(),r={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{auth:t.auth,pluginNames:[],bundler:{...r.bundler,outDir:s},build:r,buildRoot:s,env:n.env,getLogger:G(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:A(n),start:e,version:n.version}})({start:o,options:i,data:l,stores:d}),f=m.getLogger("factory"),h=f.time("Plugins initialization",{start:r});m.pluginNames.push(P);const g=[];g.push(["analytics",At],["async-queue",Ct],["build-report",Vt],["bundler-report",tn],["custom-hooks",on],["git",fn],["injection",On],["true-end",Nn]),i.customPlugins&&g.push(["custom",i.customPlugins]),g.push(["apps",ke],["error-tracking",Ie],["metrics",dt],["output",wt],["rum",Mt]);for(const[e,n]of g)m.plugins.push(...Y(m,n,e)({bundler:t,context:m,options:i,data:l,stores:d}));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 s=o.map((e=>$(e))).join(" and "),r=$(`DATADOG_${n}`);e.warn(`Conflicting keys ${s}, will use ${r}`),t.push(`${s} (using ${r})`)}else if(o.length){const e=o.map((e=>v(e))).join(" and ");t.push(`${e} (same value)`)}}t.length&&e.info(`Overrides from environment:\n - ${t.join("\n - ")}`)})(f),m.pluginNames.push(...m.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: ${zn(Array.from(t).join(", "))}`)})(m.pluginNames),m.hook("init",m),h.end(),m.plugins}))})({bundler:w,version:In}).webpack,Fn=In,Ln=Cn;exports.datadogWebpackPlugin=_n,exports.helpers=Ln,exports.version=Fn;
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"),p=require("jszip"),d=require("os"),l=require("glob"),f=require("crypto"),m=require("pretty-bytes"),h=require("p-queue"),g=require("@babel/types"),y=require("perf_hooks"),b=require("@datadog/js-instrumentation-wasm"),w=require("simple-git"),$=require("webpack");function v(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(n){if("default"!==n){var o=Object.getOwnPropertyDescriptor(e,n);Object.defineProperty(t,n,o.get?o:{enumerable:!0,get:function(){return e[n]}})}})),t.default=e,Object.freeze(t)}var k=v(g);const S=t.bold.green,E=t.bold.yellow,x=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","SITE"],P=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],D=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},j="__datadog-helper-file",C=new RegExp(j),R=["development","production","test"],M="datadog-build-plugins",A=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),T=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())}}},O=[400,401,403,404,405,409,413],I=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(O.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)},N=e=>({message:t,context:n})=>I({retries:2,minTimeout:100,url:"https://browser-http-intake.logs.datadoghq.com/v1/input/pub44d5f4eb86e1392037b7501f7adc540e",method:"POST",type:"json",getData:async()=>{const o={ddsource:e.packageName||M,message:t,service:"build-plugins",team:"language-foundations",env:e.env,version:e.version,bundler:{name:e.bundler.name,version:e.bundler.version},metadata:e.metadata,...n};return{data:JSON.stringify(o),headers:{"Content-Type":"application/json"}}}}),_=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),F=e=>e.includes(j),z=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},L=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},q=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()},K=(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)}`},B=(e="")=>{try{if(!e||e.startsWith("git@"))return e;const t=new URL(e),n="/"===t.pathname?"":t.pathname;return`${t.protocol?`${t.protocol}//`:""}${t.host}${n}`}catch{return e}},H=e=>Object.entries(e).map((([e,n])=>` - ${e}: ${t.bold.green((e=>{if(void 0===e)return"undefined";if(null===e)return"null";if(Array.isArray(e))return e.join(", ");if("object"==typeof e)try{return JSON.stringify(e,null,2)}catch{return String(e)}return e?.toString()??""})(n))}`)).join("\n");let U=0;const W={debug:0,info:1,warn:2,error:3,none:4},J=e=>e.split(">").map(_).join(">"),G=(e,n,o,r)=>{const s=J(e);return(i,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}|${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=N(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){G(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}W[a]>=W[r]&&d(`${p(l)} ${f}`)}},V=(e,n,o)=>(r,s={})=>{const{level:i="debug",start:a=!0,log:u=!0,tags:c=[]}=s,p={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${i}`],logLevel:i,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 s=d();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: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(q(n))}`,i)},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)}}},Y=(e,t,n="warn")=>o=>{const r=G(o,e,t,n);return{getLogger:r=>Y(e,t,n)(`${J(o)}>${r}`),time:V(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)}},Q=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],X=(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)},Z=(e,t,n)=>{const o=e.getLogger(M);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),s=t(e).map((e=>((e,t)=>{const n={...e},o=_(e.name);for(const r of Q){const s=e[r];s&&(n[r]=X(o,r,s,t))}return n})(e,o))),i=s.map((e=>`plugin:${e.name}`));return r.tag(i),r.end(),s}},ee=async e=>i.mkdir(e,{recursive:!0}),te=(e,t)=>{var n;n=c.dirname(e),a.mkdirSync(n,{recursive:!0}),a.writeFileSync(e,t,{encoding:"utf-8"})},ne=e=>a.readFileSync(e,{encoding:"utf-8"}),oe=e=>{try{return a.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},re=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})}},se=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},ie="apps",ae="datadog-apps-plugin",ue="api/unstable/app-builder-code/apps",ce="datadog-apps-assets.zip",pe=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},de=[".ts",".js",".tsx",".jsx"];const le=(e,t,n)=>{const o=e=>{const t=e.manualChunks;"function"==typeof t&&(e.manualChunks=(e=>(t,n)=>{const o=n.getModuleInfo(t);if(!o||!(o.importers||[]).some((e=>e.startsWith(he))))return e(t,n)})(t))};return{outputOptions(e){if(Array.isArray(e))for(const t of e)o(t);else e&&o(e);return e},buildStart(){for(const t of e)this.emitFile({type:"chunk",id:`${he}${t.name}`,name:`backend/${t.name}`,preserveSignature:"exports-only"})},writeBundle(e,o){const r=e.dir||c.dirname(e.file||"");for(const[e,s]of Object.entries(o))if("chunk"===s.type&&s.facadeModuleId&&s.facadeModuleId.startsWith(he)){const o=s.facadeModuleId.slice(he.length),i=c.resolve(r,e);t.set(o,i),n.debug(`Backend function "${o}" output: ${i}`)}}}};function fe(e,t){const n=[];return n.push(`import { ${e} } from ${JSON.stringify(t)};`),function(){try{return require.resolve("@datadog/action-catalog/action-execution"),!0}catch{return!1}}()&&n.push("import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';"),n.push(""),n.push('/** @param {import("./context.types").Context} $ */'),n.push("export async function main($) {"),n.push(" globalThis.$ = $;"),n.push(""),n.push(" // Register the $.Actions-based implementation for executeAction"),n.push(" if (typeof setExecuteActionImplementation === 'function') {\n setExecuteActionImplementation(async (actionId, request) => {\n const actionPath = actionId.replace(/^com\\\\.datadoghq\\\\./, '');\n const pathParts = actionPath.split('.');\n let actionFn = $.Actions;\n for (const part of pathParts) {\n if (!actionFn) throw new Error('Action not found: ' + actionId);\n actionFn = actionFn[part];\n }\n if (typeof actionFn !== 'function') throw new Error('Action is not a function: ' + actionId);\n return actionFn(request);\n });\n }"),n.push(""),n.push(" // backendFunctionArgs is a template expression resolved at runtime by"),n.push(" // App Builder's executeBackendFunction client via template_params."),n.push(" const args = JSON.parse('${backendFunctionArgs}' || '[]');"),n.push(` const result = await ${e}(...args);`),n.push(" return result;"),n.push("}"),n.join("\n")}const me=(e,t,n)=>({...le(e,t,n)}),he="\0dd-backend:";const ge=(e,t)=>F(t)?j:t.startsWith(e)||c.isAbsolute(t)?t:c.resolve(e,t),ye=(e,t)=>{let n,o=ge(process.cwd(),e);for(;!n;){const e=c.resolve(o,t);if(oe(e)&&(n=e),o=o.split(c.sep).slice(0,-1).join(c.sep),[c.sep,""].includes(o))break}return n},be=(e,t)=>{const n=[...e].map((e=>ge(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},we=t.bold.red,$e=t.bold.yellow,ve=e=>{const t=ye(e,"package.json");if(t)try{const e=ne(t);return JSON.parse(e)}catch(e){return}},ke=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=ve(e);o||t.warn($e("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(we("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=B(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);s||t.error(we("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(we("Unable to compute the app identifier.")),{identifier:i,name:r}},Se=t.green.bold,Ee=t.yellow.bold,xe=t.cyan.bold,Pe=t.bold,De=(e,t={},n)=>async()=>{const o=await re(e,{contentType:"application/zip",filename:ce});return T({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ce);const t=P("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},je=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,P("APPS_INTAKE_URL")||`https://api.${a}/${ue}/${u}/upload`);var a,u;const c=A({bundler:t.bundlerName,plugin:"apps",version:t.version}),p=H({identifier:t.identifier,intakeUrl:i,defaultHeaders:`\n${JSON.stringify(c,null,2)}`}),d=`an archive of:\n - ${Se(e.assets.length.toString())} files\n - ${Se(m(e.size))}\n\nWith the configuration:\n${p}`;if(t.dryRun)return n.error(`\n${xe("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${d}`),{errors:r,warnings:s};try{const r=await I({auth:{apiKey:t.apiKey,appKey:t.appKey},url:i,method:"POST",type:"json",getData:De(e.archivePath,c,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${Ee(`${t}/5`)}): ${e.message}`;s.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: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${Pe("Standalone :")}\n ${xe(i)}\n\n${Pe("AppBuilder :")}\n ${xe(a)}`)}const a=P("APPS_VERSION_NAME")?.trim();if(a){const e=((e,t)=>`https://api.${e}/${ue}/${t}/release/live`)(t.site,t.identifier);await I({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 ${Ee(`${t}/5`)}): ${e.message}`;s.push(o),n.warn(o)}}),n.info(`Released version ${Pe(a)} to live.`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));r.push(t)}return{errors:r,warnings:s}},Ce=t.yellow.bold,Re=t.red.bold,Me=({options:e,context:t})=>{const n=t.getLogger(ae);let o;const r=(e=>{const t=e[ie]||{};return{enable:t.enable??!!e[ie],include:t.include||[],dryRun:t.dryRun??!P("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim(),backendDir:t.backendDir?.trim()||"backend"}})(e);if(!r.enable)return[];const s=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 de){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(de.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,r.backendDir),n),u=new Map,l=s.length>0,f=async()=>{const e=n.time("handle assets");let s;try{const e=n.time("resolve identifier"),{name:o,identifier:f}=ke(t.buildRoot,n,{url:t.git?.remote,name:r.name,identifier:r.identifier});if(!f||!o)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=[...r.include,`${m}/**/*`],g=await pe(h,t.buildRoot);if(!g.length)return void n.debug("No assets to upload.");const y=new Set(u.values()),b=(l?g.filter((e=>!y.has(e.absolutePath))):g).map((e=>({...e,relativePath:c.join("frontend",e.relativePath)})));if(l)for(const[e,t]of u)b.push({absolutePath:t,relativePath:`backend/${e}.js`});const w=n.time("archive assets"),$=await(async e=>{const t=await i.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),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(),s=c.dirname($.archivePath);const v=n.time("upload assets"),{errors:k,warnings:S}=await je($,{apiKey:t.auth.apiKey,appKey:t.auth.appKey,bundlerName:t.bundler.name,dryRun:r.dryRun,identifier:f,name:o,site:t.auth.site,version:t.version},n);if(v.end(),S.length>0&&n.warn(`${Ce("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){o=e,n.error(`${Re("Failed to upload assets:")}\n${e?.message||e}`)}if(s&&await(async e=>i.rm(e,{force:!0,maxRetries:3,recursive:!0}))(s),e.end(),o)throw o},m=[];return l&&["rollup","vite"].includes(t.bundler.name)?m.push(function(e,t,n){const o=new Map(e.map((e=>[e.name,e])));return{name:"datadog-apps-backend-plugin",enforce:"pre",resolveId:e=>e.startsWith(he)?e:null,load(e){if(!e.startsWith(he))return null;const t=e.slice(he.length),r=o.get(t);return r?fe(r.name,r.entryPath):(n.error(`Backend function "${t}" not found.`),null)},rollup:le(e,t,n),vite:me(e,t,n)}}(s,u,n)):l&&n.warn(`Backend functions are not yet supported for ${t.bundler.name}. Skipping backend build.`),m.push({name:ae,enforce:"post",async asyncTrueEnd(){await f()}}),m},Ae="errorTracking",Te="datadog-error-tracking-plugin",Oe=(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}},Ie=/[/]+|[\\]+/g,Ne=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,_e=(e,t)=>{const n=e.replace(Ne,"").split(Ie),o=t.replace(Ne,"").split(Ie),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},Fe=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([se(e.minifiedFilePath),se(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:_e(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}},ze=t.green.bold,Le=t.yellow.bold,qe=t.red.bold,Ke=(e,t={})=>async()=>T({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await re(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}),Be=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,P("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const p=A({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),d=H({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(p,null,2)}`}),l=`\nUploading ${ze(e.length.toString())} sourcemaps with configuration:\n${d}`;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 I({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:Ke(i,p),onRetry:(t,n)=>{const r=`Failed to upload ${Le(e.sourcemap)} | ${Le(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 ${ze(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:s,errors:r}},He=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=>({...Oe(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=>Fe(e,i,s,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 Be(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 ${ze(`${e.length-l.length}/${e.length}`)} sourcemaps in ${ze(q(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?`${qe(e.file)} | ${qe(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()},Ue=e=>{const n=t.bold.red,o=e[Ae]||{},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},We=({options:e,context:t})=>{const n=t.getLogger(Te),o=n.time("validate options"),r=((e,t)=>{const n=[],o=Ue(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Te}.`);const r={enable:!!e[Ae],...e[Ae],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 He(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:Te,enforce:"post",async git(e){s=e,i&&await u()},async buildReport(t){i=t,!s&&L(e)||await u()},async asyncTrueEnd(){a||await u()}}]};var Je=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(Je||{});const Ge="datadog-live-debugger-plugin";function Ve(e){return"function"==typeof e?e:e.default}function Ye(e,t,n,o){const r=c.relative(t,e).replace(/\\/g,"/"),s=Qe(n);if(s)return`${r};${s}`;const i=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${r};<anonymous>@${i}:${o}`}function Qe(e){const t=e.node,n=e.parent;return"id"in t&&k.isIdentifier(t.id)?t.id.name:k.isObjectMethod(t)||k.isClassMethod(t)||k.isClassPrivateMethod(t)?et(t.key):k.isVariableDeclarator(n)&&k.isIdentifier(n.id)?n.id.name:k.isAssignmentExpression(n)?function(e){if(k.isIdentifier(e))return e.name;if(k.isMemberExpression(e)||k.isOptionalMemberExpression(e)){const t=Xe(e.object),n=Ze(e.property,e.computed);if(t&&n)return`${t}.${n}`}return null}(n.left):k.isObjectProperty(n)||k.isClassProperty(n)||k.isClassPrivateProperty(n)?et(n.key):null}function Xe(e){if(k.isIdentifier(e))return e.name;if(k.isThisExpression(e))return"this";if(k.isMemberExpression(e)||k.isOptionalMemberExpression(e)){const t=Xe(e.object),n=Ze(e.property,e.computed);if(t&&n)return`${t}.${n}`}return null}function Ze(e,t){return k.isPrivateName(e)&&k.isIdentifier(e.id)?`#${e.id.name}`:t?null:k.isIdentifier(e)?e.name:null}function et(e){return k.isIdentifier(e)?e.name:k.isStringLiteral(e)||k.isNumericLiteral(e)||k.isBigIntLiteral(e)?String(e.value):k.isPrivateName(e)&&k.isIdentifier(e.id)?`#${e.id.name}`:null}function tt(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function nt(e,t,n){const o=[];for(const t of e.params)for(const e of ot(t))"this"!==e&&o.push(e);if(n&&k.isBlockStatement(e.body)){const t=new Set(e.params.flatMap((e=>ot(e)))),n="id"in e&&k.isIdentifier(e.id)?e.id.name:"";for(const r of e.body.body)if(k.isVariableDeclaration(r))for(const e of r.declarations)for(const r of ot(e.id))t.has(r)||r===n||o.push(r)}return o.length>25?o.slice(0,25):o}function ot(e){return k.isIdentifier(e)?[e.name]:k.isRestElement(e)?k.isIdentifier(e.argument)?[e.argument.name]:ot(e.argument):k.isAssignmentPattern(e)?ot(e.left):k.isObjectPattern(e)?e.properties.flatMap((e=>k.isRestElement(e)?ot(e.argument):ot(e.value))):k.isArrayPattern(e)?e.elements.flatMap((e=>e?ot(e):[])):k.isTSParameterProperty(e)&&k.isIdentifier(e.parameter)?[e.parameter.name]:[]}let rt,st,it,at,ut=!1;const ct=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function pt(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:s,namedOnly:i}=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(!ct.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:p,totalFunctions:d};(()=>{if(!ut){if(rt=require("@babel/parser").parse,st=Ve(require("@babel/traverse")),it=require("@babel/types"),at=Ve(require("magic-string")),!(rt&&st&&it&&at))throw new Error("Failed to load Live Debugger transform runtime.");ut=!0}})();const l=rt(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map;let h=0;if(st(l,{Function(e){if(d++,!function(e){const t=e.node;return!(t.generator||k.isClassMethod(t)&&"constructor"===t.kind)}(e))return void p++;if(r&&function(e,t){let n=e;for(;n;){if(tt(n,t))return!0;if(k.isStatement(n.node)||k.isExportDeclaration(n.node)){if(n.parentPath&&k.isExportDeclaration(n.parentPath.node))return tt(n.parentPath,t);break}n=n.parentPath}return!1}(e,"@dd-no-instrumentation"))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,it)))return void p++;if(i&&!Qe(e))return void p++;let t=0;if(!Qe(e)){const n=e.parentPath?.node;n&&(t=m.get(n)||0,m.set(n,t+1))}const l=Ye(n,o,e,t);try{const t=e.node,n=h++,o=`$dd_p${n}`,r=nt(t,0,!1),s=nt(t,0,!0),i=it.isArrowFunctionExpression(t)&&!it.isBlockStatement(t.body),a=[];!i&&it.isBlockStatement(t.body)&&lt(t.body.body,a,it),f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:i,bodyParenStart:i&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,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:p,totalFunctions:d};const g=new at(t);for(let e=f.length-1;e>=0;e--)dt(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 dt(e,t,n){const{probeVarName:o,probeIdx:r,functionId:s,entryVars:i,exitVars:a,returns:u,bodyStart:c,bodyEnd:p,functionEnd:d,isExpressionBody:l,bodyParenStart:f}=n,m=`$dd_e${r}`,h=`$dd_l${r}`,g=i.join(", "),y=a.join(", "),b=g===y,w=b?m:h,$=`const ${o} = $dd_probes('${s}');`,v=`const ${m} = () => ({${g}});`,k=b?"":`const ${h} = () => ({${y}});`,S=`if (${o}) $dd_entry(${o}, this, ${m}());`,E=`catch(e) { if (${o}) $dd_throw(${o}, e, this, ${m}()); 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=["{",$,v,k,"try {",S,"const $dd_rv = "].filter(Boolean).join("\n"),r=[";",`if (${o}) $dd_return(${o}, $dd_rv, this, ${m}(), ${w}());`,"return $dd_rv;",`} ${E}`,"}"].join("\n");e.appendLeft(c,n),e.appendLeft(p,r)}else{const t=["",$,v,k,"let $dd_rv;","try {",S].filter(Boolean).join("\n"),n=["",`if (${o}) $dd_return(${o}, undefined, this, ${m}(), ${w}());`,`} ${E}`,""].join("\n");e.appendLeft(c+1,t);for(const t of u)null!=t.argStart&&null!=t.argEnd?(e.appendLeft(t.argStart,"($dd_rv = "),e.appendLeft(t.argEnd,`, ${o} ? $dd_return(${o}, $dd_rv, this, ${m}(), ${w}()) : $dd_rv)`)):e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, this, ${m}(), ${w}()); `);e.appendLeft(p-1,n)}}function lt(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))lt(o.body,t,n);else if(n.isIfStatement(o))lt([o.consequent],t,n),o.alternate&&lt([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))lt([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)lt(e.consequent,t,n);else n.isTryStatement(o)?(lt(o.block.body,t,n),o.handler&&lt(o.handler.body.body,t,n),o.finalizer&&lt(o.finalizer.body,t,n)):n.isLabeledStatement(o)&&lt([o.body],t,n)}const ft=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],mt=t.bold.red,ht=Number(process.env.DD_LD_LIMIT)||1/0,gt=(e,t)=>{const n=t.getLogger(Ge);let o=0,r=0,s=0,i=0,a=0,u=0,c=0,p=0;return{name:Ge,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>ht)return{code:d};try{const n=pt({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,s+=n.skippedByCommentCount,i+=n.skippedFileCount,a+=n.skippedUnsupportedCount,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:s,skippedFileCount:i,skippedUnsupportedCount:a,totalFilesWithFunctions:p,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},yt=({options:e,context:t})=>{const n=((e,t)=>{const n=e.liveDebugger||{},o=[];if(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(!ft.includes(e)){o.push(`${mt("functionTypes")} contains invalid value "${e}". Valid values: ${ft.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 ${Ge}.`);return{enable:!!n.enable,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(Ge));return n.enable?(t.inject({type:"code",position:Je.BEFORE,injectIntoAllChunks:!0,value:"if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}"}),[gt(n,t)]):[]},bt=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],wt="metrics",$t="datadog-metrics-plugin",vt=e=>Math.floor((e||Date.now())/1e3),kt=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),St=(e="")=>e.endsWith("/")?e:`${e}/`,Et=(e,t)=>{let n=e;return e.split(St(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},xt=(e,t)=>e.split("!").pop().replace(St(t),"./"),Pt=(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)),xt(o||"no-name",n)},Dt=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),jt=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Ct=t.bold.red,Rt=t.bold.cyan,Mt=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},At=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Mt("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:q(e.duration)}))),top:!0};n.sort(Mt("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Tt=(e,t,n)=>{const o=[];var r;n&&(o.push(...At("Loader",n.loaders)),o.push(...At("Tapable",n.tapables)),o.push(...At("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=z(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 p=Array.from(s);return p.sort(Mt((e=>e.dependents.size))),t.values=p.map((e=>({name:e.name,value:e.dependents.size.toString()}))),p.sort(Mt((e=>e.dependencies.size))),n.values=p.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),p.sort(Mt("size")),o.values=p.map((e=>({name:e.name,value:m(e.size)}))),p.sort(Mt("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(Mt((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Mt((e=>e.size))).map((e=>({name:e.name,value:m(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Mt((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:q(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:q(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:q(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=K(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+=` [${Ct(e.value)}] ${" ".repeat(n)}${Rt(e.name)}\n`}}return t})(o);t.info(s)},Ot="api/v1/series",It=t.bold.green,Nt=["onStart","onLoad","onResolve","onEnd"],_t=new Map,Ft=new Map,zt=new Map,Lt=(e,t,n)=>{const o=Object.assign({},e);for(const r of Nt)o[r]=async(o,s)=>{const i=Ft.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=xt(e[0].path,n),u=zt.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=y.performance.now();try{return await s(...e)}finally{const n=y.performance.now(),s=n-c,p={start:c,end:n,duration:s,context:jt(e)};if(i.events[r].values.push(p),i.duration+=s,i.increment+=1,Ft.set(t,i),u.events[r].values.push(p),u.duration+=s,u.increment+=1,zt.set(o,u),a){const e=_t.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+=s,e.increment+=1,_t.set(t,e)}}}))};return o},qt=(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=Lt(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:Ft,modules:zt,loaders:_t};o.end(),await e.asyncHook("timings",{tapables:r,loaders:s,modules:i})}))}});class Kt{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Pt(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Dt))(e);o.length||o.push("no-loader"),this.started[n]={module:Et(n),timings:{start:y.performance.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Pt(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=y.performance.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},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 Bt{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=y.performance.now(),i=t.apply(this,r),a=()=>{this.saveResult(e,n,o,jt(r),s,y.performance.now())};return i.then(a,a),i}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const s=y.performance.now(),i=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,jt(r),s,y.performance.now()),i(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const s=y.performance.now(),i=t.apply(this,r);return this.saveResult(e,n,o,jt(r),s,y.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($t)||(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 Ht=e=>async t=>{const n=e.getLogger($t),o={name:$t},r=new Bt(e.buildRoot),s=new Kt(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})}))},Ut={filters:bt},Wt=({options:e,context:t})=>{const n=t.getLogger($t);let o=0;const r=((e,t)=>{const n=e[wt],o=vt(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enable:!!e[wt],enableDefaultPrefix:!0,enableTracing:!1,filters:bt,tags:[],...e[wt],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[];if(!r.enable)return s;const i={name:$t,enforce:"pre",esbuild:qt(t,n),webpack:Ht(t),rspack:Ht(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"),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,p=new Map,d=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$/,"");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,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}`))),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 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})(p,s);i.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 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(kt(e,o,r))}const i=Array.from(s).filter((e=>e.toSend)).length;return s.add(kt({metric:"metrics.count",type:"count",points:[[t,i+1]],tags:[],toSend:!0},o,r)),s})(new Set([...a,...d,...f]),s,r.filters,r.tags,r.prefix);await t.asyncHook("metrics",m),e.end();const h=n.time("outputing report");Tt(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: ${It(`https://api.${t.site}/${Ot}`)}\n\nMetrics:\n - ${s.join("\n - ")}`),I({method:"POST",url:`https://api.${t.site}/${Ot}?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[wt]?.timestamp||(r.timestamp=vt(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&&s.push(i),s.push(l),s},Jt="output",Gt="datadog-output-plugin",Vt=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,Yt=e=>{const t=void 0===e;return{build:Vt("build",e?.build??t),bundler:Vt("bundler",e?.bundler??t),dependencies:Vt("dependencies",e?.dependencies??t),errors:Vt("errors",e?.errors??t),logs:Vt("logs",e?.logs??t),metrics:Vt("metrics",e?.metrics??t),timings:Vt("timings",e?.timings??t),warnings:Vt("warnings",e?.warnings??t)}},Qt=(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}))}))},Xt=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},Zt=({options:e,context:t})=>{const n=(e=>({enable:!!e[Jt],path:"./",...e[Jt],files:Yt(e[Jt]?.files)}))(e),o=t.getLogger(Gt);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 p;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await ee(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){p=e}p?o.error(`Failed writing ${s}: ${p}`):o.debug(`Wrote "./${c.relative(t.buildRoot,i)}"`),e.end()})())};return[{name:Gt,buildReport(e){const t=o.time("serialize report"),n=z(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:Qt(o,(e=>{r("bundler",e)})),rollup:Xt((e=>{r("bundler",e)})),vite:Xt((e=>{r("bundler",e)})),webpack:Qt(o,(e=>{r("bundler",e)}))}]},en="rum",tn="datadog-rum-plugin",nn=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")});`,on="datadog-rum-privacy-plugin";const rn=(e,t)=>{const n=t.getLogger(on),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:on,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=b.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}})}}},sn=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,an=(e,t)=>{const n=e.sdk;if(n.clientToken)return sn(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 I({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 sn({...e,sdk:{clientToken:o,...n}})}},un=e=>{const n=t.bold.red,o=e[en]||{},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},cn=e=>{const t=e[en]||{},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},pn=e=>{const n=t.bold.red,o=e[en]||{},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},dn=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=un(e),r=cn(e),s=pn(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 ${tn}.`);const i={enable:!!e[en],...e[en],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(tn)),o=[];if(!n.enable)return o;if(n.sourceCodeContext&&t.inject({type:"code",position:Je.BEFORE,injectIntoAllChunks:!0,value:nn(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:Je.MIDDLE,value:c.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Je.MIDDLE,value:an(n,t)})),n.privacy){t.inject({type:"file",position:Je.BEFORE,value:c.join(__dirname,"./privacy-helpers.js")});const e=rn(n.privacy,t);o.push(e)}return o},ln="datadog-analytics-plugin",fn=({context:e})=>{const t=e.getLogger(ln);return[{name:ln,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",hn=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 ")}`)}}]},gn=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},yn=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,bn=/(\?|%3F|\|)+/gi,wn=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=kn(e),yn.lastIndex=0,yn.exec(t)?.[1]||"unknown");var t},$n=["unknown","commonjsHelpers.js",`vite${c.sep}preload-helper.js`],vn=(e,t,n)=>{const o=new Set;for(const n of e){const e=kn(n);F(n)||e===t||$n.includes(e)||o.add(e)}return o},kn=e=>e.split("!").pop().split(bn).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Sn=(e,t)=>F(t)?j:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(c.sep),o=e.split(c.sep).filter(((e,t)=>e===n[t])).join(c.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(bn).shift().replace(/^((\.\.?)?[/\\])+/g,""),En=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[ge(t,e),n]))),xn=(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 gn(n,e,t));for(const t of r){const n=Sn(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=[],p=[],d=[],l=[],f=[],m={},h={},g=t.time("indexing metafile data"),y=En(n.metafile.inputs,a),b=En(n.metafile.outputs,a);g.end();const w=e=>{if(!F(e))return e;const t=y[ge(a,e)];if(!t)return e;const n=t.imports.find((e=>!F(e.path)));return n?n.path:e},$=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(F(e))continue;const n=ge(a,e),o={name:Sn(i,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:wn(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=ge(a,e),s=Sn(i,n),u=[];for(const e of Object.keys(r.inputs)){if(F(e))continue;const n=m[ge(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${s}`)}if(r.entryPoint&&!u.length){const e=m[ge(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:wn(n)};if(h[n]=c,"map"===c.type&&l.push(c),p.push(c),!r.entryPoint)continue;const f=m[ge(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 S={inputs:{report:m,meta:y},outputs:{report:h,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,x=e=>!F(e)&&!e.match(E),P=(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(/^\.\.?\//),p=s?c.dirname(e):a,d=ge(p,t.path);if(t.external){if(x(t.path)){const e=s?d:t.path,n=S.inputs.report[e]||{filepath:e,name:Sn(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 P(d,n,o)}return o},D=t.time("looping through entries");for(const e of d){const t={},n={};for(const n of e.inputs)P(n.filepath,S.inputs,t);for(const t of e.outputs)P(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)}D.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=ge(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=p,e.build.inputs=u,e.build.entries=f,s.end(),await e.asyncHook("buildReport",e.build)}))}}),Pn=(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}),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=kn(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=vn(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),s=vn(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?ge(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=kn(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=kn(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=ge(h,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),s=d.get(o)||{name:e,filepath:o,inputs:[],size:r,type:wn(e)};if("map"===s.type&&y.add(s),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(kn(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:Sn(h,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:wn(e)};s.inputs.push(o),p.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=kn(e);if(!f.has(n)){b.set(ge(h,n),s);continue}if(p.has(n)){t.debug(`Input report already there for ${n} from ${s.name}.`);continue}const o=p.get(n)||{name:Sn(h,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};s.inputs.push(o),p.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...s,name:n.name,size:0,outputs:[s]}),d.set(s.filepath,s)}s.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 ${Sn(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 ${Sn(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=Sn(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 s=m[Sn(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(ge(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}":"${Sn(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)}}},Dn=(e,t,n)=>o=>{let r=[],s=[],i=[];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 ")||F(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=kn(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=kn(t.request);if(p.has(n))return p.get(n);if(e.context){const t=ge(kn(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=[],s=[],i=[],a.clear(),u.clear(),p.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=Sn(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:wn(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,p=t.getAssets(),l=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>ge(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"===wn(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:ge(e.bundler.outDir,t.name),type:wn(t.name)};if(u.set(o.filepath,o),s.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,s=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"===wn(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)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:d?ge(e.bundler.outDir,d):"unknown",size:a,inputs:Array.from(s.values()),outputs:Array.from(t.values()),type:d?wn(d):"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)}))},jn="datadog-build-report-plugin",Cn=e=>{const{context:t}=e,n=t.getLogger(jn);return[{name:jn,enforce:"post",esbuild:xn(t,n),rspack:Dn(t,jn,n),webpack:Dn(t,jn,n),vite:Pn(t,n),rollup:Pn(t,n)}]},Rn="datadog-bundler-report-plugin",Mn=(e,t)=>t?c.isAbsolute(t)?t:c.resolve(e,t):"",An=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)},Tn=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Mn(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},On=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=An(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=be(r,process.cwd())),e.bundler.outDir=Mn(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),In=e=>{const{context:t}=e,n=t.getLogger(Rn);return[{name:Rn,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Mn(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Mn(t.buildRoot,c.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Tn(t),rspack:Tn(t),vite:On(t),rollup:{options(e){let n;if("output"in e){const t=An(e.output);n=be(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=ge(process.cwd(),n);const e=be([n,...o],process.cwd());t.buildRoot=e===c.sep?process.cwd():e}else t.buildRoot=be(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=An(e);be(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.")}}}]},Nn="datadog-custom-hooks-plugin",_n=e=>{const{context:t}=e,n=t.getLogger(Nn),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:Nn,enforce:"pre"}]};class Fn{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=ne(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 zn=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await Ln(e);for(const e of t)if(e.name===n)return B(e.refs.push);return B(t[0].refs.push)},Ln=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},qn=async e=>e.revparse("HEAD"),Kn=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),Bn=async e=>e.branch(),Hn=async e=>e.show(["-s","--format=%s"]),Un=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),Wn="datadog-git-plugin",Jn=e=>{const{options:t,context:n}=e,o=n.getLogger(Wn),r=o.time("get git information",{start:!1}),s=async e=>{try{const t=await(async e=>{const t=[qn(e),Bn(e),Hn(e),Un(e),Kn(e),zn(e)],[n,o,r,s,i,a]=await Promise.all(t),[u,c,p,d,l,f]=s.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 Fn(i)}})(await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=w.simpleGit(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return w.simpleGit(t)})(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:Wn,enforce:"pre",buildRoot(e){if(L(t))try{r.resume();const t=ye(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}`)}}}]},Gn="datadog-injection-plugin",Vn=/^https?:\/\//,Yn=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],Qn=t.bold.yellow,Xn=async(e,t=process.cwd())=>(e=>i.readFile(e,{encoding:"utf-8"}))(ge(t,e)),Zn=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(Vn)?await(async(e,t=5e3)=>{let n;return Promise.race([I({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await Xn(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} - ${K(r)}`;e.fallback?(t.debug(`Fallback for "${i}": ${s.toString()}`),o=await Zn(e.fallback,t,n)):t.warn(`Failed "${i}": ${s.toString()}`)}return o},eo=(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`},to=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 Zn(s,t,n);if(e){const t=s.position||Je.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)},no=e=>e instanceof Error&&"code"in e,oo=e=>Yn.includes(e),ro=(e,t,n)=>{e.warn(`"${Qn(t)}" files are not supported (${Qn(n)}).`)},so=a.promises,io=(e,t,n)=>({setup(o){const{onStart:r,onResolve:s,onLoad:u,onEnd:p,esbuild:l,initialOptions:f}=o,m=[],h=`${t.bundler.name}.${Je.MIDDLE}.${j}.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 gn(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await ee(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:Gn}))),u({filter:b,namespace:Gn},(async()=>({contents:eo(n,{position:Je.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),p((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=eo(n,{position:Je.BEFORE}),s=eo(n,{position:Je.AFTER}),i=eo(n,{position:Je.BEFORE,onAllChunks:!0}),a=eo(n,{position:Je.AFTER,onAllChunks:!0});if(!(r||s||i||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:i,f=o?s:a;if(!d&&!f)continue;const h=ge(t.buildRoot,n),{base:g,ext:y}=c.parse(h);oo(y)?u.push((async()=>{try{const e=await so.readFile(h,"utf-8"),t=await l.transform(e,{loader:"default",banner:d,footer:f});await so.writeFile(h,t.code)}catch(t){if(!no(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${h}: ${t}`)}})()):ro(e,y,g)}await Promise.all(u)}))}}),ao=j,uo="?inject-proxy",co=(e,t)=>({banner(n){const o=eo(t,{position:Je.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:s}=c.parse(n.fileName);return oo(s)?o:(ro(e,s,r),"")},async resolveId(e,n,o){if(F(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&eo(t,{position:Je.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}${uo}`}return null},load(e){if(F(e))return eo(t,{position:Je.MIDDLE});if(e.endsWith(uo)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(ao)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=eo(t,{position:Je.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:s}=c.parse(n.fileName);return oo(s)?o:(ro(e,s,r),"")}}),po=(e,t,n,o,r)=>s=>{const i=new WeakMap,u=e.sources.ConcatSource,p=n.bundler.name,d=c.resolve(n.bundler.outDir,`${p}.${Je.MIDDLE}.${j}.js`);te(d,"");s.hooks.shutdown.tap(Gn,(()=>{var e;e=d,a.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const l=async()=>{await to(t,o,r,n.buildRoot)};s.hooks.beforeRun.tapPromise(Gn,l),s.hooks.watchRun.tapPromise(Gn,l),s.hooks.compilation.tap(Gn,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:Gn,stage:o},(()=>{const e=eo(r,{position:Je.BEFORE}),o=eo(r,{position:Je.AFTER}),s=eo(r,{position:Je.BEFORE,onAllChunks:!0}),a=eo(r,{position:Je.AFTER,onAllChunks:!0});for(const r of n.chunks){let p=e,d=o;if(r.canBeInitial()||(p=s,d=a),""!==p||""!==d)for(const e of r.files){const{base:o,ext:r}=c.parse(e);oo(r)?n.updateAsset(e,(e=>{const t=i.get(e);if(!t||t.banner!==p||t.footer!==d){const t=new u(p,"\n",e,"\n",d);return i.set(e,{source:t,banner:p,footer:d}),t}return t.source})):ro(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}})(s.options.entry);s.options.entry=f},lo=e=>{const{bundler:t,context:n}=e,o=n.getLogger(Gn),r=new Map,s=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++U}`,e)};const i={name:Gn,enforce:"post",esbuild:io(o,n,s),webpack:po(t,o,n,r,s),rspack:po(t,o,n,r,s),rollup:co(o,s),vite:{...co(o,s),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>eo(s,{position:Je.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:C},handler:()=>({code:eo(s,{position:Je.MIDDLE})})}:i.buildStart=async()=>{await to(o,r,s,n.buildRoot)},[i]},fo="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()},s=e=>{e.hooks.shutdown.tapPromise(fo,r)},i={async writeBundle(){},async closeBundle(){await r()}};return[{name:fo,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:i,rollup:i,rspack:s}]},ho={[wt]:Ut},go=t.bold.red;var yo="3.1.2-dev.0";const bo=(({bundler:t,version:n})=>{const o=Date.now();return e.createUnplugin(((e,r)=>{const s=Date.now(),i=((e={})=>{const t={site:P("SITE")||e.auth?.site||"datadoghq.com"};return Object.defineProperty(t,"apiKey",{value:P("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(t,"appKey",{value:P("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:t}})(e);"esbuild"===r.framework&&(r.esbuildHostName=M);const a=process.env.BUILD_PLUGINS_ENV||"production",u=R.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,p=r.framework,d={bundler:{name:p,version:c},env:u,metadata:i.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(),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:Y(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:N(n),start:e,version:n.version}})({start:o,options:i,data:d,stores:l}),m=f.getLogger("factory"),h=m.time("Plugins initialization",{start:s});f.pluginNames.push(M);const g=[];g.push(["analytics",fn],["async-queue",hn],["build-report",Cn],["bundler-report",In],["custom-hooks",_n],["git",Jn],["injection",lo],["true-end",mo]),i.customPlugins&&g.push(["custom",i.customPlugins]),g.push(["apps",Me],["error-tracking",We],["live-debugger",yt],["metrics",Wt],["output",Zt],["rum",dn]);for(const[e,n]of g)f.plugins.push(...Z(f,n,e)({bundler:t,context:f,options:i,data:d,stores:l}));return(e=>{const t=[];for(const n of x){const o=D(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>E(e))).join(" and "),s=E(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${s}`),t.push(`${r} (using ${s})`)}else if(o.length){const e=o.map((e=>S(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: ${go(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),h.end(),f.plugins}))})({bundler:$,version:yo}).webpack,wo=yo,$o=ho;exports.datadogWebpackPlugin=bo,exports.helpers=$o,exports.version=wo;
2
2
  //# sourceMappingURL=index.js.map