@datadog/rollup-plugin 3.0.1-dev.3 → 3.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/index.js +1 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/index.mjs +1 -1
- package/dist/src/index.mjs.map +1 -1
- package/package.json +3 -4
package/dist/src/index.mjs
CHANGED
|
@@ -6,5 +6,5 @@ import cjsModule from 'node:module';
|
|
|
6
6
|
const __filename = cjsUrl.fileURLToPath(import.meta.url);
|
|
7
7
|
const __dirname = cjsPath.dirname(__filename);
|
|
8
8
|
const require = cjsModule.createRequire(import.meta.url);
|
|
9
|
-
const b=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],w="__datadog-helper-file",v=new RegExp(w),$=["development","production","test"],k="datadog-build-plugins",S=[400,403,413],E=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(S.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)},D=e=>({message:t,context:n})=>E({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||k,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"}}}}),x=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),R=e=>e.includes(w),P=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},M=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},T=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()},j=(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)}`},O=(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}};let z=0;const N={debug:0,info:1,warn:2,error:3,none:4},A=e=>e.split(">").map(x).join(">"),I=(e,n,o,s)=>{const r=A(e);return(i,a="debug",{forward:u}={})=>{let p=t.dim,c=console.log;"error"===a?(p=t.red,c=console.error):"warn"===a?(p=t.yellow,c=console.warn):"info"===a&&(p=t.cyan,c=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${r}]`,d="string"==typeof i?i:JSON.stringify(i,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:d,time:Date.now()}),"error"===a&&o.errors.push(d),"warn"===a&&o.warnings.push(d),u){const t=async()=>{try{const t=D(n);await t({message:d,context:{plugin:e,status:a}})}catch(t){I(e,n,o,s)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}N[a]>=N[s]&&c(`${p(l)} ${d}`)}},C=(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(T(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)}}},_=(e,t,n="warn")=>o=>{const s=I(o,e,t,n);return{getLogger:s=>_(e,t,n)(`${A(o)}>${s}`),time:C(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)}},L=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],F=(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)},K=(e,t,n)=>{const o=e.getLogger(k);return e=>{const s=o.time(`hook | init ${n}`,{log:!1}),r=t(e).map((e=>((e,t)=>{const n={...e},o=x(e.name);for(const s of L){const r=e[s];r&&(n[s]=F(o,s,r,t))}return n})(e,o))),i=r.map((e=>`plugin:${e.name}`));return s.tag(i),s.end(),r}},H="errorTracking",q="datadog-error-tracking-plugin",B=(e,n,s)=>{if(".map"!==o.extname(s))throw new Error(`The file ${t.green.bold(s)} is not a sourcemap.`);const r=s.replace(/\.map$/,""),i=o.relative(n,r),a=((e,t)=>{if(e.startsWith("/"))return o.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,i);return{minifiedFilePath:r,minifiedUrl:a,relativePath:i}},W=async e=>r.mkdir(e,{recursive:!0}),U=(e,t)=>{var n;n=o.dirname(e),i.mkdirSync(n,{recursive:!0}),i.writeFileSync(e,t,{encoding:"utf-8"})},G=e=>{try{return i.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},J=async(e,t)=>{if("function"==typeof i.openAsBlob){const n=await i.openAsBlob(e,{type:t.contentType});return new s([n],t.filename)}{const n=u.toWeb(i.createReadStream(e)),o=await new Response(n).blob();return new s([o],t.filename,{type:t.contentType})}},V=async e=>{const t={empty:!1,exists:!0};try{const{size:n}=await r.stat(e);0===n&&(t.empty=!0)}catch(e){if("ENOENT"!==e.code)throw e;t.exists=!1}return t},Y=/[/]+|[\\]+/g,Q=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,X=(e,t)=>{const n=e.replace(Q,"").split(Y),o=t.replace(Q,"").split(Y),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},Z=async(e,t,n,s)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([V(e.minifiedFilePath),V(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:X(e.relativePath,t)}})(e,n),i=[],a=[],u=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(s)try{u.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:s.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{a.push(`${o.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:s.hash,repository_url:s.remote}],version:1})})}catch(t){a.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&a.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:u,errors:i,warnings:a}},ee=t.green.bold,te=t.yellow.bold,ne=t.red.bold,oe=(e,t={})=>async()=>{const n=new FormData,o=c();for(const[t,o]of e.content){const e="file"===o.type?await J(o.path,o.options):new Blob([o.value],{type:o.options.contentType});n.append(t,e,o.options.filename)}const s=new Request("fake://url",{method:"POST",body:n});return{data:u.fromWeb(s.body).pipe(o),headers:{"Content-Encoding":"gzip",...t,...Object.fromEntries(s.headers.entries())}}},se=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(p.default?p.default:p)({concurrency:t.maxConcurrency}),u=(c=n.site,b("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const l={"DD-EVP-ORIGIN":`${n.bundlerName}-build-plugin_sourcemaps`,"DD-EVP-ORIGIN-VERSION":n.version},d=Object.entries({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(l,null,2)}`}).map((([e,t])=>` - ${e}: ${ee(t.toString())}`)).join("\n"),m=`\nUploading ${ee(e.length.toString())} sourcemaps with configuration:\n${d}`;o.info(m);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 E({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:oe(i,l),onRetry:(t,n)=>{const s=`Failed to upload ${te(e.sourcemap)} | ${te(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 ${ee(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:r,errors:s}},re=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=>({...B(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=>Z(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 se(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site},o);if(l.end(),o.info(`Done uploading ${ee(`${e.length-d.length}/${e.length}`)} sourcemaps in ${ee(T(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?`${ne(e.file)} | ${ne(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()},ie=e=>{const n=t.bold.red,o=e[H]||{},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},ae=({options:e,context:t})=>{const n=t.getLogger(q),o=n.time("validate options"),s=((e,t)=>{const n=[],o=ie(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${q}.`);const s={enable:!!e[H],...e[H],sourcemaps:void 0};return o.config&&(s.sourcemaps=o.config),s})(e,n);if(o.end(),!s.enable)return[];let r,i;const a=async()=>{if(!s.sourcemaps)return;const e=n.time("sourcemaps process");await re(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:q,enforce:"post",async git(e){r=e,i&&await a()},async buildReport(t){i=t,!r&&M(e)||await a()}}]},ue=[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}],pe="metrics",ce="datadog-metrics-plugin",le=e=>Math.floor((e||Date.now())/1e3),de=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),me=(e="")=>e.endsWith("/")?e:`${e}/`,fe=(e,t)=>{let n=e;return e.split(me(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},ge=(e,t)=>e.split("!").pop().replace(me(t),"./"),he=(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)),ge(o||"no-name",n)},ye=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),be=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),we=t.bold.red,ve=t.bold.cyan,$e=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},ke=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort($e("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:T(e.duration)}))),top:!0};n.sort($e("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Se=(e,t,n)=>{const o=[];var s;n&&(o.push(...ke("Loader",n.loaders)),o.push(...ke("Tapable",n.tapables)),o.push(...ke("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=P(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($e((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort($e((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort($e("size")),o.values=c.map((e=>({name:e.name,value:l(e.size)}))),c.sort($e("aggregatedSize")),s.values=c.map((e=>({name:e.name,value:l(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($e((e=>e.size))).map((e=>({name:e.name,value:l(e.size)}))),top:!0},{name:"Entry aggregated size",values:(s.build.entries||[]).sort($e((e=>e.size))).map((e=>({name:e.name,value:l(e.size)}))),top:!0},{name:"Entry number of modules",values:(s.build.entries||[]).sort($e((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:T(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:T(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:T(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=j(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+=` [${we(e.value)}] ${" ".repeat(n)}${ve(e.name)}\n`}}return t})(o);t.info(r)},Ee="api/v1/series",De=t.bold.green,xe=["onStart","onLoad","onResolve","onEnd"],Re=new Map,Pe=new Map,Me=new Map,Te=(e,t,n)=>{const o=Object.assign({},e);for(const s of xe)o[s]=async(o,r)=>{const i=Pe.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=ge(e[0].path,n),u=Me.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[s]=u.events[s]||{name:s,values:[]};const p=d.now();try{return await r(...e)}finally{const n=d.now(),r=n-p,c={start:p,end:n,duration:r,context:be(e)};if(i.events[s].values.push(c),i.duration+=r,i.increment+=1,Pe.set(t,i),u.events[s].values.push(c),u.duration+=r,u.increment+=1,Me.set(o,u),a){const e=Re.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,Re.set(t,e)}}}))};return o},je=(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=Te(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:Pe,modules:Me,loaders:Re};o.end(),await e.asyncHook("timings",{tapables:s,loaders:r,modules:i})}))}});class Oe{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=he(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(ye))(e);o.length||o.push("no-loader"),this.started[n]={module:fe(n),timings:{start:d.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=he(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=d.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 ze{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=d.now(),i=t.apply(this,s),a=()=>{this.saveResult(e,n,o,be(s),r,d.now())};return i.then(a,a),i}}getAsyncTapPatch(e,t,n,o){return(...s)=>{this.checkNewHooks();const r=d.now(),i=s.pop();return t.apply(this,[...s,(...t)=>(this.saveResult(e,n,o,be(s),r,d.now()),i(...t))])}}getDefaultTapPatch(e,t,n,o){return(...s)=>{this.checkNewHooks();const r=d.now(),i=t.apply(this,s);return this.saveResult(e,n,o,be(s),r,d.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(ce)||(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 Ne=e=>async t=>{const n=e.getLogger(ce),o={name:ce},s=new ze(e.buildRoot),r=new Oe(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})}))},Ae={filters:ue},Ie=({options:e,context:t})=>{const n=t.getLogger(ce);let o=0;const s=((e,t)=>{const n=e[pe],o=le(n?.timestamp);let s=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(s+=s?`.${n.prefix}`:n.prefix),{enable:!!e[pe],enableDefaultPrefix:!0,enableTracing:!1,filters:ue,tags:[],...e[pe],timestamp:o,prefix:s.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),r=[];if(!s.enable)return r;const i={name:ce,enforce:"pre",esbuild:je(t,n),webpack:Ne(t),rspack:Ne(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(de(e,o,s))}const i=Array.from(r).filter((e=>e.toSend)).length;return r.add(de({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 g=n.time("outputing report");Se(t,n,p),g.end();const h=n.time("sending metrics to Datadog");await((e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.info("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: ${De(`https://api.${t.site}/${Ee}`)}\n\nMetrics:\n - ${r.join("\n - ")}`),E({method:"POST",url:`https://api.${t.site}/${Ee}?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),h.end()},d={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){a.resume(),t.build.start=t.build.start||Date.now(),e[pe]?.timestamp||(s.timestamp=le(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},Ce="output",_e="datadog-output-plugin",Le=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,Fe=e=>{const t=void 0===e;return{build:Le("build",e?.build??t),bundler:Le("bundler",e?.bundler??t),dependencies:Le("dependencies",e?.dependencies??t),errors:Le("errors",e?.errors??t),logs:Le("logs",e?.logs??t),metrics:Le("metrics",e?.metrics??t),timings:Le("timings",e?.timings??t),warnings:Le("warnings",e?.warnings??t)}},Ke=(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}))}))},He=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},qe=({options:e,context:t})=>{const n=(e=>({enable:!!e[Ce],path:"./",...e[Ce],files:Fe(e[Ce]?.files)}))(e),s=t.getLogger(_e);if(!n.enable)return[];const r=(e,r)=>{const u=n.files[e];if(!r||!1===u)return;t.queue((async()=>{const e=s.time(`output ${u}`),p=((e,t,n)=>{const s=o.isAbsolute(t)?t:o.resolve(e,t);return o.resolve(s,n)})(t.bundler.outDir,n.path,u);let c;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await W(o.dirname(e));const n=i.createWriteStream(e),s=new a(t,void 0,2),r=new Promise(((e,t)=>{s.on("end",(()=>{e()})),s.on("error",(e=>{t(e)}))}));return s.pipe(n),r})(p,e)}catch(e){c=e}c?s.error(`Failed writing ${u}: ${c}`):s.info(`Wrote "${p}"`),e.end()})())};return[{name:_e,buildReport(e){const t=s.time("serialize report"),n=P(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:Ke(s,(e=>{r("bundler",e)})),rollup:He((e=>{r("bundler",e)})),vite:He((e=>{r("bundler",e)})),webpack:Ke(s,(e=>{r("bundler",e)}))}]};var Be=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(Be||{});const We="rum",Ue="datadog-rum-plugin",Ge="datadog-rum-privacy-plugin";const Je=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Ve=(e,t)=>{const n=e.sdk;if(n.clientToken)return Je(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 E({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 Je({...e,sdk:{clientToken:o,...n}})}},Ye=e=>{const n=t.bold.red,o=e[We]||{},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.`);return s.config={applicationId:"unknown_application_id",allowUntrustedEvents:!1,compressIntakeRequests:!1,defaultPrivacyLevel:"mask",enablePrivacyForActionName:!1,sessionReplaySampleRate:0,sessionSampleRate:100,silentMultipleInit:!1,site:"datadoghq.com",startSessionReplayRecordingManually:!1,storeContextsAcrossPages:!1,telemetrySampleRate:20,traceSampleRate:100,trackingConsent:"granted",trackLongTasks:!1,trackResources:!1,trackUserInteractions:!1,trackViewsManually:!1,...o.sdk},s},Qe=e=>{const t=e[We]||{},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},Xe=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=Ye(e),s=Qe(e);if(n.push(...o.errors),n.push(...s.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Ue}.`);const r={enable:!!e[We],...e[We],sdk:void 0,privacy:void 0};return o.config&&(r.sdk=o.config),s.config&&(r.privacy=s.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(r.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),r})(e,t.getLogger(Ue)),s=[];if(!n.enable)return s;if(n.sdk&&(t.inject({type:"file",position:Be.MIDDLE,value:o.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Be.MIDDLE,value:Ve(n,t)})),n.privacy){t.inject({type:"file",position:Be.BEFORE,value:o.join(__dirname,"./privacy-helpers.js")});const e=((e,t)=>{const n=t.getLogger(Ge),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);return{name:Ge,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(e,t){try{return m({id:t,code:e},o)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}}}})(n.privacy,t);s.push(e)}return s},Ze="datadog-analytics-plugin",et=({context:e})=>{const t=e.getLogger(Ze);return[{name:Ze,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}`)}})())}}]},tt="datadog-async-queue-plugin",nt=e=>{const{context:t,stores:n}=e,o=t.getLogger(tt),s=[];return t.queue=e=>{const t=e.catch((e=>{s.push(e.message||e.toString())}));n.queue.push(t)},[{name:tt,asyncTrueEnd:async()=>{await Promise.all(n.queue),s.length>0&&o.error(`Error occurred while processing async queue:\n ${s.join("\n ")}`)}}]},ot=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("*")?f.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},st=(e,t)=>R(t)?w:t.startsWith(e)||o.isAbsolute(t)?t:o.resolve(e,t),rt=(e,t)=>{const n=[...e].map((e=>st(t||process.cwd(),e).split(o.sep))),s=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<s;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(o.sep)||o.sep},it=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,at=/(\?|%3F|\|)+/gi,ut=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=lt(e),it.lastIndex=0,it.exec(t)?.[1]||"unknown");var t},pt=["unknown","commonjsHelpers.js",`vite${o.sep}preload-helper.js`],ct=(e,t,n)=>{const o=new Set;for(const n of e){const e=lt(n);R(n)||e===t||pt.includes(e)||o.add(e)}return o},lt=e=>e.split("!").pop().split(at).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),dt=(e,t)=>R(t)?w:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(o.sep),s=e.split(o.sep).filter(((e,t)=>e===n[t])).join(o.sep);return e.replace(s,"")})(t.split("!").pop(),e).split("node_modules").pop().split(at).shift().replace(/^((\.\.?)?[/\\])+/g,""),mt=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[st(t,e),n]))),ft=(e,t)=>({setup(n){const s=new Map;let r=[];const i=t.time("build report",{start:!1});n.onStart((async()=>{s.clear(),r=[],i.resume();const o=t.time("process entries");r.push(...await ot(n,e,t));for(const t of r){const n=dt(e.bundler.outDir,t.resolved);t.name?s.set(n,t.name):s.set(n,n)}o.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),a=e.bundler.outDir,u=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const p=[],c=[],l=[],d=[],m=[],f={},g={},h=t.time("indexing metafile data"),y=mt(n.metafile.inputs,u),b=mt(n.metafile.outputs,u);h.end();const w=e=>{if(!R(e))return e;const t=y[st(u,e)];if(!t)return e;const n=t.imports.find((e=>!R(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(R(e))continue;const n=st(u,e),o={name:dt(a,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:ut(e)};f[n]=o,p.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,o]of Object.entries(n.metafile.outputs)){const n=st(u,e),r=dt(a,n),i=[];for(const e of Object.keys(o.inputs)){if(R(e))continue;const n=f[st(u,e)];n?i.push(n):t.debug(`Input ${e} not found for output ${r}`)}if(o.entryPoint&&!i.length){const e=f[st(u,o.entryPoint)];if(!e){t.debug(`Input ${o.entryPoint} not found for output ${r}`);continue}i.push(e)}const p={name:r,filepath:n,inputs:i,size:o.bytes,type:ut(n)};if(g[n]=p,"map"===p.type&&d.push(p),c.push(p),!o.entryPoint)continue;const m=f[st(u,w(o.entryPoint))];if(m){if(!s.get(m.name))continue;const e={...p,name:s.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=g[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:g,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,D=e=>!R(e)&&!e.match(E),x=(e,n,s={})=>{if(!D(e))return s;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),s;if(s[r.filepath])return s;s[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),s;if(!i.imports||!i.imports.length)return s;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),c=i?o.dirname(e):u,l=st(c,t.path);if(t.external){if(D(t.path)){const e=i?l:t.path,n=S.inputs.report[e]||{filepath:e,name:dt(a,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),p.includes(n)||p.push(n),S.inputs.report[e]=n,s[n.filepath]=n}}else x(l,n,s)}return s},P=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)}P.end();const M=t.time("aggregate dependencies and dependents");for(const e of p){if("external"===e.type)continue;const n=S.inputs.meta[e.filepath];if(n)for(const s of n.imports){if(!D(s.path))continue;const n=s.path.match(/^\.?\.\//),r=n?o.dirname(e.filepath):u,i=st(r,s.path);let a;if(s.external){const e=n?i:s.path;a=S.inputs.report[e]}else a=S.inputs.report[i];a?(e.dependencies.add(a),a.dependents.add(e)):t.debug(`Could not find input file of ${s.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}M.end(),e.build.outputs=c,e.build.inputs=p,e.build.entries=m,i.end(),await e.asyncHook("buildReport",e.build)}))}}),gt=(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}),a=t.time("filling dependencies and dependents",{start:!1}),u=t.time("filling sourcemaps inputs",{start:!1}),p=new Map,c=new Map,l=new Map,d=new Map;return{buildStart(){d.clear(),p.clear(),c.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=lt(e.id),o=d.get(t)||{dependencies:new Set,dependents:new Set},s=ct(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),r=ct(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);d.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,m){o.resume();const f=n.dir?st(e.buildRoot,n.dir):e.bundler.outDir,g=new Set,h=new Set,y=new Map;i.resume();for(const[e,{dependencies:t,dependents:n}]of d){for(const n of t){const t=lt(n),o=d.get(t)||{dependencies:new Set,dependents:new Set};o.dependents.has(e)||(o.dependents.add(e),d.set(t,o))}for(const t of n){const n=lt(t),o=d.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),d.set(n,o))}}i.end(),r.resume();for(const[e,n]of Object.entries(m)){const o=st(f,e),s="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),r=c.get(o)||{name:e,filepath:o,inputs:[],size:s,type:ut(e)};if("map"===r.type&&h.add(r),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(lt(e)!==e)continue;const n=p.get(e)||{name:dt(f,e),dependencies:new Set,dependents:new Set,filepath:e,size:t.originalLength,type:ut(e)};r.inputs.push(n),p.set(n.filepath,n)}if("imports"in n)for(const e of n.imports){const n=lt(e);if(!d.has(n)){y.set(st(f,n),r);continue}if(p.has(n)){t.debug(`Input report already there for ${n} from ${r.name}.`);continue}const o=p.get(n)||{name:dt(f,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};r.inputs.push(o),p.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...r,name:n.name,size:0,outputs:[r]}),c.set(r.filepath,r)}r.end();for(const[e,n]of y){const o=c.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}a.resume();for(const[e,n]of p){const o=d.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 ${dt(f,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 ${dt(f,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(a.end(),h.size){u.resume();for(const e of h){const n=e.filepath.replace(/\.map$/,""),o=c.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}u.end()}const b=(e,n=new Map)=>{if(n.has(e))return n;const o=dt(f,e),s=c.get(e);if(!s)return p.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,s);const r=m[dt(f,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)b(st(f,e),n);return n};s.resume();for(const e of g){const n=b(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}":"${dt(f,e.filepath)}" already reported.`),l.set(e.filepath,e)}s.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(p.values()),e.build.outputs=Array.from(c.values()),e.build.entries=Array.from(l.values()),s.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},ht=(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 ")||R(e)),g=e=>e.replace(/(^external[^"]+"|"$)/g,""),h=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=lt(e);t.add(n),n.startsWith("external ")&&t.add(g(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(c.has(e)){const n=c.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else c.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=lt(t.request);if(c.has(n))return c.get(n);if(e.context){const t=st(lt(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)h(e);r.end();const i=n.time("building inputs");for(const n of t){const t=n.identifier(),o=dt(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)?g(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:g(o),dependencies:new Set,dependents:new Set,filepath:t,type:"external"}:{size:n.size()||0,name:o,dependencies:new Set,dependents:new Set,filepath:t,type:ut(t)};s.push(u),a.set(t,u),w(n)&&a.set(g(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=>st(e.bundler.outDir,t))),g=n.time("indexing chunks"),h=t.chunkGraph;for(const e of o){const t=d(e),n=(h?.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"===ut(e))continue;const t=p.get(e)||new Set;for(const e of n)t.add(e);p.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of c){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:st(e.bundler.outDir,t.name),type:ut(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");for(const[o,s]of t.entrypoints){const t=new Map,r=new Map;let a=0;const p=s.chunks.flatMap(d),c=s.chunks.filter((e=>h.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||s.name&&e.includes(s.name))).find((e=>"js"===ut(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?st(e.bundler.outDir,c):"unknown",size:a,inputs:Array.from(r.values()),outputs:Array.from(t.values()),type:c?ut(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)}))},yt="datadog-build-report-plugin",bt=e=>{const{context:t}=e,n=t.getLogger(yt);return[{name:yt,enforce:"post",esbuild:ft(t,n),rspack:ht(t,yt,n),webpack:ht(t,yt,n),vite:gt(t,n),rollup:gt(t,n)}]},wt="datadog-bundler-report-plugin",vt=(e,t)=>t?o.isAbsolute(t)?t:o.resolve(e,t):"",$t=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?o.dirname(e.file):void 0)).filter(Boolean)},kt=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=vt(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},St=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,s=$t(o);e.buildRoot=t.root??process.cwd(),o&&s.length&&(n=rt(s,process.cwd())),e.bundler.outDir=vt(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Et=e=>{const{context:t}=e,n=t.getLogger(wt);return[{name:wt,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=vt(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=vt(t.buildRoot,o.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:kt(t),rspack:kt(t),vite:St(t),rollup:{options(e){let n;if("output"in e){const t=$t(e.output);n=rt(t,process.cwd())}const s=(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(o.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=st(process.cwd(),n);const e=rt([n,...s],process.cwd());t.buildRoot=e===o.sep?process.cwd():e}else t.buildRoot=rt(s,process.cwd()),t.bundler.outDir=o.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=$t(e);rt(o,process.cwd()).startsWith(t.bundler.outDir)||n.info("The output directory has been changed by a plugin and may introduce some inconsistencies in the build report.")}}}]},Dt="datadog-custom-hooks-plugin",xt=e=>{const{context:t}=e,n=t.getLogger(Dt),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:Dt,enforce:"pre"}]};class Rt{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=(o=e,i.readFileSync(o,{encoding:"utf-8"}));var o;const s=JSON.parse(n);if(!s.sources)return void t("Missing 'sources' field in sourcemap.");const r=s.sources;if(0===r.length)return void t("Empty 'sources' field in sourcemap.");const a=this.matchSources(r);if(0!==a.length)return a;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 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 Pt=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await Mt(e);for(const e of t)if(e.name===n)return O(e.refs.push);return O(t[0].refs.push)},Mt=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},Tt=async e=>e.revparse("HEAD"),jt=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),Ot=async e=>e.branch(),zt=async e=>e.show(["-s","--format=%s"]),Nt=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),At="datadog-git-plugin",It=e=>{const{options:t,context:n}=e,s=n.getLogger(At),r=s.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t=[Tt(e),Ot(e),zt(e),Nt(e),jt(e),Pt(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 Rt(i)}})(await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=g(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return g(t)})(o.dirname(e)));n.git=t,r.end(),await n.asyncHook("git",n.git)}catch(e){s.error(`Could not get git information: ${e.message}`)}};return[{name:At,enforce:"pre",buildRoot(e){if(M(t))try{r.resume();const t=((e,t)=>{let n,s=st(process.cwd(),e);for(;!n;){const e=o.resolve(s,t);if(G(e)&&(n=e),s=s.split(o.sep).slice(0,-1).join(o.sep),[o.sep,""].includes(s))break}return n})(e,".git");if(!t)return void s.warn("No .git directory found, skipping git plugin.");n.queue(i(t))}catch(e){s.error(`Could not get git information: ${e.message}`)}}}]},Ct="datadog-injection-plugin",_t=/^https?:\/\//,Lt=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(st(t,e)),Ft=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(_t)?await(async(e,t=5e3)=>{let n;return Promise.race([E({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(s):await Lt(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} - ${j(s)}`;e.fallback?(t.info(`Fallback for "${i}": ${r.toString()}`),o=await Ft(e.fallback,t,n)):t.warn(`Failed "${i}": ${r.toString()}`)}return o},Kt=e=>{if(0===e.size)return"";return`// begin injection by Datadog build plugins\n${Array.from(e.values()).map((e=>`(() => {${e}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},Ht=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 Ft(r,t,n);e&&o.set(s,{value:e,position:r.position||Be.BEFORE})}return o})(t,e,o);for(const[e,t]of s.entries())n[t.position].set(e,t.value)},qt=i.promises,Bt=(e,t,n)=>({setup(s){const{onStart:a,onResolve:u,onLoad:p,onEnd:c,esbuild:l,initialOptions:d}=s,m=[],f=`${t.bundler.name}.${Be.MIDDLE}.${w}.js`,g=i.realpathSync(h.tmpdir()),y=o.resolve(g,f),b=new RegExp(`${f}$`),v=d.inject;d.inject=v?[...v]:[],d.inject.push(y),a((async()=>{m.push(...await ot(s,t,e)),s.initialOptions.inject=v;try{await(async(e,t)=>{await W(o.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),u({filter:b},(async e=>({path:e.path,namespace:Ct}))),p({filter:b,namespace:Ct},(async()=>({contents:Kt(n[Be.MIDDLE])||" ",resolveDir:t.buildRoot,loader:"js"}))),c((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const s=Kt(n[Be.BEFORE]),r=Kt(n[Be.AFTER]);if(!s&&!r)return;const i=Object.entries(o.metafile.outputs).map((([e,n])=>{const o=n.entryPoint;if(!o)return;return m.find((e=>e.resolved.endsWith(o)))?st(t.buildRoot,e):void 0})).filter(Boolean).map((async t=>{try{const e=await qt.readFile(t,"utf-8"),n=await l.transform(e,{loader:"default",banner:s,footer:r});await qt.writeFile(t,n.code)}catch(n){if(!(e=>e instanceof Error&&"code"in e)(n)||"ENOENT"!==n.code)throw n;e.warn(`Could not inject content in ${t}: ${n}`)}}));await Promise.all(i)}))}}),Wt=w,Ut="?inject-proxy",Gt=e=>({banner:t=>t.isEntry?Kt(e[Be.BEFORE]):"",async resolveId(t,n,o){if(R(t))return{id:t,moduleSideEffects:!0};if(o.isEntry&&Kt(e[Be.MIDDLE])){const e=await this.resolve(t,n,o);if(!e||e.external)return e;return(await this.load(e)).moduleSideEffects=!0,`${e.id}${Ut}`}return null},load(t){if(R(t))return Kt(e[Be.MIDDLE]);if(t.endsWith(Ut)){const e=t.slice(0,-13),n=this.getModuleInfo(e);let o=`import ${JSON.stringify(Wt)};\nexport * from ${JSON.stringify(e)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(e)};`),o}return null},footer:t=>t.isEntry?Kt(e[Be.AFTER]):""}),Jt=(e,t,n,s,r)=>a=>{const u=new WeakMap,p=e.sources.ConcatSource,c=n.bundler.name,l=o.resolve(n.bundler.outDir,`${c}.${Be.MIDDLE}.${w}.js`);U(l,"");a.hooks.shutdown.tap(Ct,(()=>{var e;e=l,i.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));a.hooks.beforeRun.tapPromise(Ct,(async()=>{await Ht(t,s,r,n.buildRoot)})),a.hooks.compilation.tap(Ct,(t=>{const n=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;t.hooks.processAssets.tap({name:Ct,stage:n},(()=>{const e=Kt(r[Be.BEFORE]),n=Kt(r[Be.AFTER]);for(const o of t.chunks)if(o.canBeInitial())for(const s of o.files)t.updateAsset(s,(t=>{const o=u.get(t);if(!o||o.banner!==e||o.footer!==n){const o=new p(e,"\n",t,"\n",n);return u.set(t,{source:o,banner:e,footer:n}),o}return o.source}))}))}));const d=(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}})(a.options.entry);a.options.entry=d},Vt=e=>{const{bundler:t,context:n}=e,o=n.getLogger(Ct),s=new Map,r={[Be.BEFORE]:new Map,[Be.MIDDLE]:new Map,[Be.AFTER]:new Map};n.inject=e=>{s.set(`${Date.now()}.${performance.now()}.${++z}`,e)};const i={name:Ct,enforce:"post",esbuild:Bt(o,n,r),webpack:Jt(t,o,n,s,r),rspack:Jt(t,o,n,s,r),rollup:Gt(r),vite:{...Gt(r),enforce:"pre"}};var a;return a=n.bundler.name,["rspack","webpack"].includes(a)?i.load={filter:{id:v},handler:()=>({code:Kt(r[Be.MIDDLE])})}:i.buildStart=async()=>{await Ht(o,s,r,n.buildRoot)},[i]},Yt="datadog-true-end-plugin",Qt=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(Yt,s)},i={async writeBundle(){},async closeBundle(){await s()}};return[{name:Yt,enforce:"post",webpack:r,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:i,rollup:i,rspack:r}]},Xt={[pe]:Ae},Zt=t.bold.green,en=t.bold.red;var tn="3.0.1-dev.3";const nn=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,s)=>{const r=Date.now(),i=((e={})=>{const t={site:b("SITE")||e.auth?.site||"datadoghq.com"};return Object.defineProperty(t,"apiKey",{value:b("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(t,"appKey",{value:b("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:t}})(e);"esbuild"===s.framework&&(s.esbuildHostName=k);const a=process.env.BUILD_PLUGINS_ENV||"production",u=$.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:_(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:D(n),start:e,version:n.version}})({start:o,options:i,data:l,stores:d}),f=m.getLogger("factory"),g=f.time("Plugins initialization",{start:r});m.pluginNames.push(k);const h=[];h.push(["analytics",et],["async-queue",nt],["build-report",bt],["bundler-report",Et],["custom-hooks",xt],["git",It],["injection",Vt],["true-end",Qt]),i.customPlugins&&h.push(["custom",i.customPlugins]),h.push(["error-tracking",ae],["metrics",Ie],["output",qe],["rum",Xe]);for(const[e,n]of h)m.plugins.push(...K(m,n,e)({bundler:t,context:m,options:i,data:l,stores:d}));return m.pluginNames.push(...m.plugins.map((e=>e.name))),(e=>{const t=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","SITE"],n=[];for(const e of t)b(e)&&n.push(`${Zt(`DD_${e}`)} or ${Zt(`DATADOG_${e}`)}`);n.length&&e.info(`Overrides from environment:\n - ${n.join("\n - ")}`)})(f),(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: ${en(Array.from(t).join(", "))}`)})(m.pluginNames),m.hook("init",m),g.end(),m.plugins}))})({bundler:y,version:tn}).rollup,on=tn,sn=Xt;export{nn as datadogRollupPlugin,sn as helpers,on as version};
|
|
9
|
+
const w=t.bold.green,b=t.bold.yellow,v=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","SITE"],$=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],k=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},S="__datadog-helper-file",D=new RegExp(S),E=["development","production","test"],x="datadog-build-plugins",R=[400,403,413],P=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(R.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)},M=e=>({message:t,context:n})=>P({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||x,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"}}}}),T=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),j=e=>e.includes(S),O=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},z=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},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()},A=(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)}`},I=(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}};let C=0;const _={debug:0,info:1,warn:2,error:3,none:4},L=e=>e.split(">").map(T).join(">"),F=(e,n,o,s)=>{const r=L(e);return(i,a="debug",{forward:u}={})=>{let p=t.dim,c=console.log;"error"===a?(p=t.red,c=console.error):"warn"===a?(p=t.yellow,c=console.warn):"info"===a&&(p=t.cyan,c=console.log);const l=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${r}]`,d="string"==typeof i?i:JSON.stringify(i,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:d,time:Date.now()}),"error"===a&&o.errors.push(d),"warn"===a&&o.warnings.push(d),u){const t=async()=>{try{const t=M(n);await t({message:d,context:{plugin:e,status:a}})}catch(t){F(e,n,o,s)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}_[a]>=_[s]&&c(`${p(l)} ${d}`)}},K=(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(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)}}},H=(e,t,n="warn")=>o=>{const s=F(o,e,t,n);return{getLogger:s=>H(e,t,n)(`${L(o)}>${s}`),time:K(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)}},q=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],B=(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)},W=(e,t,n)=>{const o=e.getLogger(x);return e=>{const s=o.time(`hook | init ${n}`,{log:!1}),r=t(e).map((e=>((e,t)=>{const n={...e},o=T(e.name);for(const s of q){const r=e[s];r&&(n[s]=B(o,s,r,t))}return n})(e,o))),i=r.map((e=>`plugin:${e.name}`));return s.tag(i),s.end(),r}},U="errorTracking",G="datadog-error-tracking-plugin",J=(e,n,s)=>{if(".map"!==o.extname(s))throw new Error(`The file ${t.green.bold(s)} is not a sourcemap.`);const r=s.replace(/\.map$/,""),i=o.relative(n,r),a=((e,t)=>{if(e.startsWith("/"))return o.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,i);return{minifiedFilePath:r,minifiedUrl:a,relativePath:i}},V=async e=>r.mkdir(e,{recursive:!0}),Y=(e,t)=>{var n;n=o.dirname(e),i.mkdirSync(n,{recursive:!0}),i.writeFileSync(e,t,{encoding:"utf-8"})},Q=e=>{try{return i.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},X=async(e,t)=>{if("function"==typeof i.openAsBlob){const n=await i.openAsBlob(e,{type:t.contentType});return new s([n],t.filename)}{const n=u.toWeb(i.createReadStream(e)),o=await new Response(n).blob();return new s([o],t.filename,{type:t.contentType})}},Z=async e=>{const t={empty:!1,exists:!0};try{const{size:n}=await r.stat(e);0===n&&(t.empty=!0)}catch(e){if("ENOENT"!==e.code)throw e;t.exists=!1}return t},ee=/[/]+|[\\]+/g,te=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,ne=(e,t)=>{const n=e.replace(te,"").split(ee),o=t.replace(te,"").split(ee),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},oe=async(e,t,n,s)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([Z(e.minifiedFilePath),Z(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:ne(e.relativePath,t)}})(e,n),i=[],a=[],u=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(s)try{u.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:s.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{a.push(`${o.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:s.hash,repository_url:s.remote}],version:1})})}catch(t){a.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&a.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:u,errors:i,warnings:a}},se=t.green.bold,re=t.yellow.bold,ie=t.red.bold,ae=(e,t={})=>async()=>{const n=new FormData,o=c();for(const[t,o]of e.content){const e="file"===o.type?await X(o.path,o.options):new Blob([o.value],{type:o.options.contentType});n.append(t,e,o.options.filename)}const s=new Request("fake://url",{method:"POST",body:n});return{data:u.fromWeb(s.body).pipe(o),headers:{"Content-Encoding":"gzip",...t,...Object.fromEntries(s.headers.entries())}}},ue=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(p.default?p.default:p)({concurrency:t.maxConcurrency}),u=(c=n.site,$("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const l={"DD-EVP-ORIGIN":`${n.bundlerName}-build-plugin_sourcemaps`,"DD-EVP-ORIGIN-VERSION":n.version},d=Object.entries({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(l,null,2)}`}).map((([e,t])=>` - ${e}: ${se(t.toString())}`)).join("\n"),m=`\nUploading ${se(e.length.toString())} sourcemaps with configuration:\n${d}`;o.info(m);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 P({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:ae(i,l),onRetry:(t,n)=>{const s=`Failed to upload ${re(e.sourcemap)} | ${re(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 ${se(e.length.toString())} uploads.`),await Promise.all(f),await a.onIdle(),{warnings:r,errors:s}},pe=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=>({...J(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=>oe(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 ue(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site},o);if(l.end(),o.info(`Done uploading ${se(`${e.length-d.length}/${e.length}`)} sourcemaps in ${se(N(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?`${ie(e.file)} | ${ie(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()},ce=e=>{const n=t.bold.red,o=e[U]||{},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},le=({options:e,context:t})=>{const n=t.getLogger(G),o=n.time("validate options"),s=((e,t)=>{const n=[],o=ce(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${G}.`);const s={enable:!!e[U],...e[U],sourcemaps:void 0};return o.config&&(s.sourcemaps=o.config),s})(e,n);if(o.end(),!s.enable)return[];let r,i;const a=async()=>{if(!s.sourcemaps)return;const e=n.time("sourcemaps process");await pe(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:G,enforce:"post",async git(e){r=e,i&&await a()},async buildReport(t){i=t,!r&&z(e)||await a()}}]},de=[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}],me="metrics",fe="datadog-metrics-plugin",ge=e=>Math.floor((e||Date.now())/1e3),he=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),ye=(e="")=>e.endsWith("/")?e:`${e}/`,we=(e,t)=>{let n=e;return e.split(ye(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},be=(e,t)=>e.split("!").pop().replace(ye(t),"./"),ve=(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)),be(o||"no-name",n)},$e=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),ke=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Se=t.bold.red,De=t.bold.cyan,Ee=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(Ee("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:N(e.duration)}))),top:!0};n.sort(Ee("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Re=(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=O(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(Ee((e=>e.dependents.size))),t.values=c.map((e=>({name:e.name,value:e.dependents.size.toString()}))),c.sort(Ee((e=>e.dependencies.size))),n.values=c.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),c.sort(Ee("size")),o.values=c.map((e=>({name:e.name,value:l(e.size)}))),c.sort(Ee("aggregatedSize")),s.values=c.map((e=>({name:e.name,value:l(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(Ee((e=>e.size))).map((e=>({name:e.name,value:l(e.size)}))),top:!0},{name:"Entry aggregated size",values:(s.build.entries||[]).sort(Ee((e=>e.size))).map((e=>({name:e.name,value:l(e.size)}))),top:!0},{name:"Entry number of modules",values:(s.build.entries||[]).sort(Ee((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:N(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:N(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:N(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=A(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+=` [${Se(e.value)}] ${" ".repeat(n)}${De(e.name)}\n`}}return t})(o);t.info(r)},Pe="api/v1/series",Me=t.bold.green,Te=["onStart","onLoad","onResolve","onEnd"],je=new Map,Oe=new Map,ze=new Map,Ne=(e,t,n)=>{const o=Object.assign({},e);for(const s of Te)o[s]=async(o,r)=>{const i=Oe.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=be(e[0].path,n),u=ze.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[s]=u.events[s]||{name:s,values:[]};const p=d.now();try{return await r(...e)}finally{const n=d.now(),r=n-p,c={start:p,end:n,duration:r,context:ke(e)};if(i.events[s].values.push(c),i.duration+=r,i.increment+=1,Oe.set(t,i),u.events[s].values.push(c),u.duration+=r,u.increment+=1,ze.set(o,u),a){const e=je.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,je.set(t,e)}}}))};return o},Ae=(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=Ne(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:Oe,modules:ze,loaders:je};o.end(),await e.asyncHook("timings",{tapables:s,loaders:r,modules:i})}))}});class Ie{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=ve(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map($e))(e);o.length||o.push("no-loader"),this.started[n]={module:we(n),timings:{start:d.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=ve(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=d.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 Ce{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=d.now(),i=t.apply(this,s),a=()=>{this.saveResult(e,n,o,ke(s),r,d.now())};return i.then(a,a),i}}getAsyncTapPatch(e,t,n,o){return(...s)=>{this.checkNewHooks();const r=d.now(),i=s.pop();return t.apply(this,[...s,(...t)=>(this.saveResult(e,n,o,ke(s),r,d.now()),i(...t))])}}getDefaultTapPatch(e,t,n,o){return(...s)=>{this.checkNewHooks();const r=d.now(),i=t.apply(this,s);return this.saveResult(e,n,o,ke(s),r,d.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(fe)||(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 _e=e=>async t=>{const n=e.getLogger(fe),o={name:fe},s=new Ce(e.buildRoot),r=new Ie(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})}))},Le={filters:de},Fe=({options:e,context:t})=>{const n=t.getLogger(fe);let o=0;const s=((e,t)=>{const n=e[me],o=ge(n?.timestamp);let s=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(s+=s?`.${n.prefix}`:n.prefix),{enable:!!e[me],enableDefaultPrefix:!0,enableTracing:!1,filters:de,tags:[],...e[me],timestamp:o,prefix:s.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),r=[];if(!s.enable)return r;const i={name:fe,enforce:"pre",esbuild:Ae(t,n),webpack:_e(t),rspack:_e(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(he(e,o,s))}const i=Array.from(r).filter((e=>e.toSend)).length;return r.add(he({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 g=n.time("outputing report");Re(t,n,p),g.end();const h=n.time("sending metrics to Datadog");await((e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.info("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: ${Me(`https://api.${t.site}/${Pe}`)}\n\nMetrics:\n - ${r.join("\n - ")}`),P({method:"POST",url:`https://api.${t.site}/${Pe}?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),h.end()},d={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){a.resume(),t.build.start=t.build.start||Date.now(),e[me]?.timestamp||(s.timestamp=ge(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},Ke="output",He="datadog-output-plugin",qe=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,Be=e=>{const t=void 0===e;return{build:qe("build",e?.build??t),bundler:qe("bundler",e?.bundler??t),dependencies:qe("dependencies",e?.dependencies??t),errors:qe("errors",e?.errors??t),logs:qe("logs",e?.logs??t),metrics:qe("metrics",e?.metrics??t),timings:qe("timings",e?.timings??t),warnings:qe("warnings",e?.warnings??t)}},We=(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}))}))},Ue=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},Ge=({options:e,context:t})=>{const n=(e=>({enable:!!e[Ke],path:"./",...e[Ke],files:Be(e[Ke]?.files)}))(e),s=t.getLogger(He);if(!n.enable)return[];const r=(e,r)=>{const u=n.files[e];if(!r||!1===u)return;t.queue((async()=>{const e=s.time(`output ${u}`),p=((e,t,n)=>{const s=o.isAbsolute(t)?t:o.resolve(e,t);return o.resolve(s,n)})(t.bundler.outDir,n.path,u);let c;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await V(o.dirname(e));const n=i.createWriteStream(e),s=new a(t,void 0,2),r=new Promise(((e,t)=>{s.on("end",(()=>{e()})),s.on("error",(e=>{t(e)}))}));return s.pipe(n),r})(p,e)}catch(e){c=e}c?s.error(`Failed writing ${u}: ${c}`):s.info(`Wrote "${p}"`),e.end()})())};return[{name:He,buildReport(e){const t=s.time("serialize report"),n=O(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:We(s,(e=>{r("bundler",e)})),rollup:Ue((e=>{r("bundler",e)})),vite:Ue((e=>{r("bundler",e)})),webpack:We(s,(e=>{r("bundler",e)}))}]};var Je=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(Je||{});const Ve="rum",Ye="datadog-rum-plugin",Qe="datadog-rum-privacy-plugin";const Xe=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,Ze=(e,t)=>{const n=e.sdk;if(n.clientToken)return Xe(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 P({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 Xe({...e,sdk:{clientToken:o,...n}})}},et=e=>{const n=t.bold.red,o=e[Ve]||{},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.`);return s.config={applicationId:"unknown_application_id",allowUntrustedEvents:!1,compressIntakeRequests:!1,defaultPrivacyLevel:"mask",enablePrivacyForActionName:!1,sessionReplaySampleRate:0,sessionSampleRate:100,silentMultipleInit:!1,site:"datadoghq.com",startSessionReplayRecordingManually:!1,storeContextsAcrossPages:!1,telemetrySampleRate:20,traceSampleRate:100,trackingConsent:"granted",trackLongTasks:!1,trackResources:!1,trackUserInteractions:!1,trackViewsManually:!1,...o.sdk},s},tt=e=>{const t=e[Ve]||{},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},nt=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=et(e),s=tt(e);if(n.push(...o.errors),n.push(...s.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${Ye}.`);const r={enable:!!e[Ve],...e[Ve],sdk:void 0,privacy:void 0};return o.config&&(r.sdk=o.config),s.config&&(r.privacy=s.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(r.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),r})(e,t.getLogger(Ye)),s=[];if(!n.enable)return s;if(n.sdk&&(t.inject({type:"file",position:Je.MIDDLE,value:o.join(__dirname,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Je.MIDDLE,value:Ze(n,t)})),n.privacy){t.inject({type:"file",position:Je.BEFORE,value:o.join(__dirname,"./privacy-helpers.js")});const e=((e,t)=>{const n=t.getLogger(Qe),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);return{name:Qe,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(e,t){try{return m({id:t,code:e},o)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}}}})(n.privacy,t);s.push(e)}return s},ot="datadog-analytics-plugin",st=({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}`)}})())}}]},rt="datadog-async-queue-plugin",it=e=>{const{context:t,stores:n}=e,o=t.getLogger(rt),s=[];return t.queue=e=>{const t=e.catch((e=>{s.push(e.message||e.toString())}));n.queue.push(t)},[{name:rt,asyncTrueEnd:async()=>{await Promise.all(n.queue),s.length>0&&o.error(`Error occurred while processing async queue:\n ${s.join("\n ")}`)}}]},at=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("*")?f.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},ut=(e,t)=>j(t)?S:t.startsWith(e)||o.isAbsolute(t)?t:o.resolve(e,t),pt=(e,t)=>{const n=[...e].map((e=>ut(t||process.cwd(),e).split(o.sep))),s=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<s;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(o.sep)||o.sep},ct=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,lt=/(\?|%3F|\|)+/gi,dt=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=gt(e),ct.lastIndex=0,ct.exec(t)?.[1]||"unknown");var t},mt=["unknown","commonjsHelpers.js",`vite${o.sep}preload-helper.js`],ft=(e,t,n)=>{const o=new Set;for(const n of e){const e=gt(n);j(n)||e===t||mt.includes(e)||o.add(e)}return o},gt=e=>e.split("!").pop().split(lt).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),ht=(e,t)=>j(t)?S:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(o.sep),s=e.split(o.sep).filter(((e,t)=>e===n[t])).join(o.sep);return e.replace(s,"")})(t.split("!").pop(),e).split("node_modules").pop().split(lt).shift().replace(/^((\.\.?)?[/\\])+/g,""),yt=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[ut(t,e),n]))),wt=(e,t)=>({setup(n){const s=new Map;let r=[];const i=t.time("build report",{start:!1});n.onStart((async()=>{s.clear(),r=[],i.resume();const o=t.time("process entries");r.push(...await at(n,e,t));for(const t of r){const n=ht(e.bundler.outDir,t.resolved);t.name?s.set(n,t.name):s.set(n,n)}o.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),a=e.bundler.outDir,u=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const p=[],c=[],l=[],d=[],m=[],f={},g={},h=t.time("indexing metafile data"),y=yt(n.metafile.inputs,u),w=yt(n.metafile.outputs,u);h.end();const b=e=>{if(!j(e))return e;const t=y[ut(u,e)];if(!t)return e;const n=t.imports.find((e=>!j(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(j(e))continue;const n=ut(u,e),o={name:ht(a,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:dt(e)};f[n]=o,p.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,o]of Object.entries(n.metafile.outputs)){const n=ut(u,e),r=ht(a,n),i=[];for(const e of Object.keys(o.inputs)){if(j(e))continue;const n=f[ut(u,e)];n?i.push(n):t.debug(`Input ${e} not found for output ${r}`)}if(o.entryPoint&&!i.length){const e=f[ut(u,o.entryPoint)];if(!e){t.debug(`Input ${o.entryPoint} not found for output ${r}`);continue}i.push(e)}const p={name:r,filepath:n,inputs:i,size:o.bytes,type:dt(n)};if(g[n]=p,"map"===p.type&&d.push(p),c.push(p),!o.entryPoint)continue;const m=f[ut(u,b(o.entryPoint))];if(m){if(!s.get(m.name))continue;const e={...p,name:s.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=g[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:g,meta:w}},D=/(<runtime>|https:|file:|data:|#)/g,E=e=>!j(e)&&!e.match(D),x=(e,n,s={})=>{if(!E(e))return s;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),s;if(s[r.filepath])return s;s[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),s;if(!i.imports||!i.imports.length)return s;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),c=i?o.dirname(e):u,l=ut(c,t.path);if(t.external){if(E(t.path)){const e=i?l:t.path,n=S.inputs.report[e]||{filepath:e,name:ht(a,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),p.includes(n)||p.push(n),S.inputs.report[e]=n,s[n.filepath]=n}}else x(l,n,s)}return s},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 p){if("external"===e.type)continue;const n=S.inputs.meta[e.filepath];if(n)for(const s of n.imports){if(!E(s.path))continue;const n=s.path.match(/^\.?\.\//),r=n?o.dirname(e.filepath):u,i=ut(r,s.path);let a;if(s.external){const e=n?i:s.path;a=S.inputs.report[e]}else a=S.inputs.report[i];a?(e.dependencies.add(a),a.dependents.add(e)):t.debug(`Could not find input file of ${s.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}P.end(),e.build.outputs=c,e.build.inputs=p,e.build.entries=m,i.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}),a=t.time("filling dependencies and dependents",{start:!1}),u=t.time("filling sourcemaps inputs",{start:!1}),p=new Map,c=new Map,l=new Map,d=new Map;return{buildStart(){d.clear(),p.clear(),c.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=gt(e.id),o=d.get(t)||{dependencies:new Set,dependents:new Set},s=ft(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),r=ft(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);d.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,m){o.resume();const f=n.dir?ut(e.buildRoot,n.dir):e.bundler.outDir,g=new Set,h=new Set,y=new Map;i.resume();for(const[e,{dependencies:t,dependents:n}]of d){for(const n of t){const t=gt(n),o=d.get(t)||{dependencies:new Set,dependents:new Set};o.dependents.has(e)||(o.dependents.add(e),d.set(t,o))}for(const t of n){const n=gt(t),o=d.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),d.set(n,o))}}i.end(),r.resume();for(const[e,n]of Object.entries(m)){const o=ut(f,e),s="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),r=c.get(o)||{name:e,filepath:o,inputs:[],size:s,type:dt(e)};if("map"===r.type&&h.add(r),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(gt(e)!==e)continue;const n=p.get(e)||{name:ht(f,e),dependencies:new Set,dependents:new Set,filepath:e,size:t.originalLength,type:dt(e)};r.inputs.push(n),p.set(n.filepath,n)}if("imports"in n)for(const e of n.imports){const n=gt(e);if(!d.has(n)){y.set(ut(f,n),r);continue}if(p.has(n)){t.debug(`Input report already there for ${n} from ${r.name}.`);continue}const o=p.get(n)||{name:ht(f,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};r.inputs.push(o),p.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...r,name:n.name,size:0,outputs:[r]}),c.set(r.filepath,r)}r.end();for(const[e,n]of y){const o=c.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}a.resume();for(const[e,n]of p){const o=d.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 ${ht(f,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 ${ht(f,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(a.end(),h.size){u.resume();for(const e of h){const n=e.filepath.replace(/\.map$/,""),o=c.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}u.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=ht(f,e),s=c.get(e);if(!s)return p.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,s);const r=m[ht(f,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(ut(f,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),l.has(e.filepath)&&t.debug(`Entry "${e.name}":"${ht(f,e.filepath)}" already reported.`),l.set(e.filepath,e)}s.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(p.values()),e.build.outputs=Array.from(c.values()),e.build.entries=Array.from(l.values()),s.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},vt=(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 ")||j(e)),g=e=>e.replace(/(^external[^"]+"|"$)/g,""),h=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=gt(e);t.add(n),n.startsWith("external ")&&t.add(g(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(c.has(e)){const n=c.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else c.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},w=(e,t)=>{if("request"in t&&t.request){const n=gt(t.request);if(c.has(n))return c.get(n);if(e.context){const t=ut(gt(e.context),n);if(c.has(t))return c.get(t)}}},b=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)h(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=w(n,e);if(!o?.identifier())return!1;const s=o.identifier();return!!f(s)&&(s!==t&&(b(o)?g(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=b(n)?{size:0,name:g(o),dependencies:new Set,dependents:new Set,filepath:t,type:"external"}:{size:n.size()||0,name:o,dependencies:new Set,dependents:new Set,filepath:t,type:dt(t)};s.push(u),a.set(t,u),b(n)&&a.set(g(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=>ut(e.bundler.outDir,t))),g=n.time("indexing chunks"),h=t.chunkGraph;for(const e of o){const t=d(e),n=(h?.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"===dt(e))continue;const t=p.get(e)||new Set;for(const e of n)t.add(e);p.set(e,t)}}g.end();const y=n.time("building outputs");for(const t of c){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:ut(e.bundler.outDir,t.name),type:dt(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 w=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}`)}w.end();const b=n.time("building entries");for(const[o,s]of t.entrypoints){const t=new Map,r=new Map;let a=0;const p=s.chunks.flatMap(d),c=s.chunks.filter((e=>h.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||s.name&&e.includes(s.name))).find((e=>"js"===dt(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?ut(e.bundler.outDir,c):"unknown",size:a,inputs:Array.from(r.values()),outputs:Array.from(t.values()),type:c?dt(c):"unknown"};i.push(l)}b.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)}))},$t="datadog-build-report-plugin",kt=e=>{const{context:t}=e,n=t.getLogger($t);return[{name:$t,enforce:"post",esbuild:wt(t,n),rspack:vt(t,$t,n),webpack:vt(t,$t,n),vite:bt(t,n),rollup:bt(t,n)}]},St="datadog-bundler-report-plugin",Dt=(e,t)=>t?o.isAbsolute(t)?t:o.resolve(e,t):"",Et=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?o.dirname(e.file):void 0)).filter(Boolean)},xt=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Dt(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Rt=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,s=Et(o);e.buildRoot=t.root??process.cwd(),o&&s.length&&(n=pt(s,process.cwd())),e.bundler.outDir=Dt(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Pt=e=>{const{context:t}=e,n=t.getLogger(St);return[{name:St,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Dt(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Dt(t.buildRoot,o.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:xt(t),rspack:xt(t),vite:Rt(t),rollup:{options(e){let n;if("output"in e){const t=Et(e.output);n=pt(t,process.cwd())}const s=(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(o.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=ut(process.cwd(),n);const e=pt([n,...s],process.cwd());t.buildRoot=e===o.sep?process.cwd():e}else t.buildRoot=pt(s,process.cwd()),t.bundler.outDir=o.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=Et(e);pt(o,process.cwd()).startsWith(t.bundler.outDir)||n.info("The output directory has been changed by a plugin and may introduce some inconsistencies in the build report.")}}}]},Mt="datadog-custom-hooks-plugin",Tt=e=>{const{context:t}=e,n=t.getLogger(Mt),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:Mt,enforce:"pre"}]};class jt{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=(o=e,i.readFileSync(o,{encoding:"utf-8"}));var o;const s=JSON.parse(n);if(!s.sources)return void t("Missing 'sources' field in sourcemap.");const r=s.sources;if(0===r.length)return void t("Empty 'sources' field in sourcemap.");const a=this.matchSources(r);if(0!==a.length)return a;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 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 Ot=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await zt(e);for(const e of t)if(e.name===n)return I(e.refs.push);return I(t[0].refs.push)},zt=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},Nt=async e=>e.revparse("HEAD"),At=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),It=async e=>e.branch(),Ct=async e=>e.show(["-s","--format=%s"]),_t=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),Lt="datadog-git-plugin",Ft=e=>{const{options:t,context:n}=e,s=n.getLogger(Lt),r=s.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t=[Nt(e),It(e),Ct(e),_t(e),At(e),Ot(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 jt(i)}})(await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=g(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return g(t)})(o.dirname(e)));n.git=t,r.end(),await n.asyncHook("git",n.git)}catch(e){s.error(`Could not get git information: ${e.message}`)}};return[{name:Lt,enforce:"pre",buildRoot(e){if(z(t))try{r.resume();const t=((e,t)=>{let n,s=ut(process.cwd(),e);for(;!n;){const e=o.resolve(s,t);if(Q(e)&&(n=e),s=s.split(o.sep).slice(0,-1).join(o.sep),[o.sep,""].includes(s))break}return n})(e,".git");if(!t)return void s.warn("No .git directory found, skipping git plugin.");n.queue(i(t))}catch(e){s.error(`Could not get git information: ${e.message}`)}}}]},Kt="datadog-injection-plugin",Ht=/^https?:\/\//,qt=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(ut(t,e)),Bt=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(Ht)?await(async(e,t=5e3)=>{let n;return Promise.race([P({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(s):await qt(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} - ${A(s)}`;e.fallback?(t.info(`Fallback for "${i}": ${r.toString()}`),o=await Bt(e.fallback,t,n)):t.warn(`Failed "${i}": ${r.toString()}`)}return o},Wt=e=>{if(0===e.size)return"";return`// begin injection by Datadog build plugins\n${Array.from(e.values()).map((e=>`(() => {${e}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},Ut=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 Bt(r,t,n);e&&o.set(s,{value:e,position:r.position||Je.BEFORE})}return o})(t,e,o);for(const[e,t]of s.entries())n[t.position].set(e,t.value)},Gt=i.promises,Jt=(e,t,n)=>({setup(s){const{onStart:a,onResolve:u,onLoad:p,onEnd:c,esbuild:l,initialOptions:d}=s,m=[],f=`${t.bundler.name}.${Je.MIDDLE}.${S}.js`,g=i.realpathSync(h.tmpdir()),y=o.resolve(g,f),w=new RegExp(`${f}$`),b=d.inject;d.inject=b?[...b]:[],d.inject.push(y),a((async()=>{m.push(...await at(s,t,e)),s.initialOptions.inject=b;try{await(async(e,t)=>{await V(o.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),u({filter:w},(async e=>({path:e.path,namespace:Kt}))),p({filter:w,namespace:Kt},(async()=>({contents:Wt(n[Je.MIDDLE])||" ",resolveDir:t.buildRoot,loader:"js"}))),c((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const s=Wt(n[Je.BEFORE]),r=Wt(n[Je.AFTER]);if(!s&&!r)return;const i=Object.entries(o.metafile.outputs).map((([e,n])=>{const o=n.entryPoint;if(!o)return;return m.find((e=>e.resolved.endsWith(o)))?ut(t.buildRoot,e):void 0})).filter(Boolean).map((async t=>{try{const e=await Gt.readFile(t,"utf-8"),n=await l.transform(e,{loader:"default",banner:s,footer:r});await Gt.writeFile(t,n.code)}catch(n){if(!(e=>e instanceof Error&&"code"in e)(n)||"ENOENT"!==n.code)throw n;e.warn(`Could not inject content in ${t}: ${n}`)}}));await Promise.all(i)}))}}),Vt=S,Yt="?inject-proxy",Qt=e=>({banner:t=>t.isEntry?Wt(e[Je.BEFORE]):"",async resolveId(t,n,o){if(j(t))return{id:t,moduleSideEffects:!0};if(o.isEntry&&Wt(e[Je.MIDDLE])){const e=await this.resolve(t,n,o);if(!e||e.external)return e;return(await this.load(e)).moduleSideEffects=!0,`${e.id}${Yt}`}return null},load(t){if(j(t))return Wt(e[Je.MIDDLE]);if(t.endsWith(Yt)){const e=t.slice(0,-13),n=this.getModuleInfo(e);let o=`import ${JSON.stringify(Vt)};\nexport * from ${JSON.stringify(e)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(e)};`),o}return null},footer:t=>t.isEntry?Wt(e[Je.AFTER]):""}),Xt=(e,t,n,s,r)=>a=>{const u=new WeakMap,p=e.sources.ConcatSource,c=n.bundler.name,l=o.resolve(n.bundler.outDir,`${c}.${Je.MIDDLE}.${S}.js`);Y(l,"");a.hooks.shutdown.tap(Kt,(()=>{var e;e=l,i.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));a.hooks.beforeRun.tapPromise(Kt,(async()=>{await Ut(t,s,r,n.buildRoot)})),a.hooks.compilation.tap(Kt,(t=>{const n=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;t.hooks.processAssets.tap({name:Kt,stage:n},(()=>{const e=Wt(r[Je.BEFORE]),n=Wt(r[Je.AFTER]);for(const o of t.chunks)if(o.canBeInitial())for(const s of o.files)t.updateAsset(s,(t=>{const o=u.get(t);if(!o||o.banner!==e||o.footer!==n){const o=new p(e,"\n",t,"\n",n);return u.set(t,{source:o,banner:e,footer:n}),o}return o.source}))}))}));const d=(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}})(a.options.entry);a.options.entry=d},Zt=e=>{const{bundler:t,context:n}=e,o=n.getLogger(Kt),s=new Map,r={[Je.BEFORE]:new Map,[Je.MIDDLE]:new Map,[Je.AFTER]:new Map};n.inject=e=>{s.set(`${Date.now()}.${performance.now()}.${++C}`,e)};const i={name:Kt,enforce:"post",esbuild:Jt(o,n,r),webpack:Xt(t,o,n,s,r),rspack:Xt(t,o,n,s,r),rollup:Qt(r),vite:{...Qt(r),enforce:"pre"}};var a;return a=n.bundler.name,["rspack","webpack"].includes(a)?i.load={filter:{id:D},handler:()=>({code:Wt(r[Je.MIDDLE])})}:i.buildStart=async()=>{await Ut(o,s,r,n.buildRoot)},[i]},en="datadog-true-end-plugin",tn=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(en,s)},i={async writeBundle(){},async closeBundle(){await s()}};return[{name:en,enforce:"post",webpack:r,esbuild:{setup(e){e.onEnd((async()=>{await n()})),e.onDispose((()=>{o()}))}},vite:i,rollup:i,rspack:r}]},nn={[me]:Le},on=t.bold.red;var sn="3.0.2";const rn=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,s)=>{const r=Date.now(),i=((e={})=>{const t={site:$("SITE")||e.auth?.site||"datadoghq.com"};return Object.defineProperty(t,"apiKey",{value:$("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(t,"appKey",{value:$("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:t}})(e);"esbuild"===s.framework&&(s.esbuildHostName=x);const a=process.env.BUILD_PLUGINS_ENV||"production",u=E.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:H(n,o,t.logLevel),asyncHook:()=>{throw new Error("AsyncHook function called before it was initialized.")},hook:()=>{throw new Error("Hook function called before it was initialized.")},inject:()=>{throw new Error("Inject function called before it was initialized.")},plugins:[],queue:()=>{throw new Error("Queue function called before it was initialized.")},sendLog:M(n),start:e,version:n.version}})({start:o,options:i,data:l,stores:d}),f=m.getLogger("factory"),g=f.time("Plugins initialization",{start:r});m.pluginNames.push(x);const h=[];h.push(["analytics",st],["async-queue",it],["build-report",kt],["bundler-report",Pt],["custom-hooks",Tt],["git",Ft],["injection",Zt],["true-end",tn]),i.customPlugins&&h.push(["custom",i.customPlugins]),h.push(["error-tracking",le],["metrics",Fe],["output",Ge],["rum",nt]);for(const[e,n]of h)m.plugins.push(...W(m,n,e)({bundler:t,context:m,options:i,data:l,stores:d}));return(e=>{const t=[];for(const n of v){const o=k(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const s=o.map((e=>b(e))).join(" and "),r=b(`DATADOG_${n}`);e.warn(`Conflicting keys ${s}, will use ${r}`),t.push(`${s} (using ${r})`)}else if(o.length){const e=o.map((e=>w(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: ${on(Array.from(t).join(", "))}`)})(m.pluginNames),m.hook("init",m),g.end(),m.plugins}))})({bundler:y,version:sn}).rollup,an=sn,un=nn;export{rn as datadogRollupPlugin,un as helpers,an as version};
|
|
10
10
|
//# sourceMappingURL=index.mjs.map
|
package/dist/src/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../../core/src/helpers/env.ts"],"sourcesContent":["// Unless explicitly stated otherwise all files in this repository are licensed under the MIT License.\n// This product includes software developed at Datadog (https://www.datadoghq.com/).\n// Copyright 2019-Present Datadog, Inc.\n\n// Return the environment variable that would be prefixed with either DATADOG_ or DD_.\nexport const getDDEnvValue = (key:
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../core/src/helpers/env.ts"],"sourcesContent":["// Unless explicitly stated otherwise all files in this repository are licensed under the MIT License.\n// This product includes software developed at Datadog (https://www.datadoghq.com/).\n// Copyright 2019-Present Datadog, Inc.\n\nimport chalk from 'chalk';\n\nimport type { Logger } from '../types';\n\nconst green = chalk.bold.green;\nconst yellow = chalk.bold.yellow;\n\n// All the variables that can be overriden, listed for easier code search:\n// - DD_API_KEY\n// - DATADOG_API_KEY\n// - DD_APP_KEY\n// - DATADOG_APP_KEY\n// - DD_SOURCEMAP_INTAKE_URL\n// - DATADOG_SOURCEMAP_INTAKE_URL\n// - DD_SITE\n// - DATADOG_SITE\nconst OVERRIDE_VARIABLES = ['API_KEY', 'APP_KEY', 'SOURCEMAP_INTAKE_URL', 'SITE'] as const;\ntype ENV_KEY = (typeof OVERRIDE_VARIABLES)[number];\n\n// Return the environment variable that would be prefixed with either DATADOG_ or DD_.\nexport const getDDEnvValue = (key: ENV_KEY) => {\n return process.env[`DATADOG_${key}`] || process.env[`DD_${key}`];\n};\n\n// Returns the keys that are defined in the environment.\nexport const getUsedKey = (key: ENV_KEY) => {\n const usedKeys: string[] = [];\n if (process.env[`DD_${key}`]) {\n usedKeys.push(`DD_${key}`);\n }\n if (process.env[`DATADOG_${key}`]) {\n usedKeys.push(`DATADOG_${key}`);\n }\n return usedKeys;\n};\n\n// Keep track of which configurations are overriden by the environment.\nexport const notifyOnEnvOverrides = (log: Logger) => {\n const overridenValues: string[] = [];\n\n for (const value of OVERRIDE_VARIABLES) {\n const usedKeys = getUsedKey(value);\n\n if (\n usedKeys.length > 1 &&\n !usedKeys.every((k) => process.env[k] === process.env[usedKeys[0]])\n ) {\n // Notify if more than one is defined, and that they are different.\n // Resulting in a conflict, given getDDEnvValue() we resolve with DATADOG_${value}.\n const keys = usedKeys.map((k) => yellow(k)).join(' and ');\n const usedKey = yellow(`DATADOG_${value}`);\n log.warn(`Conflicting keys ${keys}, will use ${usedKey}`);\n overridenValues.push(`${keys} (using ${usedKey})`);\n } else if (usedKeys.length) {\n // Key is used with no conflicts.\n const keys = usedKeys.map((k) => green(k)).join(' and ');\n overridenValues.push(`${keys} (same value)`);\n }\n }\n\n if (overridenValues.length) {\n log.info(`Overrides from environment:\\n - ${overridenValues.join('\\n - ')}`);\n }\n};\n"],"names":[],"mappings":";;;;;;;;AAQA"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@datadog/rollup-plugin",
|
|
3
3
|
"packageManager": "yarn@4.0.2",
|
|
4
|
-
"version": "3.0.
|
|
4
|
+
"version": "3.0.2",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"author": "Datadog",
|
|
7
7
|
"description": "Datadog Rollup Plugin",
|
|
@@ -54,7 +54,7 @@
|
|
|
54
54
|
"watch": "yarn build --watch"
|
|
55
55
|
},
|
|
56
56
|
"dependencies": {
|
|
57
|
-
"@datadog/js-instrumentation-wasm": "1.0.
|
|
57
|
+
"@datadog/js-instrumentation-wasm": "1.0.5",
|
|
58
58
|
"async-retry": "1.3.3",
|
|
59
59
|
"chalk": "2.3.1",
|
|
60
60
|
"glob": "11.0.0",
|
|
@@ -87,6 +87,5 @@
|
|
|
87
87
|
},
|
|
88
88
|
"peerDependencies": {
|
|
89
89
|
"rollup": ">= 3.x < 5.x"
|
|
90
|
-
}
|
|
91
|
-
"stableVersion": "3.0.0"
|
|
90
|
+
}
|
|
92
91
|
}
|