@datadog/esbuild-plugin 3.2.2 → 3.2.3

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.
@@ -1,2 +1,2 @@
1
- import{createUnplugin as e}from"unplugin";import t from"chalk";import n from"async-retry";import{File as o}from"buffer";import r,{mkdtemp as i}from"fs/promises";import s from"fs";import{JsonStreamStringify as a}from"json-stream-stringify";import u from"path";import{Readable as c}from"stream";import{spawn as d}from"child_process";import{randomBytes as l,createHash as p,randomUUID as f}from"crypto";import m from"http";import h,{tmpdir as g}from"os";import*as y from"eslint-scope";import b from"jszip";import{glob as w}from"glob";import v from"pretty-bytes";import $ from"p-queue";import k from"@jridgewell/remapping";import{performance as x}from"perf_hooks";import{instrument as E}from"@datadog/js-instrumentation-wasm";import{simpleGit as S}from"simple-git";import I from"esbuild";import D from"node:url";import A from"node:path";import P from"node:module";const j=D.fileURLToPath(import.meta.url),M=A.dirname(j),C=P.createRequire(import.meta.url),T="__datadog-helper-file",O=new RegExp(T),N=["development","production","test"],R=["datadoghq.com","us3.datadoghq.com","us5.datadoghq.com","datadoghq.eu","ddog-gov.com","us2.ddog-gov.com","ap1.datadoghq.com","ap2.datadoghq.com","datad0g.com"],_=R[0],F="datadog-build-plugins",z=t.bold.green,L=t.bold.yellow,U=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","APPS_AUTH_METHOD","SITE"],B=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],q=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},V=(e,t,n)=>{if(void 0!==e)return(e=>R.some((t=>t===e)))(e)?e:void n.push(`${t} "${e}" is not a supported Datadog site. See the site parameters in https://docs.datadoghq.com/getting_started/site/.`)},K=e=>{if(null===e||"object"!=typeof e)return"";const t="title"in e&&"string"==typeof e.title?e.title:void 0,n="detail"in e&&"string"==typeof e.detail?e.detail:void 0;return t&&n?`${t}: ${n}`:t||(n?`detail: ${n}`:"")},H=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),W=async e=>{const{getForm:t,defaultHeaders:n={},zip:o=!0}=e,r=await t(),i=new Request("fake://url",{method:"POST",body:r});return{data:o?i.body.pipeThrough(new CompressionStream("gzip")):i.body,headers:{"Content-Encoding":o?"gzip":"multipart/form-data",...n,...Object.fromEntries(i.headers.entries())}}},J=[400,401,403,404,405,409,413],G=async e=>{const{auth:t,url:o,method:r="GET",getData:i,type:s="text"}=e,a={retries:0===e.retries?0:e.retries||5,onRetry:e.onRetry,maxTimeout:e.maxTimeout,minTimeout:e.minTimeout};return n((async(e,n)=>{let a;try{const e={method:r,duplex:"half"};let n={"X-Datadog-Origin":"build-plugins"};if(t&&"accessToken"in t?t.accessToken&&(n.Authorization=`Bearer ${t.accessToken}`):(t?.apiKey&&(n["DD-API-KEY"]=t.apiKey),t?.appKey&&(n["DD-APPLICATION-KEY"]=t.appKey)),"function"==typeof i){const{data:t,headers:o}=await i();e.body=t,n={...n,...o}}a=await fetch(o,{...e,headers:n})}catch(t){return e(t),{}}if(!a.ok){let t=`HTTP ${a.status} ${a.statusText}`;try{const e=(e=>{try{const t=JSON.parse(e);if(null!==t&&"object"==typeof t)if("errors"in t&&Array.isArray(t.errors)){const e=t.errors.map(K).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=K(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(J.includes(a.status))return e(new Error(t)),{};throw new Error(t)}try{let e;return e="json"===s?await a.json():await a.text(),e}catch(t){return e(t),{}}}),a)},Y=e=>({message:t,context:n})=>G({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||F,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"}}}}),Q=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),Z=e=>e.includes(T),X=e=>{const t={bundler:e.bundler,errors:e.errors,metadata:e.metadata,warnings:e.warnings,logs:e.logs,timings:e.timings,start:e.start,end:e.end,duration:e.duration,writeDuration:e.writeDuration,entries:[],inputs:[],outputs:[]};for(const n of e.entries||[]){const e={...n,inputs:[],outputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),n.outputs&&(e.outputs=n.outputs.map((e=>e.filepath))),t.entries.push(e)}for(const n of e.inputs||[]){const e={...n,dependencies:[],dependents:[]};if(n.dependencies)for(const t of n.dependencies)e.dependencies.push(t.filepath);if(n.dependents)for(const t of n.dependents)e.dependents.push(t.filepath);t.inputs.push(e)}for(const n of e.outputs||[]){const e={...n,inputs:[]};n.inputs&&(e.inputs=n.inputs.map((e=>e.filepath))),t.outputs.push(e)}return t},ee=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},te=e=>{const t=Math.floor(e/1e3/60/60/24),n=new Date(e-24*t*60*60*1e3),o=n.getUTCHours(),r=n.getUTCMinutes(),i=n.getUTCSeconds(),s=n.getUTCMilliseconds(),a=`${t?`${t}d `:""}${o?`${o}h `:""}${r?`${r}m `:""}${i?`${i}s`:""}`.trim();return`${a}${!a||s?` ${s}ms`:""}`.trim()},ne=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),r=Math.min(10,Math.floor(o/2)),i=o-r;return`${e.slice(0,r)}${n}${e.slice(-i)}`},oe=(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}},re=e=>e.trim().toLowerCase().replace(/[^a-z0-9_:./-]+/g,"_").replace(/^_+|_+$/g,"")||"unknown",ie=e=>Object.entries(e).map((([e,n])=>` - ${e}: ${t.bold.green((e=>{if(void 0===e)return"undefined";if(null===e)return"null";if(Array.isArray(e))return e.join(", ");if("object"==typeof e)try{return JSON.stringify(e,null,2)}catch{return String(e)}return e?.toString()??""})(n))}`)).join("\n");let se=0;const ae={debug:0,info:1,warn:2,error:3,none:4},ue=e=>e.split(">").map(Q).join(">"),ce=(e,n,o,r)=>{const i=ue(e);return(s,a="debug",{forward:u,context:c}={})=>{let d=t.dim,l=console.log;"error"===a?(d=t.red,l=console.error):"warn"===a?(d=t.yellow,l=console.warn):"info"===a&&(d=t.cyan,l=console.log);const p=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=Y(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){ce(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}ae[a]>=ae[r]&&l(`${d(p)} ${f}`)}},de=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:c=[]}=i,d={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(d);const l=()=>d.spans.filter((e=>!e.end)),p=n=>{l().length||(!d.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),d.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=l();if(i?.length){i.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of i)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),p(e)}return{timer:d,resume:p,end:e=>{f(e,!1);const n=d.spans.reduce(((e,t)=>e+(t.end-t.start)),0);d.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(te(n))}`,s)},pause:f,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=l();for(const n of t)n.tags.push(...e)}else d.tags.push(...e)}}},le=(e,t,n="warn")=>o=>{const r=ce(o,e,t,n);return{getLogger:r=>le(e,t,n)(`${ue(o)}>${r}`),time:de(o,t.timings,r),error:(e,t)=>r(e,"error",t),warn:(e,t)=>r(e,"warn",t),info:(e,t)=>r(e,"info",t),debug:(e,t)=>r(e,"debug",t)}},pe=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],fe=(e,t,n,o)=>{const r=n=>function(...r){const i=o.time(`${e} | ${t}`,{log:!1,tags:["type:hook",`hook:${t}`]}),s=n.apply(this,r);return s instanceof Promise?s.finally((()=>{i.end()})):(i.end(),s)};return"object"==typeof n&&null!==n&&"handler"in n?{...n,handler:r(n.handler)}:r(n)},me=(e,t,n)=>{const o=e.getLogger(F);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=Q(e.name);for(const r of pe){const i=e[r];i&&(n[r]=fe(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},he=new Set,ge=(e,t,n)=>{const o=e[t];if(o&&"object"==typeof o&&"enable"in o){const e=o.enable;if("boolean"!=typeof e&&void 0!==e&&(he.has(t)||(he.add(t),n.warn(`\`${t}.enable\` should be a boolean, got ${typeof e}. Non-boolean values are coerced today but will be rejected in the next major.`))),void 0!==e)return!!e}return!!o},ye="apps",be="datadog-apps-plugin",we="api/unstable/app-builder-code/apps",ve="datadog-apps-assets.zip",$e=/\.backend\.(ts|tsx|js|jsx)$/,ke=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],xe=["apiKey","oauth"],Ee=e=>{const t=e[ye]||{},n=(e=>{if(void 0!==e){if(xe.includes(e))return e;throw new Error(`apps.authOverrides.method must be one of: ${xe.join(", ")}`)}})(B("APPS_AUTH_METHOD")||t.authOverrides?.method)||"apiKey";return{include:t.include||[],dryRun:t.dryRun??!B("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim(),authOverrides:{method:n}}},Se=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),Ie=async e=>r.mkdir(e,{recursive:!0}),De=(e,t)=>{var n;n=u.dirname(e),s.mkdirSync(n,{recursive:!0}),s.writeFileSync(e,t,{encoding:"utf-8"})},Ae=e=>s.readFileSync(e,{encoding:"utf-8"}),Pe=e=>{try{return s.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},je=async(e,t)=>{if("function"==typeof s.openAsBlob){const n=await s.openAsBlob(e,{type:t.contentType});return new o([n],t.filename)}{const n=c.toWeb(s.createReadStream(e)),r=await new Response(n).blob();return new o([r],t.filename,{type:t.contentType})}},Me=async e=>{const t={empty:!1,exists:!0};try{const{size:n}=await r.stat(e);0===n&&(t.empty=!0)}catch(e){if("ENOENT"!==e.code)throw e;t.exists=!1}return t};var Ce=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(Ce||{});const Te=()=>import("oauth4webapi"),Oe=t.cyan.bold,Ne=e=>e.toString("base64url"),Re=e=>({client_id:e}),_e=e=>({issuer:new URL(e.authorizationUrl).origin,authorization_endpoint:e.authorizationUrl,token_endpoint:e.tokenUrl}),Fe=(e,t)=>`${e}:${t.clientId}:${((e,t)=>p("sha256").update([t.clientId,e,t.authorizationUrl,t.tokenUrl].join("|")).digest("hex").slice(0,16))(e,t)}`,ze=(e,t,n)=>{e.writeHead(t,{"Content-Type":"text/html; charset=UTF-8"}),e.end(n)},Le=(e,t,n=Date.now())=>({accessToken:e.access_token,expiresAt:"number"==typeof e.expires_in?n+1e3*e.expires_in:void 0,expiresIn:e.expires_in,refreshToken:e.refresh_token,scope:e.scope,site:t,tokenType:e.token_type}),Ue=e=>null!==e&&"object"==typeof e&&!Array.isArray(e),Be=e=>e instanceof Error?e.message:String(e),qe=e=>{const t=Be(e).toLowerCase();return"NoEntry"===(e=>Ue(e)&&"string"==typeof e.code?e.code:void 0)(e)||t.includes("noentry")||t.includes("no matching entry")||t.includes("not found")},Ve=async(e,t)=>{const{AsyncEntry:n}=await import("@napi-rs/keyring");return new n("datadog-build-plugins:oauth",Fe(e,t))},Ke=(e,t)=>new Error(`Could not ${e} Datadog OAuth token in the OS credential store. ${t instanceof Error?t.message:String(t)}`),He=async(e,t)=>{try{const n=await Ve(e,t),o=await n.getPassword();if(!o)return;const r=JSON.parse(o);return(e=>{if(Ue(e)&&1===e.version&&Ue(e.token)&&"string"==typeof e.token.accessToken&&"string"==typeof e.token.clientId&&"string"==typeof e.token.site)return e})(r)?.token}catch(e){if(qe(e))return;throw Ke("read",e)}},We=async(e,t,n,o=e.site)=>{if(t.cacheTokens)try{await(async(e,t,n)=>{try{const o=await Ve(e,n),r={version:1,token:t};await o.setPassword(JSON.stringify(r))}catch(e){throw Ke("save",e)}})(o,((e,t)=>({accessToken:e.accessToken,clientId:t,expiresAt:e.expiresAt,refreshToken:e.refreshToken,scope:e.scope,site:e.site,tokenType:e.tokenType}))(e,t.clientId),t),n.debug("Saved Datadog OAuth token to the OS credential store.")}catch(e){n.warn(`Could not save Datadog OAuth token to the OS credential store; continuing without a persistent cache. ${Be(e)}`)}},Je=async(e,t,n)=>{if(t.cacheTokens)try{await(async(e,t)=>{try{const n=await Ve(e,t);await n.deletePassword()}catch(e){if(!qe(e))throw Ke("delete",e)}})(e,t)}catch(e){n.warn(`Could not delete cached Datadog OAuth token. ${Be(e)}`)}},Ge=async(e,t,n)=>{if(!t.cacheTokens)return;let o;try{o=await He(e,t)}catch(e){n.warn(`Could not read cached Datadog OAuth token; starting browser authorization. ${Be(e)}`)}if(o){if(void 0===(r=o).expiresAt||r.expiresAt>Date.now()+3e5)return n.debug("Using cached Datadog OAuth access token."),(e=>({accessToken:e.accessToken,expiresAt:e.expiresAt,refreshToken:e.refreshToken,scope:e.scope,site:e.site,tokenType:e.tokenType}))(o);var r;if(o.refreshToken)try{n.debug("Refreshing cached Datadog OAuth access token.");const r=await(async(e,t,n)=>{const o=await Te(),r=_e(t),i=Re(t.clientId),s=await o.refreshTokenGrantRequest(r,i,o.None(),n),a=await o.processRefreshTokenResponse(r,i,s);return Le({...a,refresh_token:a.refresh_token||n},e)})(e,t,o.refreshToken);return await We(r,t,n),r}catch(o){return n.warn(`Cached Datadog OAuth token could not be refreshed; starting browser authorization. ${o instanceof Error?o.message:String(o)}`),void await Je(e,t,n)}}},Ye=async(e,t,n)=>{const o=await Te(),r=_e(t),i=Re(t.clientId),s=Ne(l(32)),a=await(async e=>(await Te()).calculatePKCECodeChallenge(e))(s),u=Ne(l(32)),c=(e=>{const t=new URL(e.authorizationUrl);return t.searchParams.set("redirect_uri",e.redirectUri),t.searchParams.set("client_id",e.clientId),t.searchParams.set("response_type","code"),t.searchParams.set("code_challenge",e.codeChallenge),t.searchParams.set("code_challenge_method","S256"),t.searchParams.set("state",e.state),t})({authorizationUrl:t.authorizationUrl,clientId:t.clientId,codeChallenge:a,redirectUri:t.redirectUri,state:u}),p=(async e=>{const t=new URL(e.redirectUri),n=Number(t.port||80);if("http:"!==t.protocol)throw new Error("OAuth redirect URI must use http for the local OAuth callback.");if(!Number.isInteger(n)||n<=0)throw new Error("OAuth redirect URI must include a valid port.");let o,r=!1;const i=m.createServer();try{return await new Promise(((s,a)=>{const u=e=>{r||(r=!0,e())};i.on("request",((n,o)=>{const r=new URL(n.url||"/",t.origin);if(r.pathname!==t.pathname)return void ze(o,404,"Not found.");let i;try{i=e.oauth.validateAuthResponse(e.authorizationServer,e.client,r,e.state)}catch(e){return ze(o,400,"OAuth authorization failed. You may now close this tab."),void u((()=>a(e instanceof Error?e:new Error(String(e)))))}if(!i.get("code"))return ze(o,400,"Missing OAuth authorization code. You may now close this tab."),void u((()=>a(new Error("Missing OAuth authorization code."))));ze(o,200,"OAuth authorization complete. You may now close this tab."),u((()=>s({callbackParameters:i})))})),i.once("error",(e=>u((()=>a(e))))),o=setTimeout((()=>{u((()=>a(new Error(`Timed out waiting for OAuth callback after ${e.timeoutMs}ms.`))))}),e.timeoutMs);try{const e="localhost"===t.hostname?void 0:t.hostname;i.listen(n,e)}catch(e){u((()=>a(e instanceof Error?e:new Error(String(e)))))}}))}finally{o&&clearTimeout(o),i.listening&&(i.close(),i.closeAllConnections?.(),i.closeIdleConnections?.())}})({authorizationServer:r,client:i,oauth:o,redirectUri:t.redirectUri,state:u,timeoutMs:t.timeoutMs});n.info(`Authorize Datadog Apps upload:\n ${Oe(c.toString())}`),t.openBrowser&&((e,t)=>{const n="darwin"===process.platform?{command:"open",args:[e]}:"win32"===process.platform?{command:"cmd",args:["/c","start","",e]}:{command:"xdg-open",args:[e]};try{const e=d(n.command,n.args,{detached:!0,stdio:"ignore"});e.once("error",(e=>{t.warn(`Could not open browser automatically: ${Be(e)}`)})),e.unref()}catch(e){t.warn(`Could not open browser automatically: ${Be(e)}`)}})(c.toString(),n);return(async e=>{const t=await Te(),n=_e(e),o=Re(e.clientId),r=await t.authorizationCodeGrantRequest(n,o,t.None(),e.callbackParameters,e.redirectUri,e.codeVerifier),i=await t.processAuthorizationCodeResponse(n,o,r);return Le(i,e.site)})({callbackParameters:(await p).callbackParameters,clientId:t.clientId,codeVerifier:s,redirectUri:t.redirectUri,site:e,tokenUrl:t.tokenUrl,authorizationUrl:t.authorizationUrl})},Qe=new Map,Ze=(e,t)=>{const n=(e=>{const t=(e=>"datad0g.com"===e?"f4bacdd2-0c8c-49f5-bf3e-a62ba3ec02e6":"e17b9ffa-3daf-4124-ba1b-4ac8c547d506")(e),n=`https://api.${e}/oauth2/v1`;return{authorizationUrl:`${n}/authorize`,cacheTokens:!0,clientId:t,openBrowser:!0,redirectUri:"http://localhost:8060",timeoutMs:3e5,tokenUrl:`${n}/token`}})(e),o=`${e}:${n.clientId}`;let r=Qe.get(o);return r||(r=(async(e,t,n)=>{const o=await Ge(e,t,n);if(o)return o;const r=await Ye(e,t,n);return await We(r,t,n,e),r})(e,n,t).catch((e=>{throw Qe.delete(o),e})),Qe.set(o,r)),r},Xe='Set apps.authOverrides.method: "oauth" or DD_APPS_AUTH_METHOD=oauth to use OAuth, or set DD_API_KEY and DD_APP_KEY to use API/App key auth.';class et extends Error{constructor(){super(`Missing authentication. ${Xe}`),this.statusCode=400,this.name="MissingAuthenticationError"}}const tt=(e,t,n)=>{if("oauth"===e)return e=>(async({auth:e,log:t,...n})=>{const{site:o}=e,r=await Ze(o,t);if(!r.accessToken)throw new Error("OAuth authentication did not return an access token.");return G({...n,auth:{accessToken:r.accessToken}})})({...e,auth:t,log:n});if(t.apiKey&&t.appKey)return e=>G({...e,auth:{apiKey:t.apiKey,appKey:t.appKey}});throw new et};function nt(e,t){if(!function(e){return"Program"===e.type}(e))throw new Error(`Expected a Program node from this.parse() for ${t}, got ${e.type}`);return e}function ot(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function rt(e){return"type"===e.importKind||"type"===e.exportKind}function it(e,t){return function(e,t){const n=nt(e,t),o=function(e){const t=new Map;for(const n of e.body)if("FunctionDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"function"});else if("ClassDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"class"});else if("VariableDeclaration"===n.type)for(const e of n.declarations)"Identifier"===e.id.type&&t.set(e.id.name,{kind:"variable",init:e.init});else if("ImportDeclaration"===n.type)for(const e of n.specifiers)t.set(e.local.name,{kind:"import"});return t}(n),r=[];for(const e of n.body){if("ExportDefaultDeclaration"===e.type)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);if("ExportAllDeclaration"===e.type)throw new Error(`"export *" is not supported in .backend.ts files. Use explicit named exports instead: ${t}`);if("ExportNamedDeclaration"!==e.type)continue;e.declaration&&r.push(...ut(e.declaration,t).map((e=>({kind:"local",name:e,localName:e}))));const n="string"==typeof e.source?.value?e.source.value:null;for(const i of e.specifiers){if("Identifier"!==i.exported.type)continue;if("default"===i.exported.name)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);const e="Identifier"===i.local.type?i.local.name:"string"==typeof i.local.value?i.local.value:null;e&&(n?r.push({kind:"re-export",name:i.exported.name,localName:e,source:n}):("Identifier"===i.local.type&&ct(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const st=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function at(e){return null==e||st.has(e.type)}function ut(e,t){if("FunctionDeclaration"===e.type&&e.id)return[e.id.name];if("ClassDeclaration"===e.type)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${t}`);if("VariableDeclaration"===e.type)return e.declarations.flatMap((e=>{if("Identifier"!==e.id.type)throw new Error(`Destructured exports are not supported in backend files. Use individual named exports instead: ${t}`);if(at(e.init))throw new Error(`Non-function export "${e.id.name}" in backend file ${t}. Only function exports are supported — use "export function ${e.id.name}(…) { }" instead.`);return[e.id.name]}));throw new Error(`Unsupported export declaration type "${e.type}" in backend file ${t}. Only function and variable exports are allowed.`)}function ct(e,t,n){const o=t.get(e);if(o){if("class"===o.kind)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${n}`);if("variable"===o.kind&&at(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function dt(e){const t=e.relativePath.split(u.sep).join("/");return`${p("sha256").update(t).digest("hex")}.${e.name}`}function lt(e){const t=[];for(const{exportName:n,queryName:o}of e)t.push(`export async function ${n}(...args) {`),t.push(` return globalThis.DD_APPS_RUNTIME.executeBackendFunction(${JSON.stringify(o)}, args);`),t.push("}"),t.push("");return t.join("\n")}function pt(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return C.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}(n)&&o.push("import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';"),o.push(""),o.push('/** @param {import("./context.types").Context} $ */'),o.push("export async function main($) {"),o.push(" globalThis.$ = $;"),o.push(""),o.push(" // Register the $.Actions-based implementation for executeAction"),o.push(" if (typeof setExecuteActionImplementation === 'function') {\n setExecuteActionImplementation(async (actionId, request) => {\n const actionPath = actionId.replace(/^com\\.datadoghq\\./, '');\n const pathParts = actionPath.split('.');\n let actionFn = $.Actions;\n for (const part of pathParts) {\n if (!actionFn) throw new Error('Action not found: ' + actionId);\n actionFn = actionFn[part];\n }\n if (typeof actionFn !== 'function') throw new Error('Action is not a function: ' + actionId);\n return actionFn(request);\n });\n }"),o.push(""),o.push(" const args = $.backendFunctionArgs ?? [];"),o.push(` const result = await ${e}(...args);`),o.push(" return result;"),o.push("}"),o.join("\n")}function ft(e,t,n){const o={state:t},r=e=>{n._?.(e,o),function(e,t){return t[e.type]}(e,n)?.(e,o);for(const t of Object.keys(e))"type"!==t&&i(e[t])},i=e=>{if(Array.isArray(e))for(const t of e)mt(t)&&r(t);else mt(e)&&r(e)};r(e)}function mt(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function ht(e){ft(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=y.analyze(e,{ecmaVersion:2022,ignoreEval:!0,sourceType:"module"}),n=new Map;for(const e of t.scopes)for(const t of e.references)n.set(t.identifier,t);return{scopeManager:t,referencesByIdentifier:n,moduleScope:wt(t)}}function gt(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function yt(e){return e.defs.some((e=>"ImportBinding"===e.type))}function bt(e,t){return t.moduleScope.set.get(e)}function wt(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function vt(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:$t(e,t)},r=[];return ft(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(St(o,t.unsupportedAliases,t.scopeAnalysis))throw Pt(n,"action-catalog call aliases");if(St(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw Pt(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!kt(o,t.scopeAnalysis))return!1;if(e.optional||Et(o))throw Pt(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function $t(e,t){const n=new Set;return ft(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&St(e.init,t.actionFunctions,t))return Dt(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&kt(e.init,t))return Dt(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!St(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:At(e.value))).map((e=>e.name));return Dt(e,t,n)}(e,t))n.add(o)},AssignmentExpression(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.left.type&&"Identifier"===e.right.type&&St(e.right,t.actionFunctions,t))return It([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&kt(e.right,t))return It([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!St(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:At(e.value)));return It(n,t)}(e,t))n.add(o)}}),n}function kt(e,t){const n=xt(e);return!!n&&St(n,t.actionNamespaces,t)}function xt(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?xt(e.object):void 0}function Et(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&Et(e.object)}function St(e,t,n){return function(e,t,n){const o=gt(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function It(e,t){return e.flatMap((e=>{const n=gt(e,t.moduleScope);return n?[n]:[]}))}function Dt(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function At(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?At(e.argument):At(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?At(e):[]));case"RestElement":return At(e.argument);case"AssignmentPattern":return At(e.left);case"MemberExpression":return[]}}function Pt(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const jt="@datadog/action-catalog";function Mt(e,t,n){const o=e.get(t);if(!o)return Ft(t,[],n.name);const r=gt(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?zt(t,[],n.name):Ot({modules:e,visitedExports:new Set},t,r,[]):zt(t,[],n.name)}function Ct(e,t,n,o){const r=e.modules.get(t);if(!r)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"export",exportName:n,message:`Module '${e}' was not collected while resolving export '${n}'.`,hops:t}}(t,o,n);if("default"===n)return Rt(t,o,n);const i=`${t}\0${n}`;if(e.visitedExports.has(i))return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"cycle",exportName:n,message:`Resolving export '${n}' from module '${e}' would cycle through the module graph.`,hops:t}}(t,o,n);e.visitedExports.add(i);try{const t=r.exportsByName.get(n);return t?function(e,t,n,o,r){if("unsupported"===o.kind)return function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-export",exportName:n,exportReason:o,message:`Export '${n}' from module '${e}' is unsupported: ${o}.`,hops:t}}(t.id,r,n,o.reason);if("re-export"===o.kind)return"default"===o.importedName?Rt(t.id,r,n):Ct(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return Ot(e,t.id,o.variable,[...r,{kind:"local-export",moduleId:t.id,exportName:n,localName:o.variable.name}])}(e,r,n,t,o):function(e,t,n,o){let r;for(const i of t.starExports){const s=Ct(e,i.resolvedId,n,[...o,{kind:"star-export",moduleId:t.id,exportName:n,sourceModuleId:i.resolvedId}]);if("unsupported"===s.kind){if("missing-export"===s.reason)continue;return s}if(!r||!Tt(r,s)){if(r)return Nt(t.id,o,n);r=s}}return r??function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-export",exportName:n,message:`Module '${e}' does not expose export '${n}'.`,hops:t}}(t.id,o,n)}(e,r,n,o)}finally{e.visitedExports.delete(i)}}function Tt(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function Ot(e,t,n,o){const r=e.modules.get(t);if(!r)return Ft(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return _t(t,r,n);if("namespace"===o.kind)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"namespace-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported namespace import.`,hops:t}}(t,r,n);if("default"===o.importedName)return _t(t,r,n);return Ct(e,o.resolvedId,o.importedName,[...r,{kind:"import",moduleId:t,localName:n,exportName:o.importedName,sourceModuleId:o.resolvedId}])}(e,r.id,n.name,i,o);const s=r.topLevelBindingsByVariable.get(n);return s?"const"===s.kind?{kind:"local",moduleId:r.id,variable:n,binding:s,hops:o}:"mutable"===s.kind?function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"mutable-binding",variableName:n,declarationKind:o,message:`Variable '${n}' in module '${e}' is declared with mutable '${o}'.`,hops:t}}(r.id,o,n.name,s.declarationKind):function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-binding",variableName:n,bindingReason:o,message:`Variable '${n}' in module '${e}' has unsupported binding: ${o}.`,hops:t}}(r.id,o,n.name,s.reason):function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-static-binding",variableName:n,message:`Variable '${n}' in module '${e}' does not have a recorded top-level static binding.`,hops:t}}(r.id,o,n.name)}function Nt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"ambiguous-star-export",exportName:n,message:`Module '${e}' exposes ambiguous star exports for '${n}'.`,hops:t}}function Rt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-export",exportName:n,message:`Export '${n}' from module '${e}' resolves through an unsupported default export.`,hops:t}}function _t(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported default import.`,hops:t}}function Ft(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"variable",variableName:n,message:`Module '${e}' was not collected while resolving variable '${n}'.`,hops:t}}function zt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unresolved-identifier",variableName:n,message:`Identifier '${n}' in module '${e}' is not a resolvable reference.`,hops:t}}function Lt(e,t,n){const o=Qt(n);switch(o.type){case"Literal":return function(e,t){if("string"==typeof t.value)return{kind:"resolved",moduleId:e,value:t.value};return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-string-literal",valueType:t,message:`Literal value type '${t}' in module '${e}' is not a string.`}}(e,typeof t.value)}(t,o);case"TemplateLiteral":return function(e,t){if(t.expressions.length>0)return function(e){return{kind:"unsupported",moduleId:e,reason:"dynamic-template-literal",message:`Dynamic template literals in module '${e}' cannot be resolved to static strings.`}}(e);return{kind:"resolved",moduleId:e,value:t.quasis.map((e=>e.value.cooked??e.value.raw)).join("")}}(t,o);case"Identifier":return function(e,t,n){const o=Mt(e.modules,t,n);if("unsupported"===o.kind)return an(o,n.name);if(!o.binding.expression)return un(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return tn(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return Lt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=Ut(e,t,n);if("unsupported"===o.kind)return o;return Lt(e,o.moduleId,o.expression)}(e,t,o);default:return function(e,t){return{kind:"unsupported",moduleId:e,reason:"unsupported-expression",expressionType:t,message:`Expression type '${t}' in module '${e}' cannot be resolved to a static string.`}}(t,o.type)}}function Ut(e,t,n){if(n.optional)return function(e){return{kind:"unsupported",moduleId:e,reason:"optional-member-expression",message:`Optional member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if(n.computed)return function(e){return{kind:"unsupported",moduleId:e,reason:"computed-member-expression",message:`Computed member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if("Identifier"!==n.property.type)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-static-member-property",propertyType:t,message:`Member property type '${t}' in module '${e}' is not statically named.`}}(t,n.property.type);const o=Bt(e,t,n.object);return"unsupported"===o.kind?o:function(e,t,n){let o;for(const r of t.properties){if("SpreadElement"===r.type)return sn(e);if(r.computed)return en(e);if(Yt(r)===n){if(o)return nn(e,n);if("init"!==r.kind)return Xt(e,n);if(!qt(r))return rn(e,n,r.value.type);o=r}}if(!o)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"missing-object-property",propertyName:t,message:`Static object in module '${e}' does not have property '${t}'.`}}(e,n);return{kind:"resolved",moduleId:e,expression:o.value}}(o.moduleId,o.expression,n.property.name)}function Bt(e,t,n){if("Super"===n.type)return on(t,n.type);const o=Qt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=Ut(e,t,o);return"unsupported"===n.kind?n:Bt(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return on(t,o.type);const r=Mt(e.modules,t,o);if("unsupported"===r.kind)return an(r,o.name);if(!r.binding.expression)return un(r.moduleId,r.variable.name);if(e.mutatedImportedObjectVariables.has(r.variable))return function(e,t){return{kind:"unsupported",moduleId:e,reason:"imported-object-mutation",variableName:t,message:`Imported object '${t}' from module '${e}' is mutated in the module graph.`}}(r.moduleId,r.variable.name);if(e.seenVariables.has(r.variable))return tn(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return Bt(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function qt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function Vt(e){const t=new Set;for(const n of e.values())ft(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){Ht(e.left,t)},UpdateExpression(e,{state:t}){Ht(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Ht(e.argument,t)},ForInStatement(e,{state:t}){Kt(e.left,t)},ForOfStatement(e,{state:t}){Kt(e.left,t)}});return t}function Kt(e,t){"VariableDeclaration"!==e.type&&Ht(e,t)}function Ht(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&Ht(e.left,t):Ht(e.argument,t);else for(const n of e.elements)n&&Ht(n,t);else for(const n of e.properties)Ht("RestElement"===n.type?n.argument:n.value,t);else{const n=Gt(e);n&&Wt(n,t)}else Wt(e,t)}function Wt(e,t){const n=Jt(t,e,new Set);n&&t.mutatedVariables.add(n)}function Jt(e,t,n){const o=gt(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),yt(o)){const n=Mt(e.modules,e.record.id,t);return"local"===n.kind?n.variable:void 0}const r=function(e){for(const t of e.defs){const e=t.node;if("VariableDeclarator"===e.type&&e.init)return e.init}return}(o);if(!r)return;const i=function(e){const t=Qt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return Gt(t);return}(r);return i?Jt(e,i,n):void 0}function Gt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?Gt(e.object):void 0}function Yt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function Qt(e){let t=e;for(;Zt(t);)t=t.expression;return t}function Zt(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function Xt(e,t){return{kind:"unsupported",moduleId:e,reason:"accessor-object-property",propertyName:t,message:`Static object property '${t}' in module '${e}' is an accessor.`}}function en(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function tn(e,t){return{kind:"unsupported",moduleId:e,reason:"cycle",variableName:t,message:`Resolving variable '${t}' in module '${e}' would cycle through static string values.`}}function nn(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function on(e,t){return{kind:"unsupported",moduleId:e,reason:"non-object-member-value",expressionType:t,message:`Expression type '${t}' in module '${e}' is not a static object value.`}}function rn(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unsupported-object-property-value",propertyName:t,valueType:n,message:`Static object property '${t}' in module '${e}' has unsupported value type '${n}'.`}}function sn(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function an(e,t){return{kind:"unsupported",moduleId:e.moduleId,reason:"static-definition-unsupported",variableName:t,definition:e,message:`Variable '${t}' could not be resolved to a static definition: ${e.message}`}}function un(e,t){return{kind:"unsupported",moduleId:e,reason:"uninitialized-const",variableName:t,message:`Const variable '${t}' in module '${e}' does not have an initializer.`}}const cn=new Set(["node_modules",".yarn"]);function dn(e,t,n,o=[]){if(!An(e,t))return null;const r=nt(n,e),i=ht(r),s=function(e,t){const n=function(e){return e.body.flatMap((e=>("ImportDeclaration"===e.type||"ExportNamedDeclaration"===e.type||"ExportAllDeclaration"===e.type)&&e.source&&ot(e.source)?[e.source.value]:[]))}(e);return t.map(((e,t)=>({source:n[t]??e,resolvedId:e})))}(r,o);return{id:e,ast:r,scopeAnalysis:i,staticDependencies:s,unsupportedDependencies:In(r),importsByVariable:ln(r,i,s),exportsByName:pn(r,i,s),starExports:hn(r,s),topLevelBindingsByVariable:gn(r,i)}}function ln(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!ot(r.source))continue;const e=Sn(n,r.source.value);for(const n of r.specifiers){const[r]=t.scopeManager.getDeclaredVariables(n);r&&("ImportSpecifier"!==n.type?o.set(r,{kind:"ImportDefaultSpecifier"===n.type?"default":"namespace",resolvedId:e}):o.set(r,{kind:"named",importedName:xn(n.imported),resolvedId:e}))}}return o}function pn(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&mn(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):fn(r,t,n,o);return o}function fn(e,t,n,o){if(e.declaration)!function(e,t,n){if(!e)return;if("VariableDeclaration"===e.type){for(const o of e.declarations){const e=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const t of e)n.set(t.name,{kind:"unsupported",reason:"binding pattern export"});continue}const[r]=e;r&&n.set(o.id.name,{kind:"local",variable:r})}return}if(("FunctionDeclaration"===e.type||"ClassDeclaration"===e.type)&&e.id){const[o]=t.scopeManager.getDeclaredVariables(e);o&&n.set(e.id.name,{kind:"local",variable:o})}}(e.declaration,t,o);else if(e.source&&ot(e.source)){const t=Sn(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=xn(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:xn(n.local),resolvedId:t}):o.set(e,{kind:"unsupported",reason:"default re-export",resolvedId:t})}}else for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=xn(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=bt(xn(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function mn(e,t,n){const o=En(e);o&&ot(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Sn(t,e.source.value)})}function hn(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||En(e)||!ot(e.source)?[]:[{resolvedId:Sn(t,e.source.value)}]))}function gn(e,t){const n=new Map;for(const o of e.body)yn(o,t,n);return function(e,t,n){ft(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){vn(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){vn(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&vn(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){wn(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){wn(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function yn(e,t,n){if("VariableDeclaration"===e.type)return void bn(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void bn(e.declaration,t,n);const o="ExportNamedDeclaration"===e.type||"ExportDefaultDeclaration"===e.type?e.declaration:e;if(o&&("FunctionDeclaration"===o.type||"ClassDeclaration"===o.type)&&o.id){const[e]=t.scopeManager.getDeclaredVariables(o);e&&n.set(e,{kind:"unsupported",reason:`${o.type} binding`})}}function bn(e,t,n){for(const o of e.declarations){const r=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const e of r)n.set(e,{kind:"unsupported",reason:"binding pattern"});continue}const[i]=r;i&&("const"===e.kind?n.set(i,{kind:"const",expression:o.init??null}):n.set(i,{kind:"mutable",declarationKind:e.kind}))}}function wn(e,t,n){"VariableDeclaration"!==e.type&&vn(e,t,n)}function vn(e,t,n){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&vn(e.left,t,n):vn(e.argument,t,n);else for(const o of e.elements)o&&vn(o,t,n);else for(const o of e.properties)vn("RestElement"===o.type?o.argument:o.value,t,n);else{const o=kn(e);o&&$n(o,t,n,"mutated object binding")}else $n(e,t,n,"reassigned binding")}function $n(e,t,n,o){const r=gt(e,t);if(!r||yt(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function kn(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?kn(e.object):void 0}function xn(e){return"Identifier"===e.type?e.name:String(e.value)}function En(e){const t=e.exported;return t?xn(t):void 0}function Sn(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function In(e){const t=[];return ft(e,t,{ImportExpression(e,{state:t}){const n=function(e){return jn(e.source,"non-literal dynamic import")}(e);Dn(n)&&t.push({specifier:n,kind:"dynamic-import"})},CallExpression(e,{state:t}){if(function(e){return"Import"===e.callee.type}(e)){const n=function(e){return jn(e.arguments[0],"non-literal dynamic import")}(e);Dn(n)&&t.push({specifier:n,kind:"dynamic-import"})}else(function(e){if("Identifier"!==e.callee.type||"require"!==e.callee.name)return!1;const[t]=e.arguments;return!t||!ot(t)||Mn(t.value)})(e)&&t.push({specifier:Pn(e),kind:"require"})}}),t}function Dn(e){return"non-literal dynamic import"===e||Mn(e)}function An(e,t){if(!ke.some((t=>e.endsWith(t))))return!1;const n=u.relative(u.resolve(t),e);return!n.startsWith("..")&&!u.isAbsolute(n)&&!n.split(u.sep).some((e=>cn.has(e)))}function Pn(e){return jn(e.arguments[0],"local require")}function jn(e,t){return ot(e)?e.value:t}function Mn(e){return e.startsWith(".")||e.startsWith("/")}function Cn(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function Tn(e,t,n){const o=new Set;return function(e,t,n,o){const r=[e],i=new Set;for(;r.length>0;){const s=r.shift();if(i.has(s))continue;i.add(s);const a=t.get(s);if(!a)throw Cn(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw Cn(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(An(i,n)){if(!t.has(i))throw Cn(e,`uncollected local import ${i} from ${a.id}`);r.push(i)}}}}(e,t,n,(({record:e})=>{const n=function(e){const t=new Set,n=new Set;for(const r of e.body)if("ImportDeclaration"===r.type&&"string"==typeof(o=r.source.value)&&(o===jt||o.startsWith(`${jt}/`))&&!rt(r))for(const e of r.specifiers)rt(e)||("ImportNamespaceSpecifier"===e.type?n.add(e.local.name):t.add(e.local.name));var o;return{functions:t,namespaces:n}}(e.ast),r=function(e,t){const n=new Set,o=new Set;for(const r of e.scopeManager.scopes)for(const e of r.variables)yt(e)&&(t.functions.has(e.name)&&n.add(e),t.namespaces.has(e.name)&&o.add(e));return{moduleScope:e,actionFunctions:n,actionNamespaces:o}}(e.scopeAnalysis,n);for(const n of vt(e.ast,r,e.id)){const r=On(n,t,e);r&&o.add(r)}})),[...o].sort()}function On(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw _n(n.id,"non-object action-catalog call arguments");const r=function(e,t){let n;for(const o of e.properties){if("SpreadElement"===o.type)throw _n(t,"spread object arguments");if(o.computed)throw _n(t,"computed object property keys");if(Rn(o)){if(n)throw _n(t,"multiple connectionId properties");if("init"!==o.kind)throw _n(t,"accessor connectionId properties");if(!Nn(o))throw _n(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return Lt({modules:e,mutatedImportedObjectVariables:Vt(e),seenVariables:new Set},t,n)}(t,n.id,r.value);if("resolved"===i.kind)return i.value;throw s=n.id,a=`static string resolution ${function(e){return"static-definition-unsupported"===e.reason?`${e.reason}/${e.definition.reason}`:e.reason}(i)}: ${i.message}`,new Error(`Unsupported action-catalog connectionId in ${s}: ${a}.`);var s,a}function Nn(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function Rn(e){return"connectionId"===function(e){if("Identifier"===e.key.type)return e.key.name;if("Literal"===e.key.type&&"string"==typeof e.key.value)return e.key.value;return}(e)}function _n(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const Fn=/^(?:\0|virtual:)/;function zn(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=Ln(n.id);if(r=o,Fn.test(r))return;var r;const i=dn(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(Ln));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function Ln(e){return e.split("?")[0]}function Un(e,t){const n=zn(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>Tn(e,n.getModuleRecords(),t)}}function Bn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function qn(e,t,n=[]){return{configFile:!1,root:e,logLevel:"silent",build:{minify:!1,target:"esnext",rollupOptions:{output:{format:"es",exports:"named",inlineDynamicImports:!0},preserveEntrySignatures:"exports-only",treeshake:!1,onwarn(e,t){"MODULE_LEVEL_DIRECTIVE"!==e.code&&t(e)}}},resolve:{extensions:[...ke,".json"]},plugins:[Bn("dd-backend-resolve",t),...n]}}function Vn(e){return`${e.relativePath}/${e.name}`}async function Kn(e,t,n,o){const r=Vn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return pt(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=Un(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=qn(n,{[i]:s},[a.plugin]),c=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),d=Array.isArray(c)?c[0]:c;if(!("output"in d))throw new Error(`Unexpected vite.build result for "${r}"`);const l="chunk"===d.output[0].type?d.output[0].code:"",p={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${l.length} bytes)`),{func:p,code:l}}async function Hn(e,t,n,o,r,i){const s=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,a=Vn(t);i.debug(`Calling Datadog API: ${s}`);const u=JSON.stringify({data:{type:"queries",attributes:{query:{id:f(),name:a,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e,allowedConnectionIds:t.allowedConnectionIds,context:{backendFunctionArgs:n}}},onlyTriggerManually:!0}},template_params:{}}}}),c=await r({url:s,method:"POST",type:"json",getData:()=>({data:u,headers:{"Content-Type":"application/json"}})}),d=c.data?.id;if(!d)throw new Error("No receipt ID returned from Datadog API");return i.debug(`Query execution started with receipt: ${d}`),async function(e,t,n,o){const r=`https://api.${t.site}/api/v2/app-builder/queries/execution-long-polling/${e}`,i=10;for(let e=0;e<i;e++){o.debug(`Long-poll attempt ${e+1}/${i}...`);const t=await n({url:r,type:"json"});if(t.errors?.length){const e=t.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const s=t.data?.attributes;if(o.debug(`Long-poll response, done: ${s?.done}`),s?.done){if(!s.outputs)throw new Error("Query execution completed without outputs");return s.outputs}}throw new Error("Query execution timed out")}(d,o,r,i)}function Wn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class Jn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function Gn(e,t,n){const{functionName:o,args:r=[]}=await function(e){return new Promise(((t,n)=>{let o="";e.on("data",(e=>{o+=e.toString()})),e.on("end",(()=>{try{t(JSON.parse(o))}catch{n(new Error("Invalid JSON body"))}})),e.on("error",n)}))}(e);if(!o||"string"!=typeof o)throw new Jn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new Jn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function Yn(e,t,n,o,r,i){const s=t=>Kn(e,t,r,i),a=t();return a.length>0&&i.info(`Dev server middleware active for ${a.length} backend function(s): ${a.map((e=>e.name)).join(", ")}`),o||i.warn(`Auth credentials not configured. The /__dd/executeAction endpoint will be unavailable. ${Xe}`),(e,r,a)=>{if("POST"!==e.method)return void a();const u=(c=t(),new Map(c.map((e=>[dt(e),e]))));var c;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await Gn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){Wn(t,e instanceof Jn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,r,u,s).catch((()=>{Wn(r,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!o)return void Wn(r,400,`Auth credentials not configured. ${Xe}`);(async function(e,t,n,o,r,i,s){try{const{func:a,code:u,args:c}=await Gn(e,n,o),d=Vn(a);s.debug(`Executing action: ${d} with args`);const l=await Hn(u,a,c,r,i,s);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:l}))}catch(e){const n=e instanceof Jn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";s.debug(`Error handling executeAction: ${o}`),Wn(t,n,o)}})(e,r,u,s,n,o,i).catch((()=>{Wn(r,500,"Unexpected error")}))}else a()}}const Qn=async(e,t)=>{const n=(await Promise.all(e.map((e=>w(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>u.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(u.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(u.sep);if(!e.every((e=>e.startsWith(`${r}${u.sep}`))))break;n=r}return n})(o),i=o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o.split(u.sep).join("/")}}));return i},Zn=(e,t)=>Z(t)?T:t.startsWith(e)||u.isAbsolute(t)?t:u.resolve(e,t),Xn=(e,t)=>{let n,o=Zn(process.cwd(),e);for(;!n;){const e=u.resolve(o,t);if(Pe(e)&&(n=e),o=o.split(u.sep).slice(0,-1).join(u.sep),[u.sep,""].includes(o))break}return n},eo=(e,t)=>{const n=[...e].map((e=>Zn(t||process.cwd(),e).split(u.sep))),o=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<o;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(u.sep)||u.sep},to=t.bold.red,no=t.bold.yellow,oo=e=>{const t=Xn(e,"package.json");if(t)try{const e=Ae(t);return JSON.parse(e)}catch(e){return}},ro=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=oo(e);o||t.warn(no("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(to("Unable to determine the app name to compute the app identifier."));const i=((e,t)=>{const n=e||(e=>{if(e&&e.repository)return"string"==typeof e.repository?e.repository:"url"in e.repository?e.repository.url:void 0})(t);if(!n)return;const o=oe(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(to("Unable to determine the git remote to compute the app identifier."));const s=n?.identifier||((e,t)=>{if(!e||!t)return;const n=`${e}:${t}`;return p("md5").update(n).digest("hex")})(i,r);return s&&r||t.error(to("Unable to compute the app identifier.")),{identifier:s,name:r}},io=t.green.bold,so=t.yellow.bold,ao=t.cyan.bold,uo=t.bold,co=(e,t={},n)=>async()=>{const o=await je(e,{contentType:"application/zip",filename:ve});return W({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ve);const t=B("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},lo=async(e,t,n)=>{const o=[],r=[],i=t.doAuthenticatedRequest;if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:r};const s=(a=t.site,u=t.identifier,B("APPS_INTAKE_URL")||`https://api.${a}/${we}/${u}/upload`);var a,u;const d=H({bundler:t.bundlerName,plugin:"apps",version:t.version}),l=ie({identifier:t.identifier,intakeUrl:s,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),p=`an archive of:\n - ${io(e.assets.length.toString())} files\n - ${io(v(e.size))}\n\nWith the configuration:\n${l}`;if(t.dryRun)return n.error(`\n${ao("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await i({url:s,method:"POST",type:"json",getData:co(e.archivePath,d,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${so(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}});if(n.debug(`Uploaded ${p}\n`),o.app_builder_id){const e=`https://app.${t.site}/app-builder/apps/${o.app_builder_id}`;n.info(`Your application is available at:\n ${ao(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${we}/${t}/release/live`)(t.site,t.identifier);await i({url:e,method:"PUT",type:"json",getData:async()=>({data:c.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...d}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${so(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${uo(o.version_id)} to live.`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));o.push(t)}return{errors:o,warnings:r}},po=t.yellow.bold,fo=t.red.bold,mo="manifest.json";async function ho(e){const t=await r.mkdtemp(u.join(h.tmpdir(),"dd-apps-manifest-")),n=u.join(t,mo);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[dt(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await Se(t),e}return{manifestAsset:{absolutePath:n,relativePath:mo},cleanup:()=>Se(t)}}const go=async({backendOutputs:e,backendFunctions:t,context:n,doAuthenticatedRequest:o,options:i})=>{const a=n.getLogger(be),{auth:c,buildRoot:d,bundler:{name:l,outDir:p},git:f,version:m}=n,g=a.time("handle assets");let y,w,v;try{const n=a.time("resolve identifier"),{name:g,identifier:v}=ro(d,a,{url:f?.remote,name:i.name,identifier:i.identifier});if(!v||!g)throw new Error("Missing apps identification.\nEither:\n - pass an 'options.apps.identifier' and 'options.apps.name' to your plugin's configuration.\n - have a 'name' and a 'repository' in your 'package.json'.\n - have a valid remote url on your git project.\n");n.end();const $=u.relative(d,p),k=[...i.include,`${$}/**/*`],x=await Qn(k,d);if(!x.length)return void a.debug("No assets to upload.");const E=new Set(e.values()),S=x.filter((e=>!E.has(e.absolutePath))).map((e=>({...e,relativePath:`frontend/${e.relativePath}`})));for(const[t,n]of e)S.push({absolutePath:n,relativePath:`backend/${t}.js`});const{manifestAsset:I,cleanup:D}=await ho(t);w=D,S.push(I);const A=a.time("archive assets"),P=await(async e=>{const t=await r.mkdtemp(u.join(h.tmpdir(),"dd-apps-")),n=u.join(t,ve),o=new b;for(const t of e)o.file(t.relativePath,s.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=s.createWriteStream(n),i=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});i.on("error",t),r.on("error",t),r.on("close",e),i.pipe(r)}));const{size:i}=await r.stat(n);return{archivePath:n,size:i,assets:e}})(S);A.end(),y=u.dirname(P.archivePath);const j=a.time("upload assets"),{errors:M,warnings:C}=await lo(P,{bundlerName:l,doAuthenticatedRequest:o,dryRun:i.dryRun,identifier:v,name:g,site:c.site,version:m},a);if(j.end(),C.length>0&&a.warn(`${po("Warnings while uploading assets:")}\n - ${C.join("\n - ")}`),M.length>0){const e=M.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){v=e,a.error(`${fo("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await Se(y),w&&await w(),g.end(),v)throw v};const yo=u.join(M,"./apps-runtime.mjs"),bo=async()=>{throw new Error("Dry run should not perform authenticated requests.")},wo=({bundler:e,context:t,options:n})=>{const o=t.getLogger(be),{auth:r,buildRoot:s}=t;t.inject({type:"file",position:Ce.MIDDLE,value:yo});const{setBackendFunctions:a,getBackendFunctions:c}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[$e],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=it(this.parse(e),t);if(0===n.length)return o.warn(`Backend file ${t} has no exported functions. Did you forget to add a named export?`),a(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=u.relative(n,t).replace($e,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:dt(e)})}return{functions:r,proxyCode:lt(i)}}(n,t,s);return a(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let a,d=new Map,l=c();if(l.length>0){const t=await async function(e,t,n,o){const r=await i(u.join(g(),"dd-apps-backend-")),s=new Map,a=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const i of t){const t=dt(i),c=`\0dd-backend:${t}`,d=pt(i.name,i.absolutePath,n),l=Un(i.absolutePath,n),p=qn(n,{[c]:d},[l.plugin]),f=await e({...p,build:{...p.build,write:!0,outDir:r,emptyOutDir:!1,rollupOptions:{...p.build.rollupOptions,input:{[t]:c},output:{...p.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=u.resolve(r,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}a.set(i.absolutePath,l.getAllowedConnectionIds())}return{outDir:r,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:a.get(e.absolutePath)})))}}(e.build,l,s,o);a=t.outDir,d=t.outputs,l=t.functions}try{const e=n.dryRun?bo:tt(n.authOverrides.method,r,o);await go({backendOutputs:d,backendFunctions:l,context:t,doAuthenticatedRequest:e,options:n})}finally{a&&await Se(a)}},configureServer(t){let i;try{i=tt(n.authOverrides.method,r,o)}catch(e){if(!(e instanceof et))throw e}t.middlewares.use(Yn(e.build,c,r,i,s,o))}}},vo=({options:e,context:t,bundler:n})=>{const o=t.getLogger(be),r=Ee(e);return"vite"!==t.bundler.name?(o.warn(`The apps plugin only supports Vite; skipping under '${t.bundler.name}'.`),[]):[{name:be,enforce:"post",vite:wo({bundler:n,context:t,options:r})}]},$o="errorTracking",ko="datadog-error-tracking-plugin",xo=(e,n,o)=>{if(".map"!==u.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=u.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return u.join(e,t);try{const n=e.replace(/\/*$/,"/"),o=new URL(n),r=t.replace(/^[\\/]*/,"");return new URL(r,o).href}catch{return`${e}${t}`}})(e,i);return{minifiedFilePath:r,minifiedUrl:s,relativePath:i}},Eo=/[/]+|[\\]+/g,So=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Io=(e,t)=>{const n=e.replace(So,"").split(Eo),o=t.replace(So,"").split(Eo),r=n.join("/");let i="";for(let e=0;e<o.length;e+=1){const t=o.slice(-e).join("/");r.startsWith(t)&&(i=t)}return i},Do=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([Me(e.minifiedFilePath),Me(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Io(e.relativePath,t)}})(e,n),i=[],s=[],a=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(o)try{a.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${u.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:o.hash,repository_url:o.remote}],version:1})})}catch(t){s.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&s.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:a,errors:i,warnings:s}},Ao=e=>{const t=e.message.match(/HTTP (\d{3})/);return t?`status_code:${t[1]}`:"status_code:unknown"},Po=e=>{const t=Ao(e);return"status_code:unknown"!==t?`error_type:http_${t.replace("status_code:","")}`:`error_type:${re(e.name||"unknown")}`},jo=(e,t,n)=>{const o=((e,t)=>`${e}|${t.join("|")}`)(t,n),r=e.metrics.get(o);r?r.value++:e.metrics.set(o,{name:t,value:1,tags:n})},Mo=(e,t,n)=>{jo(e,"retry",[...e.baseTags,`attempt:${n}`,Ao(t),Po(t)])},Co=(e,t)=>{jo(e,"failure",[...e.baseTags,Ao(t),Po(t)])},To=(e,t)=>{if(!t.sendMetrics)return;if(!e.metrics.size)return;const n=(e=>{const t=Math.floor(Date.now()/1e3);return Array.from(e.metrics.values()).map((e=>({metric:`sourcemaps.upload.${e.name}`,type:"count",points:[[t,e.value]],tags:e.tags})))})(e);for(const e of n)t.addMetric(e)},Oo=t.green.bold,No=t.yellow.bold,Ro=t.red.bold,_o=(e,t={})=>async()=>W({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await je(o.path,o.options):new Blob([o.value],{type:o.options.contentType});t.append(n,e,o.options.filename)}return t},defaultHeaders:t,zip:!0}),Fo=async(e,t,n,o)=>{const r=[],i=[];if(!n.apiKey)return r.push({error:new Error("No authentication token provided")}),{errors:r,warnings:i};if(0===e.length)return i.push("No sourcemaps to upload"),{errors:r,warnings:i};const s=o.time("Queue uploads"),a=new($.default?$.default:$)({concurrency:t.maxConcurrency}),u=(c=n.site,B("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const d=H({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),l=(e=>({metrics:new Map,baseTags:[`service:${e.service}`]}))(t),p=ie({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),f=`\nUploading ${Oo(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(f);const m=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};m.push(a.add((async()=>{try{await G({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:_o(s,d),onRetry:(t,n)=>{Mo(l,t,n);const r=`Failed to upload ${No(e.sourcemap)} | ${No(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(Co(l,n),r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}s.end(),o.debug(`Queued ${Oo(e.length.toString())} uploads.`);try{await Promise.all(m),await a.onIdle()}finally{To(l,n)}return{warnings:i,errors:r}},zo=async(e,t,n)=>{const o=n.time("get sourcemaps files"),r=((e,t)=>{if(!t.outputs||0===t.outputs.length)throw new Error("No output files found.");return t.outputs.filter((e=>e.filepath.endsWith(".map"))).map((e=>e.filepath)).map((n=>({...xo(e.minifiedPathPrefix,t.outDir,n),sourcemapFilePath:n,minifiedPathPrefix:e.minifiedPathPrefix})))})(e.sourcemaps,{outDir:t.outDir,outputs:t.outputs});o.end();const i=n.time("send sourcemaps");await(async(e,t,n,o)=>{const r=Date.now(),i=t.minifiedPathPrefix,s={git_repository_url:n.git?.remote,git_commit_sha:n.git?.hash,plugin_version:n.version,project_path:n.outDir,service:t.service,type:"js_sourcemap",version:t.releaseVersion},a=o.time("Compute payloads"),u=await Promise.all(e.map((e=>Do(e,s,i,n.git))));a.end();const c=u.map((e=>e.errors)).flat(),d=u.map((e=>e.warnings)).flat();if(d.length>0&&o.warn(`Warnings while preparing payloads:\n - ${d.join("\n - ")}`),c.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${c.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const l=o.time("Upload sourcemaps"),{errors:p,warnings:f}=await Fo(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site,sendMetrics:n.sendMetrics,addMetric:n.addMetric},o);if(l.end(),o.debug(`Done uploading ${Oo(`${e.length-p.length}/${e.length}`)} sourcemaps in ${Oo(te(Date.now()-r))}.`),p.length>0){const e=`Failed to upload some sourcemaps:\n - ${p.map((({metadata:e,error:t})=>{const n=t.cause||t.stack||t.message;return e?`${Ro(e.file)} | ${Ro(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{addMetric:t.addMetric,apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,sendMetrics:t.sendMetrics,site:t.site,version:t.version},n),i.end()},Lo=e=>{const n=t.bold.red,o=e[$o]||{},r={errors:[]};if(o.sourcemaps){const t=o.sourcemaps,i=t.releaseVersion||e.metadata?.version;i||r.errors.push(`${n("sourcemaps.releaseVersion")} is required (set it directly or via ${n("metadata.version")}).`),t.releaseVersion&&e.metadata?.version&&t.releaseVersion!==e.metadata.version&&r.errors.push(`${n("sourcemaps.releaseVersion")} must match ${n("metadata.version")} when both are configured.`),t.service||r.errors.push(`${n("sourcemaps.service")} is required.`),t.minifiedPathPrefix||r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} is required.`),t.minifiedPathPrefix&&!(e=>{let t;try{t=new URL(e).host}catch{}return!(!t&&!e.startsWith("/"))})(t.minifiedPathPrefix)&&r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} must be a valid URL or start with '/'.`),i&&(r.config={bailOnError:!1,dryRun:!1,maxConcurrency:20,...t,releaseVersion:i})}return r},Uo=({options:e,context:t})=>{const n=t.getLogger(ko),o=n.time("validate options"),r=((e,t)=>{const n=[],o=Lo(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${ko}.`);return{...e[$o],sourcemaps:o.config}})(e,n);o.end();const i=ge(e,"metrics",n);let s,a,u=!1;const c=async()=>{if(!r.sourcemaps||u)return;u=!0;const e=n.time("sourcemaps process");await zo(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:s,addMetric:t.addMetric,outDir:t.bundler.outDir,outputs:a?.outputs||[],sendMetrics:i,site:t.auth.site,version:t.version},n),e.end()};return[{name:ko,enforce:"post",async git(e){s=e,a&&await c()},async buildReport(t){a=t,!s&&ee(e)||await c()},async asyncTrueEnd(){u||await c()}}]},Bo="liveDebugger",qo="datadog-live-debugger-plugin",Vo="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",Ko="__DD_LIVE_DEBUGGER_BUILD__",Ho=e=>void 0===e?Vo:`${Vo};if(typeof globalThis.${Ko}==='undefined'){globalThis.${Ko}={version:${JSON.stringify(e)}}}`;function Wo(e){return"function"==typeof e?e:e.default}function Jo(e,t,n,o,r){const i=u.relative(t,e).replace(/\\/g,"/"),s=Go(n,r);if(s)return`${i};${s}`;const a=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${a}:${o}`}function Go(e,t){const n=e.node,o=e.parent;return"id"in n&&t.isIdentifier(n.id)?n.id.name:t.isObjectMethod(n)||t.isClassMethod(n)||t.isClassPrivateMethod(n)?Zo(n.key,t):t.isVariableDeclarator(o)&&t.isIdentifier(o.id)?o.id.name:t.isAssignmentExpression(o)?function(e,t){if(t.isIdentifier(e))return e.name;if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=Yo(e.object,t),o=Qo(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}(o.left,t):t.isObjectProperty(o)||t.isClassProperty(o)||t.isClassPrivateProperty(o)?Zo(o.key,t):null}function Yo(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=Yo(e.object,t),o=Qo(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function Qo(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function Zo(e,t){return t.isIdentifier(e)?e.name:t.isStringLiteral(e)||t.isNumericLiteral(e)||t.isBigIntLiteral(e)?String(e.value):t.isPrivateName(e)&&t.isIdentifier(e.id)?`#${e.id.name}`:null}function Xo(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function er(e,t){const n=[];if(t.isBlockStatement(e.body)){const o=e.params.flatMap((e=>sr(e,t))),r=new Set(o),i="id"in e&&t.isIdentifier(e.id)?e.id.name:"";for(const o of e.body.body)if(t.isVariableDeclaration(o)){const e=o.end;if(null==e)continue;for(const s of o.declarations)for(const o of sr(s.id,t))r.has(o)||o===i||n.push({name:o,declarationEnd:e,temporalDeadZones:[]})}}const o=n.length>25?n.slice(0,25):n;if(t.isBlockStatement(e.body)){const n=o.map((({name:e})=>e)),r=new Set(n),i=function(e,t,n){const o=new Map;for(const r of e.body)tr(r,t,o,n);return o}(e.body,r,t);for(const e of o)e.temporalDeadZones=i.get(e.name)??[]}return o}function tr(e,t,n,o){o.isFunctionDeclaration(e)||o.isClassDeclaration(e)||(o.isBlockStatement(e)?nr(e,t,n,o):o.isIfStatement(e)?(tr(e.consequent,t,n,o),e.alternate&&tr(e.alternate,t,n,o)):o.isForStatement(e)||o.isForInStatement(e)||o.isForOfStatement(e)||o.isWhileStatement(e)||o.isDoWhileStatement(e)?tr(e.body,t,n,o):o.isSwitchStatement(e)?function(e,t,n,o){for(const r of e.cases){or(r.consequent,e.start,t,n,o);for(const e of r.consequent)tr(e,t,n,o)}}(e,t,n,o):o.isTryStatement(e)?(nr(e.block,t,n,o),e.handler&&nr(e.handler.body,t,n,o),e.finalizer&&nr(e.finalizer,t,n,o)):(o.isLabeledStatement(e)||o.isWithStatement(e))&&tr(e.body,t,n,o))}function nr(e,t,n,o){or(e.body,e.start,t,n,o);for(const r of e.body)tr(r,t,n,o)}function or(e,t,n,o,r){if(null!=t)for(const i of e)r.isVariableDeclaration(i)&&"var"!==i.kind?rr(i,t,n,o,r):r.isClassDeclaration(i)&&i.id&&ir(i.id.name,t,i.end,n,o)}function rr(e,t,n,o,r){for(const i of e.declarations)for(const s of sr(i.id,r))ir(s,t,e.end,n,o)}function ir(e,t,n,o,r){if(null==n||!o.has(e))return;const i=r.get(e)??[];i.push({start:t,end:n}),r.set(e,i)}function sr(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:sr(e.argument,t):t.isAssignmentPattern(e)?sr(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?sr(e.argument,t):sr(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?sr(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const ar=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let ur,cr,dr,lr,pr=!1;function fr(e){try{return function(e){switch(e){case"@babel/parser":return C("@babel/parser");case"@babel/traverse":return C("@babel/traverse");case"@babel/types":return C("@babel/types");case"magic-string":return C("magic-string");default:throw new Error(`Unknown peer dependency: ${e}`)}}(e)}catch(e){throw function(e){if(!function(e){if(!(e instanceof Error))return!1;const t=e.code;if("MODULE_NOT_FOUND"!==t&&"ERR_MODULE_NOT_FOUND"!==t)return!1;return ar.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=ar.find((t=>e.message.includes(t))),n=t??ar.join(", ");return new Error(`Datadog Live Debugger could not load "${n}". It is an optional peer dependency that must be installed in your project when the \`liveDebugger\` plugin is enabled. Install the peer dependencies with: \`npm install --save-dev ${ar.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const mr=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function hr(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,c=0,d=0,l=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:1,skippedUnsupportedCount:d,totalFunctions:l};if(!mr.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l};pr||(ur=fr("@babel/parser").parse,cr=Wo(fr("@babel/traverse")),dr=fr("@babel/types"),lr=Wo(fr("magic-string")),pr=!0);const p=ur(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map,h=new Set,g=new Map,y=new Map;let b=0;if(cr(p,{Function(e){l++;const t=function(e,t){if(t.isClassMethod(e.node)&&"constructor"===e.node.kind&&kr(e,t))return e.node;return}(e,dr);if(t&&(m.set(t,t.body.start),g.set(t,function(e,t){const n=[];for(const o of e)br(o,n,t);return n}(t.body.body,dr))),!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,dr))return void d++;if(r&&function(e,t,n){let o=e;for(;o;){if(Xo(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return Xo(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",dr))return void c++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,dr)))return void d++;if(s&&!Go(e,dr))return void d++;let p=0;if(!Go(e,dr)){const t=e.parentPath?.node;t&&(p=y.get(t)||0,y.set(t,p+1))}const w=Jo(n,o,e,p,dr);try{const t=e.node,n=b++,o=`$dd_p${n}`,r=function(e,t){const n=[];for(const o of e.params)for(const e of sr(o,t))"this"!==e&&n.push(e);return n.length>25?n.slice(0,25):n}(t,dr),i=er(t,dr),s=dr.isArrowFunctionExpression(t)&&!dr.isBlockStatement(t.body),a=s&&dr.isSequenceExpression(t.body),c=function(e,t){if(t.isFunction(e.node)&&!t.isArrowFunctionExpression(e.node))return;let n=e.parentPath;for(;n;){const e=n.node;if(t.isClassMethod(e)&&"constructor"===e.kind){if(!kr(n,t))return;return{node:e,parent:n.parent,parentPath:n.parentPath}}if(t.isFunction(e)){if(t.isArrowFunctionExpression(e)){n=n.parentPath;continue}return}n=n.parentPath}return}(e,dr),d=null!=c;c&&(h.add(c.node),m.set(c.node,c.node.body.start));const l=[],p=s||!dr.isBlockStatement(t.body)||!Sr(t.body.body,dr);let g;if(!s&&dr.isBlockStatement(t.body)&&Er(t.body.body,l,dr),!s&&dr.isBlockStatement(t.body)&&t.body.directives.length>0){g=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,hasSequenceExpressionBody:a,aliasesExpressionBodySuperCall:d&&s&&$r(t.body,dr),needsTrailingReturn:p,useThisAlias:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:g,functionId:w,probeVarName:o,probeIdx:String(n),entryVars:r,localVars:i,returns:l}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l};const w=new lr(t),v=function(e){const t=new Set;for(const n of e)n.aliasesExpressionBodySuperCall&&t.add(vr({start:n.bodyStart,end:n.bodyEnd}));return t}(f),$=function(e,t,n,o){const r=[];for(const i of e){const e=t.get(i);null!=e&&r.push({bodyStart:e,superCalls:(n.get(i)??[]).filter((e=>!o.has(vr(e))))})}return r}(h,m,g,v);for(let e=f.length-1;e>=0;e--)gr(w,t,f[e]);for(const e of $)yr(w,t,e);return{code:w.toString(),map:w.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l}}function gr(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,localVars:a,returns:u,bodyStart:c,bodyEnd:d,functionEnd:l,isExpressionBody:p,hasSequenceExpressionBody:f,aliasesExpressionBodySuperCall:m,useThisAlias:h,bodyParenStart:g,directivesEnd:y}=n,b=`$dd_e${r}`,w=`$dd_rv${r}`,v=h?"$dd_t":"this",$=s.join(", "),k=""!==$,x=k?`, ${b}()`:"";const E=`const ${o} = $dd_probes('${i.replace(/['\\\n\r\u2028\u2029]/g,(e=>{switch(e){case"'":return"\\'";case"\\":return"\\\\";case"\n":return"\\n";case"\r":return"\\r";case"\u2028":return"\\u2028";case"\u2029":return"\\u2029";default:return e}}))}');`,S=k?`const ${b} = () => ({${$}});`:"",I=`if (${o}) $dd_entry(${o}, ${v}${x});`,D=`catch(e) { if (${o}) $dd_throw(${o}, e, ${v}${x}); throw e; }`;if(p){if(null!=g){const n=function(e,t,n){const o=[];for(let r=t;r<n;r++)"("===e[r]&&o.push(r);return o}(t,g,c),o=function(e,t,n){const o=[];for(let r=n-1;r>=t;r--)")"===e[r]&&o.push(r);return o}(t,d,l),r=Math.min(n.length,o.length);for(let t=0;t<r;t++){const r=n[t],i=o[t];e.remove(r,r+1),e.remove(i,i+1)}}const n=["{",E,S,"try {",I,m?`const ${w} = ($dd_t = `:`const ${w} = `].filter(Boolean).join("\n");let r=f?");":";";m&&(r=f?"));":");");const i=[r,`if (${o}) $dd_return(${o}, ${w}, ${v}${xr(b,k,a,d)});`,`return ${w};`,`} ${D}`,"}"].join("\n");if(d-c>=2){const o=f?`${n}(${t[c]}`:n+t[c];e.update(c,c+1,o),e.update(d-1,d,t[d-1]+i)}else e.update(c,d,n+t.slice(c,d)+i)}else{const r=[E,S,"try {",`let ${w};`,I].filter(Boolean).join("\n");for(const t of u){const n=xr(b,k,a,t.start);if(null!=t.argStart&&null!=t.argEnd){const r=t.hasSequenceExpressionArgument?`(${w} = (`:`(${w} = `,i=t.hasSequenceExpressionArgument?")":"";e.appendLeft(t.argStart,r),e.appendLeft(t.argEnd,`${i}, ${o} ? $dd_return(${o}, ${w}, ${v}${n}) : ${w})`)}else e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, ${v}${n}); `)}if(null!=y){const n=y-1;e.update(n,y,`${t[n]}\n${r}`)}else e.update(c,c+1,`${t[c]}${r}`);const i=xr(b,k,a,d),s=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, ${v}${i});\n`:""}} ${D}\n`;e.update(d-1,d,`${s}${t[d-1]}`)}}function yr(e,t,n){e.update(n.bodyStart,n.bodyStart+1,`${t[n.bodyStart]}let $dd_t;`);for(const t of n.superCalls)e.appendLeft(t.start,"($dd_t = "),e.appendLeft(t.end,")")}function br(e,t,n){$r(e,n)&&t.push({start:e.start,end:e.end});const o=Object.values(e);for(const e of o)if(Array.isArray(e))for(const o of e)wr(o,t,n);else wr(e,t,n)}function wr(e,t,n){n.isNode(e)&&(n.isFunction(e)&&!n.isArrowFunctionExpression(e)||br(e,t,n))}function vr(e){return`${e.start}:${e.end}`}function $r(e,t){return t.isCallExpression(e)&&t.isSuper(e.callee)}function kr(e,t){const n=e.parentPath?.parentPath;if(!n)return!1;const o=n.node;return(t.isClassDeclaration(o)||t.isClassExpression(o))&&null!=o.superClass}function xr(e,t,n,o){const r=function(e,t){const n=e.filter((({declarationEnd:e,temporalDeadZones:n})=>e<=t&&!function(e,t){return e.some((({start:e,end:n})=>e<=t&&t<n))}(n,t))).map((({name:e})=>e));if(0===n.length)return;return`{${n.join(", ")}}`}(n,o);return t&&r?`, ${e}(), ${r}`:t?`, ${e}()`:r?`, undefined, ${r}`:""}function Er(e,t,n){for(const o of e)if(n.isReturnStatement(o))t.push({start:o.start,end:o.end,argStart:o.argument?.start??void 0,argEnd:o.argument?.end??void 0,hasSequenceExpressionArgument:n.isSequenceExpression(o.argument)});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))Er(o.body,t,n);else if(n.isIfStatement(o))Er([o.consequent],t,n),o.alternate&&Er([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))Er([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)Er(e.consequent,t,n);else n.isTryStatement(o)?(Er(o.block.body,t,n),o.handler&&Er(o.handler.body.body,t,n),o.finalizer&&Er(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&Er([o.body],t,n)}function Sr(e,t){if(0===e.length)return!1;const n=e[e.length-1];if(t.isReturnStatement(n))return!0;if(t.isIfStatement(n)&&n.alternate){const e=t.isBlockStatement(n.consequent)?n.consequent.body:[n.consequent],o=t.isBlockStatement(n.alternate)?n.alternate.body:[n.alternate];return Sr(e,t)&&Sr(o,t)}return!1}const Ir=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Dr=t.bold.red,Ar=Number(process.env.DD_LD_LIMIT)||1/0,Pr=(e,t)=>{const n=t.getLogger(qo);let o=0,r=0,i=0,s=0,a=0,u=0,c=0,d=0;return{name:qo,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(l,p){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?p.includes(e):e.test(p))))return{code:l}}for(const t of e.exclude){if("string"==typeof t?p.includes(t):t.test(p))return{code:l}}if(d>=Ar)return{code:l};try{const f=hr({code:l,filePath:p,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,c+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&d++,0===f.instrumentedCount)return{code:l};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),h=f.map&&m?function(e,t,n,o){try{return k(e,((e,n)=>1===n.depth?t:null))}catch(t){return o.error(`Failed to compose source map for ${n}: ${t}`,{forward:!0}),e}}(f.map,m,p,n):f.map;return{code:f.code,map:h}}catch(e){return n.error(`Instrumentation Error in ${p}: ${e}`,{forward:!0}),{code:l}}}},buildEnd:()=>{c>0&&n.info(`Live Debugger: ${o}/${c} functions instrumented across ${u}/${d} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:d,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},jr=({options:e,context:t})=>{const n=((e,t)=>{const n=e[Bo]||{},o=e.metadata?.version,r=[];if(void 0!==n.include)if(Array.isArray(n.include)){for(const e of n.include)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Dr("include")} patterns must be strings or RegExp`);break}}else r.push(`${Dr("include")} must be an array of strings or RegExp`);if(void 0!==n.exclude)if(Array.isArray(n.exclude)){for(const e of n.exclude)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Dr("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Dr("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Dr("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Ir.includes(e)){r.push(`${Dr("functionTypes")} contains invalid value "${e}". Valid values: ${Ir.join(", ")}`);break}}else r.push(`${Dr("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Dr("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${qo}.`);return{version:o,include:n.include||[/\.[jt]sx?$/],exclude:n.exclude||[/\/node_modules\//,/\.min\.js$/,/\/pyodide-lib\//,/^vite\//,/\0/,/commonjsHelpers\.js$/,/__vite-browser-external/,/@datadog\/browser-/,/browser-sdk\/packages\//],honorSkipComments:n.honorSkipComments??!0,functionTypes:n.functionTypes,namedOnly:n.namedOnly??!1}})(e,t.getLogger(qo));return t.inject({type:"code",position:Ce.BEFORE,injectIntoAllChunks:!0,value:Ho(n.version)}),[Pr(n,t)]};const Mr=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/^sourcemaps\.upload\.(failure|retry)$/.test(e.metric)&&(t.count=0),/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],Cr="metrics",Tr="datadog-metrics-plugin",Or=e=>Math.floor((e||Date.now())/1e3),Nr=(e,t)=>{const n=[`bundler:${re(e.bundler.name)}`,`plugin_version:${re(e.version)}`,`site:${re(e.auth.site)}`];return e.build.metadata.name&&n.push(`build_name:${re(e.build.metadata.name)}`),e.build.metadata.version&&n.push(`build_version:${re(e.build.metadata.version)}`),[...n,...t]},Rr=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),_r=(e,t,n,o,r)=>{const i=new Set;for(const t of e){let e={...t,toSend:!0};if(n?.length)for(const t of n){const n=t({metric:e.metric,type:e.type,points:e.points,tags:e.tags});n?e={...n,toSend:e.toSend}:e.toSend=!1}i.add(Rr(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Rr({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i},Fr=(e="")=>e.endsWith("/")?e:`${e}/`,zr=(e,t)=>{let n=e;return e.split(Fr(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},Lr=(e,t)=>e.split("!").pop().replace(Fr(t),"./"),Ur=(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)),Lr(o||"no-name",n)},Br=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),qr=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Vr=t.bold.red,Kr=t.bold.cyan,Hr=e=>(t,n)=>{let o,r;return"function"==typeof e?(o=e(t),r=e(n)):(o=t[e],r=n[e]),o>r?-1:o<r?1:0},Wr=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Hr("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:te(e.duration)}))),top:!0};n.sort(Hr("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Jr=(e,t,n)=>{const o=[];var r;n&&(o.push(...Wr("Loader",n.loaders)),o.push(...Wr("Tapable",n.tapables)),o.push(...Wr("Module",n.modules))),o.push(...(e=>{const t={name:"Module total dependents",values:[],top:!0},n={name:"Module total dependencies",values:[],top:!0},o={name:"Module size",values:[],top:!0},r={name:"Module aggregated size",values:[],top:!0},i=new Set,s=X(e.build),a=new Map,u=new Map,c=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)c.has(n)||c.set(n,new Set),c.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(c.has(e.filepath)){const t=c.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),c.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=c.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const d=Array.from(i);return d.sort(Hr((e=>e.dependents.size))),t.values=d.map((e=>({name:e.name,value:e.dependents.size.toString()}))),d.sort(Hr((e=>e.dependencies.size))),n.values=d.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),d.sort(Hr("size")),o.values=d.map((e=>({name:e.name,value:v(e.size)}))),d.sort(Hr("aggregatedSize")),r.values=d.map((e=>({name:e.name,value:v(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(Hr((e=>e.size))).map((e=>({name:e.name,value:v(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Hr((e=>e.size))).map((e=>({name:e.name,value:v(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Hr((e=>e.size))).map((e=>({name:e.name,value:e.inputs.length.toString()})))||[],top:!0}])),o.push(...(e=>{const t={name:"General Numbers",values:[],top:!1},n=e.build.inputs?e.build.inputs.length:0,o=e.build.outputs?e.build.outputs.length:0,r=e.build.warnings.length,i=e.build.errors.length,s=e.build.entries?e.build.entries.length:0;return e.build.start&&t.values.push({name:"Overhead duration",value:te(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:te(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:te(e.build.writeDuration)}),t.values.push({name:"Number of modules",value:n.toString()},{name:"Number of assets",value:o.toString()},{name:"Number of entries",value:s.toString()},{name:"Number of warnings",value:r.toString()},{name:"Number of errors",value:i.toString()}),[t]})(e));const i=(e=>{let t="";for(const t of e){t.top&&t.values.length>=5&&(t.values=t.values.slice(0,5),t.name=`Top 5 ${t.name}`);for(const e of t.values)e.name=ne(e.name,60)}const n=Math.max(...e.map((e=>e.name.length))),o=Math.max(...e.flatMap((e=>e.values.map((e=>e.name.length))))),r=Math.max(...e.flatMap((e=>e.values.map((e=>e.value.length))))),i=Math.max(n+4,o+r+4);for(const n of e){if(0===n.values.length)continue;const e=i-(n.name.length+4);t+=`\n== ${n.name} ${"=".repeat(e)}=\n`;for(const e of n.values){const n=r-e.value.length;t+=` [${Vr(e.value)}] ${" ".repeat(n)}${Kr(e.name)}\n`}}return t})(o);t.info(i)},Gr="api/v1/series",Yr=t.bold.green,Qr=(e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.debug("No metrics to send.");const o=Array.from(e).filter((e=>e.toSend)).map((e=>({...e,toSend:void 0}))),r=new Map;for(const e of o)r.has(e.metric)||r.set(e.metric,0),r.set(e.metric,r.get(e.metric)+1);const i=Array.from(r.entries()).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>`${e} - ${t}`));return n.debug(`\nSending ${o.length} metrics with configuration:\n - intake: ${Yr(`https://api.${t.site}/${Gr}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),G({method:"POST",url:`https://api.${t.site}/${Gr}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))},Zr=["onStart","onLoad","onResolve","onEnd"],Xr=new Map,ei=new Map,ti=new Map,ni=(e,t,n)=>{const o=Object.assign({},e);for(const r of Zr)o[r]=async(o,i)=>{const s=ei.get(t)||{name:t,increment:0,duration:0,events:{}};s.events[r]=s.events[r]||{name:r,values:[]};const a="onLoad"===r;return(0,e[r])(o,(async(...e)=>{const o=Lr(e[0].path,n),u=ti.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=x.now();try{return await i(...e)}finally{const n=x.now(),i=n-c,d={start:c,end:n,duration:i,context:qr(e)};if(s.events[r].values.push(d),s.duration+=i,s.increment+=1,ei.set(t,s),u.events[r].values.push(d),u.duration+=i,u.increment+=1,ti.set(o,u),a){const e=Xr.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(d),e.duration+=i,e.increment+=1,Xr.set(t,e)}}}))};return o},oi=(e,t)=>({setup:n=>{n.initialOptions.metafile=!0;const o=t.time("wrapping plugins");((e,t)=>{const n=e.initialOptions.plugins;if(n){const e=n.map((e=>({...e})));for(const o of n){const n=o.setup;o.setup=async r=>{const i=ni(r,o.name,t);await n({...i,initialOptions:{...i.initialOptions,plugins:e}})}}}})(n,e.buildRoot),o.end(),n.onEnd((async n=>{if(!n.metafile)return void t.warn("Missing metafile, can't proceed with modules data.");const o=t.time("getting plugins results"),{plugins:r,loaders:i,modules:s}={plugins:ei,modules:ti,loaders:Xr};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class ri{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Ur(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Br))(e);o.length||o.push("no-loader"),this.started[n]={module:zr(n),timings:{start:x.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Ur(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=x.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},i=n.loaders.join(",");r.events[i]=r.events[i]||{name:i,values:[]},r.events[i].values.push(n.timings),r.increment+=1,r.duration+=o,t.set(n.module,r);for(const t of n.loaders){const n=e.get(t)||{name:t,increment:0,duration:0,events:{}};n.increment+=1,n.duration+=o,e.set(t,n)}}return{loaders:e,modules:t}}}class ii{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,r,i){const s=this.timings.get(t)||{name:t,duration:0,increment:0,events:{}};s.events[n]||(s.events[n]={name:n,values:[]}),s.events[n].values.push({start:r,end:i,duration:i-r,context:o,type:e}),s.duration+=i-r,s.increment+=1,this.timings.set(t,s)}getResults(){const e=this.timings;for(const[t,n]of this.timings){const o=n;o.duration=Object.values(n.events).map((e=>e.values.reduce(((e,t)=>e+t.end-t.start),0))).reduce(((e,t)=>e+t),0),e.set(t,o)}return{monitoredTaps:this.monitoredTaps,tapables:this.tapables,hooks:this.hooks,timings:e}}getPromiseTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=x.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,qr(r),i,x.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=x.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,qr(r),i,x.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=x.now(),s=t.apply(this,r);return this.saveResult(e,n,o,qr(r),i,x.now()),s}}getTapPatch(e,t,n,o){switch(e){case"promise":return this.getPromiseTapPatch(e,t,n,o);case"async":return this.getAsyncTapPatch(e,t,n,o);default:return this.getDefaultTapPatch(e,t,n,o)}}newTap(e,t,n,o){return(r,i)=>{const s="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${s}`;if(this.monitoredTaps[u])return n.call(o,r,i);this.monitoredTaps[u]=!0;const c=this.getTapPatch(e,i,s,t);return n.call(o,r,c)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(Tr)||(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 si=e=>async t=>{const n=e.getLogger(Tr),o={name:Tr},r=new ii(e.buildRoot),i=new ri(e.buildRoot),s=n.time("parse compiler hooks");r.throughHooks(t),s.end(),t.hooks.thisCompilation.tap(o,(e=>{const t=n.time("parse compilation hooks");r.throughHooks(e),t.end(),e.hooks.buildModule.tap(o,(t=>{i.startModule(t,e)})),e.hooks.succeedModule.tap(o,(t=>{i.doneModule(t,e)})),e.hooks.failedModule&&e.hooks.failedModule.tap(o,(t=>{i.doneModule(t,e)}))})),t.hooks.afterEmit.tapPromise(o,(async()=>{const{timings:t}=r.getResults(),{loaders:n,modules:o}=i.getResults();await e.asyncHook("timings",{tapables:t,loaders:n,modules:o})}))},ai={filters:Mr},ui=({options:e,context:t,stores:n})=>{const o=t.getLogger(Tr);let r=0;((e,t)=>{e.addMetric=e=>{t.metrics.add(e)}})(t,n);const i=((e,t)=>{const n=e[Cr],o=Or(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enableDefaultPrefix:!0,enableTracing:!1,filters:Mr,tags:[],...e[Cr],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[],a={name:Tr,enforce:"pre",esbuild:oi(t,o),webpack:si(t),rspack:si(t)},u=o.time("build",{start:!1}),c=i.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,l;const p=async()=>{if(!n.metrics.size)return;const e=o.time("aggregating collected metrics"),r=(()=>{const e=new Set(n.metrics);n.metrics.clear();const o=Nr(t,i.tags);return _r(e,i.timestamp,i.filters,o,i.prefix)})();await t.asyncHook("metrics",r),e.end();const s=o.time("sending collected metrics to Datadog");await Qr(r,{apiKey:t.auth.apiKey,site:t.auth.site},o),s.end()},f=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-r;const e=o.time("aggregating metrics"),n=i.timestamp,s=o.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,c=new Map,d=new Map,l=new Map;for(const e of i){for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");l.has(n)||l.set(n,[]),l.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`entryName:${e}`))),d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");l.has(r)&&o.push(...l.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of i){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(l,n);s.end();const u=o.time("aggregate plugins metrics"),c=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"plugins.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values()){let e=0,r=0;for(const i of Object.values(o.events)){let s=0;r+=i.values.length;for(const t of i.values){const n=t.end-t.start;s+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,s]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,i.values.length]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(d?.tapables,n);u.end();const p=o.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(d?.loaders,n);p.end();const m=new Set([...a,...c,...f]),h=Nr(t,i.tags),g=_r(m,n,i.filters,h,i.prefix);await t.asyncHook("metrics",g),e.end();const y=o.time("outputing report");Jr(t,o,d),y.end();const b=o.time("sending metrics to Datadog");await Qr(g,{apiKey:t.auth.apiKey,site:t.auth.site},o),b.end()},m={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){u.resume(),t.build.start=t.build.start||Date.now(),e[Cr]?.timestamp||(i.timestamp=Or(t.build.start))},buildEnd(){u.end(),r=Date.now()},async timings(e){d=e,l&&await f()},async buildReport(e){l=e,!d&&c||await f()},async flush(){await p()}};return i.enableTracing&&s.push(a),s.push(m),s},ci="output",di="datadog-output-plugin",li=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,pi=e=>{const t=void 0===e;return{build:li("build",e?.build??t),bundler:li("bundler",e?.bundler??t),dependencies:li("dependencies",e?.dependencies??t),errors:li("errors",e?.errors??t),logs:li("logs",e?.logs??t),metrics:li("metrics",e?.metrics??t),timings:li("timings",e?.timings??t),warnings:li("warnings",e?.warnings??t)}},fi=(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}))}))},mi=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},hi=({options:e,context:t})=>{const n=t.getLogger(di),o=(e=>({path:"./",...e[ci],files:pi(e[ci]?.files)}))(e),r=(e,r)=>{const i=o.files[e];if(!r||!1===i)return;t.queue((async()=>{const e=n.time(`output ${i}`),c=((e,t,n)=>{const o=u.isAbsolute(t)?t:u.resolve(e,t);return u.resolve(o,n)})(t.bundler.outDir,o.path,i);let d;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await Ie(u.dirname(e));const n=s.createWriteStream(e),o=new a(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(c,e)}catch(e){d=e}d?n.error(`Failed writing ${i}: ${d}`):n.debug(`Wrote "./${u.relative(t.buildRoot,c)}"`),e.end()})())};return[{name:di,buildReport(e){const t=n.time("serialize report"),o=X(e);t.end(),r("build",{bundler:o.bundler,metadata:o.metadata,start:o.start,end:o.end,duration:o.duration,writeDuration:o.writeDuration,entries:o.entries,outputs:o.outputs}),r("logs",o.logs),r("timings",o.timings),r("dependencies",o.inputs),r("errors",o.errors),r("warnings",o.warnings)},metrics(e){r("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{r("bundler",e.metafile)}))}},rspack:fi(n,(e=>{r("bundler",e)})),rollup:mi((e=>{r("bundler",e)})),vite:mi((e=>{r("bundler",e)})),webpack:fi(n,(e=>{r("bundler",e)}))}]},gi="rum",yi="datadog-rum-plugin",bi=e=>`(function(c,n){try{if(typeof window==='undefined')return;var w=window,m=w[n]=w[n]||{},s=new Error().stack;s&&(m[s]=c)}catch(e){}})(${JSON.stringify(e)},${JSON.stringify("DD_SOURCE_CODE_CONTEXT")});`,wi="datadog-rum-privacy-plugin";const vi=(e,t)=>{const n=t.getLogger(wi),o=function(e,t){const n={privacy:{addToDictionaryHelper:{expression:{code:e}}}};return["esbuild","webpack","rspack"].includes(t)&&(n.output={...n.output,inlineSourceMap:!1,embedCodeInSourceMap:!0}),n}(e.helperCodeExpression,t.bundler.name);let r=0,i=0;return{name:wi,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(e,t){try{const n=function(e){if("rspack"===e?.framework||"webpack"===e?.framework)switch(typeof e.inputSourceMap){case"undefined":return;case"string":return e.inputSourceMap;default:return JSON.stringify(e.inputSourceMap)}}(this.getNativeBuildContext?.()),s=E({id:t,code:e,map:n},o);return 0===s.privacyDictionarySize?{code:e}:(r+=s.privacyDictionarySize,i++,s)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${r} entries across ${i} files`,{forward:!0,context:{dictionaryEntryCount:r,fileCount:i}})}}},$i=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,ki=(e,t)=>{const n=e.sdk;if(n.clientToken)return $i(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 G({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 $i({...e,sdk:{clientToken:o,...n}})}},xi=e=>{const n=t.bold.red,o=e[gi]||{},r={errors:[]};if(!o.sdk)return r;o.sdk.applicationId||r.errors.push(`Missing ${n("applicationId")} in the SDK configuration.`),e.auth.apiKey&&e.auth.appKey||o.sdk.clientToken||r.errors.push(`Missing ${n('"auth.apiKey"')} and/or ${n('"auth.appKey"')} to fetch missing client token.`);const i={applicationId:"unknown_application_id",allowUntrustedEvents:!1,compressIntakeRequests:!1,defaultPrivacyLevel:"mask",enablePrivacyForActionName:!1,sessionReplaySampleRate:0,sessionSampleRate:100,silentMultipleInit:!1,site:e.auth.site||"datadoghq.com",startSessionReplayRecordingManually:!1,storeContextsAcrossPages:!1,telemetrySampleRate:20,traceSampleRate:100,trackingConsent:"granted",trackLongTasks:!1,trackResources:!1,trackUserInteractions:!1,trackViewsManually:!1};return r.config={...i,...o.sdk},r},Ei=e=>{const t=e[gi]||{},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},Si=e=>{const n=t.bold.red,o=e[gi]||{},r={errors:[]};if(!o.sourceCodeContext)return r;const i=o.sourceCodeContext;return i?.service&&"string"==typeof i.service||r.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),r.config={...i,version:i.version||e.metadata?.version},r},Ii=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=xi(e),r=Ei(e),i=Si(e);if(n.push(...o.errors),n.push(...r.errors),n.push(...i.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${yi}.`);const s={...e[gi],sdk:void 0,privacy:void 0,sourceCodeContext:void 0};return o.config&&(s.sdk=o.config),r.config&&(s.privacy=r.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(s.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),i.config&&(s.sourceCodeContext=i.config),s})(e,t.getLogger(yi)),o=[];if(n.sourceCodeContext&&t.inject({type:"code",position:Ce.BEFORE,injectIntoAllChunks:!0,value:bi(n.sourceCodeContext)}),n.sdk&&(t.inject({type:"file",position:Ce.MIDDLE,value:u.join(M,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Ce.MIDDLE,value:ki(n,t)})),n.privacy){t.inject({type:"file",position:Ce.BEFORE,value:u.join(M,"./privacy-helpers.js")});const e=vi(n.privacy,t);o.push(e)}return o},Di="datadog-analytics-plugin",Ai=({context:e})=>{const t=e.getLogger(Di);return[{name:Di,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}`)}})())}}]},Pi="datadog-async-queue-plugin",ji=e=>{const{context:t,stores:n}=e,o=t.getLogger(Pi),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:Pi,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Mi=async(e,t,n)=>{const o=[],r=e.initialOptions.entryPoints,i=[],s=[];if(Array.isArray(r))for(const e of r){const t=e&&"object"==typeof e?e.in:e;i.push({path:t})}else r&&"object"==typeof r&&i.push(...Object.entries(r).map((([e,t])=>({name:e,path:t}))));const a=i.flatMap((e=>{return(t=e.path,t.includes("*")?w.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const i=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});i.errors.length&&s.push(...i.errors.map((e=>e.text))),i.path&&o.push({name:n.name,resolved:i.path,original:n.path})}));for(const e of s)n.error(e);return await Promise.all(a),o},Ci=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Ti=/(\?|%3F|\|)+/gi,Oi=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=_i(e),Ci.lastIndex=0,Ci.exec(t)?.[1]||"unknown");var t},Ni=["unknown","commonjsHelpers.js",`vite${u.sep}preload-helper.js`],Ri=(e,t,n)=>{const o=new Set;for(const n of e){const e=_i(n);Z(n)||e===t||Ni.includes(e)||o.add(e)}return o},_i=e=>e.split("!").pop().split(Ti).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),Fi=(e,t)=>Z(t)?T:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(u.sep),o=e.split(u.sep).filter(((e,t)=>e===n[t])).join(u.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(Ti).shift().replace(/^((\.\.?)?[/\\])+/g,""),zi=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[Zn(t,e),n]))),Li=(e,t)=>({setup(n){const o=new Map;let r=[];const i=t.time("build report",{start:!1});n.onStart((async()=>{o.clear(),r=[],i.resume();const s=t.time("process entries");r.push(...await Mi(n,e,t));for(const t of r){const n=Fi(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}s.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),s=e.bundler.outDir,a=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const c=[],d=[],l=[],p=[],f=[],m={},h={},g=t.time("indexing metafile data"),y=zi(n.metafile.inputs,a),b=zi(n.metafile.outputs,a);g.end();const w=e=>{if(!Z(e))return e;const t=y[Zn(a,e)];if(!t)return e;const n=t.imports.find((e=>!Z(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(Z(e))continue;const n=Zn(a,e),o={name:Fi(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Oi(e)};m[n]=o,c.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=Zn(a,e),i=Fi(s,n),u=[];for(const e of Object.keys(r.inputs)){if(Z(e))continue;const n=m[Zn(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!u.length){const e=m[Zn(a,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}u.push(e)}const c={name:i,filepath:n,inputs:u,size:r.bytes,type:Oi(n)};if(h[n]=c,"map"===c.type&&p.push(c),d.push(c),!r.entryPoint)continue;const f=m[Zn(a,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...c,name:o.get(f.name)||f.name,outputs:[c],size:c.size};l.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of p){const n=h[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:h,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!Z(e)&&!e.match(E),I=(e,n,o={})=>{if(!S(e))return o;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),o;if(o[r.filepath])return o;o[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),o;if(!i.imports||!i.imports.length)return o;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),d=i?u.dirname(e):a,l=Zn(d,t.path);if(t.external){if(S(t.path)){const e=i?l:t.path,n=x.inputs.report[e]||{filepath:e,name:Fi(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),c.includes(n)||c.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(l,n,o)}return o},D=t.time("looping through entries");for(const e of l){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const A=t.time("aggregate dependencies and dependents");for(const e of c){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?u.dirname(e.filepath):a,i=Zn(r,o.path);let s;if(o.external){const e=n?i:o.path;s=x.inputs.report[e]}else s=x.inputs.report[i];s?(e.dependencies.add(s),s.dependents.add(e)):t.debug(`Could not find input file of ${o.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}A.end(),e.build.outputs=d,e.build.inputs=c,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),Ui=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),i=t.time("filling inputs and outputs",{start:!1}),a=t.time("completing dependencies and dependents",{start:!1}),u=t.time("filling dependencies and dependents",{start:!1}),c=t.time("filling sourcemaps inputs",{start:!1}),d=new Map,l=new Map,p=new Map,f=new Map;return{buildStart(){f.clear(),d.clear(),l.clear(),p.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=_i(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=Ri(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=Ri(new Set([...e.dynamicImporters,...e.importers]),t);for(const e of i)o.dependents.add(e);for(const e of r)o.dependencies.add(e);f.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,m){o.resume();const h=n.dir?Zn(e.buildRoot,n.dir):e.bundler.outDir,g=new Set,y=new Set,b=new Map;a.resume();for(const[e,{dependencies:t,dependents:n}]of f){for(const n of t){const t=_i(n),o=f.get(t)||{dependencies:new Set,dependents:new Set};o.dependents.has(e)||(o.dependents.add(e),f.set(t,o))}for(const t of n){const n=_i(t),o=f.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),f.set(n,o))}}a.end(),i.resume();for(const[e,n]of Object.entries(m)){const o=Zn(h,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),i=l.get(o)||{name:e,filepath:o,inputs:[],size:r,type:Oi(e)};if("map"===i.type&&y.add(i),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(_i(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=s.statSync(e).size}catch(e){n=t.renderedLength}const o=d.get(e)||{name:Fi(h,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Oi(e)};i.inputs.push(o),d.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=_i(e);if(!f.has(n)){b.set(Zn(h,n),i);continue}if(d.has(n)){t.debug(`Input report already there for ${n} from ${i.name}.`);continue}const o=d.get(n)||{name:Fi(h,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};i.inputs.push(o),d.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...i,name:n.name,size:0,outputs:[i]}),l.set(i.filepath,i)}i.end();for(const[e,n]of b){const o=l.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of d){const o=f.get(e);if(o){for(const e of o.dependencies){const o=d.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${Fi(h,e)} of ${n.name}`)}for(const e of o.dependents){const o=d.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${Fi(h,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){c.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=l.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}c.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=Fi(h,e),r=l.get(e);if(!r)return d.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[Fi(h,e)];if(!i)return t.debug(`Could not find asset for ${o}`),n;const s=[];"imports"in i&&s.push(...i.imports),"dynamicImports"in i&&s.push(...i.dynamicImports);for(const e of s)w(Zn(h,e),n);return n};r.resume();for(const e of g){const n=w(e.filepath);e.outputs=Array.from(n.values()),e.inputs=Array.from(new Set(e.outputs.flatMap((e=>e.inputs)))),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),p.has(e.filepath)&&t.debug(`Entry "${e.name}":"${Fi(h,e.filepath)}" already reported.`),p.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(d.values()),e.build.outputs=Array.from(l.values()),e.build.entries=Array.from(p.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},Bi=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,c=new Map,d=new Map,l=[],p=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||Z(e)),h=e=>e.replace(/(^external[^"]+"|"$)/g,""),g=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=_i(e);t.add(n),n.startsWith("external ")&&t.add(h(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(d.has(e)){const n=d.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else d.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=_i(t.request);if(d.has(n))return d.get(n);if(e.context){const t=Zn(_i(e.context),n);if(d.has(t))return d.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],i=[],s=[],a.clear(),u.clear(),d.clear(),p.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),i=n.time("indexing modules");for(const e of t)g(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=Fi(e.bundler.outDir,t),i=new Set(y(n).map((e=>{const o=b(n,e);if(!o?.identifier())return!1;const r=o.identifier();return!!m(r)&&(r!==t&&(w(o)?h(r):r))})).filter(Boolean));if(!m(t))continue;const s=p.get(t)||{dependents:new Set,dependencies:new Set};for(const e of i){const n=p.get(e)||{dependencies:new Set,dependents:new Set};n.dependents.add(t),s.dependencies.add(e),p.set(e,n)}p.set(t,s);const u=w(n)?{size:0,name:h(o),dependencies:new Set,dependents:new Set,filepath:t,type:"external"}:{size:n.size()||0,name:o,dependencies:new Set,dependents:new Set,filepath:t,type:Oi(t)};r.push(u),a.set(t,u),w(n)&&a.set(h(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=p.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,d=t.getAssets(),p=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>Zn(e.bundler.outDir,t))),h=n.time("indexing chunks"),g=t.chunkGraph;for(const e of o){const t=p(e),n=(g?.getChunkModules(e)||[]).flatMap((e=>"modules"in e&&Array.isArray(e.modules)?e.modules.map((e=>e.identifier())):e.identifier())).filter(m);for(const e of t){if("map"===Oi(e))continue;const t=c.get(e)||new Set;for(const e of n)t.add(e);c.set(e,t)}}h.end();const y=n.time("building outputs");for(const t of d){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:Zn(e.bundler.outDir,t.name),type:Oi(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){l.push(o);continue}const r=c.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of l){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return new Set;t.add(e);const n=new Set(e.chunks);for(const o of e.childrenIterable||[]){const e=v(o,t);for(const t of e)n.add(t)}return n};for(const[o,r]of t.entrypoints){const t=new Map,i=new Map;let a=0;const c=v(r),d=Array.from(c).flatMap(p),l=r.chunks.filter((e=>g.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===Oi(e)));for(const e of d){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)i.has(e.filepath)||i.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:l?Zn(e.bundler.outDir,l):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:l?Oi(l):"unknown"};s.push(f)}w.end();for(const n of t.errors)e.build.errors.push(n.message);for(const n of t.warnings)e.build.warnings.push(n.message);e.build.inputs=r,e.build.outputs=i,e.build.entries=s,f.end(),await e.asyncHook("buildReport",e.build)}))},qi="datadog-build-report-plugin",Vi=e=>{const{context:t}=e,n=t.getLogger(qi);return[{name:qi,enforce:"post",esbuild:Li(t,n),rspack:Bi(t,qi,n),webpack:Bi(t,qi,n),vite:Ui(t,n),rollup:Ui(t,n)}]},Ki="datadog-bundler-report-plugin",Hi=(e,t)=>t?u.isAbsolute(t)?t:u.resolve(e,t):"",Wi=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?u.dirname(e.file):void 0)).filter(Boolean)},Ji=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Hi(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Gi=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Wi(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=eo(r,process.cwd())),e.bundler.outDir=Hi(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Yi=e=>{const{context:t}=e,n=t.getLogger(Ki);return[{name:Ki,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Hi(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Hi(t.buildRoot,u.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Ji(t),rspack:Ji(t),vite:Gi(t),rollup:{options(e){let n;if("output"in e){const t=Wi(e.output);n=eo(t,process.cwd())}const o=(e=>{const t=new Set;if(e.input){const n=Array.isArray(e.input)?e.input:"object"==typeof e.input?Object.values(e.input):[e.input];for(const e of n){if("string"!=typeof e)throw new Error("Invalid input type");t.add(u.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=Zn(process.cwd(),n);const e=eo([n,...o],process.cwd());t.buildRoot=e===u.sep?process.cwd():e}else t.buildRoot=eo(o,process.cwd()),t.bundler.outDir=u.resolve(process.cwd(),"dist");t.hook("buildRoot",t.buildRoot)},buildStart(e){t.bundler.rawConfig=e},renderStart(e){t.bundler.rawConfig.outputs=t.bundler.rawConfig.outputs||[],t.bundler.rawConfig.outputs.push(e),t.hook("bundlerReport",t.bundler);const o=Wi(e);eo(o,process.cwd()).startsWith(t.bundler.outDir)||n.warn("The output directory has been changed by a plugin and may introduce some inconsistencies in the build report.")}}}]},Qi="datadog-custom-hooks-plugin",Zi=e=>{const{context:t}=e,n=t.getLogger(Qi),o=e=>(o,...r)=>{const i=n.time(`execution | ${o}`,{tags:["type:custom-hook",`hook:${o}`]}),s=[],a=[];for(const n of t.plugins){if(!(o in n))continue;const t=n[o];if("function"==typeof t)try{const i=t(...r);i instanceof Promise&&(e||s.push(`Plugin "${n.name}" returned a promise on the non async hook "${o}".`),a.push(i))}catch(e){s.push(`Plugin "${n.name}" errored on hook "${o}". [${e}]`)}else s.push(`Plugin "${n.name}" has an invalid hook type for "${o}". [${typeof t}]`)}if(s.length>0){for(const e of s)n.error(e);throw new Error("Some plugins errored during the hook execution.")}return Promise.all(a).finally((()=>i.end()))};return t.hook=o(!1),t.asyncHook=o(!0),[{name:Qi,enforce:"pre"}]};class Xi{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=Ae(e),o=JSON.parse(n);if(!o.sources)return void t("Missing 'sources' field in sourcemap.");const r=o.sources;if(0===r.length)return void t("Empty 'sources' field in sourcemap.");const i=this.matchSources(r);if(0!==i.length)return i;t(`${r.map(this.displaySource).join(", ")} not in the tracked files.`)}matchSources(e){let t=[];const n=new Set;for(const o of e){const e=this.getFilename(o);if(n.has(e))continue;n.add(e);const r=this.trackedFilenames.get(e);r&&(t=t.concat(r))}return t}rawTrackedFilesList(){let e=[];return this.trackedFilenames.forEach((t=>{e=e.concat(t)})),e}getFilename(e){let t=e.lastIndexOf("/");-1===t?t=0:t++;let n=e.lastIndexOf("?");return(-1===n||n<=t)&&(n=e.length),e.substring(t,n)}}const es=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await ts(e);for(const e of t)if(e.name===n)return oe(e.refs.push);return oe(t[0].refs.push)},ts=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},ns=async e=>e.revparse("HEAD"),os=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),rs=async e=>e.branch(),is=async e=>e.show(["-s","--format=%s"]),ss=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),as="datadog-git-plugin",us=e=>{const{options:t,context:n}=e,o=n.getLogger(as),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=S(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return S(t)})(u.dirname(e));if(0===(await t.getRemotes(!0)).length)return o.warn("No git remotes available, skipping git plugin. This is expected for a repository that has not been pushed yet."),void r.end();const i=await(async e=>{const t=[ns(e),rs(e),is(e),ss(e),os(e),es(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,c,d,l,p,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:c,date:d},committer:{name:l,email:p,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new Xi(s)}})(t);n.git=i,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:as,enforce:"pre",buildRoot(e){if(ee(t))try{r.resume();const t=Xn(e,".git");if(!t)return o.warn("No .git directory found, skipping git plugin."),void r.end();n.queue(i(t))}catch(e){o.error(`Could not get git information: ${e.message}`)}}}]},cs="datadog-injection-plugin",ds=/^https?:\/\//,ls=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],ps=t.bold.yellow,fs=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(Zn(t,e)),ms=async(e,t,n=process.cwd())=>{let o;const r=await(async e=>"function"==typeof e.value?e.value():e.value)(e);try{if("file"===e.type)o=r.match(ds)?await(async(e,t=5e3)=>{let n;return Promise.race([G({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(r):await fs(r,n);else{if("code"!==e.type)throw new Error(`Invalid item type "${e.type}", only accepts "code" or "file".`);o=r}}catch(i){const s=`${e.type} - ${ne(r)}`;e.fallback?(t.debug(`Fallback for "${s}": ${i.toString()}`),o=await ms(e.fallback,t,n)):t.warn(`Failed "${s}": ${i.toString()}`)}return o},hs=(e,t)=>{const n=e.filter((e=>e.position===t.position&&(!t.onAllChunks||e.injectIntoAllChunks)));if(0===n.length)return"";return`// begin injection by Datadog build plugins\n${n.map((e=>`(() => {${e.value}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},gs=async(e,t,n,o=process.cwd())=>{const r=await(async(e,t,n=process.cwd())=>{const o=new Map;for(const[r,i]of e.entries()){const e=await ms(i,t,n);if(e){const t=i.position||Ce.BEFORE;o.set(r,{value:e,injectIntoAllChunks:"injectIntoAllChunks"in i&&i.injectIntoAllChunks,position:t})}}return o})(t,e,o);for(const e of r.values())n.push(e)},ys=e=>e instanceof Error&&"code"in e,bs=e=>ls.includes(e),ws=(e,t,n)=>{e.warn(`"${ps(t)}" files are not supported (${ps(n)}).`)},vs=s.promises,$s=(e,t,n)=>({setup(o){const{onStart:i,onResolve:a,onLoad:c,onEnd:d,esbuild:l,initialOptions:p}=o,f=[],m=`${t.bundler.name}.${Ce.MIDDLE}.${T}.js`,g=s.realpathSync(h.tmpdir()),y=u.resolve(g,m),b=new RegExp(`${m}$`),w=p.inject;p.inject=w?[...w]:[],p.inject.push(y),i((async()=>{f.push(...await Mi(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await Ie(u.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),a({filter:b},(async e=>({path:e.path,namespace:cs}))),c({filter:b,namespace:cs},(async()=>({contents:hs(n,{position:Ce.MIDDLE})||" ",resolveDir:t.buildRoot,loader:"js"}))),d((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");const r=hs(n,{position:Ce.BEFORE}),i=hs(n,{position:Ce.AFTER}),s=hs(n,{position:Ce.BEFORE,onAllChunks:!0}),a=hs(n,{position:Ce.AFTER,onAllChunks:!0});if(!(r||i||s||a))return;const c=[];for(const[n,d]of Object.entries(o.metafile.outputs)){const o=d.entryPoint&&f.some((e=>e.resolved.endsWith(d.entryPoint))),p=o?r:s,m=o?i:a;if(!p&&!m)continue;const h=Zn(t.buildRoot,n),{base:g,ext:y}=u.parse(h);bs(y)?c.push((async()=>{try{const e=await vs.readFile(h,"utf-8"),t=await l.transform(e,{loader:"default",banner:p,footer:m});await vs.writeFile(h,t.code)}catch(t){if(!ys(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${h}: ${t}`)}})()):ws(e,y,g)}await Promise.all(c)}))}}),ks=T,xs="?inject-proxy",Es=(e,t)=>({banner(n){const o=hs(t,{position:Ce.BEFORE,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return bs(i)?o:(ws(e,i,r),"")},async resolveId(e,n,o){if(Z(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&hs(t,{position:Ce.MIDDLE})){if(e.endsWith(".html"))return null;const t=await this.resolve(e,n,o);if(!t||t.external)return t;return(await this.load(t)).moduleSideEffects=!0,`${t.id}${xs}`}return null},load(e){if(Z(e))return hs(t,{position:Ce.MIDDLE});if(e.endsWith(xs)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(ks)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null},footer(n){const o=hs(t,{position:Ce.AFTER,onAllChunks:!n.isEntry});if(""===o||!n.fileName)return"";const{base:r,ext:i}=u.parse(n.fileName);return bs(i)?o:(ws(e,i,r),"")}}),Ss=(e,t,n,o,r)=>i=>{const a=new WeakMap,c=e.sources.ConcatSource,d=n.bundler.name,l=u.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${d}.${Ce.MIDDLE}.${T}.js`);De(l,"");i.hooks.shutdown.tap(cs,(()=>{var e;e=l,s.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const p=async()=>{await gs(t,o,r,n.buildRoot)};i.hooks.beforeRun.tapPromise(cs,p),i.hooks.watchRun.tapPromise(cs,p),i.hooks.compilation.tap(cs,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:cs,stage:o},(()=>{const e=hs(r,{position:Ce.BEFORE}),o=hs(r,{position:Ce.AFTER}),i=hs(r,{position:Ce.BEFORE,onAllChunks:!0}),s=hs(r,{position:Ce.AFTER,onAllChunks:!0});for(const r of n.chunks){let d=e,l=o;if(r.canBeInitial()||(d=i,l=s),""!==d||""!==l)for(const e of r.files){const{base:o,ext:r}=u.parse(e);bs(r)?n.updateAsset(e,(e=>{const t=a.get(e);if(!t||t.banner!==d||t.footer!==l){const t=new c(d,"\n",e,"\n",l);return a.set(e,{source:t,banner:d,footer:l}),t}return t.source})):ws(t,r,o)}}}))}));const f=(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}})(i.options.entry);i.options.entry=f},Is=e=>{const{bundler:t,context:n}=e,o=n.getLogger(cs),r=new Map,i=[];n.inject=e=>{r.set(`${Date.now()}.${performance.now()}.${++se}`,e)};const s={name:cs,enforce:"post",esbuild:$s(o,n,i),webpack:Ss(t,o,n,r,i),rspack:Ss(t,o,n,r,i),rollup:Es(o,i),vite:{...Es(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>hs(i,{position:Ce.MIDDLE})?[{tag:"script",attrs:{type:"module",src:"/@id/__datadog-helper-file"},injectTo:"head-prepend"}]:[]}}};var a;return a=n.bundler.name,["rspack","webpack"].includes(a)?s.load={filter:{id:O},handler:()=>({code:hs(i,{position:Ce.MIDDLE})})}:s.buildStart=async()=>{await gs(o,r,i,n.buildRoot)},[s]},Ds="datadog-true-end-plugin",As=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=async()=>{await t.asyncHook("flush")},r=()=>{t.hook("syncTrueEnd")},i=async()=>{r(),await n(),await o()},s=e=>{e.hooks.shutdown.tapPromise(Ds,i)},a={async writeBundle(){},async closeBundle(){await i()}};return[{name:Ds,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n(),await o()})),e.onDispose((()=>{r()}))}},vite:a,rollup:a,rspack:s}]},Ps={[Cr]:ai},js=t.bold.red;var Ms="3.2.2";const Cs=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,r)=>{const i=Date.now(),s=((e={})=>{const t=(e=>{const t=[];return void 0===e||void 0!==e.version&&"string"!=typeof e.version&&t.push("metadata.version must be a string"),t})(e.metadata),n=B("SITE"),o={site:V(n,"DATADOG_SITE/DD_SITE",t)??V(e.auth?.site,"auth.site",t)??_};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:B("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:B("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=F);const a=process.env.BUILD_PLUGINS_ENV||"production",u=N.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,d=r.framework,l={bundler:{name:d,version:c},env:u,metadata:s.metadata||{},packageName:`@datadog/${d}-plugin`,version:n},p={errors:[],logs:[],metrics:new Set,queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{addMetric:()=>{throw new Error("AddMetric function called before it was initialized.")},auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:le(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:Y(n),start:e,version:n.version}})({start:o,options:s,data:l,stores:p}),m=f.getLogger("factory"),h=m.time("Plugins initialization",{start:i});f.pluginNames.push(F);const g=[];g.push(["analytics",Ai],["async-queue",ji],["build-report",Vi],["bundler-report",Yi],["custom-hooks",Zi],["git",us],["injection",Is],["true-end",As]),s.customPlugins&&g.push(["custom",s.customPlugins]);const y=[["apps",ye,vo],["error-tracking",$o,Uo],["live-debugger",Bo,jr],["metrics",Cr,ui],["output",ci,hi],["rum",gi,Ii]];for(const[e,t,n]of y)ge(s,t,m)&&g.push([e,n]);for(const[e,n]of g)f.plugins.push(...me(f,n,e)({bundler:t,context:f,options:s,data:l,stores:p}));return(e=>{const t=[];for(const n of U){const o=q(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>L(e))).join(" and "),i=L(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>z(e))).join(" and ");t.push(`${e} (same value)`)}}t.length&&e.info(`Overrides from environment:\n - ${t.join("\n - ")}`)})(m),f.pluginNames.push(...f.plugins.map((e=>e.name))),(e=>{const t=new Set(e.filter((t=>e.filter((e=>e===t)).length>1)));if(t.size>0)throw new Error(`Duplicate plugin names: ${js(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),h.end(),f.plugins}))})({bundler:I,version:Ms}).esbuild,Ts=Ms,Os=Ps;export{Cs as datadogEsbuildPlugin,Os as helpers,Ts as version};
1
+ import{createUnplugin as e}from"unplugin";import t from"chalk";import n from"async-retry";import{File as o}from"buffer";import r,{mkdtemp as i}from"fs/promises";import s from"fs";import{JsonStreamStringify as a}from"json-stream-stringify";import u from"path";import{Readable as c}from"stream";import{spawn as d}from"child_process";import{randomBytes as l,createHash as p,randomUUID as f}from"crypto";import m from"http";import h,{tmpdir as g}from"os";import*as y from"eslint-scope";import b from"jszip";import{glob as w}from"glob";import v from"pretty-bytes";import $ from"p-queue";import k from"@jridgewell/remapping";import{performance as x}from"perf_hooks";import{instrument as E}from"@datadog/js-instrumentation-wasm";import{simpleGit as S}from"simple-git";import I from"magic-string";import D from"esbuild";import P from"node:url";import A from"node:path";import j from"node:module";const M=P.fileURLToPath(import.meta.url),T=A.dirname(M),C=j.createRequire(import.meta.url),O="__datadog-helper-file",N=new RegExp(O),R=["development","production","test"],_=["datadoghq.com","us3.datadoghq.com","us5.datadoghq.com","datadoghq.eu","ddog-gov.com","us2.ddog-gov.com","ap1.datadoghq.com","ap2.datadoghq.com","datad0g.com"],F=_[0],z="datadog-build-plugins",L=t.bold.green,U=t.bold.yellow,B=["API_KEY","APP_KEY","SOURCEMAP_INTAKE_URL","APPS_INTAKE_URL","APPS_UPLOAD_ASSETS","APPS_VERSION_NAME","APPS_AUTH_METHOD","SITE"],q=e=>process.env[`DATADOG_${e}`]||process.env[`DD_${e}`],V=e=>{const t=[];return process.env[`DD_${e}`]&&t.push(`DD_${e}`),process.env[`DATADOG_${e}`]&&t.push(`DATADOG_${e}`),t},K=(e,t,n)=>{if(void 0!==e)return(e=>_.some((t=>t===e)))(e)?e:void n.push(`${t} "${e}" is not a supported Datadog site. See the site parameters in https://docs.datadoghq.com/getting_started/site/.`)},H=e=>{if(null===e||"object"!=typeof e)return"";const t="title"in e&&"string"==typeof e.title?e.title:void 0,n="detail"in e&&"string"==typeof e.detail?e.detail:void 0;return t&&n?`${t}: ${n}`:t||(n?`detail: ${n}`:"")},W=e=>({"DD-EVP-ORIGIN":`${e.bundler}-build-plugin_${e.plugin}`,"DD-EVP-ORIGIN-VERSION":e.version}),J=async e=>{const{getForm:t,defaultHeaders:n={},zip:o=!0}=e,r=await t(),i=new Request("fake://url",{method:"POST",body:r});return{data:o?i.body.pipeThrough(new CompressionStream("gzip")):i.body,headers:{"Content-Encoding":o?"gzip":"multipart/form-data",...n,...Object.fromEntries(i.headers.entries())}}},G=[400,401,403,404,405,409,413],Y=async e=>{const{auth:t,url:o,method:r="GET",getData:i,type:s="text"}=e,a={retries:0===e.retries?0:e.retries||5,onRetry:e.onRetry,maxTimeout:e.maxTimeout,minTimeout:e.minTimeout};return n((async(e,n)=>{let a;try{const e={method:r,duplex:"half"};let n={"X-Datadog-Origin":"build-plugins"};if(t&&"accessToken"in t?t.accessToken&&(n.Authorization=`Bearer ${t.accessToken}`):(t?.apiKey&&(n["DD-API-KEY"]=t.apiKey),t?.appKey&&(n["DD-APPLICATION-KEY"]=t.appKey)),"function"==typeof i){const{data:t,headers:o}=await i();e.body=t,n={...n,...o}}a=await fetch(o,{...e,headers:n})}catch(t){return e(t),{}}if(!a.ok){let t=`HTTP ${a.status} ${a.statusText}`;try{const e=(e=>{try{const t=JSON.parse(e);if(null!==t&&"object"==typeof t)if("errors"in t&&Array.isArray(t.errors)){const e=t.errors.map(H).filter((e=>e.length>0)).join("\n");if(e)return e}else{const e=H(t);if(e)return e}}catch{}return e})(await a.text());e&&(t+=`\n${e}`)}catch{}if(G.includes(a.status))return e(new Error(t)),{};throw new Error(t)}try{let e;return e="json"===s?await a.json():await a.text(),e}catch(t){return e(t),{}}}),a)},Q=e=>({message:t,context:n})=>Y({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||z,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"}}}}),Z=e=>e.replace(/^@dd\/(datadog-|internal-)?|^datadog-|-plugin$/g,""),X=e=>e.includes(O),ee=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},te=e=>{const t=!!e.errorTracking?.sourcemaps,n=e.enableGit??!0;return t&&n},ne=e=>{const t=Math.floor(e/1e3/60/60/24),n=new Date(e-24*t*60*60*1e3),o=n.getUTCHours(),r=n.getUTCMinutes(),i=n.getUTCSeconds(),s=n.getUTCMilliseconds(),a=`${t?`${t}d `:""}${o?`${o}h `:""}${r?`${r}m `:""}${i?`${i}s`:""}`.trim();return`${a}${!a||s?` ${s}ms`:""}`.trim()},oe=(e,t=60,n="[...]")=>{if(e.length<=t)return e;const o=Math.max(4,t-n.length),r=Math.min(10,Math.floor(o/2)),i=o-r;return`${e.slice(0,r)}${n}${e.slice(-i)}`},re=(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}},ie=e=>e.trim().toLowerCase().replace(/[^a-z0-9_:./-]+/g,"_").replace(/^_+|_+$/g,"")||"unknown",se=e=>Object.entries(e).map((([e,n])=>` - ${e}: ${t.bold.green((e=>{if(void 0===e)return"undefined";if(null===e)return"null";if(Array.isArray(e))return e.join(", ");if("object"==typeof e)try{return JSON.stringify(e,null,2)}catch{return String(e)}return e?.toString()??""})(n))}`)).join("\n"),ae={debug:0,info:1,warn:2,error:3,none:4},ue=e=>e.split(">").map(Z).join(">"),ce=(e,n,o,r)=>{const i=ue(e);return(s,a="debug",{forward:u,context:c}={})=>{let d=t.dim,l=console.log;"error"===a?(d=t.red,l=console.error):"warn"===a?(d=t.yellow,l=console.warn):"info"===a&&(d=t.cyan,l=console.log);const p=`[${n.metadata?.name?`${n.metadata.name}|`:""}${a}|${n.bundler.name}|${i}]`,f="string"==typeof s?s:JSON.stringify(s,null,2);if(o.logs.push({bundler:n.bundler.name,pluginName:e,type:a,message:f,time:Date.now()}),"error"===a&&o.errors.push(f),"warn"===a&&o.warnings.push(f),u){const t=async()=>{try{const t=Q(n);await t({message:f,context:{plugin:e,status:a,...c}})}catch(t){ce(e,n,o,r)(`Error forwarding log: ${t}`,"debug")}};o.queue.push(t())}ae[a]>=ae[r]&&l(`${d(p)} ${f}`)}},de=(e,n,o)=>(r,i={})=>{const{level:s="debug",start:a=!0,log:u=!0,tags:c=[]}=i,d={pluginName:e,label:r,spans:[],tags:[...c,`plugin:${e}`,`level:${s}`],logLevel:s,total:0};n.push(d);const l=()=>d.spans.filter((e=>!e.end)),p=n=>{l().length||(!d.spans.length&&u&&o(t.dim(`[${t.cyan(r)}] : start`),"debug"),d.spans.push({start:n||Date.now(),tags:[`plugin:${e}`]}))},f=(e,n=!0)=>{const i=l();if(i?.length){i.length>1&&o(`Timer ${t.cyan(r)} has more than one ongoing span.`,"debug");for(const t of i)t.end=e||Date.now()}else n&&o(`Timer ${t.cyan(r)} cannot be paused, no ongoing span.`,"debug")};if(a){let e;"number"==typeof a&&(e=a),p(e)}return{timer:d,resume:p,end:e=>{f(e,!1);const n=d.spans.reduce(((e,t)=>e+(t.end-t.start)),0);d.total=n,u&&o(`[${t.cyan(r)}] : ${t.cyan(ne(n))}`,s)},pause:f,tag:(e,t={})=>{const{span:n=!1}=t;if(n){const t=l();for(const n of t)n.tags.push(...e)}else d.tags.push(...e)}}},le=(e,t,n="warn")=>o=>{const r=ce(o,e,t,n);return{getLogger:r=>le(e,t,n)(`${ue(o)}>${r}`),time:de(o,t.timings,r),error:(e,t)=>r(e,"error",t),warn:(e,t)=>r(e,"warn",t),info:(e,t)=>r(e,"info",t),debug:(e,t)=>r(e,"debug",t)}},pe=["buildEnd","buildStart","load","resolveId","transform","watchChange","writeBundle","buildRoot","init","buildReport","bundlerReport","git"],fe=(e,t,n,o)=>{const r=n=>function(...r){const i=o.time(`${e} | ${t}`,{log:!1,tags:["type:hook",`hook:${t}`]}),s=n.apply(this,r);return s instanceof Promise?s.finally((()=>{i.end()})):(i.end(),s)};return"object"==typeof n&&null!==n&&"handler"in n?{...n,handler:r(n.handler)}:r(n)},me=(e,t,n)=>{const o=e.getLogger(z);return e=>{const r=o.time(`hook | init ${n}`,{log:!1}),i=t(e).map((e=>((e,t)=>{const n={...e},o=Z(e.name);for(const r of pe){const i=e[r];i&&(n[r]=fe(o,r,i,t))}return n})(e,o))),s=i.map((e=>`plugin:${e.name}`));return r.tag(s),r.end(),i}},he=new Set,ge=(e,t,n)=>{const o=e[t];if(o&&"object"==typeof o&&"enable"in o){const e=o.enable;if("boolean"!=typeof e&&void 0!==e&&(he.has(t)||(he.add(t),n.warn(`\`${t}.enable\` should be a boolean, got ${typeof e}. Non-boolean values are coerced today but will be rejected in the next major.`))),void 0!==e)return!!e}return!!o},ye="apps",be="datadog-apps-plugin",we="api/unstable/app-builder-code/apps",ve="datadog-apps-assets.zip",$e=/\.backend\.(ts|tsx|js|jsx)$/,ke=[".ts",".tsx",".js",".jsx",".mjs",".cjs",".mts",".cts"],xe=["apiKey","oauth"],Ee=e=>{const t=e[ye]||{},n=(e=>{if(void 0!==e){if(xe.includes(e))return e;throw new Error(`apps.authOverrides.method must be one of: ${xe.join(", ")}`)}})(q("APPS_AUTH_METHOD")||t.authOverrides?.method)||((e=>Boolean((q("API_KEY")||e.auth?.apiKey)&&(q("APP_KEY")||e.auth?.appKey)))(e)?"apiKey":"oauth");return{include:t.include||[],dryRun:t.dryRun??!q("APPS_UPLOAD_ASSETS"),identifier:t.identifier?.trim(),name:t.name?.trim()||e.metadata?.name?.trim(),authOverrides:{method:n}}},Se=async e=>r.rm(e,{force:!0,maxRetries:3,recursive:!0}),Ie=async e=>r.mkdir(e,{recursive:!0}),De=(e,t)=>{var n;n=u.dirname(e),s.mkdirSync(n,{recursive:!0}),s.writeFileSync(e,t,{encoding:"utf-8"})},Pe=e=>s.readFileSync(e,{encoding:"utf-8"}),Ae=e=>{try{return s.existsSync(e)}catch(e){if("ENOENT"===e.code)return!1;throw e}},je=async(e,t)=>{if("function"==typeof s.openAsBlob){const n=await s.openAsBlob(e,{type:t.contentType});return new o([n],t.filename)}{const n=c.toWeb(s.createReadStream(e)),r=await new Response(n).blob();return new o([r],t.filename,{type:t.contentType})}},Me=async e=>{const t={empty:!1,exists:!0};try{const{size:n}=await r.stat(e);0===n&&(t.empty=!0)}catch(e){if("ENOENT"!==e.code)throw e;t.exists=!1}return t};var Te=(e=>(e[e.BEFORE=0]="BEFORE",e[e.MIDDLE=1]="MIDDLE",e[e.AFTER=2]="AFTER",e))(Te||{});const Ce=()=>import("oauth4webapi"),Oe=t.cyan.bold,Ne=e=>e.toString("base64url"),Re=e=>({client_id:e}),_e=e=>({issuer:new URL(e.authorizationUrl).origin,authorization_endpoint:e.authorizationUrl,token_endpoint:e.tokenUrl}),Fe=(e,t)=>`${e}:${t.clientId}:${((e,t)=>p("sha256").update([t.clientId,e,t.authorizationUrl,t.tokenUrl].join("|")).digest("hex").slice(0,16))(e,t)}`,ze=(e,t,n)=>{e.writeHead(t,{"Content-Type":"text/html; charset=UTF-8"}),e.end(n)},Le=(e,t,n=Date.now())=>({accessToken:e.access_token,expiresAt:"number"==typeof e.expires_in?n+1e3*e.expires_in:void 0,expiresIn:e.expires_in,refreshToken:e.refresh_token,scope:e.scope,site:t,tokenType:e.token_type}),Ue=e=>null!==e&&"object"==typeof e&&!Array.isArray(e),Be=e=>e instanceof Error?e.message:String(e),qe=e=>{const t=Be(e).toLowerCase();return"NoEntry"===(e=>Ue(e)&&"string"==typeof e.code?e.code:void 0)(e)||t.includes("noentry")||t.includes("no matching entry")||t.includes("not found")},Ve=async(e,t)=>{const{AsyncEntry:n}=await import("@napi-rs/keyring");return new n("datadog-build-plugins:oauth",Fe(e,t))},Ke=(e,t)=>new Error(`Could not ${e} Datadog OAuth token in the OS credential store. ${t instanceof Error?t.message:String(t)}`),He=async(e,t)=>{try{const n=await Ve(e,t),o=await n.getPassword();if(!o)return;const r=JSON.parse(o);return(e=>{if(Ue(e)&&1===e.version&&Ue(e.token)&&"string"==typeof e.token.accessToken&&"string"==typeof e.token.clientId&&"string"==typeof e.token.site)return e})(r)?.token}catch(e){if(qe(e))return;throw Ke("read",e)}},We=async(e,t,n,o=e.site)=>{if(t.cacheTokens)try{await(async(e,t,n)=>{try{const o=await Ve(e,n),r={version:1,token:t};await o.setPassword(JSON.stringify(r))}catch(e){throw Ke("save",e)}})(o,((e,t)=>({accessToken:e.accessToken,clientId:t,expiresAt:e.expiresAt,refreshToken:e.refreshToken,scope:e.scope,site:e.site,tokenType:e.tokenType}))(e,t.clientId),t),n.debug("Saved Datadog OAuth token to the OS credential store.")}catch(e){n.warn(`Could not save Datadog OAuth token to the OS credential store; continuing without a persistent cache. ${Be(e)}`)}},Je=async(e,t,n)=>{if(t.cacheTokens)try{await(async(e,t)=>{try{const n=await Ve(e,t);await n.deletePassword()}catch(e){if(!qe(e))throw Ke("delete",e)}})(e,t)}catch(e){n.warn(`Could not delete cached Datadog OAuth token. ${Be(e)}`)}},Ge=async(e,t,n)=>{if(!t.cacheTokens)return;let o;try{o=await He(e,t)}catch(e){n.warn(`Could not read cached Datadog OAuth token; starting browser authorization. ${Be(e)}`)}if(o){if(void 0===(r=o).expiresAt||r.expiresAt>Date.now()+3e5)return n.debug("Using cached Datadog OAuth access token."),(e=>({accessToken:e.accessToken,expiresAt:e.expiresAt,refreshToken:e.refreshToken,scope:e.scope,site:e.site,tokenType:e.tokenType}))(o);var r;if(o.refreshToken)try{n.debug("Refreshing cached Datadog OAuth access token.");const r=await(async(e,t,n)=>{const o=await Ce(),r=_e(t),i=Re(t.clientId),s=await o.refreshTokenGrantRequest(r,i,o.None(),n),a=await o.processRefreshTokenResponse(r,i,s);return Le({...a,refresh_token:a.refresh_token||n},e)})(e,t,o.refreshToken);return await We(r,t,n),r}catch(o){return n.warn(`Cached Datadog OAuth token could not be refreshed; starting browser authorization. ${o instanceof Error?o.message:String(o)}`),void await Je(e,t,n)}}},Ye=async(e,t,n)=>{const o=await Ce(),r=_e(t),i=Re(t.clientId),s=Ne(l(32)),a=await(async e=>(await Ce()).calculatePKCECodeChallenge(e))(s),u=Ne(l(32)),c=(e=>{const t=new URL(e.authorizationUrl);return t.searchParams.set("redirect_uri",e.redirectUri),t.searchParams.set("client_id",e.clientId),t.searchParams.set("response_type","code"),t.searchParams.set("code_challenge",e.codeChallenge),t.searchParams.set("code_challenge_method","S256"),t.searchParams.set("state",e.state),t})({authorizationUrl:t.authorizationUrl,clientId:t.clientId,codeChallenge:a,redirectUri:t.redirectUri,state:u}),p=(async e=>{const t=new URL(e.redirectUri),n=Number(t.port||80);if("http:"!==t.protocol)throw new Error("OAuth redirect URI must use http for the local OAuth callback.");if(!Number.isInteger(n)||n<=0)throw new Error("OAuth redirect URI must include a valid port.");let o,r=!1;const i=m.createServer();try{return await new Promise(((s,a)=>{const u=e=>{r||(r=!0,e())};i.on("request",((n,o)=>{const r=new URL(n.url||"/",t.origin);if(r.pathname!==t.pathname)return void ze(o,404,"Not found.");let i;try{i=e.oauth.validateAuthResponse(e.authorizationServer,e.client,r,e.state)}catch(e){return ze(o,400,"OAuth authorization failed. You may now close this tab."),void u((()=>a(e instanceof Error?e:new Error(String(e)))))}if(!i.get("code"))return ze(o,400,"Missing OAuth authorization code. You may now close this tab."),void u((()=>a(new Error("Missing OAuth authorization code."))));ze(o,200,"OAuth authorization complete. You may now close this tab."),u((()=>s({callbackParameters:i})))})),i.once("error",(e=>u((()=>a(e))))),o=setTimeout((()=>{u((()=>a(new Error(`Timed out waiting for OAuth callback after ${e.timeoutMs}ms.`))))}),e.timeoutMs);try{const e="localhost"===t.hostname?void 0:t.hostname;i.listen(n,e)}catch(e){u((()=>a(e instanceof Error?e:new Error(String(e)))))}}))}finally{o&&clearTimeout(o),i.listening&&(i.close(),i.closeAllConnections?.(),i.closeIdleConnections?.())}})({authorizationServer:r,client:i,oauth:o,redirectUri:t.redirectUri,state:u,timeoutMs:t.timeoutMs});n.info(`Authorize Datadog Apps upload:\n ${Oe(c.toString())}`),t.openBrowser&&((e,t)=>{const n="darwin"===process.platform?{command:"open",args:[e]}:"win32"===process.platform?{command:"cmd",args:["/c","start","",e]}:{command:"xdg-open",args:[e]};try{const e=d(n.command,n.args,{detached:!0,stdio:"ignore"});e.once("error",(e=>{t.warn(`Could not open browser automatically: ${Be(e)}`)})),e.unref()}catch(e){t.warn(`Could not open browser automatically: ${Be(e)}`)}})(c.toString(),n);return(async e=>{const t=await Ce(),n=_e(e),o=Re(e.clientId),r=await t.authorizationCodeGrantRequest(n,o,t.None(),e.callbackParameters,e.redirectUri,e.codeVerifier),i=await t.processAuthorizationCodeResponse(n,o,r);return Le(i,e.site)})({callbackParameters:(await p).callbackParameters,clientId:t.clientId,codeVerifier:s,redirectUri:t.redirectUri,site:e,tokenUrl:t.tokenUrl,authorizationUrl:t.authorizationUrl})},Qe=new Map,Ze=(e,t)=>{const n=(e=>{const t=(e=>"datad0g.com"===e?"f4bacdd2-0c8c-49f5-bf3e-a62ba3ec02e6":"e17b9ffa-3daf-4124-ba1b-4ac8c547d506")(e),n=`https://api.${e}/oauth2/v1`;return{authorizationUrl:`${n}/authorize`,cacheTokens:!0,clientId:t,openBrowser:!0,redirectUri:"http://localhost:8060",timeoutMs:3e5,tokenUrl:`${n}/token`}})(e),o=`${e}:${n.clientId}`;let r=Qe.get(o);return r||(r=(async(e,t,n)=>{const o=await Ge(e,t,n);if(o)return o;const r=await Ye(e,t,n);return await We(r,t,n,e),r})(e,n,t).catch((e=>{throw Qe.delete(o),e})),Qe.set(o,r)),r},Xe='Set apps.authOverrides.method: "oauth" or DD_APPS_AUTH_METHOD=oauth to use OAuth, or set DD_API_KEY and DD_APP_KEY to use API/App key auth.';class et extends Error{constructor(){super(`Missing authentication. ${Xe}`),this.statusCode=400,this.name="MissingAuthenticationError"}}const tt=(e,t,n)=>{if("oauth"===e)return e=>(async({auth:e,log:t,...n})=>{const{site:o}=e,r=await Ze(o,t);if(!r.accessToken)throw new Error("OAuth authentication did not return an access token.");return Y({...n,auth:{accessToken:r.accessToken}})})({...e,auth:t,log:n});if(t.apiKey&&t.appKey)return e=>Y({...e,auth:{apiKey:t.apiKey,appKey:t.appKey}});throw new et};function nt(e,t){if(!function(e){return"Program"===e.type}(e))throw new Error(`Expected a Program node from this.parse() for ${t}, got ${e.type}`);return e}function ot(e){return"object"==typeof e&&null!==e&&"Literal"===e.type&&"string"==typeof e.value}function rt(e){return"type"===e.importKind||"type"===e.exportKind}function it(e,t){return function(e,t){const n=nt(e,t),o=function(e){const t=new Map;for(const n of e.body)if("FunctionDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"function"});else if("ClassDeclaration"===n.type&&n.id)t.set(n.id.name,{kind:"class"});else if("VariableDeclaration"===n.type)for(const e of n.declarations)"Identifier"===e.id.type&&t.set(e.id.name,{kind:"variable",init:e.init});else if("ImportDeclaration"===n.type)for(const e of n.specifiers)t.set(e.local.name,{kind:"import"});return t}(n),r=[];for(const e of n.body){if("ExportDefaultDeclaration"===e.type)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);if("ExportAllDeclaration"===e.type)throw new Error(`"export *" is not supported in .backend.ts files. Use explicit named exports instead: ${t}`);if("ExportNamedDeclaration"!==e.type)continue;e.declaration&&r.push(...ut(e.declaration,t).map((e=>({kind:"local",name:e,localName:e}))));const n="string"==typeof e.source?.value?e.source.value:null;for(const i of e.specifiers){if("Identifier"!==i.exported.type)continue;if("default"===i.exported.name)throw new Error(`Default exports are not supported in .backend.ts files. Use a named export instead: ${t}`);const e="Identifier"===i.local.type?i.local.name:"string"==typeof i.local.value?i.local.value:null;e&&(n?r.push({kind:"re-export",name:i.exported.name,localName:e,source:n}):("Identifier"===i.local.type&&ct(e,o,t),r.push({kind:"local",name:i.exported.name,localName:e})))}}return r}(e,t).map((e=>e.name))}const st=new Set(["ArrayExpression","Literal","ObjectExpression","TemplateLiteral"]);function at(e){return null==e||st.has(e.type)}function ut(e,t){if("FunctionDeclaration"===e.type&&e.id)return[e.id.name];if("ClassDeclaration"===e.type)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${t}`);if("VariableDeclaration"===e.type)return e.declarations.flatMap((e=>{if("Identifier"!==e.id.type)throw new Error(`Destructured exports are not supported in backend files. Use individual named exports instead: ${t}`);if(at(e.init))throw new Error(`Non-function export "${e.id.name}" in backend file ${t}. Only function exports are supported — use "export function ${e.id.name}(…) { }" instead.`);return[e.id.name]}));throw new Error(`Unsupported export declaration type "${e.type}" in backend file ${t}. Only function and variable exports are allowed.`)}function ct(e,t,n){const o=t.get(e);if(o){if("class"===o.kind)throw new Error(`Class exports are not supported in .backend.ts files. Only function exports are allowed: ${n}`);if("variable"===o.kind&&at(o.init))throw new Error(`Non-function export "${e}" in backend file ${n}. Only function exports are supported — use "export function ${e}(…) { }" instead.`)}}function dt(e){const t=e.relativePath.split(u.sep).join("/");return`${p("sha256").update(t).digest("hex")}.${e.name}`}function lt(e){const t=[];for(const{exportName:n,queryName:o}of e)t.push(`export async function ${n}(...args) {`),t.push(` return globalThis.DD_APPS_RUNTIME.executeBackendFunction(${JSON.stringify(o)}, args);`),t.push("}"),t.push("");return t.join("\n")}function pt(e,t,n){const o=[];return o.push(`import { ${e} } from ${JSON.stringify(t)};`),function(e){try{return C.resolve("@datadog/action-catalog/action-execution",{paths:[e]}),!0}catch{return!1}}(n)&&o.push("import { setExecuteActionImplementation } from '@datadog/action-catalog/action-execution';"),o.push(""),o.push('/** @param {import("./context.types").Context} $ */'),o.push("export async function main($) {"),o.push(" globalThis.$ = $;"),o.push(""),o.push(" // Register the $.Actions-based implementation for executeAction"),o.push(" if (typeof setExecuteActionImplementation === 'function') {\n setExecuteActionImplementation(async (actionId, request) => {\n const actionPath = actionId.replace(/^com\\.datadoghq\\./, '');\n const pathParts = actionPath.split('.');\n let actionFn = $.Actions;\n for (const part of pathParts) {\n if (!actionFn) throw new Error('Action not found: ' + actionId);\n actionFn = actionFn[part];\n }\n if (typeof actionFn !== 'function') throw new Error('Action is not a function: ' + actionId);\n return actionFn(request);\n });\n }"),o.push(""),o.push(" const args = $.backendFunctionArgs ?? [];"),o.push(` const result = await ${e}(...args);`),o.push(" return result;"),o.push("}"),o.join("\n")}function ft(e,t,n){const o={state:t},r=e=>{n._?.(e,o),function(e,t){return t[e.type]}(e,n)?.(e,o);for(const t of Object.keys(e))"type"!==t&&i(e[t])},i=e=>{if(Array.isArray(e))for(const t of e)mt(t)&&r(t);else mt(e)&&r(e)};r(e)}function mt(e){return"object"==typeof e&&null!==e&&"type"in e&&"string"==typeof e.type}function ht(e){ft(e,null,{_(e){const t=e;t.range||"number"!=typeof t.start||"number"!=typeof t.end||(t.range=[t.start,t.end])}});const t=y.analyze(e,{ecmaVersion:2022,ignoreEval:!0,sourceType:"module"}),n=new Map;for(const e of t.scopes)for(const t of e.references)n.set(t.identifier,t);return{scopeManager:t,referencesByIdentifier:n,moduleScope:wt(t)}}function gt(e,t){return t.referencesByIdentifier.get(e)?.resolved??void 0}function yt(e){return e.defs.some((e=>"ImportBinding"===e.type))}function bt(e,t){return t.moduleScope.set.get(e)}function wt(e){return e.scopes.find((e=>"module"===e.type))??e.globalScope}function vt(e,t,n){const o={scopeAnalysis:t,unsupportedAliases:$t(e,t)},r=[];return ft(e,o,{CallExpression(e,{state:t}){(function(e,t,n){const o=e.callee;if("Identifier"===o.type){if(St(o,t.unsupportedAliases,t.scopeAnalysis))throw At(n,"action-catalog call aliases");if(St(o,t.scopeAnalysis.actionFunctions,t.scopeAnalysis)){if(e.optional)throw At(n,"optional action-catalog calls");return!0}return!1}if("MemberExpression"!==o.type)return!1;if(!kt(o,t.scopeAnalysis))return!1;if(e.optional||Et(o))throw At(n,"optional or computed action-catalog namespace calls");return!0})(e,t,n)&&r.push(e)}}),r}function $t(e,t){const n=new Set;return ft(e,t,{VariableDeclarator(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.id.type&&"Identifier"===e.init?.type&&St(e.init,t.actionFunctions,t))return Dt(e,t,[e.id.name]);if("Identifier"===e.id.type&&"MemberExpression"===e.init?.type&&kt(e.init,t))return Dt(e,t,[e.id.name]);if("ObjectPattern"!==e.id.type||"Identifier"!==e.init?.type||!St(e.init,t.actionNamespaces,t))return[];const n=e.id.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Pt(e.value))).map((e=>e.name));return Dt(e,t,n)}(e,t))n.add(o)},AssignmentExpression(e,{state:t}){for(const o of function(e,t){if("Identifier"===e.left.type&&"Identifier"===e.right.type&&St(e.right,t.actionFunctions,t))return It([e.left],t);if("Identifier"===e.left.type&&"MemberExpression"===e.right.type&&kt(e.right,t))return It([e.left],t);if("ObjectPattern"!==e.left.type||"Identifier"!==e.right.type||!St(e.right,t.actionNamespaces,t))return[];const n=e.left.properties.flatMap((e=>"RestElement"===e.type||e.computed?[]:Pt(e.value)));return It(n,t)}(e,t))n.add(o)}}),n}function kt(e,t){const n=xt(e);return!!n&&St(n,t.actionNamespaces,t)}function xt(e){return"Identifier"===e.object.type?e.object:"MemberExpression"===e.object.type?xt(e.object):void 0}function Et(e){return!(!e.optional&&!e.computed)||"MemberExpression"===e.object.type&&Et(e.object)}function St(e,t,n){return function(e,t,n){const o=gt(e,n);return!!o&&t.has(o)}(e,t,n.moduleScope)}function It(e,t){return e.flatMap((e=>{const n=gt(e,t.moduleScope);return n?[n]:[]}))}function Dt(e,t,n){const o=new Set(n);return t.moduleScope.scopeManager.getDeclaredVariables(e).filter((e=>o.has(e.name)))}function Pt(e){switch(e.type){case"Identifier":return[e];case"ObjectPattern":return e.properties.flatMap((e=>"RestElement"===e.type?Pt(e.argument):Pt(e.value)));case"ArrayPattern":return e.elements.flatMap((e=>e?Pt(e):[]));case"RestElement":return Pt(e.argument);case"AssignmentPattern":return Pt(e.left);case"MemberExpression":return[]}}function At(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const jt="@datadog/action-catalog";function Mt(e,t,n){const o=e.get(t);if(!o)return Ft(t,[],n.name);const r=gt(n,o.scopeAnalysis);return r?function(e,t){return t.defs.some((t=>t.name===e))}(n,r)?zt(t,[],n.name):Ot({modules:e,visitedExports:new Set},t,r,[]):zt(t,[],n.name)}function Tt(e,t,n,o){const r=e.modules.get(t);if(!r)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"export",exportName:n,message:`Module '${e}' was not collected while resolving export '${n}'.`,hops:t}}(t,o,n);if("default"===n)return Rt(t,o,n);const i=`${t}\0${n}`;if(e.visitedExports.has(i))return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"cycle",exportName:n,message:`Resolving export '${n}' from module '${e}' would cycle through the module graph.`,hops:t}}(t,o,n);e.visitedExports.add(i);try{const t=r.exportsByName.get(n);return t?function(e,t,n,o,r){if("unsupported"===o.kind)return function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-export",exportName:n,exportReason:o,message:`Export '${n}' from module '${e}' is unsupported: ${o}.`,hops:t}}(t.id,r,n,o.reason);if("re-export"===o.kind)return"default"===o.importedName?Rt(t.id,r,n):Tt(e,o.resolvedId,o.importedName,[...r,{kind:"re-export",moduleId:t.id,exportName:n,sourceModuleId:o.resolvedId,sourceExportName:o.importedName}]);return Ot(e,t.id,o.variable,[...r,{kind:"local-export",moduleId:t.id,exportName:n,localName:o.variable.name}])}(e,r,n,t,o):function(e,t,n,o){let r;for(const i of t.starExports){const s=Tt(e,i.resolvedId,n,[...o,{kind:"star-export",moduleId:t.id,exportName:n,sourceModuleId:i.resolvedId}]);if("unsupported"===s.kind){if("missing-export"===s.reason)continue;return s}if(!r||!Ct(r,s)){if(r)return Nt(t.id,o,n);r=s}}return r??function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-export",exportName:n,message:`Module '${e}' does not expose export '${n}'.`,hops:t}}(t.id,o,n)}(e,r,n,o)}finally{e.visitedExports.delete(i)}}function Ct(e,t){return e.moduleId===t.moduleId&&e.variable===t.variable}function Ot(e,t,n,o){const r=e.modules.get(t);if(!r)return Ft(t,o,n.name);const i=r.importsByVariable.get(n);if(i)return function(e,t,n,o,r){if("default"===o.kind)return _t(t,r,n);if("namespace"===o.kind)return function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"namespace-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported namespace import.`,hops:t}}(t,r,n);if("default"===o.importedName)return _t(t,r,n);return Tt(e,o.resolvedId,o.importedName,[...r,{kind:"import",moduleId:t,localName:n,exportName:o.importedName,sourceModuleId:o.resolvedId}])}(e,r.id,n.name,i,o);const s=r.topLevelBindingsByVariable.get(n);return s?"const"===s.kind?{kind:"local",moduleId:r.id,variable:n,binding:s,hops:o}:"mutable"===s.kind?function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"mutable-binding",variableName:n,declarationKind:o,message:`Variable '${n}' in module '${e}' is declared with mutable '${o}'.`,hops:t}}(r.id,o,n.name,s.declarationKind):function(e,t,n,o){return{kind:"unsupported",moduleId:e,reason:"unsupported-binding",variableName:n,bindingReason:o,message:`Variable '${n}' in module '${e}' has unsupported binding: ${o}.`,hops:t}}(r.id,o,n.name,s.reason):function(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-static-binding",variableName:n,message:`Variable '${n}' in module '${e}' does not have a recorded top-level static binding.`,hops:t}}(r.id,o,n.name)}function Nt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"ambiguous-star-export",exportName:n,message:`Module '${e}' exposes ambiguous star exports for '${n}'.`,hops:t}}function Rt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-export",exportName:n,message:`Export '${n}' from module '${e}' resolves through an unsupported default export.`,hops:t}}function _t(e,t,n){return{kind:"unsupported",moduleId:e,reason:"default-import",variableName:n,message:`Variable '${n}' in module '${e}' is an unsupported default import.`,hops:t}}function Ft(e,t,n){return{kind:"unsupported",moduleId:e,reason:"missing-module-record",requestKind:"variable",variableName:n,message:`Module '${e}' was not collected while resolving variable '${n}'.`,hops:t}}function zt(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unresolved-identifier",variableName:n,message:`Identifier '${n}' in module '${e}' is not a resolvable reference.`,hops:t}}function Lt(e,t,n){const o=Qt(n);switch(o.type){case"Literal":return function(e,t){if("string"==typeof t.value)return{kind:"resolved",moduleId:e,value:t.value};return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-string-literal",valueType:t,message:`Literal value type '${t}' in module '${e}' is not a string.`}}(e,typeof t.value)}(t,o);case"TemplateLiteral":return function(e,t){if(t.expressions.length>0)return function(e){return{kind:"unsupported",moduleId:e,reason:"dynamic-template-literal",message:`Dynamic template literals in module '${e}' cannot be resolved to static strings.`}}(e);return{kind:"resolved",moduleId:e,value:t.quasis.map((e=>e.value.cooked??e.value.raw)).join("")}}(t,o);case"Identifier":return function(e,t,n){const o=Mt(e.modules,t,n);if("unsupported"===o.kind)return an(o,n.name);if(!o.binding.expression)return un(o.moduleId,o.variable.name);if(e.seenVariables.has(o.variable))return tn(o.moduleId,o.variable.name);e.seenVariables.add(o.variable);try{return Lt(e,o.moduleId,o.binding.expression)}finally{e.seenVariables.delete(o.variable)}}(e,t,o);case"MemberExpression":return function(e,t,n){const o=Ut(e,t,n);if("unsupported"===o.kind)return o;return Lt(e,o.moduleId,o.expression)}(e,t,o);default:return function(e,t){return{kind:"unsupported",moduleId:e,reason:"unsupported-expression",expressionType:t,message:`Expression type '${t}' in module '${e}' cannot be resolved to a static string.`}}(t,o.type)}}function Ut(e,t,n){if(n.optional)return function(e){return{kind:"unsupported",moduleId:e,reason:"optional-member-expression",message:`Optional member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if(n.computed)return function(e){return{kind:"unsupported",moduleId:e,reason:"computed-member-expression",message:`Computed member expressions in module '${e}' cannot be resolved to static strings.`}}(t);if("Identifier"!==n.property.type)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"non-static-member-property",propertyType:t,message:`Member property type '${t}' in module '${e}' is not statically named.`}}(t,n.property.type);const o=Bt(e,t,n.object);return"unsupported"===o.kind?o:function(e,t,n){let o;for(const r of t.properties){if("SpreadElement"===r.type)return sn(e);if(r.computed)return en(e);if(Yt(r)===n){if(o)return nn(e,n);if("init"!==r.kind)return Xt(e,n);if(!qt(r))return rn(e,n,r.value.type);o=r}}if(!o)return function(e,t){return{kind:"unsupported",moduleId:e,reason:"missing-object-property",propertyName:t,message:`Static object in module '${e}' does not have property '${t}'.`}}(e,n);return{kind:"resolved",moduleId:e,expression:o.value}}(o.moduleId,o.expression,n.property.name)}function Bt(e,t,n){if("Super"===n.type)return on(t,n.type);const o=Qt(n);if("ObjectExpression"===o.type)return{kind:"resolved",moduleId:t,expression:o};if("MemberExpression"===o.type){const n=Ut(e,t,o);return"unsupported"===n.kind?n:Bt(e,n.moduleId,n.expression)}if("Identifier"!==o.type)return on(t,o.type);const r=Mt(e.modules,t,o);if("unsupported"===r.kind)return an(r,o.name);if(!r.binding.expression)return un(r.moduleId,r.variable.name);if(e.mutatedImportedObjectVariables.has(r.variable))return function(e,t){return{kind:"unsupported",moduleId:e,reason:"imported-object-mutation",variableName:t,message:`Imported object '${t}' from module '${e}' is mutated in the module graph.`}}(r.moduleId,r.variable.name);if(e.seenVariables.has(r.variable))return tn(r.moduleId,r.variable.name);e.seenVariables.add(r.variable);try{return Bt(e,r.moduleId,r.binding.expression)}finally{e.seenVariables.delete(r.variable)}}function qt(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function Vt(e){const t=new Set;for(const n of e.values())ft(n.ast,{modules:e,mutatedVariables:t,record:n},{AssignmentExpression(e,{state:t}){Ht(e.left,t)},UpdateExpression(e,{state:t}){Ht(e.argument,t)},UnaryExpression(e,{state:t}){"delete"===e.operator&&Ht(e.argument,t)},ForInStatement(e,{state:t}){Kt(e.left,t)},ForOfStatement(e,{state:t}){Kt(e.left,t)}});return t}function Kt(e,t){"VariableDeclaration"!==e.type&&Ht(e,t)}function Ht(e,t){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&Ht(e.left,t):Ht(e.argument,t);else for(const n of e.elements)n&&Ht(n,t);else for(const n of e.properties)Ht("RestElement"===n.type?n.argument:n.value,t);else{const n=Gt(e);n&&Wt(n,t)}else Wt(e,t)}function Wt(e,t){const n=Jt(t,e,new Set);n&&t.mutatedVariables.add(n)}function Jt(e,t,n){const o=gt(t,e.record.scopeAnalysis);if(!o||n.has(o))return;if(n.add(o),yt(o)){const n=Mt(e.modules,e.record.id,t);return"local"===n.kind?n.variable:void 0}const r=function(e){for(const t of e.defs){const e=t.node;if("VariableDeclarator"===e.type&&e.init)return e.init}return}(o);if(!r)return;const i=function(e){const t=Qt(e);if("Identifier"===t.type)return t;if("MemberExpression"===t.type)return Gt(t);return}(r);return i?Jt(e,i,n):void 0}function Gt(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?Gt(e.object):void 0}function Yt(e){return"Identifier"===e.key.type?e.key.name:"Literal"===e.key.type&&"string"==typeof e.key.value?e.key.value:void 0}function Qt(e){let t=e;for(;Zt(t);)t=t.expression;return t}function Zt(e){const t=e.type;return("TSAsExpression"===t||"TSSatisfiesExpression"===t||"TSNonNullExpression"===t||"TSTypeAssertion"===t)&&!!e.expression}function Xt(e,t){return{kind:"unsupported",moduleId:e,reason:"accessor-object-property",propertyName:t,message:`Static object property '${t}' in module '${e}' is an accessor.`}}function en(e){return{kind:"unsupported",moduleId:e,reason:"computed-object-property",message:`Computed object properties in module '${e}' cannot be resolved to static strings.`}}function tn(e,t){return{kind:"unsupported",moduleId:e,reason:"cycle",variableName:t,message:`Resolving variable '${t}' in module '${e}' would cycle through static string values.`}}function nn(e,t){return{kind:"unsupported",moduleId:e,reason:"duplicate-object-property",propertyName:t,message:`Static object in module '${e}' has duplicate property '${t}'.`}}function on(e,t){return{kind:"unsupported",moduleId:e,reason:"non-object-member-value",expressionType:t,message:`Expression type '${t}' in module '${e}' is not a static object value.`}}function rn(e,t,n){return{kind:"unsupported",moduleId:e,reason:"unsupported-object-property-value",propertyName:t,valueType:n,message:`Static object property '${t}' in module '${e}' has unsupported value type '${n}'.`}}function sn(e){return{kind:"unsupported",moduleId:e,reason:"object-spread",message:`Object spreads in module '${e}' cannot be resolved to static strings.`}}function an(e,t){return{kind:"unsupported",moduleId:e.moduleId,reason:"static-definition-unsupported",variableName:t,definition:e,message:`Variable '${t}' could not be resolved to a static definition: ${e.message}`}}function un(e,t){return{kind:"unsupported",moduleId:e,reason:"uninitialized-const",variableName:t,message:`Const variable '${t}' in module '${e}' does not have an initializer.`}}const cn=new Set(["node_modules",".yarn"]);function dn(e,t,n,o=[]){if(!Pn(e,t))return null;const r=nt(n,e),i=ht(r),s=function(e,t){const n=function(e){return e.body.flatMap((e=>("ImportDeclaration"===e.type||"ExportNamedDeclaration"===e.type||"ExportAllDeclaration"===e.type)&&e.source&&ot(e.source)?[e.source.value]:[]))}(e);return t.map(((e,t)=>({source:n[t]??e,resolvedId:e})))}(r,o);return{id:e,ast:r,scopeAnalysis:i,staticDependencies:s,unsupportedDependencies:In(r),importsByVariable:ln(r,i,s),exportsByName:pn(r,i,s),starExports:hn(r,s),topLevelBindingsByVariable:gn(r,i)}}function ln(e,t,n){const o=new Map;for(const r of e.body){if("ImportDeclaration"!==r.type||!ot(r.source))continue;const e=Sn(n,r.source.value);for(const n of r.specifiers){const[r]=t.scopeManager.getDeclaredVariables(n);r&&("ImportSpecifier"!==n.type?o.set(r,{kind:"ImportDefaultSpecifier"===n.type?"default":"namespace",resolvedId:e}):o.set(r,{kind:"named",importedName:xn(n.imported),resolvedId:e}))}}return o}function pn(e,t,n){const o=new Map;for(const r of e.body)"ExportNamedDeclaration"!==r.type?"ExportDefaultDeclaration"!==r.type?"ExportAllDeclaration"===r.type&&mn(r,n,o):o.set("default",{kind:"unsupported",reason:"default export"}):fn(r,t,n,o);return o}function fn(e,t,n,o){if(e.declaration)!function(e,t,n){if(!e)return;if("VariableDeclaration"===e.type){for(const o of e.declarations){const e=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const t of e)n.set(t.name,{kind:"unsupported",reason:"binding pattern export"});continue}const[r]=e;r&&n.set(o.id.name,{kind:"local",variable:r})}return}if(("FunctionDeclaration"===e.type||"ClassDeclaration"===e.type)&&e.id){const[o]=t.scopeManager.getDeclaredVariables(e);o&&n.set(e.id.name,{kind:"local",variable:o})}}(e.declaration,t,o);else if(e.source&&ot(e.source)){const t=Sn(n,e.source.value);for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=xn(n.exported);"default"!==e?o.set(e,{kind:"re-export",importedName:xn(n.local),resolvedId:t}):o.set(e,{kind:"unsupported",reason:"default re-export",resolvedId:t})}}else for(const n of e.specifiers){if("ExportSpecifier"!==n.type)continue;const e=xn(n.exported);if("default"===e){o.set(e,{kind:"unsupported",reason:"default export"});continue}const r=bt(xn(n.local),t);o.set(e,r?{kind:"local",variable:r}:{kind:"unsupported",reason:"unresolved local export"})}}function mn(e,t,n){const o=En(e);o&&ot(e.source)&&n.set(o,{kind:"unsupported",reason:"namespace re-export",resolvedId:Sn(t,e.source.value)})}function hn(e,t){return e.body.flatMap((e=>"ExportAllDeclaration"!==e.type||En(e)||!ot(e.source)?[]:[{resolvedId:Sn(t,e.source.value)}]))}function gn(e,t){const n=new Map;for(const o of e.body)yn(o,t,n);return function(e,t,n){ft(e,{scopeAnalysis:t,bindings:n},{AssignmentExpression(e,{state:t}){vn(e.left,t.scopeAnalysis,t.bindings)},UpdateExpression(e,{state:t}){vn(e.argument,t.scopeAnalysis,t.bindings)},UnaryExpression(e,{state:t}){"delete"===e.operator&&vn(e.argument,t.scopeAnalysis,t.bindings)},ForInStatement(e,{state:t}){wn(e.left,t.scopeAnalysis,t.bindings)},ForOfStatement(e,{state:t}){wn(e.left,t.scopeAnalysis,t.bindings)}})}(e,t,n),n}function yn(e,t,n){if("VariableDeclaration"===e.type)return void bn(e,t,n);if("ExportNamedDeclaration"===e.type&&"VariableDeclaration"===e.declaration?.type)return void bn(e.declaration,t,n);const o="ExportNamedDeclaration"===e.type||"ExportDefaultDeclaration"===e.type?e.declaration:e;if(o&&("FunctionDeclaration"===o.type||"ClassDeclaration"===o.type)&&o.id){const[e]=t.scopeManager.getDeclaredVariables(o);e&&n.set(e,{kind:"unsupported",reason:`${o.type} binding`})}}function bn(e,t,n){for(const o of e.declarations){const r=t.scopeManager.getDeclaredVariables(o);if("Identifier"!==o.id.type){for(const e of r)n.set(e,{kind:"unsupported",reason:"binding pattern"});continue}const[i]=r;i&&("const"===e.kind?n.set(i,{kind:"const",expression:o.init??null}):n.set(i,{kind:"mutable",declarationKind:e.kind}))}}function wn(e,t,n){"VariableDeclaration"!==e.type&&vn(e,t,n)}function vn(e,t,n){if("Identifier"!==e.type)if("MemberExpression"!==e.type)if("ObjectPattern"!==e.type)if("ArrayPattern"!==e.type)"RestElement"!==e.type?"AssignmentPattern"===e.type&&vn(e.left,t,n):vn(e.argument,t,n);else for(const o of e.elements)o&&vn(o,t,n);else for(const o of e.properties)vn("RestElement"===o.type?o.argument:o.value,t,n);else{const o=kn(e);o&&$n(o,t,n,"mutated object binding")}else $n(e,t,n,"reassigned binding")}function $n(e,t,n,o){const r=gt(e,t);if(!r||yt(r)||!n.has(r))return;const i=n.get(r);"mutable"!==i?.kind&&n.set(r,{kind:"unsupported",reason:o})}function kn(e){return"Identifier"===e.type?e:"MemberExpression"===e.type?kn(e.object):void 0}function xn(e){return"Identifier"===e.type?e.name:String(e.value)}function En(e){const t=e.exported;return t?xn(t):void 0}function Sn(e,t){return e.find((e=>e.source===t))?.resolvedId??t}function In(e){const t=[];return ft(e,t,{ImportExpression(e,{state:t}){const n=function(e){return jn(e.source,"non-literal dynamic import")}(e);Dn(n)&&t.push({specifier:n,kind:"dynamic-import"})},CallExpression(e,{state:t}){if(function(e){return"Import"===e.callee.type}(e)){const n=function(e){return jn(e.arguments[0],"non-literal dynamic import")}(e);Dn(n)&&t.push({specifier:n,kind:"dynamic-import"})}else(function(e){if("Identifier"!==e.callee.type||"require"!==e.callee.name)return!1;const[t]=e.arguments;return!t||!ot(t)||Mn(t.value)})(e)&&t.push({specifier:An(e),kind:"require"})}}),t}function Dn(e){return"non-literal dynamic import"===e||Mn(e)}function Pn(e,t){if(!ke.some((t=>e.endsWith(t))))return!1;const n=u.relative(u.resolve(t),e);return!n.startsWith("..")&&!u.isAbsolute(n)&&!n.split(u.sep).some((e=>cn.has(e)))}function An(e){return jn(e.arguments[0],"local require")}function jn(e,t){return ot(e)?e.value:t}function Mn(e){return e.startsWith(".")||e.startsWith("/")}function Tn(e,t){return new Error(`Unsupported local module graph for ${e}: ${t} could hide an action-catalog connectionId.`)}function Cn(e,t,n){const o=new Set;return function(e,t,n,o){const r=[e],i=new Set;for(;r.length>0;){const s=r.shift();if(i.has(s))continue;i.add(s);const a=t.get(s);if(!a)throw Tn(e,`missing module record for ${s}`);o({entryId:e,moduleId:s,record:a});for(const t of a.unsupportedDependencies)throw Tn(e,`${t.kind} ${t.specifier}`);for(const o of a.staticDependencies){const i=o.resolvedId;if(Pn(i,n)){if(!t.has(i))throw Tn(e,`uncollected local import ${i} from ${a.id}`);r.push(i)}}}}(e,t,n,(({record:e})=>{const n=function(e){const t=new Set,n=new Set;for(const r of e.body)if("ImportDeclaration"===r.type&&"string"==typeof(o=r.source.value)&&(o===jt||o.startsWith(`${jt}/`))&&!rt(r))for(const e of r.specifiers)rt(e)||("ImportNamespaceSpecifier"===e.type?n.add(e.local.name):t.add(e.local.name));var o;return{functions:t,namespaces:n}}(e.ast),r=function(e,t){const n=new Set,o=new Set;for(const r of e.scopeManager.scopes)for(const e of r.variables)yt(e)&&(t.functions.has(e.name)&&n.add(e),t.namespaces.has(e.name)&&o.add(e));return{moduleScope:e,actionFunctions:n,actionNamespaces:o}}(e.scopeAnalysis,n);for(const n of vt(e.ast,r,e.id)){const r=On(n,t,e);r&&o.add(r)}})),[...o].sort()}function On(e,t,n){const[o]=e.arguments;if(!o||"ObjectExpression"!==o.type)throw _n(n.id,"non-object action-catalog call arguments");const r=function(e,t){let n;for(const o of e.properties){if("SpreadElement"===o.type)throw _n(t,"spread object arguments");if(o.computed)throw _n(t,"computed object property keys");if(Rn(o)){if(n)throw _n(t,"multiple connectionId properties");if("init"!==o.kind)throw _n(t,"accessor connectionId properties");if(!Nn(o))throw _n(t,"destructuring pattern in connectionId value");n=o}}return n}(o,n.id);if(!r)return;const i=function(e,t,n){return Lt({modules:e,mutatedImportedObjectVariables:Vt(e),seenVariables:new Set},t,n)}(t,n.id,r.value);if("resolved"===i.kind)return i.value;throw s=n.id,a=`static string resolution ${function(e){return"static-definition-unsupported"===e.reason?`${e.reason}/${e.definition.reason}`:e.reason}(i)}: ${i.message}`,new Error(`Unsupported action-catalog connectionId in ${s}: ${a}.`);var s,a}function Nn(e){const{value:t}=e;return"ObjectPattern"!==t.type&&"ArrayPattern"!==t.type&&"RestElement"!==t.type&&"AssignmentPattern"!==t.type}function Rn(e){return"connectionId"===function(e){if("Identifier"===e.key.type)return e.key.name;if("Literal"===e.key.type&&"string"==typeof e.key.value)return e.key.value;return}(e)}function _n(e,t){return new Error(`Unsupported action-catalog call in ${e}: ${t} could hide a connectionId.`)}const Fn=/^(?:\0|virtual:)/;function zn(e){const t=new Map;return{plugin:{name:"dd-backend-module-graph-collector",moduleParsed(n){const o=Ln(n.id);if(r=o,Fn.test(r))return;var r;const i=dn(o,e,n.ast,function(e){return e.importedIdResolutions?.map((({id:e})=>e))??[...e.importedIds]}(n).map(Ln));i&&t.set(i.id,i)}},getModuleRecords:()=>t}}function Ln(e){return e.split("?")[0]}function Un(e,t){const n=zn(t);return{plugin:n.plugin,getAllowedConnectionIds:()=>Cn(e,n.getModuleRecords(),t)}}function Bn(e,t){return{name:e,enforce:"pre",resolveId:e=>t[e]?{id:e,moduleSideEffects:!0}:null,load:e=>t[e]?t[e]:null}}function qn(e,t,n=[]){return{configFile:!1,root:e,logLevel:"silent",build:{minify:!1,target:"esnext",rollupOptions:{output:{format:"es",exports:"named",inlineDynamicImports:!0},preserveEntrySignatures:"exports-only",treeshake:!1,onwarn(e,t){"MODULE_LEVEL_DIRECTIVE"!==e.code&&t(e)}}},resolve:{extensions:[...ke,".json"]},plugins:[Bn("dd-backend-resolve",t),...n]}}function Vn(e){return`${e.relativePath}/${e.name}`}async function Kn(e,t,n,o){const r=Vn(t),i=`virtual:dd-backend-dev:${r}`,s=function(e,t,n){return pt(e,t,n??process.cwd())}(t.name,t.absolutePath,n),a=Un(t.absolutePath,n);o.debug(`Bundling backend function "${r}" from ${t.absolutePath}`);const u=qn(n,{[i]:s},[a.plugin]),c=await e({...u,build:{...u.build,write:!1,rollupOptions:{...u.build.rollupOptions,input:i,output:u.build.rollupOptions.output}}}),d=Array.isArray(c)?c[0]:c;if(!("output"in d))throw new Error(`Unexpected vite.build result for "${r}"`);const l="chunk"===d.output[0].type?d.output[0].code:"",p={...t,allowedConnectionIds:a.getAllowedConnectionIds()};return o.debug(`Bundled "${r}" (${l.length} bytes)`),{func:p,code:l}}async function Hn(e,t,n,o,r,i){const s=`https://api.${o.site}/api/v2/app-builder/queries/preview-async`,a=Vn(t);i.debug(`Calling Datadog API: ${s}`);const u=JSON.stringify({data:{type:"queries",attributes:{query:{id:f(),name:a,type:"action",properties:{spec:{fqn:"com.datadoghq.datatransformation.jsFunctionWithActions",inputs:{script:e,allowedConnectionIds:t.allowedConnectionIds,context:{backendFunctionArgs:n}}},onlyTriggerManually:!0}},template_params:{}}}}),c=await r({url:s,method:"POST",type:"json",getData:()=>({data:u,headers:{"Content-Type":"application/json"}})}),d=c.data?.id;if(!d)throw new Error("No receipt ID returned from Datadog API");return i.debug(`Query execution started with receipt: ${d}`),async function(e,t,n,o){const r=`https://api.${t.site}/api/v2/app-builder/queries/execution-long-polling/${e}`,i=10;for(let e=0;e<i;e++){o.debug(`Long-poll attempt ${e+1}/${i}...`);const t=await n({url:r,type:"json"});if(t.errors?.length){const e=t.errors.map((e=>e.detail||e.title)).join("; ");throw new Error(`Query execution failed: ${e}`)}const s=t.data?.attributes;if(o.debug(`Long-poll response, done: ${s?.done}`),s?.done){if(!s.outputs)throw new Error("Query execution completed without outputs");return s.outputs}}throw new Error("Query execution timed out")}(d,o,r,i)}function Wn(e,t,n){e.statusCode=t,e.setHeader("Content-Type","application/json"),e.end(JSON.stringify({success:!1,error:n}))}class Jn extends Error{constructor(e,t){super(t),this.statusCode=e}}async function Gn(e,t,n){const{functionName:o,args:r=[]}=await function(e){return new Promise(((t,n)=>{let o="";e.on("data",(e=>{o+=e.toString()})),e.on("end",(()=>{try{t(JSON.parse(o))}catch{n(new Error("Invalid JSON body"))}})),e.on("error",n)}))}(e);if(!o||"string"!=typeof o)throw new Jn(400,"Missing or invalid functionName");const i=t.get(o);if(!i)throw new Jn(404,`Backend function "${o}" not found`);return{...await n(i),args:r}}function Yn(e,t,n,o,r,i){const s=t=>Kn(e,t,r,i),a=t();return a.length>0&&i.info(`Dev server middleware active for ${a.length} backend function(s): ${a.map((e=>e.name)).join(", ")}`),o||i.warn(`Auth credentials not configured. The /__dd/executeAction endpoint will be unavailable. ${Xe}`),(e,r,a)=>{if("POST"!==e.method)return void a();const u=(c=t(),new Map(c.map((e=>[dt(e),e]))));var c;if("/__dd/debugBundle"===e.url)(async function(e,t,n,o){try{const{code:r}=await Gn(e,n,o);t.statusCode=200,t.setHeader("Content-Type","text/plain"),t.end(r)}catch(e){Wn(t,e instanceof Jn?e.statusCode:500,e instanceof Error?e.message:"Internal server error")}})(e,r,u,s).catch((()=>{Wn(r,500,"Unexpected error")}));else if("/__dd/executeAction"===e.url){if(!o)return void Wn(r,400,`Auth credentials not configured. ${Xe}`);(async function(e,t,n,o,r,i,s){try{const{func:a,code:u,args:c}=await Gn(e,n,o),d=Vn(a);s.debug(`Executing action: ${d} with args`);const l=await Hn(u,a,c,r,i,s);t.statusCode=200,t.setHeader("Content-Type","application/json"),t.end(JSON.stringify({success:!0,result:l}))}catch(e){const n=e instanceof Jn?e.statusCode:500,o=e instanceof Error?e.message:"Internal server error";s.debug(`Error handling executeAction: ${o}`),Wn(t,n,o)}})(e,r,u,s,n,o,i).catch((()=>{Wn(r,500,"Unexpected error")}))}else a()}}const Qn=async(e,t)=>{const n=(await Promise.all(e.map((e=>w(e,{absolute:!0,cwd:t,nodir:!0}))))).flat(),o=Array.from(new Set(n)).map((e=>u.relative(t,e))),r=(e=>{if(0===e.length)return"";const t=e[0].split(u.sep);let n="";for(let o=0;o<t.length-1;o++){const r=t.slice(0,o+1).join(u.sep);if(!e.every((e=>e.startsWith(`${r}${u.sep}`))))break;n=r}return n})(o);return o.map(((e,t)=>{const o=r?e.slice(r.length+1):e;return{absolutePath:n[t],relativePath:o.split(u.sep).join("/")}}))},Zn=(e,t)=>X(t)?O:t.startsWith(e)||u.isAbsolute(t)?t:u.resolve(e,t),Xn=(e,t)=>{let n,o=Zn(process.cwd(),e);for(;!n;){const e=u.resolve(o,t);if(Ae(e)&&(n=e),o=o.split(u.sep).slice(0,-1).join(u.sep),[u.sep,""].includes(o))break}return n},eo=(e,t)=>{const n=[...e].map((e=>Zn(t||process.cwd(),e).split(u.sep))),o=n.length?Math.min(...n.map((e=>e.length))):0,r=[];for(let e=0;e<o;e++){const t=n[0][e];if(!n.every((n=>n[e]===t)))break;r.push(t)}return r.length>0&&r.join(u.sep)||u.sep},to=t.bold.red,no=t.bold.yellow,oo=e=>{const t=Xn(e,"package.json");if(t)try{const e=Pe(t);return JSON.parse(e)}catch(e){return}},ro=(e,t,n)=>{if(n?.name&&n?.identifier)return{identifier:n?.identifier,name:n.name};const o=oo(e);o||t.warn(no("No package.json found to infer the app name."));const r=n?.name||o?.name?.trim();r||t.error(to("Unable to determine the app name to compute the app identifier."));const i=((e,t)=>{const n=e||(e=>{if(e&&e.repository)return"string"==typeof e.repository?e.repository:"url"in e.repository?e.repository.url:void 0})(t);if(!n)return;const o=re(n.trim());return o?o.replace(/\.git$/,""):void 0})(n?.url,o);i||t.error(to("Unable to determine the git remote to compute the app identifier."));const s=n?.identifier||((e,t)=>{if(!e||!t)return;const n=`${e}:${t}`;return p("sha256").update(n).digest("hex").slice(0,32)})(i,r);return s&&r||t.error(to("Unable to compute the app identifier.")),{identifier:s,name:r}},io=t.green.bold,so=t.yellow.bold,ao=t.cyan.bold,uo=t.bold,co=(e,t={},n)=>async()=>{const o=await je(e,{contentType:"application/zip",filename:ve});return J({getForm:()=>{const e=new FormData;e.append("name",n),e.append("bundle",o,ve);const t=q("APPS_VERSION_NAME")?.trim();return t&&e.append("version",t),e},defaultHeaders:t,zip:!1})},lo=async(e,t,n)=>{const o=[],r=[],i=t.doAuthenticatedRequest;if(!t.identifier)return o.push(new Error("No app identifier provided")),{errors:o,warnings:r};const s=(a=t.site,u=t.identifier,q("APPS_INTAKE_URL")||`https://api.${a}/${we}/${u}/upload`);var a,u;const d=W({bundler:t.bundlerName,plugin:"apps",version:t.version}),l=se({identifier:t.identifier,intakeUrl:s,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),p=`an archive of:\n - ${io(e.assets.length.toString())} files\n - ${io(v(e.size))}\n\nWith the configuration:\n${l}`;if(t.dryRun)return n.error(`\n${ao("Dry run enabled")}\n\nSkipping assets upload.\nWould have uploaded ${p}`),{errors:o,warnings:r};try{const o=await i({url:s,method:"POST",type:"json",getData:co(e.archivePath,d,t.name),onRetry:(e,t)=>{const o=`Failed to upload archive (attempt ${so(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}});if(n.debug(`Uploaded ${p}\n`),o.app_builder_id){const e=`https://app.${t.site}/app-builder/apps/${o.app_builder_id}`;n.info(`Your application is available at:\n ${ao(e)}`)}if(o.version_id){const e=((e,t)=>`https://api.${e}/${we}/${t}/release/live`)(t.site,t.identifier);await i({url:e,method:"PUT",type:"json",getData:async()=>({data:c.from(JSON.stringify({version_id:o.version_id})),headers:{"Content-Type":"application/json",...d}}),onRetry:(e,t)=>{const o=`Failed to release version (attempt ${so(`${t}/5`)}): ${e.message}`;r.push(o),n.warn(o)}}),n.info(`Published uploaded version ${uo(o.version_id)} to live.`)}}catch(e){const t=e instanceof Error?e:new Error(String(e));o.push(t)}return{errors:o,warnings:r}},po=t.yellow.bold,fo=t.red.bold,mo="manifest.json";async function ho(e){const t=await r.mkdtemp(u.join(h.tmpdir(),"dd-apps-manifest-")),n=u.join(t,mo);try{await r.writeFile(n,JSON.stringify(function(e){const t={};for(const n of e)t[dt(n)]={allowedConnectionIds:[...n.allowedConnectionIds]};return{backend:{functions:t}}}(e),null,2))}catch(e){throw await Se(t),e}return{manifestAsset:{absolutePath:n,relativePath:mo},cleanup:()=>Se(t)}}const go=async({backendOutputs:e,backendFunctions:t,context:n,doAuthenticatedRequest:o,options:i})=>{const a=n.getLogger(be),{auth:c,buildRoot:d,bundler:{name:l,outDir:p},git:f,version:m}=n,g=a.time("handle assets");let y,w,v;try{const n=a.time("resolve identifier"),{name:g,identifier:v}=ro(d,a,{url:f?.remote,name:i.name,identifier:i.identifier});if(!v||!g)throw new Error("Missing apps identification.\nEither:\n - pass an 'options.apps.identifier' and 'options.apps.name' to your plugin's configuration.\n - have a 'name' and a 'repository' in your 'package.json'.\n - have a valid remote url on your git project.\n");n.end();const $=u.relative(d,p),k=[...i.include,`${$}/**/*`],x=await Qn(k,d);if(!x.length)return void a.debug("No assets to upload.");const E=new Set(e.values()),S=x.filter((e=>!E.has(e.absolutePath))).map((e=>({...e,relativePath:`frontend/${e.relativePath}`})));for(const[t,n]of e)S.push({absolutePath:n,relativePath:`backend/${t}.js`});const{manifestAsset:I,cleanup:D}=await ho(t);w=D,S.push(I);const P=a.time("archive assets"),A=await(async e=>{const t=await r.mkdtemp(u.join(h.tmpdir(),"dd-apps-")),n=u.join(t,ve),o=new b;for(const t of e)o.file(t.relativePath,s.createReadStream(t.absolutePath),{binary:!0,compression:"DEFLATE",compressionOptions:{level:9}});await new Promise(((e,t)=>{const r=s.createWriteStream(n),i=o.generateNodeStream({type:"nodebuffer",streamFiles:!0,compression:"DEFLATE",compressionOptions:{level:9}});i.on("error",t),r.on("error",t),r.on("close",e),i.pipe(r)}));const{size:i}=await r.stat(n);return{archivePath:n,size:i,assets:e}})(S);P.end(),y=u.dirname(A.archivePath);const j=a.time("upload assets"),{errors:M,warnings:T}=await lo(A,{bundlerName:l,doAuthenticatedRequest:o,dryRun:i.dryRun,identifier:v,name:g,site:c.site,version:m},a);if(j.end(),T.length>0&&a.warn(`${po("Warnings while uploading assets:")}\n - ${T.join("\n - ")}`),M.length>0){const e=M.map((e=>e.cause||e.stack||e.message||e)).join("\n - ");throw new Error(` - ${e}`)}}catch(e){v=e,a.error(`${fo("Failed to upload assets:")}\n${e?.message||e}`)}if(y&&await Se(y),w&&await w(),g.end(),v)throw v};const yo=u.join(T,"./apps-runtime.mjs"),bo=async()=>{throw new Error("Dry run should not perform authenticated requests.")},wo=({bundler:e,context:t,options:n})=>{const o=t.getLogger(be),{auth:r,buildRoot:s}=t;t.inject({type:"file",position:Te.MIDDLE,value:yo});const{setBackendFunctions:a,getBackendFunctions:c}=function(){const e=new Map;return{setBackendFunctions(t,n){e.set(t,n)},getBackendFunctions:()=>Array.from(e.values()).flat()}}();return{transform:{filter:{id:{include:[$e],exclude:[/node_modules/,/[/\\]dist[/\\]/]}},handler(e,t){const n=it(this.parse(e),t);if(0===n.length)return o.warn(`Backend file ${t} has no exported functions. Did you forget to add a named export?`),a(t,[]),{code:"",map:null};const{functions:r,proxyCode:i}=function(e,t,n){const o=u.relative(n,t).replace($e,""),r=[],i=[];for(const n of e){const e={relativePath:o,name:n,absolutePath:t,allowedConnectionIds:[]};r.push(e),i.push({exportName:n,queryName:dt(e)})}return{functions:r,proxyCode:lt(i)}}(n,t,s);return a(t,r),o.debug(`Generated proxy for ${t} with ${r.length} export(s)`),{code:i,map:null}}},async closeBundle(){let a,d=new Map,l=c();if(l.length>0){const t=await async function(e,t,n,o){const r=await i(u.join(g(),"dd-apps-backend-")),s=new Map,a=new Map;o.debug(`Building ${t.length} backend function(s) via vite.build()`);for(const i of t){const t=dt(i),c=`\0dd-backend:${t}`,d=pt(i.name,i.absolutePath,n),l=Un(i.absolutePath,n),p=qn(n,{[c]:d},[l.plugin]),f=await e({...p,build:{...p.build,write:!0,outDir:r,emptyOutDir:!1,rollupOptions:{...p.build.rollupOptions,input:{[t]:c},output:{...p.build.rollupOptions.output,entryFileNames:"[name].js"}}}}),m=Array.isArray(f)?f[0]:f;if("output"in m)for(const e of m.output){if("chunk"!==e.type||!e.isEntry)continue;const n=u.resolve(r,e.fileName);s.set(t,n),o.debug(`Backend function "${t}" output: ${n}`)}a.set(i.absolutePath,l.getAllowedConnectionIds())}return{outDir:r,outputs:s,functions:t.map((e=>({...e,allowedConnectionIds:a.get(e.absolutePath)})))}}(e.build,l,s,o);a=t.outDir,d=t.outputs,l=t.functions}try{const e=n.dryRun?bo:tt(n.authOverrides.method,r,o);await go({backendOutputs:d,backendFunctions:l,context:t,doAuthenticatedRequest:e,options:n})}finally{a&&await Se(a)}},configureServer(t){let i;try{i=tt(n.authOverrides.method,r,o)}catch(e){if(!(e instanceof et))throw e}t.middlewares.use(Yn(e.build,c,r,i,s,o))}}},vo=({options:e,context:t,bundler:n})=>{const o=t.getLogger(be),r=Ee(e);return"vite"!==t.bundler.name?(o.warn(`The apps plugin only supports Vite; skipping under '${t.bundler.name}'.`),[]):[{name:be,enforce:"post",vite:wo({bundler:n,context:t,options:r})}]},$o="errorTracking",ko="datadog-error-tracking-plugin",xo=(e,n,o)=>{if(".map"!==u.extname(o))throw new Error(`The file ${t.green.bold(o)} is not a sourcemap.`);const r=o.replace(/\.map$/,""),i=u.relative(n,r),s=((e,t)=>{if(e.startsWith("/"))return u.join(e,t);try{const n=e.replace(/\/*$/,"/"),o=new URL(n),r=t.replace(/^[\\/]*/,"");return new URL(r,o).href}catch{return`${e}${t}`}})(e,i);return{minifiedFilePath:r,minifiedUrl:s,relativePath:i}},Eo=/[/]+|[\\]+/g,So=/^[/]+|^[\\]+|[/]+$|[\\]+$/g,Io=(e,t)=>{const n=e.replace(So,"").split(Eo),o=t.replace(So,"").split(Eo),r=n.join("/");let i="";for(let e=0;e<o.length;e+=1){const t=o.slice(-e).join("/");r.startsWith(t)&&(i=t)}return i},Do=async(e,t,n,o)=>{const r=await(async(e,t)=>{const[n,o]=await Promise.all([Me(e.minifiedFilePath),Me(e.sourcemapFilePath)]);return{file:n,sourcemap:o,repeatedPrefix:Io(e.relativePath,t)}})(e,n),i=[],s=[],a=new Map([["event",{type:"string",options:{contentType:"application/json",filename:"event"},value:JSON.stringify({...t,minified_url:e.minifiedUrl})}],["source_map",{type:"file",path:e.sourcemapFilePath,options:{filename:"source_map",contentType:"application/json"}}],["minified_file",{type:"file",path:e.minifiedFilePath,options:{filename:"minified_file",contentType:"application/javascript"}}]]);if(o)try{a.set("repository",{type:"string",options:{contentType:"application/json",filename:"repository"},value:JSON.stringify({data:[{files:o.trackedFilesMatcher.matchSourcemap(e.sourcemapFilePath,(t=>{s.push(`${u.basename(e.sourcemapFilePath)}: "${t}"`)})),hash:o.hash,repository_url:o.remote}],version:1})})}catch(t){s.push(`Could not attach git data for sourcemap ${e.sourcemapFilePath}: ${t.message}`)}return r.file.empty&&i.push(`Minified file is empty: ${e.minifiedFilePath}`),r.file.exists||i.push(`Minified file not found: ${e.minifiedFilePath}`),r.sourcemap.empty&&i.push(`Sourcemap file is empty: ${e.sourcemapFilePath}`),r.sourcemap.exists||i.push(`Sourcemap file not found: ${e.sourcemapFilePath}`),r.repeatedPrefix&&s.push(`The minified file path contains a repeated pattern with the minified path prefix: ${r.repeatedPrefix}`),{content:a,errors:i,warnings:s}},Po=e=>{const t=e.message.match(/HTTP (\d{3})/);return t?`status_code:${t[1]}`:"status_code:unknown"},Ao=e=>{const t=Po(e);return"status_code:unknown"!==t?`error_type:http_${t.replace("status_code:","")}`:`error_type:${ie(e.name||"unknown")}`},jo=(e,t,n)=>{const o=((e,t)=>`${e}|${t.join("|")}`)(t,n),r=e.metrics.get(o);r?r.value++:e.metrics.set(o,{name:t,value:1,tags:n})},Mo=(e,t,n)=>{jo(e,"retry",[...e.baseTags,`attempt:${n}`,Po(t),Ao(t)])},To=(e,t)=>{jo(e,"failure",[...e.baseTags,Po(t),Ao(t)])},Co=(e,t)=>{if(!t.sendMetrics)return;if(!e.metrics.size)return;const n=(e=>{const t=Math.floor(Date.now()/1e3);return Array.from(e.metrics.values()).map((e=>({metric:`sourcemaps.upload.${e.name}`,type:"count",points:[[t,e.value]],tags:e.tags})))})(e);for(const e of n)t.addMetric(e)},Oo=t.green.bold,No=t.yellow.bold,Ro=t.red.bold,_o=(e,t={})=>async()=>J({getForm:async()=>{const t=new FormData;for(const[n,o]of e.content){const e="file"===o.type?await je(o.path,o.options):new Blob([o.value],{type:o.options.contentType});t.append(n,e,o.options.filename)}return t},defaultHeaders:t,zip:!0}),Fo=async(e,t,n,o)=>{const r=[],i=[];if(!n.apiKey)return r.push({error:new Error("No authentication token provided")}),{errors:r,warnings:i};if(0===e.length)return i.push("No sourcemaps to upload"),{errors:r,warnings:i};const s=o.time("Queue uploads"),a=new($.default?$.default:$)({concurrency:t.maxConcurrency}),u=(c=n.site,q("SOURCEMAP_INTAKE_URL")||`https://sourcemap-intake.${c}/api/v2/srcmap`);var c;const d=W({bundler:n.bundlerName,plugin:"sourcemaps",version:n.version}),l=(e=>({metrics:new Map,baseTags:[`service:${e.service}`]}))(t),p=se({...t,intakeUrl:u,outDir:n.outDir,defaultHeaders:`\n${JSON.stringify(d,null,2)}`}),f=`\nUploading ${Oo(e.length.toString())} sourcemaps with configuration:\n${p}`;o.debug(f);const m=[];for(const s of e){const e={sourcemap:s.content.get("source_map")?.path.replace(n.outDir,"."),file:s.content.get("minified_file")?.path.replace(n.outDir,".")};m.push(a.add((async()=>{try{await Y({auth:{apiKey:n.apiKey},url:u,method:"POST",getData:_o(s,d),onRetry:(t,n)=>{Mo(l,t,n);const r=`Failed to upload ${No(e.sourcemap)} | ${No(e.file)}:\n ${t.message}\nRetrying ${n}/5`;i.push(r),o.debug(r)}})}catch(n){if(To(l,n),r.push({metadata:e,error:n}),!0===t.bailOnError)throw n}})))}s.end(),o.debug(`Queued ${Oo(e.length.toString())} uploads.`);try{await Promise.all(m),await a.onIdle()}finally{Co(l,n)}return{warnings:i,errors:r}},zo=async(e,t,n)=>{const o=n.time("get sourcemaps files"),r=((e,t)=>{if(!t.outputs||0===t.outputs.length)throw new Error("No output files found.");return t.outputs.filter((e=>e.filepath.endsWith(".map"))).map((e=>e.filepath)).map((n=>({...xo(e.minifiedPathPrefix,t.outDir,n),sourcemapFilePath:n,minifiedPathPrefix:e.minifiedPathPrefix})))})(e.sourcemaps,{outDir:t.outDir,outputs:t.outputs});o.end();const i=n.time("send sourcemaps");await(async(e,t,n,o)=>{const r=Date.now(),i=t.minifiedPathPrefix,s={git_repository_url:n.git?.remote,git_commit_sha:n.git?.hash,plugin_version:n.version,project_path:n.outDir,service:t.service,type:"js_sourcemap",version:t.releaseVersion},a=o.time("Compute payloads"),u=await Promise.all(e.map((e=>Do(e,s,i,n.git))));a.end();const c=u.map((e=>e.errors)).flat(),d=u.map((e=>e.warnings)).flat();if(d.length>0&&o.warn(`Warnings while preparing payloads:\n - ${d.join("\n - ")}`),c.length>0){const e=`Failed to prepare payloads, aborting upload :\n - ${c.join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e);return}const l=o.time("Upload sourcemaps"),{errors:p,warnings:f}=await Fo(u,t,{apiKey:n.apiKey,bundlerName:n.bundlerName,version:n.version,outDir:n.outDir,site:n.site,sendMetrics:n.sendMetrics,addMetric:n.addMetric},o);if(l.end(),o.debug(`Done uploading ${Oo(`${e.length-p.length}/${e.length}`)} sourcemaps in ${Oo(ne(Date.now()-r))}.`),p.length>0){const e=`Failed to upload some sourcemaps:\n - ${p.map((({metadata:e,error:t})=>{const n=t.cause||t.stack||t.message;return e?`${Ro(e.file)} | ${Ro(e.sourcemap)} :\n${n}`:n})).join("\n - ")}`;if(o.error(e),!0===t.bailOnError)throw new Error(e)}f.length>0&&o.warn(`Warnings while uploading sourcemaps:\n - ${f.join("\n - ")}`)})(r,e.sourcemaps,{addMetric:t.addMetric,apiKey:t.apiKey,bundlerName:t.bundlerName,git:t.git,outDir:t.outDir,sendMetrics:t.sendMetrics,site:t.site,version:t.version},n),i.end()},Lo=e=>{const n=t.bold.red,o=e[$o]||{},r={errors:[]};if(o.sourcemaps){const t=o.sourcemaps,i=t.releaseVersion||e.metadata?.version;i||r.errors.push(`${n("sourcemaps.releaseVersion")} is required (set it directly or via ${n("metadata.version")}).`),t.releaseVersion&&e.metadata?.version&&t.releaseVersion!==e.metadata.version&&r.errors.push(`${n("sourcemaps.releaseVersion")} must match ${n("metadata.version")} when both are configured.`),t.service||r.errors.push(`${n("sourcemaps.service")} is required.`),t.minifiedPathPrefix||r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} is required.`),t.minifiedPathPrefix&&!(e=>{let t;try{t=new URL(e).host}catch{}return!(!t&&!e.startsWith("/"))})(t.minifiedPathPrefix)&&r.errors.push(`${n("sourcemaps.minifiedPathPrefix")} must be a valid URL or start with '/'.`),i&&(r.config={bailOnError:!1,dryRun:!1,maxConcurrency:20,...t,releaseVersion:i})}return r},Uo=({options:e,context:t})=>{const n=t.getLogger(ko),o=n.time("validate options"),r=((e,t)=>{const n=[],o=Lo(e);if(n.push(...o.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${ko}.`);return{...e[$o],sourcemaps:o.config}})(e,n);o.end();const i=ge(e,"metrics",n);let s,a,u=!1;const c=async()=>{if(!r.sourcemaps||u)return;u=!0;const e=n.time("sourcemaps process");await zo(r,{apiKey:t.auth.apiKey,bundlerName:t.bundler.name,git:s,addMetric:t.addMetric,outDir:t.bundler.outDir,outputs:a?.outputs||[],sendMetrics:i,site:t.auth.site,version:t.version},n),e.end()};return[{name:ko,enforce:"post",async git(e){s=e,a&&await c()},async buildReport(t){a=t,!s&&te(e)||await c()},async asyncTrueEnd(){u||await c()}}]},Bo="liveDebugger",qo="datadog-live-debugger-plugin",Vo="if(typeof globalThis.$dd_probes==='undefined'){globalThis.$dd_probes=function(){}}",Ko="__DD_LIVE_DEBUGGER_BUILD__",Ho=e=>void 0===e?Vo:`${Vo};if(typeof globalThis.${Ko}==='undefined'){globalThis.${Ko}={version:${JSON.stringify(e)}}}`;function Wo(e){return"function"==typeof e?e:e.default}function Jo(e,t,n,o,r){const i=u.relative(t,e).replace(/\\/g,"/"),s=Go(n,r);if(s)return`${i};${s}`;const a=function(e){const t=e.node.loc?.start.line??0,n=e.node.loc?.start.column??0;return`${t}:${n}`}(n);return`${i};<anonymous>@${a}:${o}`}function Go(e,t){const n=e.node,o=e.parent;return"id"in n&&t.isIdentifier(n.id)?n.id.name:t.isObjectMethod(n)||t.isClassMethod(n)||t.isClassPrivateMethod(n)?Zo(n.key,t):t.isVariableDeclarator(o)&&t.isIdentifier(o.id)?o.id.name:t.isAssignmentExpression(o)?function(e,t){if(t.isIdentifier(e))return e.name;if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=Yo(e.object,t),o=Qo(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}(o.left,t):t.isObjectProperty(o)||t.isClassProperty(o)||t.isClassPrivateProperty(o)?Zo(o.key,t):null}function Yo(e,t){if(t.isIdentifier(e))return e.name;if(t.isThisExpression(e))return"this";if(t.isMemberExpression(e)||t.isOptionalMemberExpression(e)){const n=Yo(e.object,t),o=Qo(e.property,e.computed,t);if(n&&o)return`${n}.${o}`}return null}function Qo(e,t,n){return n.isPrivateName(e)&&n.isIdentifier(e.id)?`#${e.id.name}`:t?null:n.isIdentifier(e)?e.name:null}function Zo(e,t){return t.isIdentifier(e)?e.name:t.isStringLiteral(e)||t.isNumericLiteral(e)||t.isBigIntLiteral(e)?String(e.value):t.isPrivateName(e)&&t.isIdentifier(e.id)?`#${e.id.name}`:null}function Xo(e,t){if(e.node.leadingComments)for(const n of e.node.leadingComments)if(n.value.includes(t))return!0;return!1}function er(e,t){const n=[];if(t.isBlockStatement(e.body)){const o=e.params.flatMap((e=>sr(e,t))),r=new Set(o),i="id"in e&&t.isIdentifier(e.id)?e.id.name:"";for(const o of e.body.body)if(t.isVariableDeclaration(o)){const e=o.end;if(null==e)continue;for(const s of o.declarations)for(const o of sr(s.id,t))r.has(o)||o===i||n.push({name:o,declarationEnd:e,temporalDeadZones:[]})}}const o=n.length>25?n.slice(0,25):n;if(t.isBlockStatement(e.body)){const n=o.map((({name:e})=>e)),r=new Set(n),i=function(e,t,n){const o=new Map;for(const r of e.body)tr(r,t,o,n);return o}(e.body,r,t);for(const e of o)e.temporalDeadZones=i.get(e.name)??[]}return o}function tr(e,t,n,o){o.isFunctionDeclaration(e)||o.isClassDeclaration(e)||(o.isBlockStatement(e)?nr(e,t,n,o):o.isIfStatement(e)?(tr(e.consequent,t,n,o),e.alternate&&tr(e.alternate,t,n,o)):o.isForStatement(e)||o.isForInStatement(e)||o.isForOfStatement(e)||o.isWhileStatement(e)||o.isDoWhileStatement(e)?tr(e.body,t,n,o):o.isSwitchStatement(e)?function(e,t,n,o){for(const r of e.cases){or(r.consequent,e.start,t,n,o);for(const e of r.consequent)tr(e,t,n,o)}}(e,t,n,o):o.isTryStatement(e)?(nr(e.block,t,n,o),e.handler&&nr(e.handler.body,t,n,o),e.finalizer&&nr(e.finalizer,t,n,o)):(o.isLabeledStatement(e)||o.isWithStatement(e))&&tr(e.body,t,n,o))}function nr(e,t,n,o){or(e.body,e.start,t,n,o);for(const r of e.body)tr(r,t,n,o)}function or(e,t,n,o,r){if(null!=t)for(const i of e)r.isVariableDeclaration(i)&&"var"!==i.kind?rr(i,t,n,o,r):r.isClassDeclaration(i)&&i.id&&ir(i.id.name,t,i.end,n,o)}function rr(e,t,n,o,r){for(const i of e.declarations)for(const s of sr(i.id,r))ir(s,t,e.end,n,o)}function ir(e,t,n,o,r){if(null==n||!o.has(e))return;const i=r.get(e)??[];i.push({start:t,end:n}),r.set(e,i)}function sr(e,t){return t.isIdentifier(e)?[e.name]:t.isRestElement(e)?t.isIdentifier(e.argument)?[e.argument.name]:sr(e.argument,t):t.isAssignmentPattern(e)?sr(e.left,t):t.isObjectPattern(e)?e.properties.flatMap((e=>t.isRestElement(e)?sr(e.argument,t):sr(e.value,t))):t.isArrayPattern(e)?e.elements.flatMap((e=>e?sr(e,t):[])):t.isTSParameterProperty(e)&&t.isIdentifier(e.parameter)?[e.parameter.name]:[]}const ar=["@babel/parser","@babel/traverse","@babel/types","magic-string"];let ur,cr,dr,lr,pr=!1;function fr(e){try{return function(e){switch(e){case"@babel/parser":return C("@babel/parser");case"@babel/traverse":return C("@babel/traverse");case"@babel/types":return C("@babel/types");case"magic-string":return C("magic-string");default:throw new Error(`Unknown peer dependency: ${e}`)}}(e)}catch(e){throw function(e){if(!function(e){if(!(e instanceof Error))return!1;const t=e.code;if("MODULE_NOT_FOUND"!==t&&"ERR_MODULE_NOT_FOUND"!==t)return!1;return ar.some((t=>e.message.includes(t)))}(e))return e instanceof Error?e:new Error(String(e));const t=ar.find((t=>e.message.includes(t))),n=t??ar.join(", ");return new Error(`Datadog Live Debugger could not load "${n}". It is an optional peer dependency that must be installed in your project when the \`liveDebugger\` plugin is enabled. Install the peer dependencies with: \`npm install --save-dev ${ar.join(" ")}\` (or the yarn/pnpm/bun equivalent). Underlying error: ${e.message}`)}(e)}}const mr=/\bfunction\b|=>|\bclass\b|\)\s*\{/;function hr(e){const{code:t,filePath:n,buildRoot:o,honorSkipComments:r,functionTypes:i,namedOnly:s}=e;let a=0,u=0,c=0,d=0,l=0;if(function(e){return/['"][^'"]*(?:@css-module:|\?worker\b|\?sprite\b|dynamic!)[^'"]*['"]/.test(e)}(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:1,skippedUnsupportedCount:d,totalFunctions:l};if(!mr.test(t))return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l};pr||(ur=fr("@babel/parser").parse,cr=Wo(fr("@babel/traverse")),dr=fr("@babel/types"),lr=Wo(fr("magic-string")),pr=!0);const p=ur(t,{sourceType:"unambiguous",plugins:["jsx","typescript"],sourceFilename:n}),f=[],m=new Map,h=new Set,g=new Map,y=new Map;let b=0;if(cr(p,{Function(e){l++;const t=function(e,t){if(t.isClassMethod(e.node)&&"constructor"===e.node.kind&&kr(e,t))return e.node;return}(e,dr);if(t&&(m.set(t,t.body.start),g.set(t,function(e,t){const n=[];for(const o of e)br(o,n,t);return n}(t.body.body,dr))),!function(e,t){const n=e.node;return!(n.generator||t.isClassMethod(n)&&"constructor"===n.kind)}(e,dr))return void d++;if(r&&function(e,t,n){let o=e;for(;o;){if(Xo(o,t))return!0;if(n.isStatement(o.node)||n.isExportDeclaration(o.node)){if(o.parentPath&&n.isExportDeclaration(o.parentPath.node))return Xo(o.parentPath,t);break}o=o.parentPath}return!1}(e,"@dd-no-instrumentation",dr))return void c++;if(i&&!i.includes(function(e,t){if(t.isFunctionDeclaration(e))return"functionDeclaration";if(t.isArrowFunctionExpression(e))return"arrowFunction";if(t.isObjectMethod(e))return"objectMethod";if(t.isClassPrivateMethod(e))return"classPrivateMethod";if(t.isClassMethod(e))return"classMethod";return"functionExpression"}(e.node,dr)))return void d++;if(s&&!Go(e,dr))return void d++;let p=0;if(!Go(e,dr)){const t=e.parentPath?.node;t&&(p=y.get(t)||0,y.set(t,p+1))}const w=Jo(n,o,e,p,dr);try{const t=e.node,n=b++,o=`$dd_p${n}`,r=function(e,t){const n=[];for(const o of e.params)for(const e of sr(o,t))"this"!==e&&n.push(e);return n.length>25?n.slice(0,25):n}(t,dr),i=er(t,dr),s=dr.isArrowFunctionExpression(t)&&!dr.isBlockStatement(t.body),a=s&&dr.isSequenceExpression(t.body),c=function(e,t){if(t.isFunction(e.node)&&!t.isArrowFunctionExpression(e.node))return;let n=e.parentPath;for(;n;){const e=n.node;if(t.isClassMethod(e)&&"constructor"===e.kind){if(!kr(n,t))return;return{node:e,parent:n.parent,parentPath:n.parentPath}}if(t.isFunction(e)){if(t.isArrowFunctionExpression(e)){n=n.parentPath;continue}return}n=n.parentPath}return}(e,dr),d=null!=c;c&&(h.add(c.node),m.set(c.node,c.node.body.start));const l=[],p=s||!dr.isBlockStatement(t.body)||!Sr(t.body.body,dr);let g;if(!s&&dr.isBlockStatement(t.body)&&Er(t.body.body,l,dr),!s&&dr.isBlockStatement(t.body)&&t.body.directives.length>0){g=t.body.directives[t.body.directives.length-1].end}f.push({bodyStart:t.body.start,bodyEnd:t.body.end,functionEnd:t.end,isExpressionBody:s,hasSequenceExpressionBody:a,aliasesExpressionBodySuperCall:d&&s&&$r(t.body,dr),needsTrailingReturn:p,useThisAlias:d,bodyParenStart:s&&"number"==typeof t.body.extra?.parenStart?t.body.extra.parenStart:void 0,directivesEnd:g,functionId:w,probeVarName:o,probeIdx:String(n),entryVars:r,localVars:i,returns:l}),u++}catch(e){a++}}}),0===u)return{code:t,failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l};const w=new lr(t),v=function(e){const t=new Set;for(const n of e)n.aliasesExpressionBodySuperCall&&t.add(vr({start:n.bodyStart,end:n.bodyEnd}));return t}(f),$=function(e,t,n,o){const r=[];for(const i of e){const e=t.get(i);null!=e&&r.push({bodyStart:e,superCalls:(n.get(i)??[]).filter((e=>!o.has(vr(e))))})}return r}(h,m,g,v);for(let e=f.length-1;e>=0;e--)gr(w,t,f[e]);for(const e of $)yr(w,t,e);return{code:w.toString(),map:w.generateMap({source:n,hires:!0}),failedCount:a,instrumentedCount:u,skippedByCommentCount:c,skippedFileCount:0,skippedUnsupportedCount:d,totalFunctions:l}}function gr(e,t,n){const{probeVarName:o,probeIdx:r,functionId:i,entryVars:s,localVars:a,returns:u,bodyStart:c,bodyEnd:d,functionEnd:l,isExpressionBody:p,hasSequenceExpressionBody:f,aliasesExpressionBodySuperCall:m,useThisAlias:h,bodyParenStart:g,directivesEnd:y}=n,b=`$dd_e${r}`,w=`$dd_rv${r}`,v=h?"$dd_t":"this",$=s.join(", "),k=""!==$,x=k?`, ${b}()`:"";const E=`const ${o} = $dd_probes('${i.replace(/['\\\n\r\u2028\u2029]/g,(e=>{switch(e){case"'":return"\\'";case"\\":return"\\\\";case"\n":return"\\n";case"\r":return"\\r";case"\u2028":return"\\u2028";case"\u2029":return"\\u2029";default:return e}}))}');`,S=k?`const ${b} = () => ({${$}});`:"",I=`if (${o}) $dd_entry(${o}, ${v}${x});`,D=`catch(e) { if (${o}) $dd_throw(${o}, e, ${v}${x}); throw e; }`;if(p){if(null!=g){const n=function(e,t,n){const o=[];for(let r=t;r<n;r++)"("===e[r]&&o.push(r);return o}(t,g,c),o=function(e,t,n){const o=[];for(let r=n-1;r>=t;r--)")"===e[r]&&o.push(r);return o}(t,d,l),r=Math.min(n.length,o.length);for(let t=0;t<r;t++){const r=n[t],i=o[t];e.remove(r,r+1),e.remove(i,i+1)}}const n=["{",E,S,"try {",I,m?`const ${w} = ($dd_t = `:`const ${w} = `].filter(Boolean).join("\n");let r=f?");":";";m&&(r=f?"));":");");const i=[r,`if (${o}) $dd_return(${o}, ${w}, ${v}${xr(b,k,a,d)});`,`return ${w};`,`} ${D}`,"}"].join("\n");if(d-c>=2){const o=f?`${n}(${t[c]}`:n+t[c];e.update(c,c+1,o),e.update(d-1,d,t[d-1]+i)}else e.update(c,d,n+t.slice(c,d)+i)}else{const r=[E,S,"try {",`let ${w};`,I].filter(Boolean).join("\n");for(const t of u){const n=xr(b,k,a,t.start);if(null!=t.argStart&&null!=t.argEnd){const r=t.hasSequenceExpressionArgument?`(${w} = (`:`(${w} = `,i=t.hasSequenceExpressionArgument?")":"";e.appendLeft(t.argStart,r),e.appendLeft(t.argEnd,`${i}, ${o} ? $dd_return(${o}, ${w}, ${v}${n}) : ${w})`)}else e.appendLeft(t.start,`if (${o}) $dd_return(${o}, undefined, ${v}${n}); `)}if(null!=y){const n=y-1;e.update(n,y,`${t[n]}\n${r}`)}else e.update(c,c+1,`${t[c]}${r}`);const i=xr(b,k,a,d),s=`\n${n.needsTrailingReturn?`if (${o}) $dd_return(${o}, undefined, ${v}${i});\n`:""}} ${D}\n`;e.update(d-1,d,`${s}${t[d-1]}`)}}function yr(e,t,n){e.update(n.bodyStart,n.bodyStart+1,`${t[n.bodyStart]}let $dd_t;`);for(const t of n.superCalls)e.appendLeft(t.start,"($dd_t = "),e.appendLeft(t.end,")")}function br(e,t,n){$r(e,n)&&t.push({start:e.start,end:e.end});const o=Object.values(e);for(const e of o)if(Array.isArray(e))for(const o of e)wr(o,t,n);else wr(e,t,n)}function wr(e,t,n){n.isNode(e)&&(n.isFunction(e)&&!n.isArrowFunctionExpression(e)||br(e,t,n))}function vr(e){return`${e.start}:${e.end}`}function $r(e,t){return t.isCallExpression(e)&&t.isSuper(e.callee)}function kr(e,t){const n=e.parentPath?.parentPath;if(!n)return!1;const o=n.node;return(t.isClassDeclaration(o)||t.isClassExpression(o))&&null!=o.superClass}function xr(e,t,n,o){const r=function(e,t){const n=e.filter((({declarationEnd:e,temporalDeadZones:n})=>e<=t&&!function(e,t){return e.some((({start:e,end:n})=>e<=t&&t<n))}(n,t))).map((({name:e})=>e));if(0===n.length)return;return`{${n.join(", ")}}`}(n,o);return t&&r?`, ${e}(), ${r}`:t?`, ${e}()`:r?`, undefined, ${r}`:""}function Er(e,t,n){for(const o of e)if(n.isReturnStatement(o))t.push({start:o.start,end:o.end,argStart:o.argument?.start??void 0,argEnd:o.argument?.end??void 0,hasSequenceExpressionArgument:n.isSequenceExpression(o.argument)});else if(!n.isFunctionDeclaration(o)&&!n.isClassDeclaration(o))if(n.isBlockStatement(o))Er(o.body,t,n);else if(n.isIfStatement(o))Er([o.consequent],t,n),o.alternate&&Er([o.alternate],t,n);else if(n.isForStatement(o)||n.isForInStatement(o)||n.isForOfStatement(o)||n.isWhileStatement(o)||n.isDoWhileStatement(o))Er([o.body],t,n);else if(n.isSwitchStatement(o))for(const e of o.cases)Er(e.consequent,t,n);else n.isTryStatement(o)?(Er(o.block.body,t,n),o.handler&&Er(o.handler.body.body,t,n),o.finalizer&&Er(o.finalizer.body,t,n)):(n.isLabeledStatement(o)||n.isWithStatement(o))&&Er([o.body],t,n)}function Sr(e,t){if(0===e.length)return!1;const n=e[e.length-1];if(t.isReturnStatement(n))return!0;if(t.isIfStatement(n)&&n.alternate){const e=t.isBlockStatement(n.consequent)?n.consequent.body:[n.consequent],o=t.isBlockStatement(n.alternate)?n.alternate.body:[n.alternate];return Sr(e,t)&&Sr(o,t)}return!1}const Ir=["functionDeclaration","functionExpression","arrowFunction","objectMethod","classMethod","classPrivateMethod"],Dr=t.bold.red,Pr=Number(process.env.DD_LD_LIMIT)||1/0,Ar=(e,t)=>{const n=t.getLogger(qo);let o=0,r=0,i=0,s=0,a=0,u=0,c=0,d=0;return{name:qo,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(l,p){if(e.include.length>0){if(!e.include.some((e=>"string"==typeof e?p.includes(e):e.test(p))))return{code:l}}for(const t of e.exclude){if("string"==typeof t?p.includes(t):t.test(p))return{code:l}}if(d>=Pr)return{code:l};try{const f=hr({code:l,filePath:p,buildRoot:t.buildRoot,honorSkipComments:e.honorSkipComments,functionTypes:e.functionTypes,namedOnly:e.namedOnly});if(o+=f.instrumentedCount,c+=f.totalFunctions,r+=f.failedCount,i+=f.skippedByCommentCount,s+=f.skippedFileCount,a+=f.skippedUnsupportedCount,f.totalFunctions>0&&d++,0===f.instrumentedCount)return{code:l};u++;const m=function(e){const t=e.getNativeBuildContext?.();return t?.inputSourceMap}(this),h=f.map&&m?function(e,t,n,o){try{return k(e,((e,n)=>1===n.depth?t:null))}catch(t){return o.error(`Failed to compose source map for ${n}: ${t}`,{forward:!0}),e}}(f.map,m,p,n):f.map;return{code:f.code,map:h}}catch(e){return n.error(`Instrumentation Error in ${p}: ${e}`,{forward:!0}),{code:l}}}},buildEnd:()=>{c>0&&n.info(`Live Debugger: ${o}/${c} functions instrumented across ${u}/${d} files`,{forward:!0,context:{failedCount:r,skippedByCommentCount:i,skippedFileCount:s,skippedUnsupportedCount:a,totalFilesWithFunctions:d,instrumentedCount:o,totalFunctions:c,transformedFileCount:u}})}}},jr=({options:e,context:t})=>{const n=((e,t)=>{const n=e[Bo]||{},o=e.metadata?.version,r=[];if(void 0!==n.include)if(Array.isArray(n.include)){for(const e of n.include)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Dr("include")} patterns must be strings or RegExp`);break}}else r.push(`${Dr("include")} must be an array of strings or RegExp`);if(void 0!==n.exclude)if(Array.isArray(n.exclude)){for(const e of n.exclude)if("string"!=typeof e&&!(e instanceof RegExp)){r.push(`${Dr("exclude")} patterns must be strings or RegExp`);break}}else r.push(`${Dr("exclude")} must be an array of strings or RegExp`);if(void 0!==n.honorSkipComments&&"boolean"!=typeof n.honorSkipComments&&r.push(`${Dr("honorSkipComments")} must be a boolean`),void 0!==n.functionTypes)if(Array.isArray(n.functionTypes)){for(const e of n.functionTypes)if(!Ir.includes(e)){r.push(`${Dr("functionTypes")} contains invalid value "${e}". Valid values: ${Ir.join(", ")}`);break}}else r.push(`${Dr("functionTypes")} must be an array of FunctionKind values`);if(void 0!==n.namedOnly&&"boolean"!=typeof n.namedOnly&&r.push(`${Dr("namedOnly")} must be a boolean`),r.length)throw t.error(`\n - ${r.join("\n - ")}`),new Error(`Invalid configuration for ${qo}.`);return{version:o,include:n.include||[/\.[jt]sx?$/],exclude:n.exclude||[/\/node_modules\//,/\.min\.js$/,/\/pyodide-lib\//,/^vite\//,/\0/,/commonjsHelpers\.js$/,/__vite-browser-external/,/@datadog\/browser-/,/browser-sdk\/packages\//],honorSkipComments:n.honorSkipComments??!0,functionTypes:n.functionTypes,namedOnly:n.namedOnly??!1}})(e,t.getLogger(qo));return t.inject({type:"code",position:Te.BEFORE,injectIntoAllChunks:!0,value:Ho(n.version)}),[Ar(n,t)]};const Mr=[e=>/modules\.tree\.(count|size)$/.test(e.metric)?null:e,e=>e.tags.some((e=>/^assetName:.*\.map$/.test(e)||/^moduleName:\/node_modules/.test(e)))?null:e,e=>{const t={size:1e5,count:10,duration:1e3};/^sourcemaps\.upload\.(failure|retry)$/.test(e.metric)&&(t.count=0),/(entries|loaders|warnings|errors)\.count$/.test(e.metric)&&(t.count=0),/(modules\.(dependencies|dependents)$)/.test(e.metric)&&(t.count=30),/modules\.tree\.count$/.test(e.metric)&&(t.count=150),/modules\.tree\.size$/.test(e.metric)&&(t.size=15e5),/entries\.size$/.test(e.metric)&&(t.size=0),/entries\.modules\.count$/.test(e.metric)&&(t.count=0);return(e.points.length?e.points.reduce(((e,t)=>e+t[1]),0)/e.points.length:0)>t[e.type]?e:null}],Tr="metrics",Cr="datadog-metrics-plugin",Or=e=>Math.floor((e||Date.now())/1e3),Nr=(e,t)=>{const n=[`bundler:${ie(e.bundler.name)}`,`plugin_version:${ie(e.version)}`,`site:${ie(e.auth.site)}`];return e.build.metadata.name&&n.push(`build_name:${ie(e.build.metadata.name)}`),e.build.metadata.version&&n.push(`build_version:${ie(e.build.metadata.version)}`),[...n,...t]},Rr=(e,t,n)=>({...e,tags:[...e.tags,...t],metric:n?`${n}.${e.metric}`:e.metric}),_r=(e,t,n,o,r)=>{const i=new Set;for(const t of e){let e={...t,toSend:!0};if(n?.length)for(const t of n){const n=t({metric:e.metric,type:e.type,points:e.points,tags:e.tags});n?e={...n,toSend:e.toSend}:e.toSend=!1}i.add(Rr(e,o,r))}const s=Array.from(i).filter((e=>e.toSend)).length;return i.add(Rr({metric:"metrics.count",type:"count",points:[[t,s+1]],tags:[],toSend:!0},o,r)),i},Fr=(e="")=>e.endsWith("/")?e:`${e}/`,zr=(e,t)=>{let n=e;return e.split(Fr(t)),n.split("!").pop().replace(/(.*)?\/node_modules\//,"/node_modules/").replace(/^((\.)*\/)+/,"")},Lr=(e,t)=>e.split("!").pop().replace(Fr(t),"./"),Ur=(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)),Lr(o||"no-name",n)},Br=e=>e.replace(/^.*\/node_modules\/(@[a-z0-9][\w-.]+\/[a-z0-9][\w-.]*|[^/]+).*$/,"$1"),qr=e=>e.map((e=>({type:e?.constructor?.name??typeof e,name:e?.name,value:"string"==typeof e?e:void 0}))),Vr=t.bold.red,Kr=t.bold.cyan,Hr=e=>(t,n)=>{let o,r;return"function"==typeof e?(o=e(t),r=e(n)):(o=t[e],r=n[e]),o>r?-1:o<r?1:0},Wr=(e,t)=>{if(!t||!t.size)return[];const n=Array.from(t.values());n.sort(Hr("duration"));const o={name:`${e} duration`,values:n.map((e=>({name:e.name,value:ne(e.duration)}))),top:!0};n.sort(Hr("increment"));return[o,{name:`${e} hits`,values:n.map((e=>({name:e.name,value:e.increment.toString()}))),top:!0}]},Jr=(e,t,n)=>{const o=[];var r;n&&(o.push(...Wr("Loader",n.loaders)),o.push(...Wr("Tapable",n.tapables)),o.push(...Wr("Module",n.modules))),o.push(...(e=>{const t={name:"Module total dependents",values:[],top:!0},n={name:"Module total dependencies",values:[],top:!0},o={name:"Module size",values:[],top:!0},r={name:"Module aggregated size",values:[],top:!0},i=new Set,s=ee(e.build),a=new Map,u=new Map,c=new Map;for(const e of s.inputs||[]){if("map"===e.type)continue;const t=new Set(e.dependencies),n=new Set(e.dependents);for(const n of t)c.has(n)||c.set(n,new Set),c.get(n).add(e.filepath);for(const t of n)u.has(t)||u.set(t,new Set),u.get(t).add(e.filepath);if(u.has(e.filepath)){const n=u.get(e.filepath);for(const e of n)t.add(e)}if(c.has(e.filepath)){const t=c.get(e.filepath);for(const e of t)n.add(e)}u.set(e.filepath,t),c.set(e.filepath,n),a.set(e.filepath,{name:e.name,size:e.size,dependencies:t,dependents:n})}for(const[e,t]of a){const n=u.get(e)||new Set,o=c.get(e)||new Set;let r=t.size;for(const e of n)r+=a.get(e)?.size||0;i.add({name:t.name,size:t.size,aggregatedSize:r,dependents:o,dependencies:n})}if(!i.size)return[t,n,o];const d=Array.from(i);return d.sort(Hr((e=>e.dependents.size))),t.values=d.map((e=>({name:e.name,value:e.dependents.size.toString()}))),d.sort(Hr((e=>e.dependencies.size))),n.values=d.map((e=>({name:e.name,value:e.dependencies.size.toString()}))),d.sort(Hr("size")),o.values=d.map((e=>({name:e.name,value:v(e.size)}))),d.sort(Hr("aggregatedSize")),r.values=d.map((e=>({name:e.name,value:v(e.aggregatedSize||e.size)}))),[t,n,o,r]})(e)),o.push(...(r=e,[{name:"Asset size",values:(r.build.outputs||[]).filter((e=>"map"!==e.type)).sort(Hr((e=>e.size))).map((e=>({name:e.name,value:v(e.size)}))),top:!0},{name:"Entry aggregated size",values:(r.build.entries||[]).sort(Hr((e=>e.size))).map((e=>({name:e.name,value:v(e.size)}))),top:!0},{name:"Entry number of modules",values:(r.build.entries||[]).sort(Hr((e=>e.size))).map((e=>({name:e.name,value:e.inputs.length.toString()})))||[],top:!0}])),o.push(...(e=>{const t={name:"General Numbers",values:[],top:!1},n=e.build.inputs?e.build.inputs.length:0,o=e.build.outputs?e.build.outputs.length:0,r=e.build.warnings.length,i=e.build.errors.length,s=e.build.entries?e.build.entries.length:0;return e.build.start&&t.values.push({name:"Overhead duration",value:ne(e.build.start-e.start)}),e.build.duration&&t.values.push({name:"Build duration",value:ne(e.build.duration)}),e.build.writeDuration&&t.values.push({name:"Write duration",value:ne(e.build.writeDuration)}),t.values.push({name:"Number of modules",value:n.toString()},{name:"Number of assets",value:o.toString()},{name:"Number of entries",value:s.toString()},{name:"Number of warnings",value:r.toString()},{name:"Number of errors",value:i.toString()}),[t]})(e));const i=(e=>{let t="";for(const t of e){t.top&&t.values.length>=5&&(t.values=t.values.slice(0,5),t.name=`Top 5 ${t.name}`);for(const e of t.values)e.name=oe(e.name,60)}const n=Math.max(...e.map((e=>e.name.length))),o=Math.max(...e.flatMap((e=>e.values.map((e=>e.name.length))))),r=Math.max(...e.flatMap((e=>e.values.map((e=>e.value.length))))),i=Math.max(n+4,o+r+4);for(const n of e){if(0===n.values.length)continue;const e=i-(n.name.length+4);t+=`\n== ${n.name} ${"=".repeat(e)}=\n`;for(const e of n.values){const n=r-e.value.length;t+=` [${Vr(e.value)}] ${" ".repeat(n)}${Kr(e.name)}\n`}}return t})(o);t.info(i)},Gr="api/v1/series",Yr=t.bold.green,Qr=(e,t,n)=>{if(!t.apiKey)return void n.info("Won't send metrics to Datadog: missing API Key.");if(!e.size)return void n.debug("No metrics to send.");const o=Array.from(e).filter((e=>e.toSend)).map((e=>({...e,toSend:void 0}))),r=new Map;for(const e of o)r.has(e.metric)||r.set(e.metric,0),r.set(e.metric,r.get(e.metric)+1);const i=Array.from(r.entries()).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>`${e} - ${t}`));return n.debug(`\nSending ${o.length} metrics with configuration:\n - intake: ${Yr(`https://api.${t.site}/${Gr}`)}\n\nMetrics:\n - ${i.join("\n - ")}`),Y({method:"POST",url:`https://api.${t.site}/${Gr}?api_key=${t.apiKey}`,getData:()=>({data:JSON.stringify({series:o})})}).catch((e=>{n.error(`Error sending metrics ${e}`)}))},Zr=["onStart","onLoad","onResolve","onEnd"],Xr=new Map,ei=new Map,ti=new Map,ni=(e,t,n)=>{const o=Object.assign({},e);for(const r of Zr)o[r]=async(o,i)=>{const s=ei.get(t)||{name:t,increment:0,duration:0,events:{}};s.events[r]=s.events[r]||{name:r,values:[]};const a="onLoad"===r;return(0,e[r])(o,(async(...e)=>{const o=Lr(e[0].path,n),u=ti.get(o)||{name:o,increment:0,duration:0,events:{}};u.events[r]=u.events[r]||{name:r,values:[]};const c=x.now();try{return await i(...e)}finally{const n=x.now(),i=n-c,d={start:c,end:n,duration:i,context:qr(e)};if(s.events[r].values.push(d),s.duration+=i,s.increment+=1,ei.set(t,s),u.events[r].values.push(d),u.duration+=i,u.increment+=1,ti.set(o,u),a){const e=Xr.get(t)||{name:t,increment:0,duration:0,events:{}};e.events[r]=e.events[r]||{name:r,values:[]},e.events[r].values.push(d),e.duration+=i,e.increment+=1,Xr.set(t,e)}}}))};return o},oi=(e,t)=>({setup:n=>{n.initialOptions.metafile=!0;const o=t.time("wrapping plugins");((e,t)=>{const n=e.initialOptions.plugins;if(n){const e=n.map((e=>({...e})));for(const o of n){const n=o.setup;o.setup=async r=>{const i=ni(r,o.name,t);await n({...i,initialOptions:{...i.initialOptions,plugins:e}})}}}})(n,e.buildRoot),o.end(),n.onEnd((async n=>{if(!n.metafile)return void t.warn("Missing metafile, can't proceed with modules data.");const o=t.time("getting plugins results"),{plugins:r,loaders:i,modules:s}={plugins:ei,modules:ti,loaders:Xr};o.end(),await e.asyncHook("timings",{tapables:r,loaders:i,modules:s})}))}});class ri{constructor(e){this.started={},this.finished=[],this.cwd=e}startModule(e,t){const n=Ur(e,t,this.cwd),o=(e=>(e.loaders||[]).map((e=>e.loader||e)).map(Br))(e);o.length||o.push("no-loader"),this.started[n]={module:zr(n),timings:{start:x.now(),duration:0,end:0},loaders:o}}doneModule(e,t){const n=Ur(e,t,this.cwd),o=this.started[n];o&&(o.timings.end=x.now(),o.timings.duration=o.timings.end-o.timings.start,this.finished.push(o),delete this.started[n])}getResults(){const e=new Map,t=new Map;for(const n of this.finished){const o=n.timings.end-n.timings.start,r=t.get(n.module)||{name:n.module,increment:0,duration:0,events:{}},i=n.loaders.join(",");r.events[i]=r.events[i]||{name:i,values:[]},r.events[i].values.push(n.timings),r.increment+=1,r.duration+=o,t.set(n.module,r);for(const t of n.loaders){const n=e.get(t)||{name:t,increment:0,duration:0,events:{}};n.increment+=1,n.duration+=o,e.set(t,n)}}return{loaders:e,modules:t}}}class ii{constructor(e){this.monitoredTaps={},this.tapables=[],this.hooks={},this.timings=new Map,this.ignoredHooks=["normalModuleLoader"],this.cwd=e}saveResult(e,t,n,o,r,i){const s=this.timings.get(t)||{name:t,duration:0,increment:0,events:{}};s.events[n]||(s.events[n]={name:n,values:[]}),s.events[n].values.push({start:r,end:i,duration:i-r,context:o,type:e}),s.duration+=i-r,s.increment+=1,this.timings.set(t,s)}getResults(){const e=this.timings;for(const[t,n]of this.timings){const o=n;o.duration=Object.values(n.events).map((e=>e.values.reduce(((e,t)=>e+t.end-t.start),0))).reduce(((e,t)=>e+t),0),e.set(t,o)}return{monitoredTaps:this.monitoredTaps,tapables:this.tapables,hooks:this.hooks,timings:e}}getPromiseTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=x.now(),s=t.apply(this,r),a=()=>{this.saveResult(e,n,o,qr(r),i,x.now())};return s.then(a,a),s}}getAsyncTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=x.now(),s=r.pop();return t.apply(this,[...r,(...t)=>(this.saveResult(e,n,o,qr(r),i,x.now()),s(...t))])}}getDefaultTapPatch(e,t,n,o){return(...r)=>{this.checkNewHooks();const i=x.now(),s=t.apply(this,r);return this.saveResult(e,n,o,qr(r),i,x.now()),s}}getTapPatch(e,t,n,o){switch(e){case"promise":return this.getPromiseTapPatch(e,t,n,o);case"async":return this.getAsyncTapPatch(e,t,n,o);default:return this.getDefaultTapPatch(e,t,n,o)}}newTap(e,t,n,o){return(r,i)=>{const s="string"==typeof(a=r)?a:a.name;var a;const u=`${t}-${s}`;if(this.monitoredTaps[u])return n.call(o,r,i);this.monitoredTaps[u]=!0;const c=this.getTapPatch(e,i,s,t);return n.call(o,r,c)}}replaceTaps(e,t){t.tap=this.newTap("default",e,t.tap,t),t.tapAsync=this.newTap("async",e,t.tapAsync,t),t.tapPromise=this.newTap("promise",e,t.tapPromise,t)}patchHook(e,t,n){n._fakeHook||e.includes(Cr)||(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 si=e=>async t=>{const n=e.getLogger(Cr),o={name:Cr},r=new ii(e.buildRoot),i=new ri(e.buildRoot),s=n.time("parse compiler hooks");r.throughHooks(t),s.end(),t.hooks.thisCompilation.tap(o,(e=>{const t=n.time("parse compilation hooks");r.throughHooks(e),t.end(),e.hooks.buildModule.tap(o,(t=>{i.startModule(t,e)})),e.hooks.succeedModule.tap(o,(t=>{i.doneModule(t,e)})),e.hooks.failedModule&&e.hooks.failedModule.tap(o,(t=>{i.doneModule(t,e)}))})),t.hooks.afterEmit.tapPromise(o,(async()=>{const{timings:t}=r.getResults(),{loaders:n,modules:o}=i.getResults();await e.asyncHook("timings",{tapables:t,loaders:n,modules:o})}))},ai={filters:Mr},ui=({options:e,context:t,stores:n})=>{const o=t.getLogger(Cr);let r=0;((e,t)=>{e.addMetric=e=>{t.metrics.add(e)}})(t,n);const i=((e,t)=>{const n=e[Tr],o=Or(n?.timestamp);let r=!1===n?.enableDefaultPrefix?"":`build.${t}`;return n?.prefix&&(r+=r?`.${n.prefix}`:n.prefix),{enableDefaultPrefix:!0,enableTracing:!1,filters:Mr,tags:[],...e[Tr],timestamp:o,prefix:r.toLowerCase().replace(/(^\.*|\.*$)/g,"")}})(e,t.bundler.name),s=[],a={name:Cr,enforce:"pre",esbuild:oi(t,o),webpack:si(t),rspack:si(t)},u=o.time("build",{start:!1}),c=i.enableTracing&&["esbuild","webpack","rspack"].includes(t.bundler.name);let d,l;const p=async()=>{if(!n.metrics.size)return;const e=o.time("aggregating collected metrics"),r=(()=>{const e=new Set(n.metrics);n.metrics.clear();const o=Nr(t,i.tags);return _r(e,i.timestamp,i.filters,o,i.prefix)})();await t.asyncHook("metrics",r),e.end();const s=o.time("sending collected metrics to Datadog");await Qr(r,{apiKey:t.auth.apiKey,site:t.auth.site},o),s.end()},f=async()=>{t.build.end=Date.now(),t.build.duration=t.build.end-t.build.start,t.build.writeDuration=t.build.end-r;const e=o.time("aggregating metrics"),n=i.timestamp,s=o.time("aggregate universal metrics"),a=((e,t)=>{const n=new Set,o=e.inputs||[],r=e.outputs||[],i=e.entries||[],s=e.warnings.length,a=e.errors.length,u=e.duration,c=new Map,d=new Map,l=new Map;for(const e of i){for(const t of e.inputs)c.has(t.filepath)||c.set(t.filepath,[]),c.get(t.filepath).push(e.name);for(const t of e.outputs){const n=t.filepath.replace(/\.map$/,"");l.has(n)||l.set(n,[]),l.get(n).push(e.name)}}for(const e of r)for(const t of e.inputs)d.has(t.filepath)||d.set(t.filepath,[]),d.get(t.filepath).push(e.name);n.add({metric:"assets.count",type:"count",points:[[t,r.length]],tags:[]}).add({metric:"entries.count",type:"count",points:[[t,i.length]],tags:[]}).add({metric:"errors.count",type:"count",points:[[t,a]],tags:[]}).add({metric:"modules.count",type:"count",points:[[t,o.length]],tags:[]}).add({metric:"warnings.count",type:"count",points:[[t,s]],tags:[]}),u&&n.add({metric:"compilation.duration",type:"duration",points:[[t,u]],tags:[]});for(const e of o){const o=[`moduleName:${e.name}`,`moduleType:${e.type}`];c.has(e.filepath)&&o.push(...c.get(e.filepath).map((e=>`entryName:${e}`))),d.has(e.filepath)&&o.push(...d.get(e.filepath).map((e=>`assetName:${e}`))),n.add({metric:"modules.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"modules.dependencies",type:"count",points:[[t,e.dependencies.size]],tags:o}).add({metric:"modules.dependents",type:"count",points:[[t,e.dependents.size]],tags:o})}for(const e of r){const o=[`assetName:${e.name}`,`assetType:${e.type}`],r=e.filepath.replace(/\.map$/,"");l.has(r)&&o.push(...l.get(r).map((e=>`entryName:${e}`))),n.add({metric:"assets.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"assets.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o})}for(const e of i){const o=[`entryName:${e.name}`];n.add({metric:"entries.size",type:"size",points:[[t,e.size]],tags:o}).add({metric:"entries.modules.count",type:"count",points:[[t,e.inputs.length]],tags:o}).add({metric:"entries.assets.count",type:"count",points:[[t,e.outputs.length]],tags:o})}return n})(l,n);s.end();const u=o.time("aggregate plugins metrics"),c=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"plugins.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values()){let e=0,r=0;for(const i of Object.values(o.events)){let s=0;r+=i.values.length;for(const t of i.values){const n=t.end-t.start;s+=n,e+=n}n.add({metric:"plugins.hooks.duration",type:"duration",points:[[t,s]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]}).add({metric:"plugins.hooks.increment",type:"count",points:[[t,i.values.length]],tags:[`pluginName:${o.name}`,`hookName:${i.name}`]})}n.add({metric:"plugins.duration",type:"duration",points:[[t,e]],tags:[`pluginName:${o.name}`]}).add({metric:"plugins.increment",type:"count",points:[[t,r]],tags:[`pluginName:${o.name}`]})}return n})(d?.tapables,n);u.end();const p=o.time("aggregate loaders metrics"),f=((e,t)=>{const n=new Set;if(!e)return n;n.add({metric:"loaders.count",type:"count",points:[[t,e.size]],tags:[]});for(const o of e.values())n.add({metric:"loaders.duration",type:"duration",points:[[t,o.duration]],tags:[`loaderName:${o.name}`]}).add({metric:"loaders.increment",type:"count",points:[[t,o.increment]],tags:[`loaderName:${o.name}`]});return n})(d?.loaders,n);p.end();const m=new Set([...a,...c,...f]),h=Nr(t,i.tags),g=_r(m,n,i.filters,h,i.prefix);await t.asyncHook("metrics",g),e.end();const y=o.time("outputing report");Jr(t,o,d),y.end();const b=o.time("sending metrics to Datadog");await Qr(g,{apiKey:t.auth.apiKey,site:t.auth.site},o),b.end()},m={name:"datadog-universal-metrics-plugin",enforce:"post",buildStart(){u.resume(),t.build.start=t.build.start||Date.now(),e[Tr]?.timestamp||(i.timestamp=Or(t.build.start))},buildEnd(){u.end(),r=Date.now()},async timings(e){d=e,l&&await f()},async buildReport(e){l=e,!d&&c||await f()},async flush(){await p()}};return i.enableTracing&&s.push(a),s.push(m),s},ci="output",di="datadog-output-plugin",li=(e,t)=>"string"==typeof t?t.replace(/(\.json)?$/,".json"):!0===t?`${e}.json`:t,pi=e=>{const t=void 0===e;return{build:li("build",e?.build??t),bundler:li("bundler",e?.bundler??t),dependencies:li("dependencies",e?.dependencies??t),errors:li("errors",e?.errors??t),logs:li("logs",e?.logs??t),metrics:li("metrics",e?.metrics??t),timings:li("timings",e?.timings??t),warnings:li("warnings",e?.warnings??t)}},fi=(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}))}))},mi=e=>{const t=new Set;return{buildStart(){t.clear()},writeBundle(e,n){t.add(n)},closeBundle(){e((()=>Array.from(t)))}}},hi=({options:e,context:t})=>{const n=t.getLogger(di),o=(e=>({path:"./",...e[ci],files:pi(e[ci]?.files)}))(e),r=(e,r)=>{const i=o.files[e];if(!r||!1===i)return;t.queue((async()=>{const e=n.time(`output ${i}`),c=((e,t,n)=>{const o=u.isAbsolute(t)?t:u.resolve(e,t);return u.resolve(o,n)})(t.bundler.outDir,o.path,i);let d;try{const e="function"==typeof r?await r():r;await(async(e,t)=>{await Ie(u.dirname(e));const n=s.createWriteStream(e),o=new a(t,void 0,2),r=new Promise(((e,t)=>{o.on("end",(()=>{e()})),o.on("error",(e=>{t(e)}))}));return o.pipe(n),r})(c,e)}catch(e){d=e}d?n.error(`Failed writing ${i}: ${d}`):n.debug(`Wrote "./${u.relative(t.buildRoot,c)}"`),e.end()})())};return[{name:di,buildReport(e){const t=n.time("serialize report"),o=ee(e);t.end(),r("build",{bundler:o.bundler,metadata:o.metadata,start:o.start,end:o.end,duration:o.duration,writeDuration:o.writeDuration,entries:o.entries,outputs:o.outputs}),r("logs",o.logs),r("timings",o.timings),r("dependencies",o.inputs),r("errors",o.errors),r("warnings",o.warnings)},metrics(e){r("metrics",(()=>Array.from(e)))},esbuild:{setup(e){e.onEnd((e=>{r("bundler",e.metafile)}))}},rspack:fi(n,(e=>{r("bundler",e)})),rollup:mi((e=>{r("bundler",e)})),vite:mi((e=>{r("bundler",e)})),webpack:fi(n,(e=>{r("bundler",e)}))}]},gi="rum",yi="datadog-rum-plugin",bi=["8","9","a","b"],wi=(e,t)=>{const n={service:e.service,version:e.version};return e.debugId&&(n.ddDebugId=t?(e=>{const t=p("sha256").update(e).digest("hex").slice(0,32),n=`${t.slice(0,12)}4${t.slice(13)}`,o=n.charCodeAt(16)%4,r=`${n.slice(0,16)}${bi[o]}${n.slice(17)}`;return[r.slice(0,8),r.slice(8,12),r.slice(12,16),r.slice(16,20),r.slice(20,32)].join("-")})(t):f()),`(function(c,n){try{if(typeof window==='undefined')return;var w=window,m=w[n]=w[n]||{},s=new Error().stack;s&&(m[s]=c)}catch(e){}})(${JSON.stringify(n)},${JSON.stringify("DD_SOURCE_CODE_CONTEXT")});`},vi="datadog-rum-privacy-plugin";const $i=(e,t)=>{const n=t.getLogger(vi),o=function(e,t){const n={privacy:{addToDictionaryHelper:{expression:{code:e}}}};return["esbuild","webpack","rspack"].includes(t)&&(n.output={...n.output,inlineSourceMap:!1,embedCodeInSourceMap:!0}),n}(e.helperCodeExpression,t.bundler.name);let r=0,i=0;return{name:vi,enforce:"post",transform:{filter:{id:{include:e.include,exclude:e.exclude}},handler(e,t){try{const n=function(e){if("rspack"===e?.framework||"webpack"===e?.framework)switch(typeof e.inputSourceMap){case"undefined":return;case"string":return e.inputSourceMap;default:return JSON.stringify(e.inputSourceMap)}}(this.getNativeBuildContext?.()),s=E({id:t,code:e,map:n},o);return 0===s.privacyDictionarySize?{code:e}:(r+=s.privacyDictionarySize,i++,s)}catch(t){return n.error(`Instrumentation Error: ${t}`,{forward:!0}),{code:e}}}},buildEnd:()=>{n.debug(`Privacy dictionary will include ${r} entries across ${i} files`,{forward:!0,context:{dictionaryEntryCount:r,fileCount:i}})}}},ki=e=>`DD_RUM.init({${JSON.stringify(e.sdk).replace(/(^{|}$)/g,"")}});\n`,xi=(e,t)=>{const n=e.sdk;if(n.clientToken)return ki(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 Y({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 ki({...e,sdk:{clientToken:o,...n}})}},Ei=e=>{const n=t.bold.red,o=e[gi]||{},r={errors:[]};if(!o.sdk)return r;o.sdk.applicationId||r.errors.push(`Missing ${n("applicationId")} in the SDK configuration.`),e.auth.apiKey&&e.auth.appKey||o.sdk.clientToken||r.errors.push(`Missing ${n('"auth.apiKey"')} and/or ${n('"auth.appKey"')} to fetch missing client token.`);const i={applicationId:"unknown_application_id",allowUntrustedEvents:!1,compressIntakeRequests:!1,defaultPrivacyLevel:"mask",enablePrivacyForActionName:!1,sessionReplaySampleRate:0,sessionSampleRate:100,silentMultipleInit:!1,site:e.auth.site||"datadoghq.com",startSessionReplayRecordingManually:!1,storeContextsAcrossPages:!1,telemetrySampleRate:20,traceSampleRate:100,trackingConsent:"granted",trackLongTasks:!1,trackResources:!1,trackUserInteractions:!1,trackViewsManually:!1};return r.config={...i,...o.sdk},r},Si=e=>{const t=e[gi]||{},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},Ii=e=>{const n=t.bold.red,o=e[gi]||{},r={errors:[]};if(!o.sourceCodeContext)return r;const i=o.sourceCodeContext;return i?.debugId||i?.service&&"string"==typeof i.service||r.errors.push(`Missing ${n('"rum.sourceCodeContext.service"')}.`),r.config={...i,version:i.version||e.metadata?.version},r},Di=({options:e,context:t})=>{const n=((e,t)=>{const n=[],o=Ei(e),r=Si(e),i=Ii(e);if(n.push(...o.errors),n.push(...r.errors),n.push(...i.errors),n.length)throw t.error(`\n - ${n.join("\n - ")}`),new Error(`Invalid configuration for ${yi}.`);const s={...e[gi],sdk:void 0,privacy:void 0,sourceCodeContext:void 0};return o.config&&(s.sdk=o.config),r.config&&(s.privacy=r.config,t.debug(`datadog-rum-privacy plugin options: ${JSON.stringify(s.privacy,((e,t)=>t instanceof RegExp?t.toString():t))}`,{forward:!0})),i.config&&(s.sourceCodeContext=i.config),s})(e,t.getLogger(yi)),o=[],r=n.sourceCodeContext;if(r&&t.inject({type:"code",position:Te.BEFORE,injectIntoAllChunks:!0,value:e=>wi(r,e)}),n.sdk&&(t.inject({type:"file",position:Te.MIDDLE,value:u.join(T,"./rum-browser-sdk.js")}),t.inject({type:"code",position:Te.MIDDLE,value:xi(n,t)})),n.privacy){t.inject({type:"file",position:Te.BEFORE,value:u.join(T,"./privacy-helpers.js")});const e=$i(n.privacy,t);o.push(e)}return o},Pi="datadog-analytics-plugin",Ai=({context:e})=>{const t=e.getLogger(Pi);return[{name:Pi,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}`)}})())}}]},ji="datadog-async-queue-plugin",Mi=e=>{const{context:t,stores:n}=e,o=t.getLogger(ji),r=[];return t.queue=e=>{const t=e.catch((e=>{r.push(e.message||e.toString())}));n.queue.push(t)},[{name:ji,asyncTrueEnd:async()=>{await Promise.all(n.queue),r.length>0&&o.error(`Error occurred while processing async queue:\n ${r.join("\n ")}`)}}]},Ti=async(e,t,n)=>{const o=[],r=e.initialOptions.entryPoints,i=[],s=[];if(Array.isArray(r))for(const e of r){const t=e&&"object"==typeof e?e.in:e;i.push({path:t})}else r&&"object"==typeof r&&i.push(...Object.entries(r).map((([e,t])=>({name:e,path:t}))));const a=i.flatMap((e=>{return(t=e.path,t.includes("*")?w.sync(t):[t]).map((t=>[e,t]));var t})).map((async([n,r])=>{const i=await e.resolve(r,{kind:"entry-point",resolveDir:t.buildRoot});i.errors.length&&s.push(...i.errors.map((e=>e.text))),i.path&&o.push({name:n.name,resolved:i.path,original:n.path})}));for(const e of s)n.error(e);return await Promise.all(a),o},Ci=/\.(?!.*(?:\.|\/|\\))(\w{1,})/g,Oi=/(\?|%3F|\|)+/gi,Ni=e=>{return"unknown"===e?e:e.includes("webpack/runtime")?"runtime":(t=Fi(e),Ci.lastIndex=0,Ci.exec(t)?.[1]||"unknown");var t},Ri=["unknown","commonjsHelpers.js",`vite${u.sep}preload-helper.js`],_i=(e,t,n)=>{const o=new Set;for(const n of e){const e=Fi(n);X(n)||e===t||Ri.includes(e)||o.add(e)}return o},Fi=e=>e.split("!").pop().split(Oi).shift().replace(/^[^\w\s.,!@#$%^&*()=+~`\-/\\]+/,""),zi=(e,t)=>X(t)?O:"unknown"===t?t:t.includes("webpack/runtime")?t.replace("webpack/runtime/","").replace(/ +/g,"-"):((e,t)=>{const n=t.split(u.sep),o=e.split(u.sep).filter(((e,t)=>e===n[t])).join(u.sep);return e.replace(o,"")})(t.split("!").pop(),e).split("node_modules").pop().split(Oi).shift().replace(/^((\.\.?)?[/\\])+/g,""),Li=(e,t)=>Object.fromEntries(Object.entries(e).map((([e,n])=>[Zn(t,e),n]))),Ui=(e,t)=>({setup(n){const o=new Map;let r=[];const i=t.time("build report",{start:!1});n.onStart((async()=>{o.clear(),r=[],i.resume();const s=t.time("process entries");r.push(...await Ti(n,e,t));for(const t of r){const n=zi(e.bundler.outDir,t.resolved);t.name?o.set(n,t.name):o.set(n,n)}s.end(),i.pause()})),n.onEnd((async n=>{i.resume();const r=t.time("collecting errors and warnings"),s=e.bundler.outDir,a=e.buildRoot;for(const t of n.errors)e.build.errors.push(t.text);for(const t of n.warnings)e.build.warnings.push(t.text);if(r.end(),!n.metafile){const n="Missing metafile from build report.";return e.build.warnings.push(n),void t.warn(n)}const c=[],d=[],l=[],p=[],f=[],m={},h={},g=t.time("indexing metafile data"),y=Li(n.metafile.inputs,a),b=Li(n.metafile.outputs,a);g.end();const w=e=>{if(!X(e))return e;const t=y[Zn(a,e)];if(!t)return e;const n=t.imports.find((e=>!X(e.path)));return n?n.path:e},v=t.time("looping through inputs");for(const[e,t]of Object.entries(n.metafile.inputs)){if(X(e))continue;const n=Zn(a,e),o={name:zi(s,e),filepath:n,dependents:new Set,dependencies:new Set,size:t.bytes,type:Ni(e)};m[n]=o,c.push(o)}v.end();const $=t.time("looping through outputs");for(const[e,r]of Object.entries(n.metafile.outputs)){const n=Zn(a,e),i=zi(s,n),u=[];for(const e of Object.keys(r.inputs)){if(X(e))continue;const n=m[Zn(a,e)];n?u.push(n):t.debug(`Input ${e} not found for output ${i}`)}if(r.entryPoint&&!u.length){const e=m[Zn(a,r.entryPoint)];if(!e){t.debug(`Input ${r.entryPoint} not found for output ${i}`);continue}u.push(e)}const c={name:i,filepath:n,inputs:u,size:r.bytes,type:Ni(n)};if(h[n]=c,"map"===c.type&&p.push(c),d.push(c),!r.entryPoint)continue;const f=m[Zn(a,w(r.entryPoint))];if(f){if(!o.get(f.name))continue;const e={...c,name:o.get(f.name)||f.name,outputs:[c],size:c.size};l.push(e)}}$.end();const k=t.time("looping through sourcemaps");for(const e of p){const n=h[e.filepath.replace(/\.map$/,"")];n?e.inputs.push(n):t.debug(`Could not find output for sourcemap ${e.name}`)}k.end();const x={inputs:{report:m,meta:y},outputs:{report:h,meta:b}},E=/(<runtime>|https:|file:|data:|#)/g,S=e=>!X(e)&&!e.match(E),I=(e,n,o={})=>{if(!S(e))return o;const r=n.report[e];if(!r)return t.debug(`Could not find report's ${e}`),o;if(o[r.filepath])return o;o[r.filepath]=r;const i=n.meta[e];if(!i)return t.debug(`Could not find metafile's ${e}`),o;if(!i.imports||!i.imports.length)return o;for(const t of i.imports){const i=t.path.match(/^\.\.?\//),d=i?u.dirname(e):a,l=Zn(d,t.path);if(t.external){if(S(t.path)){const e=i?l:t.path,n=x.inputs.report[e]||{filepath:e,name:zi(s,t.path),size:0,type:"external",dependencies:new Set,dependents:new Set};"dependencies"in r&&(n.dependents.add(r),r.dependencies.add(n)),"inputs"in r&&!r.inputs.includes(n)&&r.inputs.push(n),c.includes(n)||c.push(n),x.inputs.report[e]=n,o[n.filepath]=n}}else I(l,n,o)}return o},D=t.time("looping through entries");for(const e of l){const t={},n={};for(const n of e.inputs)I(n.filepath,x.inputs,t);for(const t of e.outputs)I(t.filepath,x.outputs,n);e.inputs=Object.values(t),e.outputs=Object.values(n),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),f.push(e)}D.end();const P=t.time("aggregate dependencies and dependents");for(const e of c){if("external"===e.type)continue;const n=x.inputs.meta[e.filepath];if(n)for(const o of n.imports){if(!S(o.path))continue;const n=o.path.match(/^\.?\.\//),r=n?u.dirname(e.filepath):a,i=Zn(r,o.path);let s;if(o.external){const e=n?i:o.path;s=x.inputs.report[e]}else s=x.inputs.report[i];s?(e.dependencies.add(s),s.dependents.add(e)):t.debug(`Could not find input file of ${o.path} imported from ${e.name}`)}else t.debug(`Could not find metafile's ${e.name}`)}P.end(),e.build.outputs=d,e.build.inputs=c,e.build.entries=f,i.end(),await e.asyncHook("buildReport",e.build)}))}}),Bi=(e,t)=>{const n=t.time("module parsing",{start:!1}),o=t.time("build report",{start:!1}),r=t.time("filling entries",{start:!1}),i=t.time("filling inputs and outputs",{start:!1}),a=t.time("completing dependencies and dependents",{start:!1}),u=t.time("filling dependencies and dependents",{start:!1}),c=t.time("filling sourcemaps inputs",{start:!1}),d=new Map,l=new Map,p=new Map,f=new Map;return{buildStart(){f.clear(),d.clear(),l.clear(),p.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=Fi(e.id),o=f.get(t)||{dependencies:new Set,dependents:new Set},r=_i(new Set([...e.dynamicallyImportedIds,...e.importedIds]),t),i=_i(new Set([...e.dynamicImporters,...e.importers]),t);for(const e of i)o.dependents.add(e);for(const e of r)o.dependencies.add(e);f.set(t,o),n.tag([`module:${t}`],{span:!0}),n.pause()},writeBundle(n,m){o.resume();const h=n.dir?Zn(e.buildRoot,n.dir):e.bundler.outDir,g=new Set,y=new Set,b=new Map;a.resume();for(const[e,{dependencies:t,dependents:n}]of f){for(const n of t){const t=Fi(n),o=f.get(t)||{dependencies:new Set,dependents:new Set};o.dependents.has(e)||(o.dependents.add(e),f.set(t,o))}for(const t of n){const n=Fi(t),o=f.get(n)||{dependencies:new Set,dependents:new Set};o.dependencies.has(e)||(o.dependencies.add(e),f.set(n,o))}}a.end(),i.resume();for(const[e,n]of Object.entries(m)){const o=Zn(h,e),r="code"in n?Buffer.byteLength(n.code,"utf8"):Buffer.byteLength(n.source,"utf8"),i=l.get(o)||{name:e,filepath:o,inputs:[],size:r,type:Ni(e)};if("map"===i.type&&y.add(i),"modules"in n)for(const[e,t]of Object.entries(n.modules)){if(Fi(e)!==e)continue;let n=t.originalLength;if(!n&&0!==n)try{n=s.statSync(e).size}catch(e){n=t.renderedLength}const o=d.get(e)||{name:zi(h,e),dependencies:new Set,dependents:new Set,filepath:e,size:n,type:Ni(e)};i.inputs.push(o),d.set(o.filepath,o)}if("imports"in n)for(const e of n.imports){const n=Fi(e);if(!f.has(n)){b.set(Zn(h,n),i);continue}if(d.has(n)){t.debug(`Input report already there for ${n} from ${i.name}.`);continue}const o=d.get(n)||{name:zi(h,e),dependencies:new Set,dependents:new Set,filepath:n,size:0,type:"external"};i.inputs.push(o),d.set(o.filepath,o)}"isEntry"in n&&n.isEntry&&g.add({...i,name:n.name,size:0,outputs:[i]}),l.set(i.filepath,i)}i.end();for(const[e,n]of b){const o=l.get(e);o?n.inputs.includes(o)||n.inputs.push(o):t.debug(`Could not find the output report for ${e}.`)}u.resume();for(const[e,n]of d){const o=f.get(e);if(o){for(const e of o.dependencies){const o=d.get(e);o?n.dependencies.add(o):t.debug(`Could not find input for dependency ${zi(h,e)} of ${n.name}`)}for(const e of o.dependents){const o=d.get(e);o?n.dependents.add(o):t.debug(`Could not find input for dependent ${zi(h,e)} of ${n.name}`)}}else t.debug(`Could not find the import report for ${n.name}.`)}if(u.end(),y.size){c.resume();for(const e of y){const n=e.filepath.replace(/\.map$/,""),o=l.get(n);o?e.inputs.push(o):t.debug(`Could not find output for sourcemap ${e.name}`)}c.end()}const w=(e,n=new Map)=>{if(n.has(e))return n;const o=zi(h,e),r=l.get(e);if(!r)return d.has(o)||t.debug(`Could not find output for ${o}`),n;n.set(e,r);const i=m[zi(h,e)];if(!i)return t.debug(`Could not find asset for ${o}`),n;const s=[];"imports"in i&&s.push(...i.imports),"dynamicImports"in i&&s.push(...i.dynamicImports);for(const e of s)w(Zn(h,e),n);return n};r.resume();for(const e of g){const n=w(e.filepath);e.outputs=Array.from(n.values()),e.inputs=Array.from(new Set(e.outputs.flatMap((e=>e.inputs)))),e.size=e.outputs.reduce(((e,t)=>e+t.size),0),p.has(e.filepath)&&t.debug(`Entry "${e.name}":"${zi(h,e.filepath)}" already reported.`),p.set(e.filepath,e)}r.pause(),o.pause()},async closeBundle(){e.build.inputs=Array.from(d.values()),e.build.outputs=Array.from(l.values()),e.build.entries=Array.from(p.values()),r.end(),o.end(),await e.asyncHook("buildReport",e.build)}}},qi=(e,t,n)=>o=>{let r=[],i=[],s=[];const a=new Map,u=new Map,c=new Map,d=new Map,l=[],p=new Map,f=n.time("build report",{start:!1}),m=e=>!(!e||e.startsWith("webpack/runtime")||e.startsWith("multi ")||X(e)),h=e=>e.replace(/(^external[^"]+"|"$)/g,""),g=e=>{const t=(e=>{const t=e.identifier();return{identifier:()=>t,dependencies:"dependencies"in e?[...e.dependencies]:[],blocks:"blocks"in e?[...e.blocks]:[],externalType:"externalType"in e?e.externalType:void 0,external:"external"in e?e.external:void 0}})(e),n=(e=>{const t=new Set,n=["rawRequest","resource","request","userRequest"],o=e=>{const n=Fi(e);t.add(n),n.startsWith("external ")&&t.add(h(n))};o(e.identifier());for(const t of n){const n=e[t];t&&t in e&&"string"==typeof n&&o(n)}return t})(e);for(const e of n)if(d.has(e)){const n=d.get(e);n.dependencies.push(...t.dependencies||[]),n.blocks.push(...t.blocks||[])}else d.set(e,t)},y=(e,t=[])=>{if("dependencies"in e)for(const n of e.dependencies)t.push(n),y(n,t);if("blocks"in e)for(const n of e.blocks)y(n,t);return t},b=(e,t)=>{if("request"in t&&t.request){const n=Fi(t.request);if(d.has(n))return d.get(n);if(e.context){const t=Zn(Fi(e.context),n);if(d.has(t))return d.get(t)}}},w=e=>!(!("externalType"in e)||!e.externalType)||(!(!("external"in e)||!e.external)||!!e.identifier?.().startsWith("external "));o.hooks.thisCompilation.tap(t,(o=>{r=[],i=[],s=[],a.clear(),u.clear(),d.clear(),p.clear(),o.hooks.finishModules.tap(t,(t=>{f.resume();const o=n.time("dependency graph"),i=n.time("indexing modules");for(const e of t)g(e);i.end();const s=n.time("building inputs");for(const n of t){const t=n.identifier(),o=zi(e.bundler.outDir,t),i=new Set(y(n).map((e=>{const o=b(n,e);if(!o?.identifier())return!1;const r=o.identifier();return!!m(r)&&(r!==t&&(w(o)?h(r):r))})).filter(Boolean));if(!m(t))continue;const s=p.get(t)||{dependents:new Set,dependencies:new Set};for(const e of i){const n=p.get(e)||{dependencies:new Set,dependents:new Set};n.dependents.add(t),s.dependencies.add(e),p.set(e,n)}p.set(t,s);const u=w(n)?{size:0,name:h(o),dependencies:new Set,dependents:new Set,filepath:t,type:"external"}:{size:n.size()||0,name:o,dependencies:new Set,dependents:new Set,filepath:t,type:Ni(t)};r.push(u),a.set(t,u),w(n)&&a.set(h(t),u)}s.end();const u=n.time("assigning dependencies and dependents");for(const e of r){const t=p.get(e.filepath);if(t){for(const o of t.dependencies){const t=a.get(o);t?e.dependencies.add(t):n.debug(`Could not find input of dependency ${o}`)}for(const o of t.dependents){const t=a.get(o);t?e.dependents.add(t):n.debug(`Could not find input of dependent ${o}`)}}else n.debug(`Could not find dependency report for ${e.name}`)}u.end(),o.end(),f.pause()}))})),o.hooks.afterEmit.tapPromise(t,(async t=>{f.resume();const o=t.chunks,d=t.getAssets(),p=t=>[...t.files||[],...t.auxiliaryFiles||[]].map((t=>Zn(e.bundler.outDir,t))),h=n.time("indexing chunks"),g=t.chunkGraph;for(const e of o){const t=p(e),n=(g?.getChunkModules(e)||[]).flatMap((e=>"modules"in e&&Array.isArray(e.modules)?e.modules.map((e=>e.identifier())):e.identifier())).filter(m);for(const e of t){if("map"===Ni(e))continue;const t=c.get(e)||new Set;for(const e of n)t.add(e);c.set(e,t)}}h.end();const y=n.time("building outputs");for(const t of d){const o={size:t.source.size()||0,name:t.name,inputs:[],filepath:Zn(e.bundler.outDir,t.name),type:Ni(t.name)};if(u.set(o.filepath,o),i.push(o),"map"===o.type){l.push(o);continue}const r=c.get(o.filepath);if(r)for(const e of r){const t=a.get(e);t?o.inputs.push(t):n.debug(`Could not find input of ${e}`)}else n.debug(`Could not find modules for ${o.name}`)}y.end();const b=n.time("filling sourcemaps inputs");for(const e of l){const t=u.get(e.filepath.replace(/\.map$/,""));t?e.inputs.push(t):n.debug(`Output not found for sourcemap ${e.name}`)}b.end();const w=n.time("building entries"),v=(e,t=new Set)=>{if(t.has(e))return new Set;t.add(e);const n=new Set(e.chunks);for(const o of e.childrenIterable||[]){const e=v(o,t);for(const t of e)n.add(t)}return n};for(const[o,r]of t.entrypoints){const t=new Map,i=new Map;let a=0;const c=v(r),d=Array.from(c).flatMap(p),l=r.chunks.filter((e=>g.getChunkEntryModulesIterable(e)||!1)).flatMap((e=>Array.from(e.files))).filter((e=>e.includes(o)||r.name&&e.includes(r.name))).find((e=>"js"===Ni(e)));for(const e of d){const o=u.get(e);if(e&&o){if("map"!==o.type&&!t.has(o.name)){t.set(o.name,o);for(const e of o.inputs)i.has(e.filepath)||i.set(e.filepath,e);a+=o.size}}else n.debug(`Could not find output of ${JSON.stringify(e)}`)}const f={name:o,filepath:l?Zn(e.bundler.outDir,l):"unknown",size:a,inputs:Array.from(i.values()),outputs:Array.from(t.values()),type:l?Ni(l):"unknown"};s.push(f)}w.end();for(const n of t.errors)e.build.errors.push(n.message);for(const n of t.warnings)e.build.warnings.push(n.message);e.build.inputs=r,e.build.outputs=i,e.build.entries=s,f.end(),await e.asyncHook("buildReport",e.build)}))},Vi="datadog-build-report-plugin",Ki=e=>{const{context:t}=e,n=t.getLogger(Vi);return[{name:Vi,enforce:"post",esbuild:Ui(t,n),rspack:qi(t,Vi,n),webpack:qi(t,Vi,n),vite:Bi(t,n),rollup:Bi(t,n)}]},Hi="datadog-bundler-report-plugin",Wi=(e,t)=>t?u.isAbsolute(t)?t:u.resolve(e,t):"",Ji=e=>{if(!e)return[];return(Array.isArray(e)?e:[e]).map((e=>e.dir?e.dir:e.file?u.dirname(e.file):void 0)).filter(Boolean)},Gi=e=>t=>{e.bundler.rawConfig=t.options,t.options.output?.path&&(e.bundler.outDir=Wi(process.cwd(),t.options.output.path)),e.hook("bundlerReport",e.bundler),t.options.context&&(e.buildRoot=t.options.context),e.hook("buildRoot",e.buildRoot)},Yi=e=>({configResolved(t){e.bundler.rawConfig=t;let n=t.build?.outDir??"dist";const o=t.build?.rollupOptions?.output,r=Ji(o);e.buildRoot=t.root??process.cwd(),o&&r.length&&(n=eo(r,process.cwd())),e.bundler.outDir=Wi(e.buildRoot,n),e.hook("buildRoot",e.buildRoot),e.hook("bundlerReport",e.bundler)}}),Qi=e=>{const{context:t}=e,n=t.getLogger(Hi);return[{name:Hi,enforce:"pre",esbuild:{setup(e){t.bundler.rawConfig=e.initialOptions,e.initialOptions.absWorkingDir&&(t.buildRoot=e.initialOptions.absWorkingDir),e.initialOptions.outdir&&(t.bundler.outDir=Wi(t.buildRoot,e.initialOptions.outdir)),e.initialOptions.outfile&&(t.bundler.outDir=Wi(t.buildRoot,u.dirname(e.initialOptions.outfile))),t.hook("buildRoot",t.buildRoot),t.hook("bundlerReport",t.bundler),e.initialOptions.metafile=!0}},webpack:Gi(t),rspack:Gi(t),vite:Yi(t),rollup:{options(e){let n;if("output"in e){const t=Ji(e.output);n=eo(t,process.cwd())}const o=(e=>{const t=new Set;if(e.input){const n=Array.isArray(e.input)?e.input:"object"==typeof e.input?Object.values(e.input):[e.input];for(const e of n){if("string"!=typeof e)throw new Error("Invalid input type");t.add(u.dirname(e))}}return Array.from(t)})(e);if(n){t.bundler.outDir=Zn(process.cwd(),n);const e=eo([n,...o],process.cwd());t.buildRoot=e===u.sep?process.cwd():e}else t.buildRoot=eo(o,process.cwd()),t.bundler.outDir=u.resolve(process.cwd(),"dist");t.hook("buildRoot",t.buildRoot)},buildStart(e){t.bundler.rawConfig=e},renderStart(e){t.bundler.rawConfig.outputs=t.bundler.rawConfig.outputs||[],t.bundler.rawConfig.outputs.push(e),t.hook("bundlerReport",t.bundler);const o=Ji(e);eo(o,process.cwd()).startsWith(t.bundler.outDir)||n.warn("The output directory has been changed by a plugin and may introduce some inconsistencies in the build report.")}}}]},Zi="datadog-custom-hooks-plugin",Xi=e=>{const{context:t}=e,n=t.getLogger(Zi),o=e=>(o,...r)=>{const i=n.time(`execution | ${o}`,{tags:["type:custom-hook",`hook:${o}`]}),s=[],a=[];for(const n of t.plugins){if(!(o in n))continue;const t=n[o];if("function"==typeof t)try{const i=t(...r);i instanceof Promise&&(e||s.push(`Plugin "${n.name}" returned a promise on the non async hook "${o}".`),a.push(i))}catch(e){s.push(`Plugin "${n.name}" errored on hook "${o}". [${e}]`)}else s.push(`Plugin "${n.name}" has an invalid hook type for "${o}". [${typeof t}]`)}if(s.length>0){for(const e of s)n.error(e);throw new Error("Some plugins errored during the hook execution.")}return Promise.all(a).finally((()=>i.end()))};return t.hook=o(!1),t.asyncHook=o(!0),[{name:Zi,enforce:"pre"}]};class es{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=Pe(e),o=JSON.parse(n);if(!o.sources)return void t("Missing 'sources' field in sourcemap.");const r=o.sources;if(0===r.length)return void t("Empty 'sources' field in sourcemap.");const i=this.matchSources(r);if(0!==i.length)return i;t(`${r.map(this.displaySource).join(", ")} not in the tracked files.`)}matchSources(e){let t=[];const n=new Set;for(const o of e){const e=this.getFilename(o);if(n.has(e))continue;n.add(e);const r=this.trackedFilenames.get(e);r&&(t=t.concat(r))}return t}rawTrackedFilesList(){let e=[];return this.trackedFilenames.forEach((t=>{e=e.concat(t)})),e}getFilename(e){let t=e.lastIndexOf("/");-1===t?t=0:t++;let n=e.lastIndexOf("?");return(-1===n||n<=t)&&(n=e.length),e.substring(t,n)}}const ts=async e=>{const t=await e.getRemotes(!0);if(0===t.length)throw new Error("No git remotes available");const n=await ns(e);for(const e of t)if(e.name===n)return re(e.refs.push);return re(t[0].refs.push)},ns=async e=>{try{return(await e.getConfig("clone.defaultRemoteName"))?.value??"origin"}catch(e){return"origin"}},os=async e=>e.revparse("HEAD"),rs=async e=>(await e.raw("ls-files")).split(/\r\n|\r|\n/),is=async e=>e.branch(),ss=async e=>e.show(["-s","--format=%s"]),as=async e=>e.show(["-s","--format=%an,%ae,%aI,%cn,%ce,%cI"]),us="datadog-git-plugin",cs=e=>{const{options:t,context:n}=e,o=n.getLogger(us),r=o.time("get git information",{start:!1}),i=async e=>{try{const t=await(async e=>{const t={baseDir:e||process.cwd(),binary:"git",maxConcurrentProcesses:3};try{const e=S(t),n=await e.revparse("--show-toplevel");t.baseDir=n}catch{}return S(t)})(u.dirname(e));if(0===(await t.getRemotes(!0)).length)return o.warn("No git remotes available, skipping git plugin. This is expected for a repository that has not been pushed yet."),void r.end();const i=await(async e=>{const t=[os(e),is(e),ss(e),as(e),rs(e),ts(e)],[n,o,r,i,s,a]=await Promise.all(t),[u,c,d,l,p,f]=i.split(",").map((e=>e.trim()));return{commit:{author:{name:u,email:c,date:d},committer:{name:l,email:p,date:f},message:r.trim(),hash:n},hash:n,branch:o.current,remote:a.trim(),trackedFilesMatcher:new es(s)}})(t);n.git=i,r.end(),await n.asyncHook("git",n.git)}catch(e){o.error(`Could not get git information: ${e.message}`)}};return[{name:us,enforce:"pre",buildRoot(e){if(te(t))try{r.resume();const t=Xn(e,".git");if(!t)return o.warn("No .git directory found, skipping git plugin."),void r.end();n.queue(i(t))}catch(e){o.error(`Could not get git information: ${e.message}`)}}}]},ds="datadog-injection-plugin",ls=/^https?:\/\//,ps=[".mjs",".mjsx",".js",".ts",".tsx",".jsx"],fs=t.bold.yellow,ms=async(e,t=process.cwd())=>(e=>r.readFile(e,{encoding:"utf-8"}))(Zn(t,e));function hs(e){return e.some((e=>e.injectIntoAllChunks))}const gs=(e,t,n)=>{const o=e.filter((e=>e.position===t&&(!n||n.isEntry||e.injectIntoAllChunks))).map((e=>xs(e.value)?e.value(n):e.value)).filter(Boolean);if(0===o.length)return"";return`// begin injection by Datadog build plugins\n${o.map((e=>`(() => {${e}})();`)).join("\n\n")}\n// end injection by Datadog build plugins`},ys=async(e,t,n=process.cwd())=>{const o=xs(e.value)?await e.value():e.value;try{if("file"===e.type){const e=o;return await(e.match(ls)?(async(e,t=5e3)=>{let n;return Promise.race([Y({retries:2,minTimeout:100,url:e}).finally((()=>{t&&clearTimeout(n)})),new Promise(((e,o)=>{n=setTimeout((()=>{o(new Error("Timeout"))}),t)}))])})(e):ms(e,n))}return o}catch(r){const i=`${e.type} - ${oe(o)}`;return e.fallback?(t.debug(`Fallback for "${i}": ${r.toString()}`),ys(e.fallback,t,n)):(t.warn(`Failed "${i}": ${r.toString()}`),"")}},bs=async(e,t,n,o=process.cwd())=>{const r=t.filter(ks).map((e=>{const t=e.value;return{...e,value:e=>t(e.sourceOrHash)}})),i=t.filter((e=>!ks(e))),s=await Promise.all(i.map((async t=>({...t,value:await ys(t,e,o)})))),a=e=>({...e,position:e.position??Te.BEFORE});n.push(...r.map(a),...s.map(a))},ws=e=>e instanceof Error&&"code"in e,vs=e=>ps.includes(e),$s=(e,t,n)=>{e.warn(`"${fs(t)}" files are not supported (${fs(n)}).`)},ks=e=>"function"==typeof e.value&&1===e.value.length,xs=e=>"function"==typeof e,Es=s.promises,Ss=(e,t,n)=>({setup(o){const{onStart:i,onResolve:a,onLoad:c,onEnd:d,esbuild:l,initialOptions:p}=o,f=[],m=`${t.bundler.name}.${Te.MIDDLE}.${O}.js`,g=s.realpathSync(h.tmpdir()),y=u.resolve(g,m),b=new RegExp(`${m}$`),w=p.inject;p.inject=w?[...w]:[],p.inject.push(y),i((async()=>{f.push(...await Ti(o,t,e)),o.initialOptions.inject=w;try{await(async(e,t)=>{await Ie(u.dirname(e)),await r.writeFile(e,t,{encoding:"utf-8"})})(y,"")}catch(t){e.error(`Could not create the files: ${t.message}`)}})),a({filter:b},(async e=>({path:e.path,namespace:ds}))),c({filter:b,namespace:ds},(async()=>({contents:gs(n,Te.MIDDLE)||" ",resolveDir:t.buildRoot,loader:"js"}))),d((async o=>{if(!o.metafile)return void e.warn("Missing metafile from build result.");if(!function(e){return e.some((e=>e.position===Te.BEFORE||e.position===Te.AFTER))}(n))return;const r=[];for(const[i,s]of Object.entries(o.metafile.outputs)){const o=Boolean(s.entryPoint&&f.some((e=>e.resolved.endsWith(s.entryPoint))));if(!o&&!hs(n))continue;const a=Zn(t.buildRoot,i),{base:c,ext:d}=u.parse(a);vs(d)?r.push((async()=>{try{const e=`${a}.map`,t=await Es.readFile(a,"utf-8"),r=await Es.readFile(e,"utf-8").catch((()=>!1)),i=u.basename(a),s=gs(n,Te.BEFORE,{sourceOrHash:t,fileName:i,isEntry:o}),c=gs(n,Te.AFTER,{sourceOrHash:t,fileName:i,isEntry:o});if(!s&&!c)return;const d=t.replace(/\n?\/\/# sourceMappingURL=.*$/m,""),p=r?`${d}\n//# sourceMappingURL=data:application/json;base64,${Buffer.from(r).toString("base64")}`:d,f=await l.transform(p,{loader:"default",banner:s,footer:c,sourcemap:r?"external":void 0,sourcefile:i});await Promise.all([Es.writeFile(a,f.code),r&&f.map?Es.writeFile(e,f.map):null])}catch(t){if(!ws(t)||"ENOENT"!==t.code)throw t;e.warn(`Could not inject content in ${a}: ${t}`)}})()):$s(e,d,c)}await Promise.all(r)}))}}),Is=O,Ds="?inject-proxy",Ps=(e,t)=>({renderChunk(n,o){const{base:r,ext:i}=u.parse(o.fileName);if(!vs(i))return $s(e,i,r),null;const s=gs(t,Te.BEFORE,{sourceOrHash:n,fileName:o.fileName,isEntry:o.isEntry}),a=gs(t,Te.AFTER,{sourceOrHash:n,fileName:o.fileName,isEntry:o.isEntry});if(!s&&!a)return null;const c=new I(n);return s&&c.prepend(`${s}\n`),a&&c.append(`\n${a}`),{code:c.toString(),map:c.generateMap({file:o.fileName,hires:"boundary"})}},async resolveId(e,n,o){if(X(e))return{id:e,moduleSideEffects:!0};if(o.isEntry&&gs(t,Te.MIDDLE)){if(e.endsWith(".html"))return null;const t=await this.resolve(e,n,o);if(!t||t.external)return t;return(await this.load(t)).moduleSideEffects=!0,`${t.id}${Ds}`}return null},load(e){if(X(e))return gs(t,Te.MIDDLE);if(e.endsWith(Ds)){const t=e.slice(0,-13),n=this.getModuleInfo(t);let o=`import ${JSON.stringify(Is)};\nexport * from ${JSON.stringify(t)};`;return n?.hasDefaultExport&&(o+=`export { default } from ${JSON.stringify(t)};`),o}return null}}),As=(e,t,n,o,r)=>i=>{const a=new WeakMap,c=e.sources.ConcatSource,d=n.bundler.name,l=u.resolve(n.buildRoot,"node_modules",".cache","datadog-build-plugins",`${d}.${Te.MIDDLE}.${O}.js`);De(l,"");i.hooks.shutdown.tap(ds,(()=>{var e;e=l,s.rmSync(e,{force:!0,maxRetries:3,recursive:!0})}));const p=async()=>{await bs(t,o,r,n.buildRoot)};i.hooks.beforeRun.tapPromise(ds,p),i.hooks.watchRun.tapPromise(ds,p),i.hooks.compilation.tap(ds,(n=>{const o=e.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS;n.hooks.processAssets.tap({name:ds,stage:o},(()=>{for(const e of n.chunks){const o=e.canBeInitial(),i=e.contentHash?.javascript??e.hash;for(const s of e.files){const{base:e,ext:d}=u.parse(s);if(!vs(d)){$s(t,d,e);continue}const l=u.basename(s),p=gs(r,Te.BEFORE,{sourceOrHash:i,fileName:l,isEntry:o}),f=gs(r,Te.AFTER,{sourceOrHash:i,fileName:l,isEntry:o});""===p&&""===f||n.updateAsset(s,(e=>{const t=a.get(e);if(!t||t.banner!==p||t.footer!==f){const t=new c(p,"\n",e,"\n",f);return a.set(e,{source:t,banner:p,footer:f}),t}return t.source}))}}}))}));const f=(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}})(i.options.entry);i.options.entry=f},js=e=>{const{bundler:t,context:n}=e,o=n.getLogger(ds),r=[],i=[];n.inject=e=>{r.push(e)};const s={name:ds,enforce:"post",esbuild:Ss(o,n,i),webpack:As(t,o,n,r,i),rspack:As(t,o,n,r,i),rollup:Ps(o,i),vite:{...Ps(o,i),enforce:"pre",transformIndexHtml:{order:"pre",handler:()=>gs(i,Te.MIDDLE)?[{tag:"script",attrs:{type:"module",src:"/@id/__datadog-helper-file"},injectTo:"head-prepend"}]:[]}}};var a;return a=n.bundler.name,["rspack","webpack"].includes(a)?s.load={filter:{id:N},handler:()=>({code:gs(i,Te.MIDDLE)})}:s.buildStart=async()=>{await bs(o,r,i,n.buildRoot)},[s]},Ms="datadog-true-end-plugin",Ts=e=>{const{context:t}=e,n=async()=>{await t.asyncHook("asyncTrueEnd")},o=async()=>{await t.asyncHook("flush")},r=()=>{t.hook("syncTrueEnd")},i=async()=>{r(),await n(),await o()},s=e=>{e.hooks.shutdown.tapPromise(Ms,i)},a={async writeBundle(){},async closeBundle(){await i()}};return[{name:Ms,enforce:"post",webpack:s,esbuild:{setup(e){e.onEnd((async()=>{await n(),await o()})),e.onDispose((()=>{r()}))}},vite:a,rollup:a,rspack:s}]},Cs={[Tr]:ai},Os=t.bold.red;var Ns="3.2.3";const Rs=(({bundler:t,version:n})=>{const o=Date.now();return e(((e,r)=>{const i=Date.now(),s=((e={})=>{const t=(e=>{const t=[];return void 0===e||void 0!==e.version&&"string"!=typeof e.version&&t.push("metadata.version must be a string"),t})(e.metadata),n=q("SITE"),o={site:K(n,"DATADOG_SITE/DD_SITE",t)??K(e.auth?.site,"auth.site",t)??F};if(t.length)throw new Error(`Invalid Datadog plugin configuration:\n - ${t.join("\n - ")}`);return Object.defineProperty(o,"apiKey",{value:q("API_KEY")||e.auth?.apiKey,enumerable:!1}),Object.defineProperty(o,"appKey",{value:q("APP_KEY")||e.auth?.appKey,enumerable:!1}),{enableGit:!0,logLevel:"warn",metadata:{},...e,auth:o}})(e);"esbuild"===r.framework&&(r.esbuildHostName=z);const a=process.env.BUILD_PLUGINS_ENV||"production",u=R.includes(a)?a:"development",c=t.rspackVersion||t.version||t.VERSION,d=r.framework,l={bundler:{name:d,version:c},env:u,metadata:s.metadata||{},packageName:`@datadog/${d}-plugin`,version:n},p={errors:[],logs:[],metrics:new Set,queue:[],timings:[],warnings:[]},f=(({start:e,options:t,data:n,stores:o})=>{const r=process.cwd(),i={errors:o.errors,warnings:o.warnings,logs:o.logs,metadata:n.metadata,timings:o.timings,bundler:n.bundler};return{addMetric:()=>{throw new Error("AddMetric function called before it was initialized.")},auth:t.auth,pluginNames:[],bundler:{...i.bundler,outDir:r},build:i,buildRoot:r,env:n.env,getLogger:le(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:Q(n),start:e,version:n.version}})({start:o,options:s,data:l,stores:p}),m=f.getLogger("factory"),h=m.time("Plugins initialization",{start:i});f.pluginNames.push(z);const g=[];g.push(["analytics",Ai],["async-queue",Mi],["build-report",Ki],["bundler-report",Qi],["custom-hooks",Xi],["git",cs],["injection",js],["true-end",Ts]),s.customPlugins&&g.push(["custom",s.customPlugins]);const y=[["apps",ye,vo],["error-tracking",$o,Uo],["live-debugger",Bo,jr],["metrics",Tr,ui],["output",ci,hi],["rum",gi,Di]];for(const[e,t,n]of y)ge(s,t,m)&&g.push([e,n]);for(const[e,n]of g)f.plugins.push(...me(f,n,e)({bundler:t,context:f,options:s,data:l,stores:p}));return(e=>{const t=[];for(const n of B){const o=V(n);if(o.length>1&&!o.every((e=>process.env[e]===process.env[o[0]]))){const r=o.map((e=>U(e))).join(" and "),i=U(`DATADOG_${n}`);e.warn(`Conflicting keys ${r}, will use ${i}`),t.push(`${r} (using ${i})`)}else if(o.length){const e=o.map((e=>L(e))).join(" and ");t.push(`${e} (same value)`)}}t.length&&e.info(`Overrides from environment:\n - ${t.join("\n - ")}`)})(m),f.pluginNames.push(...f.plugins.map((e=>e.name))),(e=>{const t=new Set(e.filter((t=>e.filter((e=>e===t)).length>1)));if(t.size>0)throw new Error(`Duplicate plugin names: ${Os(Array.from(t).join(", "))}`)})(f.pluginNames),f.hook("init",f),h.end(),f.plugins}))})({bundler:D,version:Ns}).esbuild,_s=Ns,Fs=Cs;export{Rs as datadogEsbuildPlugin,Fs as helpers,_s as version};
2
2
  //# sourceMappingURL=index.mjs.map