prismic 1.9.0 → 1.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{A as e,C as t,D as n,E as r,I as i,M as a,N as o,P as s,S as c,T as l,_ as u,a as d,c as f,d as p,f as m,g as h,h as g,i as _,j as v,k as y,l as b,m as x,n as ee,o as te,p as ne,r as re,s as ie,t as ae,w as S,x as oe,y as se}from"./core-C9QC2jUZ.mjs";import{n as ce,t as le}from"./package-ln6JGWAi.mjs";import{C as ue,E as de,N as fe,O as pe,S as me,T as C,a as w,b as he,c as ge,d as _e,h as ve,i as ye,k as T,m as be,n as xe,o as E,p as Se,r as D,s as O,t as Ce,u as we,v as Te,w as Ee,y as De}from"./request-DFL5MlKG.mjs";import{a as Oe,s as ke}from"./packageJson-yTgvK-Vp.mjs";import{a as Ae,c as je,d as Me,i as k,l as Ne,n as Pe,r as A,s as Fe,t as Ie}from"./auth-D5YibiqF.mjs";import{i as Le,r as Re,t as ze}from"./segment-BiyM1DAx.mjs";import{t as Be}from"./update-notifier-0ylnuuXF.mjs";import*as Ve from"node:util";import{parseArgs as He,promisify as Ue}from"node:util";import{realpath as We}from"node:fs/promises";import{fileURLToPath as Ge,pathToFileURL as Ke}from"node:url";import{createHash as qe}from"node:crypto";import{dirname as Je,join as Ye,posix as Xe,sep as Ze}from"node:path";import{exec as Qe,execFile as $e}from"node:child_process";import{Readable as et}from"node:stream";import{createInterface as tt}from"node:readline";import*as nt from"node:http";import*as j from"node:os";import{homedir as rt}from"node:os";import{setTimeout as it}from"node:timers/promises";import{isMainThread as at,threadId as ot}from"worker_threads";import*as st from"node:diagnostics_channel";import{subscribe as ct}from"node:diagnostics_channel";import{createReadStream as lt,existsSync as ut,readFile as dt,readFileSync as ft,readdir as pt}from"node:fs";import{Worker as mt}from"node:worker_threads";import*as ht from"node:https";import{createGzip as gt}from"node:zlib";import*as _t from"node:net";import*as vt from"node:tls";import{AsyncLocalStorage as yt}from"node:async_hooks";function M(e,t){return async function(){let{positionals:n={},options:r={}}=e,i=e.name.split(` `).length,a=process.argv.slice(1+i),o=Object.keys(n).length>0,s=He({args:a,options:{...r,help:{type:`boolean`,short:`h`}},allowPositionals:o,strict:!0});if(s.values.help){console.info(bt(e));return}for(let[e,[t,r]]of Object.entries(n).entries())if(r.required&&!s.positionals[e])throw new P(`Missing required argument: <${t}>`);for(let[e,t]of Object.entries(r))if(t.required&&!(e in s.values))throw new P(`Missing required option: --${e}`);await t(s)}}function bt(e){let{description:t,sections:n,positionals:r={},options:i}=e,a=Object.keys(r),o=[f(t)];o.push(``),o.push(`USAGE`);let s=` ${e.name}`;if(a.length>0&&(s+=` `+a.map(e=>`<${e}>`).join(` `)),s+=` [options]`,o.push(s),a.length>0){o.push(``),o.push(`ARGUMENTS`);let e=[];for(let t in r){let n=r[t],i=n.description+(n.required?` (required)`:``);e.push([` <${t}>`,i])}o.push(b(e))}o.push(``),o.push(`OPTIONS`);let c=[];if(i){let e=Object.keys(i);for(let t of e){let e=i[t],n=`${e.short?`-${e.short}, `:` `}--${t}${e.type===`string`?` string`:``}`,r=e.description+(e.required?` (required)`:``);c.push({left:n,description:r})}}c.push({left:`-h, --help`,description:`Show help for command`});let l=c.map(e=>[` ${e.left}`,e.description]);if(o.push(b(l)),n)for(let e in n){let t=f(n[e]);o.push(``),o.push(e);for(let e of t.split(`
2
+ import{A as e,C as t,D as n,E as r,I as i,M as a,N as o,P as s,S as c,T as l,_ as u,a as d,c as f,d as p,f as m,g as h,h as g,i as _,j as v,k as y,l as b,m as x,n as ee,o as te,p as ne,r as re,s as ie,t as ae,w as S,x as oe,y as se}from"./core-C1t8NJrX.mjs";import{n as ce,t as le}from"./package-Densjvs_.mjs";import{C as ue,E as de,N as fe,O as pe,S as me,T as C,a as w,b as he,c as ge,d as _e,h as ve,i as ye,k as T,m as be,n as xe,o as E,p as Se,r as D,s as O,t as Ce,u as we,v as Te,w as Ee,y as De}from"./request-DFL5MlKG.mjs";import{a as Oe,s as ke}from"./packageJson-yTgvK-Vp.mjs";import{a as Ae,c as je,d as Me,i as k,l as Ne,n as Pe,r as A,s as Fe,t as Ie}from"./auth-v411xsfu.mjs";import{i as Le,r as Re,t as ze}from"./segment-BqeDS7HA.mjs";import{t as Be}from"./update-notifier-Bp8D-mmq.mjs";import*as Ve from"node:util";import{parseArgs as He,promisify as Ue}from"node:util";import{realpath as We}from"node:fs/promises";import{fileURLToPath as Ge,pathToFileURL as Ke}from"node:url";import{createHash as qe}from"node:crypto";import{dirname as Je,join as Ye,posix as Xe,sep as Ze}from"node:path";import{exec as Qe,execFile as $e}from"node:child_process";import{Readable as et}from"node:stream";import{createInterface as tt}from"node:readline";import*as nt from"node:http";import*as j from"node:os";import{homedir as rt}from"node:os";import{setTimeout as it}from"node:timers/promises";import{isMainThread as at,threadId as ot}from"worker_threads";import*as st from"node:diagnostics_channel";import{subscribe as ct}from"node:diagnostics_channel";import{createReadStream as lt,existsSync as ut,readFile as dt,readFileSync as ft,readdir as pt}from"node:fs";import{Worker as mt}from"node:worker_threads";import*as ht from"node:https";import{createGzip as gt}from"node:zlib";import*as _t from"node:net";import*as vt from"node:tls";import{AsyncLocalStorage as yt}from"node:async_hooks";function M(e,t){return async function(){let{positionals:n={},options:r={}}=e,i=e.name.split(` `).length,a=process.argv.slice(1+i),o=Object.keys(n).length>0,s=He({args:a,options:{...r,help:{type:`boolean`,short:`h`}},allowPositionals:o,strict:!0});if(s.values.help){console.info(bt(e));return}for(let[e,[t,r]]of Object.entries(n).entries())if(r.required&&!s.positionals[e])throw new P(`Missing required argument: <${t}>`);for(let[e,t]of Object.entries(r))if(t.required&&!(e in s.values))throw new P(`Missing required option: --${e}`);await t(s)}}function bt(e){let{description:t,sections:n,positionals:r={},options:i}=e,a=Object.keys(r),o=[f(t)];o.push(``),o.push(`USAGE`);let s=` ${e.name}`;if(a.length>0&&(s+=` `+a.map(e=>`<${e}>`).join(` `)),s+=` [options]`,o.push(s),a.length>0){o.push(``),o.push(`ARGUMENTS`);let e=[];for(let t in r){let n=r[t],i=n.description+(n.required?` (required)`:``);e.push([` <${t}>`,i])}o.push(b(e))}o.push(``),o.push(`OPTIONS`);let c=[];if(i){let e=Object.keys(i);for(let t of e){let e=i[t],n=`${e.short?`-${e.short}, `:` `}--${t}${e.type===`string`?` string`:``}`,r=e.description+(e.required?` (required)`:``);c.push({left:n,description:r})}}c.push({left:`-h, --help`,description:`Show help for command`});let l=c.map(e=>[` ${e.left}`,e.description]);if(o.push(b(l)),n)for(let e in n){let t=f(n[e]);o.push(``),o.push(e);for(let e of t.split(`
3
3
  `))o.push(e?` ${e}`:``)}o.push(``),o.push(`LEARN MORE`);let u=e.name.split(` `)[0];return o.push(` Use \`${u} <command> --help\` for more information about a command.`),o.join(`
4
4
  `)}function N(e){let t=e.name.split(` `).length;return async function(){let{positionals:[n]}=He({args:process.argv.slice(1+t),options:{help:{type:`boolean`,short:`h`}},allowPositionals:!0,strict:!1}),r=n?e.commands[n]:void 0;if(r){await r.handler();return}if(n)throw new P(`Unknown command: ${n}`);console.info(xt(e))}}function xt(e){let{name:t,description:n,sections:r,commands:i}=e,a=[n];a.push(``),a.push(`USAGE`),a.push(` ${t} <command> [options]`),a.push(``),a.push(`COMMANDS`);let o=Object.entries(i).map(([e,t])=>[` ${e}`,t.description]);if(a.push(b(o)),a.push(``),a.push(`OPTIONS`),a.push(` -h, --help Show help for command`),r)for(let e in r){let t=f(r[e]);a.push(``),a.push(e);for(let e of t.split(`
5
5
  `))a.push(e?` ${e}`:``)}return a.push(``),a.push(`LEARN MORE`),a.push(` Use \`${t} <command> --help\` for more information about a command.`),a.join(`
@@ -92,7 +92,7 @@ import{A as e,C as t,D as n,E as r,I as i,M as a,N as o,P as s,S as c,T as l,_ a
92
92
  Installs dependencies, creates the Prismic client file, slice simulator
93
93
  page, preview routes, and other files required by the detected framework.
94
94
  Skips files that already exist.
95
- `,options:{"no-install":{type:`boolean`,description:`Skip installing dependencies`}}},async({values:e})=>{if(await(await m()).setupProject(),!e[`no-install`])try{console.info(`Installing dependencies...`),await Oe()}catch{console.warn("Could not install dependencies automatically. Please install them manually (i.e. `npm install`).")}console.info(`Generated setup files.`)}),_n=M({name:`prismic gen types`,description:`Generate TypeScript types for slices and content types.`},async()=>{let e=await(await m()).generateTypes(),n=ve(await t(),e);console.info(`Generated types at ${n}`)}),vn=N({name:`prismic gen`,description:`Generate files from local Prismic models.`,commands:{setup:{handler:gn,description:`Generate framework-specific Prismic setup`},types:{handler:_n,description:`Generate TypeScript types from local models`}}});async function yn(e){let{repo:t,token:n,host:r}=e,i=jn(r),a=new URL(`customtypes`,i);try{return await E(a,{headers:{repository:t,Authorization:`Bearer ${n}`}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function bn(e,t){let{repo:n,token:r,host:i}=t,a=jn(i);await E(new URL(`customtypes/insert`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function xn(e,t){let{repo:n,token:r,host:i}=t,a=jn(i);await E(new URL(`customtypes/update`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function Sn(e,t){let{repo:n,token:r,host:i}=t,a=jn(i);await E(new URL(`customtypes/${encodeURIComponent(e)}`,a),{method:`DELETE`,headers:{repository:n,Authorization:`Bearer ${r}`}})}async function Cn(e){let{repo:t,token:n,host:r}=e,i=jn(r),a=new URL(`slices`,i);try{return await E(a,{headers:{repository:t,Authorization:`Bearer ${n}`}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function wn(e,t){let{repo:n,token:r,host:i}=t,a=jn(i);await E(new URL(`slices/insert`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function Tn(e,t){let{repo:n,token:r,host:i}=t,a=jn(i);await E(new URL(`slices/update`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function En(e,t){let{repo:n,token:r,host:i}=t,a=jn(i);await E(new URL(`slices/${encodeURIComponent(e)}`,a),{method:`DELETE`,headers:{repository:n,Authorization:`Bearer ${r}`}})}const Dn=C({values:C({url:T(),fields:pe(T(),T())}),imgixEndpoint:T()}),On={"image/png":`.png`,"image/jpeg":`.jpg`,"image/gif":`.gif`,"image/webp":`.webp`};async function kn(e,t){let{sliceId:n,variationId:r,repo:i,token:a,host:o}=t,s=e.type;if(!(s in On))throw new An(s);let c=await E(new URL(`create`,Mn(o)),{headers:{Repository:i,Authorization:`Bearer ${a}`},schema:Dn}),l=On[s],u=`${i}/shared-slices/${n}/${r}/${qe(`md5`).update(new Uint8Array(await e.arrayBuffer())).digest(`hex`)}${l}`,d=new FormData;for(let[e,t]of Object.entries(c.values.fields))d.append(e,t);d.append(`key`,u),d.append(`Content-Type`,s),d.append(`file`,e),await E(c.values.url,{method:`POST`,body:d});let f=new URL(u,Se(c.imgixEndpoint));return f.searchParams.set(`auto`,`compress,format`),f}var An=class extends Error{name=`UnsupportedFileTypeError`;constructor(e){super(`Unsupported file type: ${e||`unknown`}. Supported: ${Object.keys(On).join(`, `)}`)}};function jn(e){return new URL(`https://customtypes.${e}/`)}function Mn(e){return new URL(`https://acl-provider.${e}/`)}function Nn(e){Qe(`${process.platform===`darwin`?`open`:process.platform===`win32`?`start ""`:`xdg-open`} "${e.toString()}"`)}function B(e,t,n){let{getKey:r,equals:i=(e,t)=>JSON.stringify(e)===JSON.stringify(t)}=n,a={insert:[],update:[],delete:[]};for(let n of e){let e=t.find(e=>r(e)===r(n));e?i(n,e)||a.update.push(n):a.insert.push(n)}for(let n of t)e.some(e=>r(e)===r(n))||a.delete.push(n);return a}const Pn=C({documentsPublished:De(),documentsUnpublished:De(),releasesCreated:De(),releasesUpdated:De(),tagsCreated:De(),tagsDeleted:De()}),Fn=Object.keys(Pn.shape),In=C({config:he(Pn,{_id:T(),url:T(),active:De(),name:ue(T()),secret:ue(T()),headers:pe(T(),T())})});async function Ln(e){let{repo:t,token:n,host:r}=e,i=V(t,r),a=new URL(`app/settings/webhooks`,i);try{return await E(a,{credentials:{"prismic-auth":n},schema:Te(In)})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function Rn(e,t){let{repo:n,token:r,host:i}=t,a=V(n,i),o=new URL(`app/settings/webhooks/create`,a),s=new FormData;s.set(`url`,e.url),s.set(`name`,e.name??``),s.set(`secret`,e.secret??``),s.set(`headers`,JSON.stringify({})),s.set(`active`,`on`),s.set(`documentsPublished`,e.documentsPublished.toString()),s.set(`documentsUnpublished`,e.documentsUnpublished.toString()),s.set(`releasesCreated`,e.releasesCreated.toString()),s.set(`releasesUpdated`,e.releasesUpdated.toString()),s.set(`tagsCreated`,e.tagsCreated.toString()),s.set(`tagsDeleted`,e.tagsDeleted.toString());try{await E(o,{method:`POST`,body:s,credentials:{"prismic-auth":r}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}async function zn(e,t,n){let{repo:r,token:i,host:a}=n,o=V(r,a),s=new URL(`app/settings/webhooks/${e}`,o),c=new FormData;c.set(`url`,t.url),c.set(`name`,t.name??``),c.set(`secret`,t.secret??``),c.set(`headers`,JSON.stringify(t.headers??{})),c.set(`active`,t.active?`on`:`off`),c.set(`documentsPublished`,t.documentsPublished.toString()),c.set(`documentsUnpublished`,t.documentsUnpublished.toString()),c.set(`releasesCreated`,t.releasesCreated.toString()),c.set(`releasesUpdated`,t.releasesUpdated.toString()),c.set(`tagsCreated`,t.tagsCreated.toString()),c.set(`tagsDeleted`,t.tagsDeleted.toString());try{await E(s,{method:`POST`,body:c,credentials:{"prismic-auth":i}})}catch(e){throw e instanceof D&&(e.message=`Webhook not found`),e}}async function Bn(e,t){let{repo:n,token:r,host:i}=t,a=V(n,i),o=new URL(`app/settings/webhooks/${e}/delete`,a);try{await E(o,{method:`POST`,credentials:{"prismic-auth":r}})}catch(e){throw e instanceof D&&(e.message=`Webhook not found`),e}}const Vn=C({id:T(),scope:T(),token:T(),created_at:C({$date:Ee()})}),Hn=C({id:T(),name:T(),wroom_auths:Te(Vn)}),Un=C({app_name:T(),token:T(),timestamp:Ee()}),Wn=C({max_tokens:Ee(),tokens:Te(Un)});async function Gn(e){let t=new URL(`settings/security/contentapi`,V(e.repo,e.host));try{return await E(t,{credentials:{"prismic-auth":e.token},schema:Te(Hn)})}catch(t){throw t instanceof D&&(t.message=`Repository not found: ${e.repo}`),t}}async function Kn(e,t){let n=new URL(`settings/security/oauthapp`,V(t.repo,t.host));try{return await E(n,{method:`POST`,body:{app_name:e},credentials:{"prismic-auth":t.token},schema:Hn})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t.repo}`),e}}async function qn(e,t,n){let r=new URL(`settings/security/authorizations`,V(n.repo,n.host));try{return await E(r,{method:`POST`,body:{app:e,scope:t},credentials:{"prismic-auth":n.token},schema:Vn})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n.repo}`),e}}async function Jn(e,t){let n=new URL(`settings/security/authorizations/${encodeURIComponent(e)}`,V(t.repo,t.host));try{await E(n,{method:`DELETE`,credentials:{"prismic-auth":t.token}})}catch(e){throw e instanceof D&&(e.message=`Token not found`),e}}async function Yn(e){let t=new URL(`settings/security/customtypesapi`,V(e.repo,e.host));try{return await E(t,{credentials:{"prismic-auth":e.token},schema:Wn})}catch(t){throw t instanceof D&&(t.message=`Repository not found: ${e.repo}`),t}}async function Xn(e,t){let n=new URL(`settings/security/token`,V(t.repo,t.host));try{return await E(n,{method:`POST`,body:{app_name:e},credentials:{"prismic-auth":t.token},schema:Un})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t.repo}`),e}}async function Zn(e,t){let n=new URL(`settings/security/token/${encodeURIComponent(e)}`,V(t.repo,t.host));try{await E(n,{method:`DELETE`,credentials:{"prismic-auth":t.token}})}catch(t){throw t instanceof D&&(t.message=`Token not found: ${e}`),t}}async function Qn(e){let{domain:t,token:n,host:r}=e;return await E(new URL(`app/dashboard/repositories/${t}/exists`,ar(r)),{credentials:{"prismic-auth":n},schema:De()})}async function $n(e){let{domain:t,name:n,framework:r,agent:i,token:a,host:o}=e,s=new URL(`app/dashboard/repositories`,ar(o));s.searchParams.set(`app`,`cli`),i&&s.searchParams.set(`agent`,i),await E(s,{method:`POST`,body:{domain:t,name:n,framework:r,plan:`personal`},credentials:{"prismic-auth":a}})}const er=C({repository:C({api_access:T()})});async function tr(e){let{repo:t,token:n,host:r}=e,i=new URL(`syncState`,V(t,r));try{return(await E(i,{credentials:{"prismic-auth":n},schema:er})).repository.api_access}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function nr(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`settings/security/apiaccess`,V(n,i));try{await E(a,{method:`POST`,body:{api_access:e},credentials:{"prismic-auth":r}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}const rr=C({repository:C({name:T()})});async function ir(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`app/settings/repository`,V(n,i)),o=new FormData;o.set(`displayname`,e);try{return(await E(a,{method:`POST`,body:o,credentials:{"prismic-auth":r},schema:rr})).repository.name}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}function ar(e){return new URL(`https://${e}/`)}function V(e,t){return new URL(`https://${e}.${t}/`)}function or(e){let{repo:t,host:n,customTypeId:r}=e,i=new URL(`builder/working`,V(t,n));return i.searchParams.set(`customTypes`,r),i.href}function sr(e){let{repo:t,host:n,format:r}=e,i=[`builder`,`types`,r===`custom`?`custom-types`:`page-types`].join(`/`);return new URL(i,V(t,n)).href}async function cr(){if(process.env.AI_AGENT)return process.env.AI_AGENT.toLowerCase();if(process.env.CLAUDE_CODE_IS_COWORK===`1`||process.env.CLAUDE_CODE_IS_COWORK===`true`)return`claude-cowork`;if(process.env.CLAUDECODE===`1`||process.env.CLAUDE_CODE)return`claude-code`;if(process.env.CODEX_CI===`1`||process.env.CODEX_SANDBOX||process.env.CODEX_THREAD_ID)return`codex`;if(process.env.CURSOR_AGENT===`1`||process.env.CURSOR_EXTENSION_HOST_ROLE===`agent-exec`)return`cursor`;if(process.env.CLINE_ACTIVE===`true`)return`cline`;if(process.env.ANTIGRAVITY_AGENT)return`antigravity`;if(process.env.AUGMENT_AGENT===`1`)return`augment`;if(process.env.OPENCODE_CLIENT===`1`)return`opencode`;if(process.env.GEMINI_CLI===`1`)return`gemini-cli`;if(process.env.TRAE_AI_SHELL_ID)return`trae`;if(process.env.REPL_ID)return`replit`;if(process.env.COPILOT_MODEL||process.env.COPILOT_ALLOW_ALL||process.env.COPILOT_GITHUB_TOKEN)return`github-copilot`;let e=process.env.AGENT?.toLowerCase();if(e===`goose`||e===`amp`)return e;if(process.platform===`linux`&&await ge(new URL(`file:///opt/.devin`)))return`devin`;if(process.env.IS_SANDBOX===`yes`)return`unknown-sandbox`}var lr=M({name:`prismic repo create`,description:`Create a new Prismic repository.`,options:{name:{type:`string`,short:`n`,description:`Display name for the repository`}}},async({values:e})=>{let{name:t}=e,n=await k(),r=await A(),i=await ur({name:t,token:n,host:r});console.info(`Repository created: ${i}`),console.info(`URL: https://${i}.${r}/`)});async function ur(t){let{name:n,token:r,host:i}=t,a=await dr({token:r,host:i});if(!a)throw new P(`Failed to create a repository. Please try again.`);let o=(await m().catch(()=>void 0))?.id??`other`,s=await cr();try{await $n({domain:a,name:n??a,framework:o,agent:s,token:r,host:i})}catch(e){throw e instanceof w?new P(`Failed to create repository: ${await e.text()}`):e}return await e({repo:a,token:r,host:i,stepIds:[`createPrismicProject`]}),a}async function dr(e){let{token:t,host:n}=e,r;for(let e=0;e<5;e++){let e=crypto.randomUUID().replace(/-/g,``).slice(0,8);if(await Qn({domain:e,token:t,host:n})){r=e;break}}return r}var fr=M({name:`prismic init`,description:`
95
+ `,options:{"no-install":{type:`boolean`,description:`Skip installing dependencies`}}},async({values:e})=>{if(await(await m()).setupProject(),!e[`no-install`])try{console.info(`Installing dependencies...`),await Oe()}catch{console.warn("Could not install dependencies automatically. Please install them manually (i.e. `npm install`).")}console.info(`Generated setup files.`)}),_n=M({name:`prismic gen types`,description:`Generate TypeScript types for slices and content types.`},async()=>{let e=await(await m()).generateTypes(),n=ve(await t(),e);console.info(`Generated types at ${n}`)}),vn=N({name:`prismic gen`,description:`Generate files from local Prismic models.`,commands:{setup:{handler:gn,description:`Generate framework-specific Prismic setup`},types:{handler:_n,description:`Generate TypeScript types from local models`}}});async function yn(e){let{repo:t,token:n,host:r}=e,i=Mn(r),a=new URL(`customtypes`,i);try{return await E(a,{headers:{repository:t,Authorization:`Bearer ${n}`}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function bn(e,t){let{repo:n,token:r,host:i}=t,a=Mn(i);await E(new URL(`customtypes/insert`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function xn(e,t){let{repo:n,token:r,host:i}=t,a=Mn(i);await E(new URL(`customtypes/update`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function Sn(e,t){let{repo:n,token:r,host:i}=t,a=Mn(i);await E(new URL(`customtypes/${encodeURIComponent(e)}`,a),{method:`DELETE`,headers:{repository:n,Authorization:`Bearer ${r}`}})}async function Cn(e){let{repo:t,token:n,host:r}=e,i=Mn(r),a=new URL(`slices`,i);try{return await E(a,{headers:{repository:t,Authorization:`Bearer ${n}`}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function wn(e,t){let{repo:n,token:r,host:i}=t,a=Mn(i);await E(new URL(`slices/insert`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function Tn(e,t){let{repo:n,token:r,host:i}=t,a=Mn(i);await E(new URL(`slices/update`,a),{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:e})}async function En(e,t){let{repo:n,token:r,host:i}=t,a=Mn(i);await E(new URL(`slices/${encodeURIComponent(e)}`,a),{method:`DELETE`,headers:{repository:n,Authorization:`Bearer ${r}`}})}const Dn=C({values:C({url:T(),fields:pe(T(),T())}),imgixEndpoint:T()}),On={"image/png":`.png`,"image/jpeg":`.jpg`,"image/gif":`.gif`,"image/webp":`.webp`};async function kn(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`delete`,Nn(i));a.searchParams.set(`repository`,n),await E(a,{method:`POST`,headers:{repository:n,Authorization:`Bearer ${r}`},body:{sliceId:e}})}async function An(e,t){let{sliceId:n,variationId:r,repo:i,token:a,host:o}=t,s=e.type;if(!(s in On))throw new jn(s);let c=new URL(`presigned-url`,Nn(o));c.searchParams.set(`repository`,i);let l=await E(c,{headers:{repository:i,Authorization:`Bearer ${a}`},schema:Dn}),u=On[s],d=`${i}/shared-slices/${n}/${r}/${qe(`sha1`).update(new Uint8Array(await e.arrayBuffer())).digest(`hex`)}${u}`,f=new FormData;for(let[e,t]of Object.entries(l.values.fields))f.append(e,t);f.set(`key`,d),f.set(`Content-Type`,s),f.set(`file`,e),await E(l.values.url,{method:`POST`,body:f});let p=new URL(d,Se(l.imgixEndpoint));return p.searchParams.set(`auto`,`compress,format`),p}var jn=class extends Error{name=`UnsupportedFileTypeError`;constructor(e){super(`Unsupported file type: ${e||`unknown`}. Supported: ${Object.keys(On).join(`, `)}`)}};function Mn(e){return new URL(`https://customtypes.${e}/`)}function Nn(e){return new URL(`https://api.internal.${e}/screenshot/`)}function Pn(e){Qe(`${process.platform===`darwin`?`open`:process.platform===`win32`?`start ""`:`xdg-open`} "${e.toString()}"`)}function B(e,t,n){let{getKey:r,equals:i=(e,t)=>JSON.stringify(e)===JSON.stringify(t)}=n,a={insert:[],update:[],delete:[]};for(let n of e){let e=t.find(e=>r(e)===r(n));e?i(n,e)||a.update.push(n):a.insert.push(n)}for(let n of t)e.some(e=>r(e)===r(n))||a.delete.push(n);return a}const Fn=C({documentsPublished:De(),documentsUnpublished:De(),releasesCreated:De(),releasesUpdated:De(),tagsCreated:De(),tagsDeleted:De()}),In=Object.keys(Fn.shape),Ln=C({config:he(Fn,{_id:T(),url:T(),active:De(),name:ue(T()),secret:ue(T()),headers:pe(T(),T())})});async function Rn(e){let{repo:t,token:n,host:r}=e,i=V(t,r),a=new URL(`app/settings/webhooks`,i);try{return await E(a,{credentials:{"prismic-auth":n},schema:Te(Ln)})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function zn(e,t){let{repo:n,token:r,host:i}=t,a=V(n,i),o=new URL(`app/settings/webhooks/create`,a),s=new FormData;s.set(`url`,e.url),s.set(`name`,e.name??``),s.set(`secret`,e.secret??``),s.set(`headers`,JSON.stringify({})),s.set(`active`,`on`),s.set(`documentsPublished`,e.documentsPublished.toString()),s.set(`documentsUnpublished`,e.documentsUnpublished.toString()),s.set(`releasesCreated`,e.releasesCreated.toString()),s.set(`releasesUpdated`,e.releasesUpdated.toString()),s.set(`tagsCreated`,e.tagsCreated.toString()),s.set(`tagsDeleted`,e.tagsDeleted.toString());try{await E(o,{method:`POST`,body:s,credentials:{"prismic-auth":r}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}async function Bn(e,t,n){let{repo:r,token:i,host:a}=n,o=V(r,a),s=new URL(`app/settings/webhooks/${e}`,o),c=new FormData;c.set(`url`,t.url),c.set(`name`,t.name??``),c.set(`secret`,t.secret??``),c.set(`headers`,JSON.stringify(t.headers??{})),c.set(`active`,t.active?`on`:`off`),c.set(`documentsPublished`,t.documentsPublished.toString()),c.set(`documentsUnpublished`,t.documentsUnpublished.toString()),c.set(`releasesCreated`,t.releasesCreated.toString()),c.set(`releasesUpdated`,t.releasesUpdated.toString()),c.set(`tagsCreated`,t.tagsCreated.toString()),c.set(`tagsDeleted`,t.tagsDeleted.toString());try{await E(s,{method:`POST`,body:c,credentials:{"prismic-auth":i}})}catch(e){throw e instanceof D&&(e.message=`Webhook not found`),e}}async function Vn(e,t){let{repo:n,token:r,host:i}=t,a=V(n,i),o=new URL(`app/settings/webhooks/${e}/delete`,a);try{await E(o,{method:`POST`,credentials:{"prismic-auth":r}})}catch(e){throw e instanceof D&&(e.message=`Webhook not found`),e}}const Hn=C({id:T(),scope:T(),token:T(),created_at:C({$date:Ee()})}),Un=C({id:T(),name:T(),wroom_auths:Te(Hn)}),Wn=C({app_name:T(),token:T(),timestamp:Ee()}),Gn=C({max_tokens:Ee(),tokens:Te(Wn)});async function Kn(e){let t=new URL(`settings/security/contentapi`,V(e.repo,e.host));try{return await E(t,{credentials:{"prismic-auth":e.token},schema:Te(Un)})}catch(t){throw t instanceof D&&(t.message=`Repository not found: ${e.repo}`),t}}async function qn(e,t){let n=new URL(`settings/security/oauthapp`,V(t.repo,t.host));try{return await E(n,{method:`POST`,body:{app_name:e},credentials:{"prismic-auth":t.token},schema:Un})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t.repo}`),e}}async function Jn(e,t,n){let r=new URL(`settings/security/authorizations`,V(n.repo,n.host));try{return await E(r,{method:`POST`,body:{app:e,scope:t},credentials:{"prismic-auth":n.token},schema:Hn})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n.repo}`),e}}async function Yn(e,t){let n=new URL(`settings/security/authorizations/${encodeURIComponent(e)}`,V(t.repo,t.host));try{await E(n,{method:`DELETE`,credentials:{"prismic-auth":t.token}})}catch(e){throw e instanceof D&&(e.message=`Token not found`),e}}async function Xn(e){let t=new URL(`settings/security/customtypesapi`,V(e.repo,e.host));try{return await E(t,{credentials:{"prismic-auth":e.token},schema:Gn})}catch(t){throw t instanceof D&&(t.message=`Repository not found: ${e.repo}`),t}}async function Zn(e,t){let n=new URL(`settings/security/token`,V(t.repo,t.host));try{return await E(n,{method:`POST`,body:{app_name:e},credentials:{"prismic-auth":t.token},schema:Wn})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t.repo}`),e}}async function Qn(e,t){let n=new URL(`settings/security/token/${encodeURIComponent(e)}`,V(t.repo,t.host));try{await E(n,{method:`DELETE`,credentials:{"prismic-auth":t.token}})}catch(t){throw t instanceof D&&(t.message=`Token not found: ${e}`),t}}async function $n(e){let{domain:t,token:n,host:r}=e;return await E(new URL(`app/dashboard/repositories/${t}/exists`,or(r)),{credentials:{"prismic-auth":n},schema:De()})}async function er(e){let{domain:t,name:n,framework:r,agent:i,token:a,host:o}=e,s=new URL(`app/dashboard/repositories`,or(o));s.searchParams.set(`app`,`cli`),i&&s.searchParams.set(`agent`,i),await E(s,{method:`POST`,body:{domain:t,name:n,framework:r,plan:`personal`},credentials:{"prismic-auth":a}})}const tr=C({repository:C({api_access:T()})});async function nr(e){let{repo:t,token:n,host:r}=e,i=new URL(`syncState`,V(t,r));try{return(await E(i,{credentials:{"prismic-auth":n},schema:tr})).repository.api_access}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function rr(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`settings/security/apiaccess`,V(n,i));try{await E(a,{method:`POST`,body:{api_access:e},credentials:{"prismic-auth":r}})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}const ir=C({repository:C({name:T()})});async function ar(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`app/settings/repository`,V(n,i)),o=new FormData;o.set(`displayname`,e);try{return(await E(a,{method:`POST`,body:o,credentials:{"prismic-auth":r},schema:ir})).repository.name}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}function or(e){return new URL(`https://${e}/`)}function V(e,t){return new URL(`https://${e}.${t}/`)}function sr(e){let{repo:t,host:n,customTypeId:r}=e,i=new URL(`builder/working`,V(t,n));return i.searchParams.set(`customTypes`,r),i.href}function cr(e){let{repo:t,host:n,format:r}=e,i=[`builder`,`types`,r===`custom`?`custom-types`:`page-types`].join(`/`);return new URL(i,V(t,n)).href}async function lr(){if(process.env.AI_AGENT)return process.env.AI_AGENT.toLowerCase();if(process.env.CLAUDE_CODE_IS_COWORK===`1`||process.env.CLAUDE_CODE_IS_COWORK===`true`)return`claude-cowork`;if(process.env.CLAUDECODE===`1`||process.env.CLAUDE_CODE)return`claude-code`;if(process.env.CODEX_CI===`1`||process.env.CODEX_SANDBOX||process.env.CODEX_THREAD_ID)return`codex`;if(process.env.CURSOR_AGENT===`1`||process.env.CURSOR_EXTENSION_HOST_ROLE===`agent-exec`)return`cursor`;if(process.env.CLINE_ACTIVE===`true`)return`cline`;if(process.env.ANTIGRAVITY_AGENT)return`antigravity`;if(process.env.AUGMENT_AGENT===`1`)return`augment`;if(process.env.OPENCODE_CLIENT===`1`)return`opencode`;if(process.env.GEMINI_CLI===`1`)return`gemini-cli`;if(process.env.TRAE_AI_SHELL_ID)return`trae`;if(process.env.REPL_ID)return`replit`;if(process.env.COPILOT_MODEL||process.env.COPILOT_ALLOW_ALL||process.env.COPILOT_GITHUB_TOKEN)return`github-copilot`;let e=process.env.AGENT?.toLowerCase();if(e===`goose`||e===`amp`)return e;if(process.platform===`linux`&&await ge(new URL(`file:///opt/.devin`)))return`devin`;if(process.env.IS_SANDBOX===`yes`)return`unknown-sandbox`}var ur=M({name:`prismic repo create`,description:`Create a new Prismic repository.`,options:{name:{type:`string`,short:`n`,description:`Display name for the repository`}}},async({values:e})=>{let{name:t}=e,n=await k(),r=await A(),i=await dr({name:t,token:n,host:r});console.info(`Repository created: ${i}`),console.info(`URL: https://${i}.${r}/`)});async function dr(t){let{name:n,token:r,host:i}=t,a=await fr({token:r,host:i});if(!a)throw new P(`Failed to create a repository. Please try again.`);let o=(await m().catch(()=>void 0))?.id??`other`,s=await lr();try{await er({domain:a,name:n??a,framework:o,agent:s,token:r,host:i})}catch(e){throw e instanceof w?new P(`Failed to create repository: ${await e.text()}`):e}return await e({repo:a,token:r,host:i,stepIds:[`createPrismicProject`]}),a}async function fr(e){let{token:t,host:n}=e,r;for(let e=0;e<5;e++){let e=crypto.randomUUID().replace(/-/g,``).slice(0,8);if(await $n({domain:e,token:t,host:n})){r=e;break}}return r}var pr=M({name:`prismic init`,description:`
96
96
  Initialize a new Prismic project by creating a repository and
97
97
  prismic.config.json file. Detects the project framework, installs
98
98
  dependencies, and syncs models from Prismic.
@@ -100,42 +100,42 @@ import{A as e,C as t,D as n,E as r,I as i,M as a,N as o,P as s,S as c,T as l,_ a
100
100
  Use --repo to connect to an existing repository instead. If a
101
101
  slicemachine.config.json exists, its repository and settings will be
102
102
  migrated.
103
- `,options:{repo:{type:`string`,short:`r`,description:`Repository name`},"no-browser":{type:`boolean`,description:`Skip opening the browser automatically during login`}}},async({values:e})=>{let{repo:t,"no-browser":n}=e;try{throw await l(),new P(`A prismic.config.json file exists. This project is already initialized.`)}catch(e){if(!(e instanceof g))throw e}let i;try{i=await r()}catch(e){e instanceof ne&&console.warn(`Could not read slicemachine.config.json, ignoring.`)}let a=await k(),o=await A(),s;try{s=await y({token:a,host:o})}catch(e){if(e instanceof ye||e instanceof xe){console.info(`Not logged in. Starting login...`);let{email:e}=await Pe({onReady:e=>{n?console.info(`Open this URL to log in: ${e}`):(console.info(`Opening browser to complete login...`),console.info(`If the browser doesn't open, visit: ${e}`),Nn(e))}});console.info(`Logged in as ${e}`),a=await k(),s=await y({token:a,host:o})}else throw e}let d=(t??i?.repositoryName)?.toLowerCase();if(d){if(!s.repositories.some(e=>e.domain===d))throw new P(`Repository "${d}" not found in your account. Check the name or request access to the repository.`);if(!await se(d,{token:a,host:o}))throw new h}let f=await m();d||(d=await ur({token:a,host:o}),console.info(`Created repository: ${d}`));try{let e=o===Ne?void 0:`https://${d}.cdn.${o}/api/v2/`;await oe({repositoryName:d,documentAPIEndpoint:e,libraries:i?.libraries,routes:[]})}catch(e){throw e instanceof u?new P(`Could not find a package.json file. Run this command from a project directory.`):new P(`Failed to create prismic.config.json.`)}if(i){try{await c()}catch{}console.info(`Migrated slicemachine.config.json to prismic.config.json`)}await f.initProject();try{console.info(`Installing dependencies...`),await Oe()}catch{console.warn("Could not install dependencies automatically. Please install them manually (i.e. `npm install`).")}let[p,_,v,b]=await Promise.all([yn({repo:d,token:a,host:o}),Cn({repo:d,token:a,host:o}),f.getCustomTypes(),f.getSlices()]),x=v.map(e=>e.model),ee=B(_,b.map(e=>e.model),{getKey:e=>e.id});for(let e of ee.update)await f.updateSlice(e);for(let e of ee.delete)await f.deleteSlice(e.id);for(let e of ee.insert)await f.createSlice(e);let te=B(p,x,{getKey:e=>e.id});for(let e of te.update)await f.updateCustomType(e);for(let e of te.delete)await f.deleteCustomType(e.id);for(let e of te.insert)await f.createCustomType(e);await f.generateTypes(),console.info(`\nInitialized Prismic for repository "${d}".`),console.info("Run `prismic type create <name>` to create a content type."),console.info("Run `prismic sync` to sync models from Prismic.")});const pr=C({id:T(),label:T(),customName:ue(T()),isMaster:De()});async function mr(e){let{repo:t,token:n,host:r}=e,i=new URL(`repository/locales`,_r(r));i.searchParams.set(`repository`,t);try{return(await E(i,{headers:{Authorization:`Bearer ${n}`},schema:C({results:Te(pr)})})).results}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function hr(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`repository/locales`,_r(i));a.searchParams.set(`repository`,n);try{return await E(a,{method:`POST`,body:{id:e.id,isMaster:e.isMaster??!1,...e.customName?{customName:e.customName}:{}},headers:{Authorization:`Bearer ${r}`},schema:pr})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}async function gr(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`repository/locales/${encodeURIComponent(e)}`,_r(i));a.searchParams.set(`repository`,n),await E(a,{method:`DELETE`,headers:{Authorization:`Bearer ${r}`}})}function _r(e){return new URL(`https://api.internal.${e}/locale/`)}async function H(e,t){let{repo:n,token:r,host:i}=t,[a,o]=await Promise.all([y({token:r,host:i}),re({repo:n,token:r,host:i})]),s=o.filter(e=>(e.kind===`prod`||e.kind===`stage`)&&e.users.some(e=>e.id===a.shortId)),c=s.find(t=>t.domain===e);if(c)return c.domain;throw new vr(e,s,n)}var vr=class extends Error{name=`InvalidEnvironmentError`;repo;env;availableEnvironments;constructor(e,t,n){super(),this.repo=n,this.env=e,this.availableEnvironments=t}},yr=M({name:`prismic locale add`,description:`
103
+ `,options:{repo:{type:`string`,short:`r`,description:`Repository name`},"no-browser":{type:`boolean`,description:`Skip opening the browser automatically during login`}}},async({values:e})=>{let{repo:t,"no-browser":n}=e;try{throw await l(),new P(`A prismic.config.json file exists. This project is already initialized.`)}catch(e){if(!(e instanceof g))throw e}let i;try{i=await r()}catch(e){e instanceof ne&&console.warn(`Could not read slicemachine.config.json, ignoring.`)}let a=await k(),o=await A(),s;try{s=await y({token:a,host:o})}catch(e){if(e instanceof ye||e instanceof xe){if(Me.PRISMIC_TOKEN)throw new P(`PRISMIC_TOKEN is invalid or expired. Unset it to log in with a browser, or replace it with a valid token.`);console.info(`Not logged in. Starting login...`);let{email:e}=await Pe({onReady:e=>{n?console.info(`Open this URL to log in: ${e}`):(console.info(`Opening browser to complete login...`),console.info(`If the browser doesn't open, visit: ${e}`),Pn(e))}});console.info(`Logged in as ${e}`),a=await k(),s=await y({token:a,host:o})}else throw e}let d=(t??i?.repositoryName)?.toLowerCase();if(d){if(!s.repositories.some(e=>e.domain===d))throw new P(`Repository "${d}" not found in your account. Check the name or request access to the repository.`);if(!await se(d,{token:a,host:o}))throw new h}let f=await m();d||(d=await dr({token:a,host:o}),console.info(`Created repository: ${d}`));try{let e=o===Ne?void 0:`https://${d}.cdn.${o}/api/v2/`;await oe({repositoryName:d,documentAPIEndpoint:e,libraries:i?.libraries,routes:[]})}catch(e){throw e instanceof u?new P(`Could not find a package.json file. Run this command from a project directory.`):new P(`Failed to create prismic.config.json.`)}if(i){try{await c()}catch{}console.info(`Migrated slicemachine.config.json to prismic.config.json`)}await f.initProject();try{console.info(`Installing dependencies...`),await Oe()}catch{console.warn("Could not install dependencies automatically. Please install them manually (i.e. `npm install`).")}let[p,_,v,b]=await Promise.all([yn({repo:d,token:a,host:o}),Cn({repo:d,token:a,host:o}),f.getCustomTypes(),f.getSlices()]),x=v.map(e=>e.model),ee=B(_,b.map(e=>e.model),{getKey:e=>e.id});for(let e of ee.update)await f.updateSlice(e);for(let e of ee.delete)await f.deleteSlice(e.id);for(let e of ee.insert)await f.createSlice(e);let te=B(p,x,{getKey:e=>e.id});for(let e of te.update)await f.updateCustomType(e);for(let e of te.delete)await f.deleteCustomType(e.id);for(let e of te.insert)await f.createCustomType(e);await f.generateTypes(),console.info(`\nInitialized Prismic for repository "${d}".`),console.info("Run `prismic type create <name>` to create a content type."),console.info("Run `prismic sync` to sync models from Prismic.")});const mr=C({id:T(),label:T(),customName:ue(T()),isMaster:De()});async function hr(e){let{repo:t,token:n,host:r}=e,i=new URL(`repository/locales`,vr(r));i.searchParams.set(`repository`,t);try{return(await E(i,{headers:{Authorization:`Bearer ${n}`},schema:C({results:Te(mr)})})).results}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${t}`),e}}async function gr(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`repository/locales`,vr(i));a.searchParams.set(`repository`,n);try{return await E(a,{method:`POST`,body:{id:e.id,isMaster:e.isMaster??!1,...e.customName?{customName:e.customName}:{}},headers:{Authorization:`Bearer ${r}`},schema:mr})}catch(e){throw e instanceof D&&(e.message=`Repository not found: ${n}`),e}}async function _r(e,t){let{repo:n,token:r,host:i}=t,a=new URL(`repository/locales/${encodeURIComponent(e)}`,vr(i));a.searchParams.set(`repository`,n),await E(a,{method:`DELETE`,headers:{Authorization:`Bearer ${r}`}})}function vr(e){return new URL(`https://api.internal.${e}/locale/`)}async function H(e,t){let{repo:n,token:r,host:i}=t,[a,o]=await Promise.all([y({token:r,host:i}),re({repo:n,token:r,host:i})]),s=o.filter(e=>(e.kind===`prod`||e.kind===`stage`)&&e.users.some(e=>e.id===a.shortId)),c=s.find(t=>t.domain===e);if(c)return c.domain;throw new yr(e,s,n)}var yr=class extends Error{name=`InvalidEnvironmentError`;repo;env;availableEnvironments;constructor(e,t,n){super(),this.repo=n,this.env=e,this.availableEnvironments=t}},br=M({name:`prismic locale add`,description:`
104
104
  Add a locale to a Prismic repository.
105
105
 
106
106
  By default, this command reads the repository from prismic.config.json at the
107
107
  project root.
108
- `,positionals:{code:{description:`Locale code (e.g. fr-fr, es-es)`,required:!0}},options:{master:{type:`boolean`,description:`Set as the master locale`},name:{type:`string`,short:`n`,description:`Custom display name (for custom locales)`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,master:a=!1,name:o}=t,s=await k(),c=await A(),l=i?await H(i,{repo:r,token:s,host:c}):r;try{await hr({id:n,isMaster:a,customName:o},{repo:l,token:s,host:c})}catch(e){throw e instanceof w?new P(`Failed to add locale: ${await e.text()}`):e}console.info(`Locale added: ${n}`)}),br=M({name:`prismic locale list`,description:`
108
+ `,positionals:{code:{description:`Locale code (e.g. fr-fr, es-es)`,required:!0}},options:{master:{type:`boolean`,description:`Set as the master locale`},name:{type:`string`,short:`n`,description:`Custom display name (for custom locales)`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,master:a=!1,name:o}=t,s=await k(),c=await A(),l=i?await H(i,{repo:r,token:s,host:c}):r;try{await gr({id:n,isMaster:a,customName:o},{repo:l,token:s,host:c})}catch(e){throw e instanceof w?new P(`Failed to add locale: ${await e.text()}`):e}console.info(`Locale added: ${n}`)}),xr=M({name:`prismic locale list`,description:`
109
109
  List all locales in a Prismic repository.
110
110
 
111
111
  By default, this command reads the repository from prismic.config.json at the
112
112
  project root.
113
- `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s;try{s=await mr({repo:o,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to list locales: ${await e.text()}`):e}if(r){console.info(O(s));return}if(s.length===0){console.info(`No locales found.`);return}let c=s.map(e=>{let t=e.isMaster?` (master)`:``;return[e.id,`${e.label}${t}`]});console.info(b(c,{headers:[`ID`,`LABEL`]}))}),xr=M({name:`prismic locale remove`,description:`
113
+ `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s;try{s=await hr({repo:o,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to list locales: ${await e.text()}`):e}if(r){console.info(O(s));return}if(s.length===0){console.info(`No locales found.`);return}let c=s.map(e=>{let t=e.isMaster?` (master)`:``;return[e.id,`${e.label}${t}`]});console.info(b(c,{headers:[`ID`,`LABEL`]}))}),Sr=M({name:`prismic locale remove`,description:`
114
114
  Remove a locale from a Prismic repository.
115
115
 
116
116
  By default, this command reads the repository from prismic.config.json at the
117
117
  project root.
118
- `,positionals:{code:{description:`Locale code (e.g. en-us, fr-fr)`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r;try{await gr(n,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove locale: ${await e.text()}`):e}console.info(`Locale removed: ${n}`)}),Sr=M({name:`prismic locale set-master`,description:`
118
+ `,positionals:{code:{description:`Locale code (e.g. en-us, fr-fr)`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r;try{await _r(n,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove locale: ${await e.text()}`):e}console.info(`Locale removed: ${n}`)}),Cr=M({name:`prismic locale set-master`,description:`
119
119
  Set the master locale for a Prismic repository.
120
120
 
121
121
  By default, this command reads the repository from prismic.config.json at the
122
122
  project root.
123
- `,positionals:{code:{description:`Locale code (e.g. en-us, fr-fr)`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await mr({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to set master locale: ${await e.text()}`):e}let l=c.find(e=>e.id===n);if(!l)throw new P(`Locale "${n}" not found. Available locales: ${c.map(e=>e.id).join(`, `)}`);if(l.isMaster)throw new P(`Locale "${n}" is already the master.`);try{await hr({id:l.id,isMaster:!0,customName:l.customName??void 0},{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to set master locale: ${await e.text()}`):e}console.info(`Master locale set: ${n}`)}),Cr=N({name:`prismic locale`,description:`Manage locales in a Prismic repository.`,commands:{add:{handler:yr,description:`Add a locale`},list:{handler:br,description:`List locales`},remove:{handler:xr,description:`Remove a locale`},"set-master":{handler:Sr,description:`Set the master locale`}}}),wr=M({name:`prismic login`,description:`Log in to Prismic via browser.`,options:{"no-browser":{type:`boolean`,description:`Skip opening the browser automatically`}}},async({values:e})=>{let{"no-browser":t}=e,{email:n}=await Pe({onReady:e=>{t?console.info(`Open this URL to log in: ${e}`):(console.info(`Opening browser to complete login...`),console.info(`If the browser doesn't open, visit: ${e}`),Nn(e))}});console.info(`Logged in to Prismic as ${n}`)}),Tr=M({name:`prismic logout`,description:`Log out of Prismic.`},async()=>{if(await Ae())console.info(`Logged out of Prismic`);else throw new P(`Logout failed. You can log out manually by deleting the file.`)}),Er=M({name:`prismic preview add`,description:`
123
+ `,positionals:{code:{description:`Locale code (e.g. en-us, fr-fr)`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await hr({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to set master locale: ${await e.text()}`):e}let l=c.find(e=>e.id===n);if(!l)throw new P(`Locale "${n}" not found. Available locales: ${c.map(e=>e.id).join(`, `)}`);if(l.isMaster)throw new P(`Locale "${n}" is already the master.`);try{await gr({id:l.id,isMaster:!0,customName:l.customName??void 0},{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to set master locale: ${await e.text()}`):e}console.info(`Master locale set: ${n}`)}),wr=N({name:`prismic locale`,description:`Manage locales in a Prismic repository.`,commands:{add:{handler:br,description:`Add a locale`},list:{handler:xr,description:`List locales`},remove:{handler:Sr,description:`Remove a locale`},"set-master":{handler:Cr,description:`Set the master locale`}}}),Tr=M({name:`prismic login`,description:`Log in to Prismic via browser.`,options:{"no-browser":{type:`boolean`,description:`Skip opening the browser automatically`}}},async({values:e})=>{let{"no-browser":t}=e,{email:n}=await Pe({onReady:e=>{t?console.info(`Open this URL to log in: ${e}`):(console.info(`Opening browser to complete login...`),console.info(`If the browser doesn't open, visit: ${e}`),Pn(e))}});console.info(`Logged in to Prismic as ${n}`)}),Er=M({name:`prismic logout`,description:`Log out of Prismic.`},async()=>{if(await Ae())console.info(`Logged out of Prismic`);else throw new P(`Logout failed. You can log out manually by deleting the file.`)}),Dr=M({name:`prismic preview add`,description:`
124
124
  Add a preview configuration to a Prismic repository.
125
125
 
126
126
  By default, this command reads the repository from prismic.config.json at the
127
127
  project root.
128
- `,positionals:{url:{description:`Preview URL (e.g. https://example.com/api/preview)`,required:!0}},options:{name:{type:`string`,short:`n`,description:`Display name (defaults to hostname)`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,name:a}=t,o;try{o=new URL(n)}catch{throw new P(`Invalid URL: ${n}`)}let s=a||o.hostname,c=`${o.protocol}//${o.host}`,l=o.pathname===`/`?void 0:o.pathname,u=await k(),d=await A(),f=i?await H(i,{repo:r,token:u,host:d}):r;try{await ae({name:s,websiteURL:c,resolverPath:l},{repo:f,token:u,host:d})}catch(e){throw e instanceof w?new P(`Failed to add preview: ${await e.text()}`):e}console.info(`Preview added: ${n}`),console.info("Run `prismic preview set-simulator <url>` to set the slice simulator URL.")}),Dr=M({name:`prismic preview list`,description:`
128
+ `,positionals:{url:{description:`Preview URL (e.g. https://example.com/api/preview)`,required:!0}},options:{name:{type:`string`,short:`n`,description:`Display name (defaults to hostname)`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,name:a}=t,o;try{o=new URL(n)}catch{throw new P(`Invalid URL: ${n}`)}let s=a||o.hostname,c=`${o.protocol}//${o.host}`,l=o.pathname===`/`?void 0:o.pathname,u=await k(),d=await A(),f=i?await H(i,{repo:r,token:u,host:d}):r;try{await ae({name:s,websiteURL:c,resolverPath:l},{repo:f,token:u,host:d})}catch(e){throw e instanceof w?new P(`Failed to add preview: ${await e.text()}`):e}console.info(`Preview added: ${n}`),console.info("Run `prismic preview set-simulator <url>` to set the slice simulator URL.")}),Or=M({name:`prismic preview list`,description:`
129
129
  List all preview configurations in a Prismic repository.
130
130
 
131
131
  By default, this command reads the repository from prismic.config.json at the
132
132
  project root.
133
- `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s,c;try{[s,c]=await Promise.all([_({repo:o,token:i,host:a}),d({repo:o,token:i,host:a})])}catch(e){throw e instanceof w?new P(`Failed to list previews: ${await e.text()}`):e}if(r){console.info(O({previews:s,simulatorUrl:c??null}));return}if(s.length===0&&!c){console.info(`No preview configurations found.`);return}if(s.length>0){let e=s.map(e=>[e.url,e.label]);console.info(b(e,{headers:[`URL`,`NAME`]}))}c&&(s.length>0&&console.info(``),console.info(`Simulator: ${c}`))}),Or=M({name:`prismic preview remove`,description:`
133
+ `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s,c;try{[s,c]=await Promise.all([_({repo:o,token:i,host:a}),d({repo:o,token:i,host:a})])}catch(e){throw e instanceof w?new P(`Failed to list previews: ${await e.text()}`):e}if(r){console.info(O({previews:s,simulatorUrl:c??null}));return}if(s.length===0&&!c){console.info(`No preview configurations found.`);return}if(s.length>0){let e=s.map(e=>[e.url,e.label]);console.info(b(e,{headers:[`URL`,`NAME`]}))}c&&(s.length>0&&console.info(``),console.info(`Simulator: ${c}`))}),kr=M({name:`prismic preview remove`,description:`
134
134
  Remove a preview configuration from a Prismic repository.
135
135
 
136
136
  By default, this command reads the repository from prismic.config.json at the
137
137
  project root.
138
- `,positionals:{url:{description:`Preview URL to remove`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await _({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove preview: ${await e.text()}`):e}let l=c.find(e=>e.url===n);if(!l)throw new P(`Preview not found: ${n}`);try{await te(l.id,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove preview: ${await e.text()}`):e}console.info(`Preview removed: ${n}`)}),kr=M({name:`prismic preview set-simulator`,description:`
138
+ `,positionals:{url:{description:`Preview URL to remove`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await _({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove preview: ${await e.text()}`):e}let l=c.find(e=>e.url===n);if(!l)throw new P(`Preview not found: ${n}`);try{await te(l.id,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove preview: ${await e.text()}`):e}console.info(`Preview removed: ${n}`)}),Ar=M({name:`prismic preview set-simulator`,description:`
139
139
  Set the slice simulator URL for a Prismic repository.
140
140
 
141
141
  If the URL pathname does not end with /slice-simulator, it is appended
@@ -143,13 +143,13 @@ import{A as e,C as t,D as n,E as r,I as i,M as a,N as o,P as s,S as c,T as l,_ a
143
143
 
144
144
  By default, this command reads the repository from prismic.config.json at the
145
145
  project root.
146
- `,positionals:{url:{description:`Simulator URL (e.g. https://example.com/slice-simulator)`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a;try{a=new URL(n)}catch{throw new P(`Invalid URL: ${n}`)}a.pathname.endsWith(`/slice-simulator`)||(a.pathname=a.pathname.replace(/\/+$/,``)+`/slice-simulator`);let o=a.toString(),s=await k(),c=await A(),l=i?await H(i,{repo:r,token:s,host:c}):r;try{await ie(o,{repo:l,token:s,host:c})}catch(e){throw e instanceof w?new P(`Failed to set simulator URL: ${await e.text()}`):e}console.info(`Simulator URL set: ${o}`)}),Ar=N({name:`prismic preview`,description:`Manage preview configurations in a Prismic repository.`,commands:{add:{handler:Er,description:`Add a preview configuration`},list:{handler:Dr,description:`List preview configurations`},remove:{handler:Or,description:`Remove a preview configuration`},"set-simulator":{handler:kr,description:`Set the slice simulator URL`}}});async function jr(e){try{let{stdout:t}=await ke(`git`,[`rev-parse`,`--show-toplevel`],{nodeOptions:{cwd:Ge(e)},throwOnError:!0}),n=t.trim();return n?Se(Ke(await We(n))):void 0}catch{return}}async function Mr(e){try{let{stdout:t}=await ke(`git`,[`status`,`--porcelain`,`--untracked-files=all`],{nodeOptions:{cwd:Ge(e)},throwOnError:!0}),n=[];for(let r of t.split(`
147
- `)){if(r.length<4)continue;let t=r.slice(3),i=t.indexOf(` -> `);i!==-1&&(t=t.slice(i+4)),n.push(new URL(t,e))}return n}catch{return[]}}var Nr=M({name:`prismic pull`,description:`
146
+ `,positionals:{url:{description:`Simulator URL (e.g. https://example.com/slice-simulator)`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a;try{a=new URL(n)}catch{throw new P(`Invalid URL: ${n}`)}a.pathname.endsWith(`/slice-simulator`)||(a.pathname=a.pathname.replace(/\/+$/,``)+`/slice-simulator`);let o=a.toString(),s=await k(),c=await A(),l=i?await H(i,{repo:r,token:s,host:c}):r;try{await ie(o,{repo:l,token:s,host:c})}catch(e){throw e instanceof w?new P(`Failed to set simulator URL: ${await e.text()}`):e}console.info(`Simulator URL set: ${o}`)}),jr=N({name:`prismic preview`,description:`Manage preview configurations in a Prismic repository.`,commands:{add:{handler:Dr,description:`Add a preview configuration`},list:{handler:Or,description:`List preview configurations`},remove:{handler:kr,description:`Remove a preview configuration`},"set-simulator":{handler:Ar,description:`Set the slice simulator URL`}}});async function Mr(e){try{let{stdout:t}=await ke(`git`,[`rev-parse`,`--show-toplevel`],{nodeOptions:{cwd:Ge(e)},throwOnError:!0}),n=t.trim();return n?Se(Ke(await We(n))):void 0}catch{return}}async function Nr(e){try{let{stdout:t}=await ke(`git`,[`status`,`--porcelain`,`--untracked-files=all`],{nodeOptions:{cwd:Ge(e)},throwOnError:!0}),n=[];for(let r of t.split(`
147
+ `)){if(r.length<4)continue;let t=r.slice(3),i=t.indexOf(` -> `);i!==-1&&(t=t.slice(i+4)),n.push(new URL(t,e))}return n}catch{return[]}}var Pr=M({name:`prismic pull`,description:`
148
148
  Pull content types and slices from Prismic to local files.
149
149
 
150
150
  Remote models are the source of truth. Local files are created, updated,
151
151
  or deleted to match.
152
- `,options:{force:{type:`boolean`,short:`f`,description:`Overwrite local changes`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:n})=>{let{force:r=!1,repo:i=await S(),env:a}=n,o=await k(),s=await A(),c=await m(),l=await t(),u=a?await H(a,{repo:i,token:o,host:s}):i;console.info(`Pulling from repository: ${i}${a?` (env: ${a})`:``}`);let[d,f,p]=await Promise.all([jr(l),c.getCustomTypeLibraries(),c.getSliceLibraries()]);if(!r&&d){let e=(await Mr(d)).filter(e=>e.pathname.endsWith(`/model.json`)&&p.some(t=>be(t,e))||e.pathname.endsWith(`/index.json`)&&f.some(t=>be(t,e))).map(e=>ve(l,e));if(e.length>0)throw new P(`
152
+ `,options:{force:{type:`boolean`,short:`f`,description:`Overwrite local changes`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:n})=>{let{force:r=!1,repo:i=await S(),env:a}=n,o=await k(),s=await A(),c=await m(),l=await t(),u=a?await H(a,{repo:i,token:o,host:s}):i;console.info(`Pulling from repository: ${i}${a?` (env: ${a})`:``}`);let[d,f,p]=await Promise.all([Mr(l),c.getCustomTypeLibraries(),c.getSliceLibraries()]);if(!r&&d){let e=(await Nr(d)).filter(e=>e.pathname.endsWith(`/model.json`)&&p.some(t=>be(t,e))||e.pathname.endsWith(`/index.json`)&&f.some(t=>be(t,e))).map(e=>ve(l,e));if(e.length>0)throw new P(`
153
153
  Local model files have uncommitted changes. Commit them first so a
154
154
  pull won't silently discard your edits:
155
155
 
@@ -168,12 +168,12 @@ import{A as e,C as t,D as n,E as r,I as i,M as a,N as o,P as s,S as c,T as l,_ a
168
168
  This project isn't in a git repo, so changes can't be tracked. Choose one:
169
169
  prismic pull --force Discard local files, adopt remote
170
170
  prismic push --force Keep local files, overwrite remote
171
- `)}for(let e of y.insert)await c.createCustomType(e);for(let e of y.update)await c.updateCustomType(e);for(let e of y.delete)await c.deleteCustomType(e.id);for(let e of b.insert)await c.createSlice(e);for(let e of b.update)await c.updateSlice(e);for(let e of b.delete)await c.deleteSlice(e.id);await c.generateTypes(),await e({repo:i,token:o,host:s,stepIds:[`connectPrismic`]});let x=y.insert.length+y.update.length,ee=b.insert.length+b.update.length,te=y.delete.length+b.delete.length;if(x===0&&ee===0&&te===0){console.info(`Already up to date.`);return}console.info(`Inserted ${y.insert.length}, updated ${y.update.length}, deleted ${y.delete.length} types`),console.info(`Inserted ${b.insert.length}, updated ${b.update.length}, deleted ${b.delete.length} slices`)}),Pr=M({name:`prismic push`,description:`
171
+ `)}for(let e of y.insert)await c.createCustomType(e);for(let e of y.update)await c.updateCustomType(e);for(let e of y.delete)await c.deleteCustomType(e.id);for(let e of b.insert)await c.createSlice(e);for(let e of b.update)await c.updateSlice(e);for(let e of b.delete)await c.deleteSlice(e.id);await c.generateTypes(),await e({repo:i,token:o,host:s,stepIds:[`connectPrismic`]});let x=y.insert.length+y.update.length,ee=b.insert.length+b.update.length,te=y.delete.length+b.delete.length;if(x===0&&ee===0&&te===0){console.info(`Already up to date.`);return}console.info(`Inserted ${y.insert.length}, updated ${y.update.length}, deleted ${y.delete.length} types`),console.info(`Inserted ${b.insert.length}, updated ${b.update.length}, deleted ${b.delete.length} slices`)}),Fr=M({name:`prismic push`,description:`
172
172
  Push local content types and slices to Prismic.
173
173
 
174
174
  Local models are the source of truth. Remote models are created,
175
175
  updated, or deleted to match.
176
- `,options:{force:{type:`boolean`,short:`f`,description:`Skip safety checks`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:n})=>{let{force:r=!1,repo:i=await S(),env:a}=n,s=await k(),c=await A(),l=await m(),u=await t(),d=a?await H(a,{repo:i,token:s,host:c}):i;console.info(`Pushing to repository: ${i}${a?` (env: ${a})`:``}`);let[f,p,h]=await Promise.all([jr(u),l.getCustomTypeLibraries(),l.getSliceLibraries()]);if(!r&&f){let e=(await Mr(f)).filter(e=>e.pathname.endsWith(`/model.json`)&&h.some(t=>be(t,e))||e.pathname.endsWith(`/index.json`)&&p.some(t=>be(t,e))).map(e=>ve(u,e));if(e.length>0)throw new P(`
176
+ `,options:{force:{type:`boolean`,short:`f`,description:`Skip safety checks`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:n})=>{let{force:r=!1,repo:i=await S(),env:a}=n,s=await k(),c=await A(),l=await m(),u=await t(),d=a?await H(a,{repo:i,token:s,host:c}):i;console.info(`Pushing to repository: ${i}${a?` (env: ${a})`:``}`);let[f,p,h]=await Promise.all([Mr(u),l.getCustomTypeLibraries(),l.getSliceLibraries()]);if(!r&&f){let e=(await Nr(f)).filter(e=>e.pathname.endsWith(`/model.json`)&&h.some(t=>be(t,e))||e.pathname.endsWith(`/index.json`)&&p.some(t=>be(t,e))).map(e=>ve(u,e));if(e.length>0)throw new P(`
177
177
  Local model files have uncommitted changes. Commit them, then push:
178
178
 
179
179
  git add ${e.join(` `)}
@@ -187,35 +187,35 @@ import{A as e,C as t,D as n,E as r,I as i,M as a,N as o,P as s,S as c,T as l,_ a
187
187
  Models that would be deleted:
188
188
  ${n.join(`
189
189
  `)}
190
- `)}for(let e of b.insert)await bn(e,{repo:d,token:s,host:c});for(let e of b.update)await xn(e,{repo:d,token:s,host:c});for(let e of b.delete)await Fr(e,{repo:d,token:s,host:c});for(let e of x.insert)await wn(e,{repo:d,token:s,host:c});for(let e of x.update)await Tn(e,{repo:d,token:s,host:c});for(let e of x.delete.map(e=>e.id))await En(e,{repo:d,token:s,host:c});let ee=[];x.insert.length>0&&ee.push(`createSlice`),b.insert.some(e=>e.format===`page`)&&ee.push(`createPageType`),ee.length>0&&await e({repo:i,token:s,host:c,stepIds:ee});let te=b.insert.length+b.update.length,ne=x.insert.length+x.update.length,re=b.delete.length+x.delete.length;te===0&&ne===0&&re===0?console.info(`Already up to date.`):(console.info(`Pushed ${te} type(s), ${ne} slice(s).`),re>0&&console.info(`Deleted ${re} model(s).`))});async function Fr(e,t){let{repo:n,token:r,host:i}=t,{id:a,format:o}=e;try{await Sn(a,{repo:n,token:r,host:i})}catch(e){if(!await Ir(e))throw new P(`Could not delete type "${a}": ${e instanceof Error?e.message:String(e)}"
191
- Please try again, or manually deleting the type at: `+sr({repo:n,host:i,format:o??`custom`}));let t;try{t=await ee(a,{repo:n,token:r,host:i})}catch{throw new P(`Could not check whether type "${a}" has associated pages.
192
- Please try again, or manually delete any associated pages at: `+or({repo:n,host:i,customTypeId:a}))}throw new P(`Could not delete type "${a}" because it has${t>0?` ${t}`:``} associated ${t===1?`page`:`pages`}. \nDelete any associated pages manually before pushing at: `+or({repo:n,host:i,customTypeId:a}))}}async function Ir(e){if(!(e instanceof Ce))return!1;let t=await e.text();return t.includes(`associated documents`)||t.includes(`Delete all documents belonging`)}var Lr=M({name:`prismic repo list`,description:`List all Prismic repositories associated with your account.`,options:{json:{type:`boolean`,description:`Output as JSON`}}},async({values:e})=>{let{json:t}=e,n=await k(),r=await A(),i;try{i=await y({token:n,host:r})}catch(e){throw e instanceof w?new P(`Failed to list repositories: ${await e.text()}`):e}let a=i.repositories;if(t){console.info(O(a.map(e=>({domain:e.domain,name:e.name??null,role:e.role??null,url:`https://${e.domain}.${r}/`}))));return}if(a.length===0){console.info(`No repositories found.`);return}let o=a.map(e=>{let t=e.name||`(no name)`;return[e.domain,t,e.role??``]});console.info(b(o,{headers:[`DOMAIN`,`NAME`,`ROLE`]}))});const Rr=[`private`,`public`,`open`];var zr=M({name:`prismic repo set-api-access`,description:`
190
+ `)}for(let e of b.insert)await bn(e,{repo:d,token:s,host:c});for(let e of b.update)await xn(e,{repo:d,token:s,host:c});for(let e of b.delete)await Ir(e,{repo:d,token:s,host:c});for(let e of x.insert)await wn(e,{repo:d,token:s,host:c});for(let e of x.update)await Tn(e,{repo:d,token:s,host:c});for(let e of x.delete.map(e=>e.id))await En(e,{repo:d,token:s,host:c}),await kn(e,{repo:d,token:s,host:c}).catch(t=>{let n=t instanceof Error?t.message:String(t);console.warn(`Failed to delete screenshots for slice "${e}": ${n}`)});let ee=[];x.insert.length>0&&ee.push(`createSlice`),b.insert.some(e=>e.format===`page`)&&ee.push(`createPageType`),ee.length>0&&await e({repo:i,token:s,host:c,stepIds:ee});let te=b.insert.length+b.update.length,ne=x.insert.length+x.update.length,re=b.delete.length+x.delete.length;te===0&&ne===0&&re===0?console.info(`Already up to date.`):(console.info(`Pushed ${te} type(s), ${ne} slice(s).`),re>0&&console.info(`Deleted ${re} model(s).`))});async function Ir(e,t){let{repo:n,token:r,host:i}=t,{id:a,format:o}=e;try{await Sn(a,{repo:n,token:r,host:i})}catch(e){if(!await Lr(e))throw new P(`Could not delete type "${a}": ${e instanceof Error?e.message:String(e)}"
191
+ Please try again, or manually deleting the type at: `+cr({repo:n,host:i,format:o??`custom`}));let t;try{t=await ee(a,{repo:n,token:r,host:i})}catch{throw new P(`Could not check whether type "${a}" has associated pages.
192
+ Please try again, or manually delete any associated pages at: `+sr({repo:n,host:i,customTypeId:a}))}throw new P(`Could not delete type "${a}" because it has${t>0?` ${t}`:``} associated ${t===1?`page`:`pages`}. \nDelete any associated pages manually before pushing at: `+sr({repo:n,host:i,customTypeId:a}))}}async function Lr(e){if(!(e instanceof Ce))return!1;let t=await e.text();return t.includes(`associated documents`)||t.includes(`Delete all documents belonging`)}var Rr=M({name:`prismic repo list`,description:`List all Prismic repositories associated with your account.`,options:{json:{type:`boolean`,description:`Output as JSON`}}},async({values:e})=>{let{json:t}=e,n=await k(),r=await A(),i;try{i=await y({token:n,host:r})}catch(e){throw e instanceof w?new P(`Failed to list repositories: ${await e.text()}`):e}let a=i.repositories;if(t){console.info(O(a.map(e=>({domain:e.domain,name:e.name??null,role:e.role??null,url:`https://${e.domain}.${r}/`}))));return}if(a.length===0){console.info(`No repositories found.`);return}let o=a.map(e=>{let t=e.name||`(no name)`;return[e.domain,t,e.role??``]});console.info(b(o,{headers:[`DOMAIN`,`NAME`,`ROLE`]}))});const zr=[`private`,`public`,`open`];var Br=M({name:`prismic repo set-api-access`,description:`
193
193
  Set the Content API access level of a Prismic repository.
194
194
 
195
195
  By default, this command reads the repository from prismic.config.json at the
196
196
  project root.
197
- `,positionals:{level:{description:`Access level (${Rr.join(`, `)})`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S()}=t;if(!Rr.includes(n))throw new P(`Invalid access level: ${n}. Must be one of: ${Rr.join(`, `)}`);let i=await k(),a=await A();try{await nr(n,{repo:r,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to set repository access: ${await e.text()}`):e}console.info(`Repository access set to: ${n}`)}),Br=M({name:`prismic repo set-name`,description:`
197
+ `,positionals:{level:{description:`Access level (${zr.join(`, `)})`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S()}=t;if(!zr.includes(n))throw new P(`Invalid access level: ${n}. Must be one of: ${zr.join(`, `)}`);let i=await k(),a=await A();try{await rr(n,{repo:r,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to set repository access: ${await e.text()}`):e}console.info(`Repository access set to: ${n}`)}),Vr=M({name:`prismic repo set-name`,description:`
198
198
  Set the display name of a Prismic repository.
199
199
 
200
200
  By default, this command reads the repository from prismic.config.json at the
201
201
  project root.
202
- `,positionals:{name:{description:`Display name for the repository`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S()}=t,i=await k(),a=await A(),o;try{o=await ir(n,{repo:r,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to set repository name: ${await e.text()}`):e}console.info(`Repository name set to: ${o}`)}),Vr=M({name:`prismic repo view`,description:`
202
+ `,positionals:{name:{description:`Display name for the repository`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S()}=t,i=await k(),a=await A(),o;try{o=await ar(n,{repo:r,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to set repository name: ${await e.text()}`):e}console.info(`Repository name set to: ${o}`)}),Hr=M({name:`prismic repo view`,description:`
203
203
  View details of a Prismic repository.
204
204
 
205
205
  By default, this command reads the repository from prismic.config.json at the
206
206
  project root.
207
- `,options:{web:{type:`boolean`,short:`w`,description:`Open repository in browser`},json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`}}},async({values:e})=>{let{repo:t=await S(),web:n,json:r}=e,i=await k(),a=await A(),o=`https://${t}.${a}/`;if(n){Nn(new URL(o)),console.info(`Opening ${o}`);return}let s,c;try{[s,c]=await Promise.all([y({token:i,host:a}),tr({repo:t,token:i,host:a})])}catch(e){throw e instanceof w?new P(`Failed to fetch repository details: ${await e.text()}`):e}let l=s.repositories.find(e=>e.domain===t);if(!l)throw new P(`Repository not found: ${t}`);if(r){console.info(O({domain:l.domain,name:l.name??null,url:o,apiAccess:c}));return}let u=l.name||`(no name)`;console.info(`Name: ${u}`),console.info(`URL: ${o}`),console.info(`Content API: ${c}`)}),Hr=N({name:`prismic repo`,description:`Manage Prismic repositories.`,commands:{create:{handler:lr,description:`Create a new repository`},list:{handler:Lr,description:`List repositories`},view:{handler:Vr,description:`View repository details`},"set-name":{handler:Br,description:`Set repository display name`},"set-api-access":{handler:zr,description:`Set Content API access level`}}}),Ur=M({name:`prismic slice add-variation`,description:`Add a variation to a slice.`,positionals:{name:{description:`Name of the variation`,required:!0}},options:{to:{type:`string`,required:!0,description:`ID of the slice`},id:{type:`string`,description:`Custom ID for the variation`},screenshot:{type:`string`,short:`s`,description:`Screenshot image file path or URL`}}},async({positionals:e,values:t})=>{let[n]=e,{to:r,id:i=v(n),screenshot:a}=t,o=await m(),{model:s}=await o.getSlice(r);if(s.variations.some(e=>e.id===i))throw new P(`Variation "${i}" already exists in slice "${r}".`);let c=``;if(a){let e=await S(),t=await k(),n=await A(),r=await _e(/^https?:\/\//i.test(a)?new URL(a):Ke(a)),o;try{o=await kn(r,{sliceId:s.id,variationId:i,repo:e,token:t,host:n})}catch(e){throw e instanceof An?new P(e.message):e}c=o.toString()}s.variations=[...s.variations,{id:i,name:n,description:n,docURL:``,imageUrl:c,version:``,primary:{}}],await o.updateSlice(s),await o.generateTypes(),console.info(`Added variation "${n}" (id: "${i}") to slice "${r}"`)}),Wr=M({name:`prismic slice connect`,description:`Connect a slice to a type's slice zone.`,sections:{EXAMPLES:`
207
+ `,options:{web:{type:`boolean`,short:`w`,description:`Open repository in browser`},json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`}}},async({values:e})=>{let{repo:t=await S(),web:n,json:r}=e,i=await k(),a=await A(),o=`https://${t}.${a}/`;if(n){Pn(new URL(o)),console.info(`Opening ${o}`);return}let s,c;try{[s,c]=await Promise.all([y({token:i,host:a}),nr({repo:t,token:i,host:a})])}catch(e){throw e instanceof w?new P(`Failed to fetch repository details: ${await e.text()}`):e}let l=s.repositories.find(e=>e.domain===t);if(!l)throw new P(`Repository not found: ${t}`);if(r){console.info(O({domain:l.domain,name:l.name??null,url:o,apiAccess:c}));return}let u=l.name||`(no name)`;console.info(`Name: ${u}`),console.info(`URL: ${o}`),console.info(`Content API: ${c}`)}),Ur=N({name:`prismic repo`,description:`Manage Prismic repositories.`,commands:{create:{handler:ur,description:`Create a new repository`},list:{handler:Rr,description:`List repositories`},view:{handler:Hr,description:`View repository details`},"set-name":{handler:Vr,description:`Set repository display name`},"set-api-access":{handler:Br,description:`Set Content API access level`}}}),Wr=M({name:`prismic slice add-variation`,description:`Add a variation to a slice.`,positionals:{name:{description:`Name of the variation`,required:!0}},options:{to:{type:`string`,required:!0,description:`ID of the slice`},id:{type:`string`,description:`Custom ID for the variation`},screenshot:{type:`string`,short:`s`,description:`Screenshot image file path or URL`}}},async({positionals:e,values:t})=>{let[n]=e,{to:r,id:i=v(n),screenshot:a}=t,o=await m(),{model:s}=await o.getSlice(r);if(s.variations.some(e=>e.id===i))throw new P(`Variation "${i}" already exists in slice "${r}".`);let c=``;if(a){let e=await S(),t=await k(),n=await A(),r=await _e(/^https?:\/\//i.test(a)?new URL(a):Ke(a)),o;try{o=await An(r,{sliceId:s.id,variationId:i,repo:e,token:t,host:n})}catch(e){throw e instanceof jn?new P(e.message):e}c=o.toString()}s.variations=[...s.variations,{id:i,name:n,description:n,docURL:``,imageUrl:c,version:``,primary:{}}],await o.updateSlice(s),await o.generateTypes(),console.info(`Added variation "${n}" (id: "${i}") to slice "${r}"`)}),Gr=M({name:`prismic slice connect`,description:`Connect a slice to a type's slice zone.`,sections:{EXAMPLES:`
208
208
  Connect a slice to a type's default slice zone:
209
209
  prismic slice connect hero --to blog_post
210
210
 
211
211
  Connect to a named slice zone:
212
212
  prismic slice connect hero --to blog_post --slice-zone page_slices
213
- `},positionals:{id:{description:`ID of the slice`,required:!0}},options:{to:{type:`string`,required:!0,description:`ID of the content type`},"slice-zone":{type:`string`,description:`Slice zone field ID (default: "slices")`}}},async({positionals:e,values:t})=>{let[n]=e,{to:r,"slice-zone":i=`slices`}=t,a=await m(),{model:o}=await a.getSlice(n),{model:s}=await a.getCustomType(r),c=Object.assign({},...Object.values(s.json))[i];if(!c||c.type!==`Slices`)throw new P(`Slice zone "${i}" not found in "${r}".`);if(c.config??={},c.config.choices??={},o.id in c.config.choices)throw new P(`Slice "${o.id}" is already connected to "${r}" in slice zone "${i}".`);c.config.choices[o.id]={type:`SharedSlice`},await a.updateCustomType(s),await a.generateTypes(),console.info(`Connected slice "${n}" to "${r}"`)}),Gr=M({name:`prismic slice create`,description:`Create a new slice.`,positionals:{name:{description:`Name of the slice`,required:!0}},options:{id:{type:`string`,description:`Custom ID for the slice`}}},async({positionals:e,values:t})=>{let[n]=e,{id:r=s(n)}=t,i={id:r,name:n,type:`SharedSlice`,variations:[{id:`default`,name:`Default`,description:`Default`,docURL:``,imageUrl:``,version:``,primary:{}}]},a=await m();await a.createSlice(i),await a.generateTypes(),console.info(`Created slice "${n}" (id: "${r}")`),console.info(`Run \`prismic field add <type> --to-slice ${r}\` to add fields.`),console.info(`Run \`prismic slice connect ${r} --to <type>\` to connect the slice to a type.`)}),Kr=M({name:`prismic slice disconnect`,description:`Disconnect a slice from a type's slice zone.`,positionals:{id:{description:`ID of the slice`,required:!0}},options:{from:{type:`string`,required:!0,description:`ID of the content type`},"slice-zone":{type:`string`,description:`Slice zone field ID (default: "slices")`}}},async({positionals:e,values:t})=>{let[n]=e,{from:r,"slice-zone":i=`slices`}=t,a=await m(),{model:o}=await a.getSlice(n),{model:s}=await a.getCustomType(r),c=Object.assign({},...Object.values(s.json))[i];if(!c||c.type!==`Slices`)throw new P(`Slice zone "${i}" not found in "${r}".`);if(!c.config?.choices||!(o.id in c.config.choices))throw new P(`Slice "${o.id}" is not connected to "${r}" in slice zone "${i}".`);delete c.config.choices[o.id],await a.updateCustomType(s),await a.generateTypes(),console.info(`Disconnected slice "${n}" from "${r}"`)}),qr=M({name:`prismic slice edit`,description:`Edit a slice.`,positionals:{id:{description:`ID of the slice`,required:!0}},options:{name:{type:`string`,short:`n`,description:`New name for the slice`}}},async({positionals:e,values:t})=>{let[n]=e,r=await m(),{model:i}=await r.getSlice(n);`name`in t&&(i.name=t.name),await r.updateSlice(i),await r.generateTypes(),console.info(`Slice updated: "${i.name}" (id: ${i.id})`)}),Jr=M({name:`prismic slice edit-variation`,description:`Edit a variation of a slice.`,positionals:{id:{description:`ID of the variation`,required:!0}},options:{"from-slice":{type:`string`,required:!0,description:`ID of the slice`},name:{type:`string`,short:`n`,description:`New name for the variation`},screenshot:{type:`string`,short:`s`,description:`Screenshot image file path or URL`}}},async({positionals:e,values:t})=>{let[n]=e,{"from-slice":r,screenshot:i}=t,a=await m(),{model:o}=await a.getSlice(r),s=o.variations.find(e=>e.id===n);if(!s)throw new P(`Variation "${n}" not found in slice "${r}".`);if(`name`in t&&(s.name=t.name),i){let e=await S(),t=await k(),n=await A(),r=await _e(/^https?:\/\//i.test(i)?new URL(i):Ke(i)),a;try{a=await kn(r,{sliceId:o.id,variationId:s.id,repo:e,token:t,host:n})}catch(e){throw e instanceof An?new P(e.message):e}s.imageUrl=a.toString()}await a.updateSlice(o),await a.generateTypes(),console.info(`Variation updated: "${n}" in slice "${r}"`)}),Yr=M({name:`prismic slice list`,description:`List all slices.`,options:{json:{type:`boolean`,description:`Output as JSON`}}},async({values:e})=>{let{json:t}=e,n=await(await m()).getSlices();if(t){console.info(O(n.map(e=>e.model)));return}if(n.length===0){console.info(`No slices found.`);return}let r=n.map(({model:e})=>[e.name,e.id]);console.info(b(r,{headers:[`NAME`,`ID`]}))}),Xr=M({name:`prismic slice remove`,description:`Remove a slice.`,positionals:{id:{description:`ID of the slice`,required:!0}}},async({positionals:e})=>{let[t]=e,n=await m(),{model:r}=await n.getSlice(t);await n.deleteSlice(r.id),await n.generateTypes(),console.info(`Slice removed: ${t}`)}),Zr=M({name:`prismic slice remove-variation`,description:`Remove a variation from a slice.`,positionals:{id:{description:`ID of the variation`,required:!0}},options:{from:{type:`string`,required:!0,description:`ID of the slice`}}},async({positionals:e,values:t})=>{let[n]=e,{from:r}=t,i=await m(),{model:a}=await i.getSlice(r),o=a.variations.find(e=>e.id===n);if(!o)throw new P(`Variation "${n}" not found in slice "${r}".`);a.variations=a.variations.filter(e=>e.id!==o.id),await i.updateSlice(a),await i.generateTypes(),console.info(`Removed variation "${n}" from slice "${r}"`)}),Qr=M({name:`prismic slice view`,description:`View details of a slice.`,positionals:{id:{description:`ID of the slice`,required:!0}},options:{json:{type:`boolean`,description:`Output as JSON`}}},async({positionals:e,values:t})=>{let[n]=e,{json:r}=t,{model:i}=await(await m()).getSlice(n);if(r){console.info(O(i));return}console.info(`ID: ${i.id}`),console.info(`Name: ${i.name}`);for(let e of i.variations??[]){console.info(``),console.info(`${e.id}:`);let t=Object.entries(e.primary??{});if(t.length===0)console.info(` (no fields)`);else{let e=t.map(([e,t])=>{let n=t.config,r=n?.label||``,i=n?.placeholder?`"${n.placeholder}"`:``;return[` ${e}`,t.type,r,i]});console.info(b(e))}}}),$r=N({name:`prismic slice`,description:`Manage slices.`,commands:{create:{handler:Gr,description:`Create a new slice`},edit:{handler:qr,description:`Edit a slice`},remove:{handler:Xr,description:`Remove a slice`},list:{handler:Yr,description:`List slices`},view:{handler:Qr,description:`View a slice`},connect:{handler:Wr,description:`Connect a slice to a type's slice zone`},disconnect:{handler:Kr,description:`Disconnect a slice from a type's slice zone`},"add-variation":{handler:Ur,description:`Add a variation to a slice`},"edit-variation":{handler:Jr,description:`Edit a variation of a slice`},"remove-variation":{handler:Zr,description:`Remove a variation from a slice`}}}),ei=M({name:`prismic status`,description:`
213
+ `},positionals:{id:{description:`ID of the slice`,required:!0}},options:{to:{type:`string`,required:!0,description:`ID of the content type`},"slice-zone":{type:`string`,description:`Slice zone field ID (default: "slices")`}}},async({positionals:e,values:t})=>{let[n]=e,{to:r,"slice-zone":i=`slices`}=t,a=await m(),{model:o}=await a.getSlice(n),{model:s}=await a.getCustomType(r),c=Object.assign({},...Object.values(s.json))[i];if(!c||c.type!==`Slices`)throw new P(`Slice zone "${i}" not found in "${r}".`);if(c.config??={},c.config.choices??={},o.id in c.config.choices)throw new P(`Slice "${o.id}" is already connected to "${r}" in slice zone "${i}".`);c.config.choices[o.id]={type:`SharedSlice`},await a.updateCustomType(s),await a.generateTypes(),console.info(`Connected slice "${n}" to "${r}"`)}),Kr=M({name:`prismic slice create`,description:`Create a new slice.`,positionals:{name:{description:`Name of the slice`,required:!0}},options:{id:{type:`string`,description:`Custom ID for the slice`}}},async({positionals:e,values:t})=>{let[n]=e,{id:r=s(n)}=t,i={id:r,name:n,type:`SharedSlice`,variations:[{id:`default`,name:`Default`,description:`Default`,docURL:``,imageUrl:``,version:``,primary:{}}]},a=await m();await a.createSlice(i),await a.generateTypes(),console.info(`Created slice "${n}" (id: "${r}")`),console.info(`Run \`prismic field add <type> --to-slice ${r}\` to add fields.`),console.info(`Run \`prismic slice connect ${r} --to <type>\` to connect the slice to a type.`)}),qr=M({name:`prismic slice disconnect`,description:`Disconnect a slice from a type's slice zone.`,positionals:{id:{description:`ID of the slice`,required:!0}},options:{from:{type:`string`,required:!0,description:`ID of the content type`},"slice-zone":{type:`string`,description:`Slice zone field ID (default: "slices")`}}},async({positionals:e,values:t})=>{let[n]=e,{from:r,"slice-zone":i=`slices`}=t,a=await m(),{model:o}=await a.getSlice(n),{model:s}=await a.getCustomType(r),c=Object.assign({},...Object.values(s.json))[i];if(!c||c.type!==`Slices`)throw new P(`Slice zone "${i}" not found in "${r}".`);if(!c.config?.choices||!(o.id in c.config.choices))throw new P(`Slice "${o.id}" is not connected to "${r}" in slice zone "${i}".`);delete c.config.choices[o.id],await a.updateCustomType(s),await a.generateTypes(),console.info(`Disconnected slice "${n}" from "${r}"`)}),Jr=M({name:`prismic slice edit`,description:`Edit a slice.`,positionals:{id:{description:`ID of the slice`,required:!0}},options:{name:{type:`string`,short:`n`,description:`New name for the slice`}}},async({positionals:e,values:t})=>{let[n]=e,r=await m(),{model:i}=await r.getSlice(n);`name`in t&&(i.name=t.name),await r.updateSlice(i),await r.generateTypes(),console.info(`Slice updated: "${i.name}" (id: ${i.id})`)}),Yr=M({name:`prismic slice edit-variation`,description:`Edit a variation of a slice.`,positionals:{id:{description:`ID of the variation`,required:!0}},options:{"from-slice":{type:`string`,required:!0,description:`ID of the slice`},name:{type:`string`,short:`n`,description:`New name for the variation`},screenshot:{type:`string`,short:`s`,description:`Screenshot image file path or URL`}}},async({positionals:e,values:t})=>{let[n]=e,{"from-slice":r,screenshot:i}=t,a=await m(),{model:o}=await a.getSlice(r),s=o.variations.find(e=>e.id===n);if(!s)throw new P(`Variation "${n}" not found in slice "${r}".`);if(`name`in t&&(s.name=t.name),i){let e=await S(),t=await k(),n=await A(),r=await _e(/^https?:\/\//i.test(i)?new URL(i):Ke(i)),a;try{a=await An(r,{sliceId:o.id,variationId:s.id,repo:e,token:t,host:n})}catch(e){throw e instanceof jn?new P(e.message):e}s.imageUrl=a.toString()}await a.updateSlice(o),await a.generateTypes(),console.info(`Variation updated: "${n}" in slice "${r}"`)}),Xr=M({name:`prismic slice list`,description:`List all slices.`,options:{json:{type:`boolean`,description:`Output as JSON`}}},async({values:e})=>{let{json:t}=e,n=await(await m()).getSlices();if(t){console.info(O(n.map(e=>e.model)));return}if(n.length===0){console.info(`No slices found.`);return}let r=n.map(({model:e})=>[e.name,e.id]);console.info(b(r,{headers:[`NAME`,`ID`]}))}),Zr=M({name:`prismic slice remove`,description:`Remove a slice.`,positionals:{id:{description:`ID of the slice`,required:!0}}},async({positionals:e})=>{let[t]=e,n=await m(),{model:r}=await n.getSlice(t);await n.deleteSlice(r.id),await n.generateTypes(),console.info(`Slice removed: ${t}`)}),Qr=M({name:`prismic slice remove-variation`,description:`Remove a variation from a slice.`,positionals:{id:{description:`ID of the variation`,required:!0}},options:{from:{type:`string`,required:!0,description:`ID of the slice`}}},async({positionals:e,values:t})=>{let[n]=e,{from:r}=t,i=await m(),{model:a}=await i.getSlice(r),o=a.variations.find(e=>e.id===n);if(!o)throw new P(`Variation "${n}" not found in slice "${r}".`);a.variations=a.variations.filter(e=>e.id!==o.id),await i.updateSlice(a),await i.generateTypes(),console.info(`Removed variation "${n}" from slice "${r}"`)}),$r=M({name:`prismic slice view`,description:`View details of a slice.`,positionals:{id:{description:`ID of the slice`,required:!0}},options:{json:{type:`boolean`,description:`Output as JSON`}}},async({positionals:e,values:t})=>{let[n]=e,{json:r}=t,{model:i}=await(await m()).getSlice(n);if(r){console.info(O(i));return}console.info(`ID: ${i.id}`),console.info(`Name: ${i.name}`);for(let e of i.variations??[]){console.info(``),console.info(`${e.id}:`);let t=Object.entries(e.primary??{});if(t.length===0)console.info(` (no fields)`);else{let e=t.map(([e,t])=>{let n=t.config,r=n?.label||``,i=n?.placeholder?`"${n.placeholder}"`:``;return[` ${e}`,t.type,r,i]});console.info(b(e))}}}),ei=N({name:`prismic slice`,description:`Manage slices.`,commands:{create:{handler:Kr,description:`Create a new slice`},edit:{handler:Jr,description:`Edit a slice`},remove:{handler:Zr,description:`Remove a slice`},list:{handler:Xr,description:`List slices`},view:{handler:$r,description:`View a slice`},connect:{handler:Gr,description:`Connect a slice to a type's slice zone`},disconnect:{handler:qr,description:`Disconnect a slice from a type's slice zone`},"add-variation":{handler:Wr,description:`Add a variation to a slice`},"edit-variation":{handler:Yr,description:`Edit a variation of a slice`},"remove-variation":{handler:Qr,description:`Remove a variation from a slice`}}}),ti=M({name:`prismic status`,description:`
214
214
  Show local vs remote model differences.
215
215
 
216
216
  Reports what would be pushed to or pulled from Prismic, plus any local
217
217
  model files with uncommitted git changes that would block pull and push.
218
- `,options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:n=await S(),env:r}=e,i=await k(),a=await A(),o=await m(),s=await t(),[c,l,u,d,p]=await Promise.all([jr(s),o.getCustomTypeLibraries(),o.getSliceLibraries(),o.getCustomTypes(),o.getSlices()]),h=n,g,_,v;if(i){r&&(h=await H(r,{repo:n,token:i,host:a}));let[e,t,o]=await Promise.all([y({token:i,host:a}),yn({repo:h,token:i,host:a}),Cn({repo:h,token:i,host:a})]);g=e.email,_=B(d.map(e=>e.model),t,{getKey:e=>e.id,equals:(e,t)=>JSON.stringify(F(e))===JSON.stringify(F(t))}),v=B(p.map(e=>e.model),o,{getKey:e=>e.id,equals:(e,t)=>JSON.stringify(F(e))===JSON.stringify(F(t))})}let b=[];c&&(b=(await Mr(c)).filter(e=>e.pathname.endsWith(`/model.json`)&&u.some(t=>be(t,e))||e.pathname.endsWith(`/index.json`)&&l.some(t=>be(t,e))).map(e=>ve(s,e))),console.info(`Repository: ${n}`),r&&console.info(`Environment: ${r}`),g?console.info(`Authenticated as: ${g}`):console.info("Not logged in — log in with `prismic login` to compare with remote.");let x=_!==void 0&&v!==void 0&&_.insert.length===0&&_.update.length===0&&_.delete.length===0&&v.insert.length===0&&v.update.length===0&&v.delete.length===0;if(x&&b.length===0){console.info(``),console.info(`Already up to date.`);return}if(_&&v){let e=[],t=[..._.insert.map(e=>` ${e.id} (custom type)`),...v.insert.map(e=>` ${e.id} (slice)`)];t.length>0&&e.push([`Local-only:`,...t]);let n=[..._.delete.map(e=>` ${e.id} (custom type)`),...v.delete.map(e=>` ${e.id} (slice)`)];n.length>0&&e.push([`Remote-only:`,...n]);let r=[..._.update.map(e=>` ${e.id} (custom type)`),...v.update.map(e=>` ${e.id} (slice)`)];r.length>0&&e.push([`Differ:`,...r]);for(let t of e){console.info(``);for(let e of t)console.info(e)}}if(b.length>0&&(console.info(``),console.info(f`
218
+ `,options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:n=await S(),env:r}=e,i=await k(),a=await A(),o=await m(),s=await t(),[c,l,u,d,p]=await Promise.all([Mr(s),o.getCustomTypeLibraries(),o.getSliceLibraries(),o.getCustomTypes(),o.getSlices()]),h=n,g,_,v;if(i){r&&(h=await H(r,{repo:n,token:i,host:a}));let[e,t,o]=await Promise.all([y({token:i,host:a}),yn({repo:h,token:i,host:a}),Cn({repo:h,token:i,host:a})]);g=e.email,_=B(d.map(e=>e.model),t,{getKey:e=>e.id,equals:(e,t)=>JSON.stringify(F(e))===JSON.stringify(F(t))}),v=B(p.map(e=>e.model),o,{getKey:e=>e.id,equals:(e,t)=>JSON.stringify(F(e))===JSON.stringify(F(t))})}let b=[];c&&(b=(await Nr(c)).filter(e=>e.pathname.endsWith(`/model.json`)&&u.some(t=>be(t,e))||e.pathname.endsWith(`/index.json`)&&l.some(t=>be(t,e))).map(e=>ve(s,e))),console.info(`Repository: ${n}`),r&&console.info(`Environment: ${r}`),g?console.info(`Authenticated as: ${g}`):console.info("Not logged in — log in with `prismic login` to compare with remote.");let x=_!==void 0&&v!==void 0&&_.insert.length===0&&_.update.length===0&&_.delete.length===0&&v.insert.length===0&&v.update.length===0&&v.delete.length===0;if(x&&b.length===0){console.info(``),console.info(`Already up to date.`);return}if(_&&v){let e=[],t=[..._.insert.map(e=>` ${e.id} (custom type)`),...v.insert.map(e=>` ${e.id} (slice)`)];t.length>0&&e.push([`Local-only:`,...t]);let n=[..._.delete.map(e=>` ${e.id} (custom type)`),...v.delete.map(e=>` ${e.id} (slice)`)];n.length>0&&e.push([`Remote-only:`,...n]);let r=[..._.update.map(e=>` ${e.id} (custom type)`),...v.update.map(e=>` ${e.id} (slice)`)];r.length>0&&e.push([`Differ:`,...r]);for(let t of e){console.info(``);for(let e of t)console.info(e)}}if(b.length>0&&(console.info(``),console.info(f`
219
219
  Pull and push won't run while these model files have uncommitted git changes:
220
220
  ${b.join(`
221
221
  `)}
@@ -225,27 +225,27 @@ Please try again, or manually delete any associated pages at: `+or({repo:n,host:
225
225
  git commit -m "Update Prismic models"
226
226
 
227
227
  Or override with \`prismic push --force\` (keep local) or \`prismic pull --force\` (discard local).
228
- `)),_&&v&&!x){let e=_.insert.length+v.insert.length,t=_.update.length+v.update.length,n=_.delete.length+v.delete.length;console.info(``),console.info(`Next:`),console.info(` prismic push — would create ${e}, update ${t}, delete ${n}`),console.info(` prismic pull — would create ${n}, update ${t}, delete ${e}`)}});let ti,ni;async function ri(e){if(Me.TEST)return;let{host:t}=e;if(!await ci())return;let n=t===Ne?`cGjidifKefYb6EPaGaqpt8rQXkv5TD6P`:`Ng5oKJHCGpSWplZ9ymB7Pu7rm0sTDeiG`;ni=await cr(),await ze({writeKey:n})}function ii(e){ti=e}function ai(e){Le({userId:e.shortId,intercomHash:e.intercomHash})}function oi(e,t={}){let{watch:n}=t;Re(`Prismic CLI Start`,{properties:{commandType:e,fullCommand:process.argv.join(` `),repository:ti,watch:n,agent:ni},groupId:ti?{Repository:ti}:void 0})}function U(e,t={}){let{watch:n,success:r=!process.exitCode,error:i}=t,a=i?i instanceof Error?i.message:String(i):void 0;Re(`Prismic CLI End`,{properties:{commandType:e,fullCommand:process.argv.join(` `),success:r,repository:ti,watch:n,error:a?.slice(0,512),agent:ni},groupId:ti?{Repository:ti}:void 0})}const si=C({telemetry:De()});async function ci(){try{return!((await we(new URL(`.prismicrc`,Se(Ke(rt()))),{schema:si}).catch(()=>({telemetry:!0}))).telemetry===!1||(await we(new URL(`.prismicrc`,Se(Ke(process.cwd()))),{schema:si}).catch(()=>({telemetry:!0}))).telemetry===!1)}catch{return!0}}const li=Me.TEST?500:5e3;var ui=M({name:`prismic sync`,description:`
228
+ `)),_&&v&&!x){let e=_.insert.length+v.insert.length,t=_.update.length+v.update.length,n=_.delete.length+v.delete.length;console.info(``),console.info(`Next:`),console.info(` prismic push — would create ${e}, update ${t}, delete ${n}`),console.info(` prismic pull — would create ${n}, update ${t}, delete ${e}`)}});let ni,ri;async function ii(e){if(Me.TEST)return;let{host:t}=e;if(!await li())return;let n=t===Ne?`cGjidifKefYb6EPaGaqpt8rQXkv5TD6P`:`Ng5oKJHCGpSWplZ9ymB7Pu7rm0sTDeiG`;ri=await lr(),await ze({writeKey:n})}function ai(e){ni=e}function oi(e){Le({userId:e.shortId,intercomHash:e.intercomHash})}function si(e,t={}){let{watch:n}=t;Re(`Prismic CLI Start`,{properties:{commandType:e,fullCommand:process.argv.join(` `),repository:ni,watch:n,agent:ri},groupId:ni?{Repository:ni}:void 0})}function U(e,t={}){let{watch:n,success:r=!process.exitCode,error:i}=t,a=i?i instanceof Error?i.message:String(i):void 0;Re(`Prismic CLI End`,{properties:{commandType:e,fullCommand:process.argv.join(` `),success:r,repository:ni,watch:n,error:a?.slice(0,512),agent:ri},groupId:ni?{Repository:ni}:void 0})}const ci=C({telemetry:De()});async function li(){try{return!((await we(new URL(`.prismicrc`,Se(Ke(rt()))),{schema:ci}).catch(()=>({telemetry:!0}))).telemetry===!1||(await we(new URL(`.prismicrc`,Se(Ke(process.cwd()))),{schema:ci}).catch(()=>({telemetry:!0}))).telemetry===!1)}catch{return!0}}const ui=Me.TEST?500:5e3;var di=M({name:`prismic sync`,description:`
229
229
  Watch Prismic and continuously pull changes to local files.
230
230
 
231
231
  For one-time pulls, use \`prismic pull\`.
232
- `,options:{watch:{type:`boolean`,short:`w`,description:`Watch for changes and sync continuously`,required:!0},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:t})=>{let{repo:n=await S(),env:r}=t,i=await k(),a=await A(),o=await m(),s=r?await H(r,{repo:n,token:i,host:a}):n;oi(`sync`,{watch:!0}),process.on(`SIGINT`,()=>{console.info(`
233
- Watch stopped. Goodbye!`),U(`sync`,{watch:!0}),process.exit(0)}),console.info(`Watching repository: ${n}${r?` (env: ${r})`:``} (polling every ${li/1e3}s, Ctrl+C to stop)`);let c=``,l=0;for(;;){try{let[t,r]=await Promise.all([yn({repo:s,token:i,host:a}),Cn({repo:s,token:i,host:a})]),u=di({remoteCustomTypes:t,remoteSlices:r});if(u!==c){let s=c===``,[l,d]=await Promise.all([o.getCustomTypes(),o.getSlices()]),f=l.map(e=>e.model),p=d.map(e=>e.model),m=[],h=B(r,p,{getKey:e=>e.id});if(h.insert.length+h.update.length+h.delete.length>0){for(let e of h.update)await o.updateSlice(e);for(let e of h.delete)await o.deleteSlice(e.id);for(let e of h.insert)await o.createSlice(e);m.push(`slices`)}let g=B(t,f,{getKey:e=>e.id});if(g.insert.length+g.update.length+g.delete.length>0){for(let e of g.update)await o.updateCustomType(e);for(let e of g.delete)await o.deleteCustomType(e.id);for(let e of g.insert)await o.createCustomType(e);m.push(`custom types`)}if(await o.generateTypes(),c=u,s)await e({repo:n,token:i,host:a,stepIds:[`connectPrismic`]}),console.info(`Initial sync complete.`);else{let e=new Date().toLocaleTimeString();console.info(`[${e}] Changes detected in ${m.join(` and `)}`)}}l=0}catch(e){l++;let t=e instanceof Error?e.message:`Unknown error`;if(console.error(`Error checking for changes: ${t}`),l>=5)throw Error(`Too many consecutive errors (5), stopping watch.`)}await it(li)}});function di(e){return qe(`sha256`).update(JSON.stringify(e)).digest(`hex`)}const fi=`Prismic CLI`;var pi=M({name:`prismic token create`,description:`
232
+ `,options:{watch:{type:`boolean`,short:`w`,description:`Watch for changes and sync continuously`,required:!0},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:t})=>{let{repo:n=await S(),env:r}=t,i=await k(),a=await A(),o=await m(),s=r?await H(r,{repo:n,token:i,host:a}):n;si(`sync`,{watch:!0}),process.on(`SIGINT`,()=>{console.info(`
233
+ Watch stopped. Goodbye!`),U(`sync`,{watch:!0}),process.exit(0)}),console.info(`Watching repository: ${n}${r?` (env: ${r})`:``} (polling every ${ui/1e3}s, Ctrl+C to stop)`);let c=``,l=0;for(;;){try{let[t,r]=await Promise.all([yn({repo:s,token:i,host:a}),Cn({repo:s,token:i,host:a})]),u=fi({remoteCustomTypes:t,remoteSlices:r});if(u!==c){let s=c===``,[l,d]=await Promise.all([o.getCustomTypes(),o.getSlices()]),f=l.map(e=>e.model),p=d.map(e=>e.model),m=[],h=B(r,p,{getKey:e=>e.id});if(h.insert.length+h.update.length+h.delete.length>0){for(let e of h.update)await o.updateSlice(e);for(let e of h.delete)await o.deleteSlice(e.id);for(let e of h.insert)await o.createSlice(e);m.push(`slices`)}let g=B(t,f,{getKey:e=>e.id});if(g.insert.length+g.update.length+g.delete.length>0){for(let e of g.update)await o.updateCustomType(e);for(let e of g.delete)await o.deleteCustomType(e.id);for(let e of g.insert)await o.createCustomType(e);m.push(`custom types`)}if(await o.generateTypes(),c=u,s)await e({repo:n,token:i,host:a,stepIds:[`connectPrismic`]}),console.info(`Initial sync complete.`);else{let e=new Date().toLocaleTimeString();console.info(`[${e}] Changes detected in ${m.join(` and `)}`)}}l=0}catch(e){l++;let t=e instanceof Error?e.message:`Unknown error`;if(console.error(`Error checking for changes: ${t}`),l>=5)throw Error(`Too many consecutive errors (5), stopping watch.`)}await it(ui)}});function fi(e){return qe(`sha256`).update(JSON.stringify(e)).digest(`hex`)}const pi=`Prismic CLI`;var mi=M({name:`prismic token create`,description:`
234
234
  Create a new API token for a Prismic repository.
235
235
 
236
236
  By default, this command reads the repository from prismic.config.json at the
237
237
  project root.
238
- `,options:{write:{type:`boolean`,description:`Create a write token`},"allow-releases":{type:`boolean`,description:`Allow access to releases (read tokens only)`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,write:r,"allow-releases":i}=e;if(r&&i)throw new P(`--allow-releases is only valid for access tokens (not with --write)`);let a=await k(),o=await A(),s=n?await H(n,{repo:t,token:a,host:o}):t,c;try{if(r)c=(await Xn(fi,{repo:s,token:a,host:o})).token;else{let e=i?`master+releases`:`master`,t=(await Gn({repo:s,token:a,host:o})).find(e=>e.name===fi);t||=await Kn(fi,{repo:s,token:a,host:o}),c=(await qn(t.id,e,{repo:s,token:a,host:o})).token}}catch(e){throw e instanceof w?new P(`Failed to create token: ${await e.text()}`):e}console.info(`Token created: ${c}`);let l=r?`PRISMIC_WRITE_TOKEN`:`PRISMIC_ACCESS_TOKEN`;console.info(`Add it to your .env file: ${l}=${c}`)}),mi=M({name:`prismic token delete`,description:`
238
+ `,options:{write:{type:`boolean`,description:`Create a write token`},"allow-releases":{type:`boolean`,description:`Allow access to releases (read tokens only)`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,write:r,"allow-releases":i}=e;if(r&&i)throw new P(`--allow-releases is only valid for access tokens (not with --write)`);let a=await k(),o=await A(),s=n?await H(n,{repo:t,token:a,host:o}):t,c;try{if(r)c=(await Zn(pi,{repo:s,token:a,host:o})).token;else{let e=i?`master+releases`:`master`,t=(await Kn({repo:s,token:a,host:o})).find(e=>e.name===pi);t||=await qn(pi,{repo:s,token:a,host:o}),c=(await Jn(t.id,e,{repo:s,token:a,host:o})).token}}catch(e){throw e instanceof w?new P(`Failed to create token: ${await e.text()}`):e}console.info(`Token created: ${c}`);let l=r?`PRISMIC_WRITE_TOKEN`:`PRISMIC_ACCESS_TOKEN`;console.info(`Add it to your .env file: ${l}=${c}`)}),hi=M({name:`prismic token delete`,description:`
239
239
  Delete a token from a Prismic repository.
240
240
 
241
241
  By default, this command reads the repository from prismic.config.json at the
242
242
  project root.
243
- `,positionals:{token:{description:`Token value`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c,l;try{[c,l]=await Promise.all([Gn({repo:s,token:a,host:o}),Yn({repo:s,token:a,host:o})])}catch(e){throw e instanceof w?new P(`Failed to delete token: ${await e.text()}`):e}let u=c.flatMap(e=>e.wroom_auths).find(e=>e.token===n);if(u){try{await Jn(u.id,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to delete token: ${await e.text()}`):e}console.info(`Token deleted`);return}let d=l.tokens.find(e=>e.token===n);if(d){try{await Zn(d.token,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to delete token: ${await e.text()}`):e}console.info(`Token deleted`);return}throw new P(`Token not found: ${n}`)}),hi=N({name:`prismic token`,description:`Manage API tokens for a Prismic repository.`,commands:{list:{handler:M({name:`prismic token list`,description:`
243
+ `,positionals:{token:{description:`Token value`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c,l;try{[c,l]=await Promise.all([Kn({repo:s,token:a,host:o}),Xn({repo:s,token:a,host:o})])}catch(e){throw e instanceof w?new P(`Failed to delete token: ${await e.text()}`):e}let u=c.flatMap(e=>e.wroom_auths).find(e=>e.token===n);if(u){try{await Yn(u.id,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to delete token: ${await e.text()}`):e}console.info(`Token deleted`);return}let d=l.tokens.find(e=>e.token===n);if(d){try{await Qn(d.token,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to delete token: ${await e.text()}`):e}console.info(`Token deleted`);return}throw new P(`Token not found: ${n}`)}),gi=N({name:`prismic token`,description:`Manage API tokens for a Prismic repository.`,commands:{list:{handler:M({name:`prismic token list`,description:`
244
244
  List all API tokens for a Prismic repository.
245
245
 
246
246
  By default, this command reads the repository from prismic.config.json at the
247
247
  project root.
248
- `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s,c;try{[s,c]=await Promise.all([Gn({repo:o,token:i,host:a}),Yn({repo:o,token:i,host:a})])}catch(e){throw e instanceof w?new P(`Failed to list tokens: ${await e.text()}`):e}let l=s.flatMap(e=>e.wroom_auths.map(t=>({name:e.name,scope:t.scope,token:t.token,createdAt:new Date(t.created_at.$date).toISOString().split(`T`)[0]}))),u=c.tokens;if(r){console.info(O({accessTokens:l,writeTokens:u}));return}if(l.length>0){console.info(`ACCESS TOKENS`);let e=l.map(e=>[` ${e.name}`,e.scope,e.token,e.createdAt]);console.info(b(e))}else console.info(`ACCESS TOKENS (none)`);if(console.info(``),u.length>0){console.info(`WRITE TOKENS`);let e=u.map(e=>{let t=new Date(e.timestamp*1e3).toISOString().split(`T`)[0];return[` ${e.app_name}`,e.token,t]});console.info(b(e))}else console.info(`WRITE TOKENS (none)`)}),description:`List all tokens`},create:{handler:pi,description:`Create a new token`},delete:{handler:mi,description:`Delete a token`}}}),gi=M({name:`prismic type add-tab`,description:`Add a tab to a content type.`,positionals:{name:{description:`Name of the tab`,required:!0}},options:{to:{type:`string`,required:!0,description:`ID of the content type`},"with-slice-zone":{type:`boolean`,description:`Add a slice zone to the tab`}}},async({positionals:e,values:t})=>{let[n]=e,{to:r,"with-slice-zone":i}=t,a=await m(),{model:o}=await a.getCustomType(r);if(n in o.json)throw new P(`Tab "${n}" already exists in "${r}".`);o.json[n]=i?{slices:{type:`Slices`,fieldset:`Slice Zone`,config:{choices:{}}}}:{},await a.updateCustomType(o),await a.generateTypes(),console.info(`Added tab "${n}" to "${r}"`)}),_i=M({name:`prismic type create`,description:`Create a new content type.`,positionals:{name:{description:`Name of the content type`,required:!0}},options:{format:{type:`string`,short:`f`,description:`Type format: "custom" (default) or "page"`},single:{type:`boolean`,short:`s`,description:`Allow only one document of this type`},id:{type:`string`,description:`Custom ID for the content type`}},sections:{FORMATS:`
248
+ `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s,c;try{[s,c]=await Promise.all([Kn({repo:o,token:i,host:a}),Xn({repo:o,token:i,host:a})])}catch(e){throw e instanceof w?new P(`Failed to list tokens: ${await e.text()}`):e}let l=s.flatMap(e=>e.wroom_auths.map(t=>({name:e.name,scope:t.scope,token:t.token,createdAt:new Date(t.created_at.$date).toISOString().split(`T`)[0]}))),u=c.tokens;if(r){console.info(O({accessTokens:l,writeTokens:u}));return}if(l.length>0){console.info(`ACCESS TOKENS`);let e=l.map(e=>[` ${e.name}`,e.scope,e.token,e.createdAt]);console.info(b(e))}else console.info(`ACCESS TOKENS (none)`);if(console.info(``),u.length>0){console.info(`WRITE TOKENS`);let e=u.map(e=>{let t=new Date(e.timestamp*1e3).toISOString().split(`T`)[0];return[` ${e.app_name}`,e.token,t]});console.info(b(e))}else console.info(`WRITE TOKENS (none)`)}),description:`List all tokens`},create:{handler:mi,description:`Create a new token`},delete:{handler:hi,description:`Delete a token`}}}),_i=M({name:`prismic type add-tab`,description:`Add a tab to a content type.`,positionals:{name:{description:`Name of the tab`,required:!0}},options:{to:{type:`string`,required:!0,description:`ID of the content type`},"with-slice-zone":{type:`boolean`,description:`Add a slice zone to the tab`}}},async({positionals:e,values:t})=>{let[n]=e,{to:r,"with-slice-zone":i}=t,a=await m(),{model:o}=await a.getCustomType(r);if(n in o.json)throw new P(`Tab "${n}" already exists in "${r}".`);o.json[n]=i?{slices:{type:`Slices`,fieldset:`Slice Zone`,config:{choices:{}}}}:{},await a.updateCustomType(o),await a.generateTypes(),console.info(`Added tab "${n}" to "${r}"`)}),vi=M({name:`prismic type create`,description:`Create a new content type.`,positionals:{name:{description:`Name of the content type`,required:!0}},options:{format:{type:`string`,short:`f`,description:`Type format: "custom" (default) or "page"`},single:{type:`boolean`,short:`s`,description:`Allow only one document of this type`},id:{type:`string`,description:`Custom ID for the content type`}},sections:{FORMATS:`
249
249
  custom A non-page type (e.g. settings, navigation, author, blog
250
250
  category). This is the default.
251
251
  page A page type with a URL (e.g. homepage, blog post, landing
@@ -260,7 +260,7 @@ Watch stopped. Goodbye!`),U(`sync`,{watch:!0}),process.exit(0)}),console.info(`W
260
260
 
261
261
  Create with a custom ID:
262
262
  prismic type create "Landing Page" --format page --id landing
263
- `}},async({positionals:e,values:t})=>{let[n]=e,{format:r=`custom`,single:i=!1,id:a=s(n)}=t;if(r!==`custom`&&r!==`page`)throw new P(`Invalid format: "${r}". Use "custom" or "page".`);let o=r===`page`?{Main:{slices:{type:`Slices`,fieldset:`Slice Zone`,config:{choices:{}}}},"SEO & Metadata":{meta_title:{type:`Text`,config:{label:`Meta Title`,placeholder:`A title of the page used for social media and search engines`}},meta_description:{type:`Text`,config:{label:`Meta Description`,placeholder:`A brief summary of the page`}},meta_image:{type:`Image`,config:{label:`Meta Image`,constraint:{width:2400,height:1260},thumbnails:[]}}}}:{Main:{}};i||(o.Main={uid:{type:`UID`,config:{label:`UID`}},...o.Main});let c={id:a,label:n,repeatable:!i,status:!0,format:r,json:o},l=await m();await l.createCustomType(c),await l.generateTypes(),console.info(`Created type "${n}" (id: "${a}", format: "${r}")`),console.info(`Run \`prismic field add <type> --to-type ${a}\` to add fields.`),console.info(`Run \`prismic type view ${a}\` to view the type.`)}),vi=M({name:`prismic type edit`,description:`Edit a content type.`,positionals:{id:{description:`ID of the content type`,required:!0}},options:{name:{type:`string`,short:`n`,description:`New name for the type`},format:{type:`string`,short:`f`,description:`Type format: "custom" or "page"`}}},async({positionals:e,values:t})=>{let[n]=e;if(`format`in t&&t.format!==`custom`&&t.format!==`page`)throw new P(`Invalid format: "${t.format}". Use "custom" or "page".`);let r=await m(),{model:i}=await r.getCustomType(n);`name`in t&&(i.label=t.name),`format`in t&&(i.format=t.format),await r.updateCustomType(i),await r.generateTypes(),console.info(`Type updated: "${i.label}" (id: ${i.id})`)}),yi=M({name:`prismic type edit-tab`,description:`Edit a tab of a content type.`,positionals:{name:{description:`Current name of the tab`,required:!0}},options:{"from-type":{type:`string`,required:!0,description:`ID of the content type`},name:{type:`string`,short:`n`,description:`New name for the tab`},"with-slice-zone":{type:`boolean`,description:`Add a slice zone to the tab`},"without-slice-zone":{type:`boolean`,description:`Remove the slice zone from the tab`}}},async({positionals:e,values:t})=>{let[n]=e,{"from-type":r}=t,i=await m(),{model:a}=await i.getCustomType(r);if(!(n in a.json))throw new P(`Tab "${n}" not found in "${r}".`);if(`with-slice-zone`in t&&`without-slice-zone`in t)throw new P(`Cannot use --with-slice-zone and --without-slice-zone together.`);if(`with-slice-zone`in t){let e=a.json[n];if(Object.values(e).some(e=>e.type===`Slices`))throw new P(`Tab "${n}" already has a slice zone.`);e.slices={type:`Slices`,fieldset:`Slice Zone`,config:{choices:{}}}}if(`without-slice-zone`in t){let e=a.json[n],t=Object.entries(e).find(([,e])=>e.type===`Slices`);if(!t)throw new P(`Tab "${n}" does not have a slice zone.`);let[r,i]=t,o=i.type===`Slices`?i.config?.choices??{}:{};if(Object.keys(o).length>0)throw new P(`Cannot remove slice zone from "${n}": disconnect all slices first.`);delete e[r]}if(`name`in t){if(t.name in a.json)throw new P(`Tab "${t.name}" already exists in "${r}".`);let e={};for(let[r,i]of Object.entries(a.json))e[r===n?t.name:r]=i;a.json=e}await i.updateCustomType(a),await i.generateTypes(),console.info(`Tab updated: "${n}" in "${r}"`)}),bi=M({name:`prismic type list`,description:`List all content types.`,options:{json:{type:`boolean`,description:`Output as JSON`}}},async({values:e})=>{let{json:t}=e,n=await(await m()).getCustomTypes();if(t){console.info(O(n.map(e=>e.model)));return}if(n.length===0){console.info(`No types found.`);return}let r=n.map(({model:e})=>[e.label||`(no name)`,e.id,e.format??``]);console.info(b(r,{headers:[`NAME`,`ID`,`FORMAT`]}))}),xi=M({name:`prismic type remove`,description:`Remove a content type.`,positionals:{id:{description:`ID of the content type`,required:!0}}},async({positionals:e})=>{let[t]=e,n=await m(),{model:r}=await n.getCustomType(t);await n.deleteCustomType(r.id),await n.generateTypes(),console.info(`Type removed: ${t}`)}),Si=M({name:`prismic type remove-tab`,description:`Remove a tab from a content type.`,positionals:{name:{description:`Name of the tab`,required:!0}},options:{from:{type:`string`,required:!0,description:`ID of the content type`}}},async({positionals:e,values:t})=>{let[n]=e,{from:r}=t,i=await m(),{model:a}=await i.getCustomType(r);if(!(n in a.json))throw new P(`Tab "${n}" not found in "${r}".`);if(Object.keys(a.json).length<=1)throw new P(`Cannot remove the last tab from "${r}".`);delete a.json[n],await i.updateCustomType(a),await i.generateTypes(),console.info(`Removed tab "${n}" from "${r}"`)}),Ci=M({name:`prismic type view`,description:`View details of a content type.`,positionals:{id:{description:`ID of the content type`,required:!0}},options:{json:{type:`boolean`,description:`Output as JSON`}}},async({positionals:e,values:t})=>{let[n]=e,{json:r}=t,{model:i}=await(await m()).getCustomType(n);if(r){console.info(O(i));return}console.info(`ID: ${i.id}`),console.info(`Name: ${i.label||`(no name)`}`),console.info(`Format: ${i.format}`),console.info(`Repeatable: ${i.repeatable}`);for(let[e,t]of Object.entries(i.json)){console.info(``),console.info(`${e}:`);let n=Object.entries(t);if(n.length===0)console.info(` (no fields)`);else{let e=n.map(([e,t])=>{let n=t.config,r=n?.label||``,i=n?.placeholder?`"${n.placeholder}"`:``;return[` ${e}`,t.type,r,i]});console.info(b(e))}}}),wi=N({name:`prismic type`,description:`Manage content types.`,commands:{create:{handler:_i,description:`Create a new content type`},edit:{handler:vi,description:`Edit a content type`},remove:{handler:xi,description:`Remove a content type`},list:{handler:bi,description:`List content types`},view:{handler:Ci,description:`View a content type`},"add-tab":{handler:gi,description:`Add a tab to a content type`},"edit-tab":{handler:yi,description:`Edit a tab of a content type`},"remove-tab":{handler:Si,description:`Remove a tab from a content type`}}}),Ti=M({name:`prismic webhook create`,description:`
263
+ `}},async({positionals:e,values:t})=>{let[n]=e,{format:r=`custom`,single:i=!1,id:a=s(n)}=t;if(r!==`custom`&&r!==`page`)throw new P(`Invalid format: "${r}". Use "custom" or "page".`);let o=r===`page`?{Main:{slices:{type:`Slices`,fieldset:`Slice Zone`,config:{choices:{}}}},"SEO & Metadata":{meta_title:{type:`Text`,config:{label:`Meta Title`,placeholder:`A title of the page used for social media and search engines`}},meta_description:{type:`Text`,config:{label:`Meta Description`,placeholder:`A brief summary of the page`}},meta_image:{type:`Image`,config:{label:`Meta Image`,constraint:{width:2400,height:1260},thumbnails:[]}}}}:{Main:{}};i||(o.Main={uid:{type:`UID`,config:{label:`UID`}},...o.Main});let c={id:a,label:n,repeatable:!i,status:!0,format:r,json:o},l=await m();await l.createCustomType(c),await l.generateTypes(),console.info(`Created type "${n}" (id: "${a}", format: "${r}")`),console.info(`Run \`prismic field add <type> --to-type ${a}\` to add fields.`),console.info(`Run \`prismic type view ${a}\` to view the type.`)}),yi=M({name:`prismic type edit`,description:`Edit a content type.`,positionals:{id:{description:`ID of the content type`,required:!0}},options:{name:{type:`string`,short:`n`,description:`New name for the type`},format:{type:`string`,short:`f`,description:`Type format: "custom" or "page"`}}},async({positionals:e,values:t})=>{let[n]=e;if(`format`in t&&t.format!==`custom`&&t.format!==`page`)throw new P(`Invalid format: "${t.format}". Use "custom" or "page".`);let r=await m(),{model:i}=await r.getCustomType(n);`name`in t&&(i.label=t.name),`format`in t&&(i.format=t.format),await r.updateCustomType(i),await r.generateTypes(),console.info(`Type updated: "${i.label}" (id: ${i.id})`)}),bi=M({name:`prismic type edit-tab`,description:`Edit a tab of a content type.`,positionals:{name:{description:`Current name of the tab`,required:!0}},options:{"from-type":{type:`string`,required:!0,description:`ID of the content type`},name:{type:`string`,short:`n`,description:`New name for the tab`},"with-slice-zone":{type:`boolean`,description:`Add a slice zone to the tab`},"without-slice-zone":{type:`boolean`,description:`Remove the slice zone from the tab`}}},async({positionals:e,values:t})=>{let[n]=e,{"from-type":r}=t,i=await m(),{model:a}=await i.getCustomType(r);if(!(n in a.json))throw new P(`Tab "${n}" not found in "${r}".`);if(`with-slice-zone`in t&&`without-slice-zone`in t)throw new P(`Cannot use --with-slice-zone and --without-slice-zone together.`);if(`with-slice-zone`in t){let e=a.json[n];if(Object.values(e).some(e=>e.type===`Slices`))throw new P(`Tab "${n}" already has a slice zone.`);e.slices={type:`Slices`,fieldset:`Slice Zone`,config:{choices:{}}}}if(`without-slice-zone`in t){let e=a.json[n],t=Object.entries(e).find(([,e])=>e.type===`Slices`);if(!t)throw new P(`Tab "${n}" does not have a slice zone.`);let[r,i]=t,o=i.type===`Slices`?i.config?.choices??{}:{};if(Object.keys(o).length>0)throw new P(`Cannot remove slice zone from "${n}": disconnect all slices first.`);delete e[r]}if(`name`in t){if(t.name in a.json)throw new P(`Tab "${t.name}" already exists in "${r}".`);let e={};for(let[r,i]of Object.entries(a.json))e[r===n?t.name:r]=i;a.json=e}await i.updateCustomType(a),await i.generateTypes(),console.info(`Tab updated: "${n}" in "${r}"`)}),xi=M({name:`prismic type list`,description:`List all content types.`,options:{json:{type:`boolean`,description:`Output as JSON`}}},async({values:e})=>{let{json:t}=e,n=await(await m()).getCustomTypes();if(t){console.info(O(n.map(e=>e.model)));return}if(n.length===0){console.info(`No types found.`);return}let r=n.map(({model:e})=>[e.label||`(no name)`,e.id,e.format??``]);console.info(b(r,{headers:[`NAME`,`ID`,`FORMAT`]}))}),Si=M({name:`prismic type remove`,description:`Remove a content type.`,positionals:{id:{description:`ID of the content type`,required:!0}}},async({positionals:e})=>{let[t]=e,n=await m(),{model:r}=await n.getCustomType(t);await n.deleteCustomType(r.id),await n.generateTypes(),console.info(`Type removed: ${t}`)}),Ci=M({name:`prismic type remove-tab`,description:`Remove a tab from a content type.`,positionals:{name:{description:`Name of the tab`,required:!0}},options:{from:{type:`string`,required:!0,description:`ID of the content type`}}},async({positionals:e,values:t})=>{let[n]=e,{from:r}=t,i=await m(),{model:a}=await i.getCustomType(r);if(!(n in a.json))throw new P(`Tab "${n}" not found in "${r}".`);if(Object.keys(a.json).length<=1)throw new P(`Cannot remove the last tab from "${r}".`);delete a.json[n],await i.updateCustomType(a),await i.generateTypes(),console.info(`Removed tab "${n}" from "${r}"`)}),wi=M({name:`prismic type view`,description:`View details of a content type.`,positionals:{id:{description:`ID of the content type`,required:!0}},options:{json:{type:`boolean`,description:`Output as JSON`}}},async({positionals:e,values:t})=>{let[n]=e,{json:r}=t,{model:i}=await(await m()).getCustomType(n);if(r){console.info(O(i));return}console.info(`ID: ${i.id}`),console.info(`Name: ${i.label||`(no name)`}`),console.info(`Format: ${i.format}`),console.info(`Repeatable: ${i.repeatable}`);for(let[e,t]of Object.entries(i.json)){console.info(``),console.info(`${e}:`);let n=Object.entries(t);if(n.length===0)console.info(` (no fields)`);else{let e=n.map(([e,t])=>{let n=t.config,r=n?.label||``,i=n?.placeholder?`"${n.placeholder}"`:``;return[` ${e}`,t.type,r,i]});console.info(b(e))}}}),Ti=N({name:`prismic type`,description:`Manage content types.`,commands:{create:{handler:vi,description:`Create a new content type`},edit:{handler:yi,description:`Edit a content type`},remove:{handler:Si,description:`Remove a content type`},list:{handler:xi,description:`List content types`},view:{handler:wi,description:`View a content type`},"add-tab":{handler:_i,description:`Add a tab to a content type`},"edit-tab":{handler:bi,description:`Edit a tab of a content type`},"remove-tab":{handler:Ci,description:`Remove a tab from a content type`}}}),Ei=M({name:`prismic webhook create`,description:`
264
264
  Create a new webhook in a Prismic repository.
265
265
 
266
266
  By default, this command reads the repository from prismic.config.json at the
@@ -283,27 +283,27 @@ Watch stopped. Goodbye!`),U(`sync`,{watch:!0}),process.exit(0)}),console.info(`W
283
283
 
284
284
  Create a named webhook with a secret:
285
285
  prismic webhook create https://example.com/webhook --name "Deploy" --secret my-secret
286
- `}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,name:a,secret:o,trigger:s=[]}=t;for(let e of s)if(!Fn.includes(e))throw new P(`Invalid trigger: ${e}\nValid triggers: ${Fn.join(`, `)}`);let c=await k(),l=await A(),u=i?await H(i,{repo:r,token:c,host:l}):r,d=!(s.length>0);try{await Rn({url:n,name:a??null,secret:o??null,documentsPublished:s.includes(`documentsPublished`)||d,documentsUnpublished:s.includes(`documentsUnpublished`)||d,releasesCreated:s.includes(`releasesCreated`)||d,releasesUpdated:s.includes(`releasesUpdated`)||d,tagsCreated:s.includes(`tagsCreated`)||d,tagsDeleted:s.includes(`tagsDeleted`)||d},{repo:u,token:c,host:l})}catch(e){throw e instanceof w?new P(`Failed to create webhook: ${await e.text()}`):e}console.info(`Webhook created: ${n}`),console.info(`Run \`prismic webhook set-triggers ${n}\` to configure triggers.`)}),Ei=M({name:`prismic webhook disable`,description:`
286
+ `}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,name:a,secret:o,trigger:s=[]}=t;for(let e of s)if(!In.includes(e))throw new P(`Invalid trigger: ${e}\nValid triggers: ${In.join(`, `)}`);let c=await k(),l=await A(),u=i?await H(i,{repo:r,token:c,host:l}):r,d=!(s.length>0);try{await zn({url:n,name:a??null,secret:o??null,documentsPublished:s.includes(`documentsPublished`)||d,documentsUnpublished:s.includes(`documentsUnpublished`)||d,releasesCreated:s.includes(`releasesCreated`)||d,releasesUpdated:s.includes(`releasesUpdated`)||d,tagsCreated:s.includes(`tagsCreated`)||d,tagsDeleted:s.includes(`tagsDeleted`)||d},{repo:u,token:c,host:l})}catch(e){throw e instanceof w?new P(`Failed to create webhook: ${await e.text()}`):e}console.info(`Webhook created: ${n}`),console.info(`Run \`prismic webhook set-triggers ${n}\` to configure triggers.`)}),Di=M({name:`prismic webhook disable`,description:`
287
287
  Disable a webhook in a Prismic repository.
288
288
 
289
289
  By default, this command reads the repository from prismic.config.json at the
290
290
  project root.
291
- `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Ln({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to disable webhook: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);if(!l.config.active){console.info(`Webhook already disabled: ${n}`);return}let u=l.config._id,d=structuredClone(l.config);d.active=!1;try{await zn(u,d,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to disable webhook: ${await e.text()}`):e}console.info(`Webhook disabled: ${n}`)}),Di=M({name:`prismic webhook enable`,description:`
291
+ `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Rn({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to disable webhook: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);if(!l.config.active){console.info(`Webhook already disabled: ${n}`);return}let u=l.config._id,d=structuredClone(l.config);d.active=!1;try{await Bn(u,d,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to disable webhook: ${await e.text()}`):e}console.info(`Webhook disabled: ${n}`)}),Oi=M({name:`prismic webhook enable`,description:`
292
292
  Enable a webhook in a Prismic repository.
293
293
 
294
294
  By default, this command reads the repository from prismic.config.json at the
295
295
  project root.
296
- `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Ln({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to enable webhook: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);if(l.config.active){console.info(`Webhook already enabled: ${n}`);return}let u=l.config._id,d=structuredClone(l.config);d.active=!0;try{await zn(u,d,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to enable webhook: ${await e.text()}`):e}console.info(`Webhook enabled: ${n}`)}),Oi=M({name:`prismic webhook list`,description:`
296
+ `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Rn({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to enable webhook: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);if(l.config.active){console.info(`Webhook already enabled: ${n}`);return}let u=l.config._id,d=structuredClone(l.config);d.active=!0;try{await Bn(u,d,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to enable webhook: ${await e.text()}`):e}console.info(`Webhook enabled: ${n}`)}),ki=M({name:`prismic webhook list`,description:`
297
297
  List all webhooks in a Prismic repository.
298
298
 
299
299
  By default, this command reads the repository from prismic.config.json at the
300
300
  project root.
301
- `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s;try{s=await Ln({repo:o,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to list webhooks: ${await e.text()}`):e}if(r){console.info(O(s.map(e=>e.config)));return}if(s.length===0){console.info(`No webhooks configured.`);return}let c=s.map(e=>{let t=e.config.active?`enabled`:`disabled`,n=e.config.name?` (${e.config.name})`:``;return[`${e.config.url}${n}`,`[${t}]`]});console.info(b(c,{headers:[`URL`,`STATUS`]}))}),ki=M({name:`prismic webhook remove`,description:`
301
+ `,options:{json:{type:`boolean`,description:`Output as JSON`},repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({values:e})=>{let{repo:t=await S(),env:n,json:r}=e,i=await k(),a=await A(),o=n?await H(n,{repo:t,token:i,host:a}):t,s;try{s=await Rn({repo:o,token:i,host:a})}catch(e){throw e instanceof w?new P(`Failed to list webhooks: ${await e.text()}`):e}if(r){console.info(O(s.map(e=>e.config)));return}if(s.length===0){console.info(`No webhooks configured.`);return}let c=s.map(e=>{let t=e.config.active?`enabled`:`disabled`,n=e.config.name?` (${e.config.name})`:``;return[`${e.config.url}${n}`,`[${t}]`]});console.info(b(c,{headers:[`URL`,`STATUS`]}))}),Ai=M({name:`prismic webhook remove`,description:`
302
302
  Delete a webhook from a Prismic repository.
303
303
 
304
304
  By default, this command reads the repository from prismic.config.json at the
305
305
  project root.
306
- `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Ln({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove webhook: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);let u=l.config._id;try{await Bn(u,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove webhook: ${await e.text()}`):e}console.info(`Webhook removed: ${n}`)}),Ai=M({name:`prismic webhook set-triggers`,description:`
306
+ `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Rn({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove webhook: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);let u=l.config._id;try{await Vn(u,{repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to remove webhook: ${await e.text()}`):e}console.info(`Webhook removed: ${n}`)}),ji=M({name:`prismic webhook set-triggers`,description:`
307
307
  Update which events trigger a webhook.
308
308
 
309
309
  By default, this command reads the repository from prismic.config.json at the
@@ -315,17 +315,17 @@ Watch stopped. Goodbye!`),U(`sync`,{watch:!0}),process.exit(0)}),console.info(`W
315
315
  releasesUpdated When a release is edited or deleted
316
316
  tagsCreated When a tag is created
317
317
  tagsDeleted When a tag is deleted
318
- `}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,trigger:a=[]}=t;for(let e of a)if(!Fn.includes(e))throw new P(`Invalid trigger: ${e}\nValid triggers: ${Fn.join(`, `)}`);let o=await k(),s=await A(),c=i?await H(i,{repo:r,token:o,host:s}):r,l;try{l=await Ln({repo:c,token:o,host:s})}catch(e){throw e instanceof w?new P(`Failed to update webhook triggers: ${await e.text()}`):e}let u=l.find(e=>e.config.url===n);if(!u)throw new P(`Webhook not found: ${n}`);let d=u.config._id;try{await zn(d,{...u.config,documentsPublished:a.includes(`documentsPublished`),documentsUnpublished:a.includes(`documentsUnpublished`),releasesCreated:a.includes(`releasesCreated`),releasesUpdated:a.includes(`releasesUpdated`),tagsCreated:a.includes(`tagsCreated`),tagsDeleted:a.includes(`tagsDeleted`)},{repo:c,token:o,host:s})}catch(e){throw e instanceof w?new P(`Failed to update webhook triggers: ${await e.text()}`):e}console.info(`Webhook triggers updated: ${a.join(`, `)}`)}),ji=M({name:`prismic webhook view`,description:`
318
+ `}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i,trigger:a=[]}=t;for(let e of a)if(!In.includes(e))throw new P(`Invalid trigger: ${e}\nValid triggers: ${In.join(`, `)}`);let o=await k(),s=await A(),c=i?await H(i,{repo:r,token:o,host:s}):r,l;try{l=await Rn({repo:c,token:o,host:s})}catch(e){throw e instanceof w?new P(`Failed to update webhook triggers: ${await e.text()}`):e}let u=l.find(e=>e.config.url===n);if(!u)throw new P(`Webhook not found: ${n}`);let d=u.config._id;try{await Bn(d,{...u.config,documentsPublished:a.includes(`documentsPublished`),documentsUnpublished:a.includes(`documentsUnpublished`),releasesCreated:a.includes(`releasesCreated`),releasesUpdated:a.includes(`releasesUpdated`),tagsCreated:a.includes(`tagsCreated`),tagsDeleted:a.includes(`tagsDeleted`)},{repo:c,token:o,host:s})}catch(e){throw e instanceof w?new P(`Failed to update webhook triggers: ${await e.text()}`):e}console.info(`Webhook triggers updated: ${a.join(`, `)}`)}),Mi=M({name:`prismic webhook view`,description:`
319
319
  View details of a webhook in a Prismic repository.
320
320
 
321
321
  By default, this command reads the repository from prismic.config.json at the
322
322
  project root.
323
- `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Ln({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to fetch webhook details: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);let{config:u}=l;console.info(`URL: ${u.url}`),console.info(`Name: ${u.name||`(none)`}`),console.info(`Status: ${u.active?`enabled`:`disabled`}`),console.info(`Secret: ${u.secret?`(set)`:`(none)`}`);let d=[];for(let e of Fn)u[e]&&d.push(e);if(console.info(`Triggers: ${d.length>0?d.join(`, `):`(none)`}`),Object.keys(u.headers).length>0){console.info(`Headers:`);for(let[e,t]of Object.entries(u.headers))console.info(` ${e}: ${t}`)}else console.info(`Headers: (none)`)}),Mi=N({name:`prismic webhook`,description:`Manage webhooks in a Prismic repository.`,commands:{list:{handler:Oi,description:`List all webhooks`},create:{handler:Ti,description:`Create a new webhook`},view:{handler:ji,description:`View webhook details`},remove:{handler:ki,description:`Delete a webhook`},enable:{handler:Di,description:`Enable a webhook`},disable:{handler:Ei,description:`Disable a webhook`},"set-triggers":{handler:Ai,description:`Update webhook triggers`}}}),Ni=M({name:`prismic whoami`,description:`Show the currently logged in user.`},async()=>{let e=await y({token:await k(),host:await A()});console.info(e.email)});const Pi=me({exp:de(Ee())});function Fi(e){try{let[,t]=e.split(`.`);return t?fe(Pi,JSON.parse(Buffer.from(t,`base64url`).toString())):void 0}catch{return}}const W=typeof __SENTRY_DEBUG__>`u`||__SENTRY_DEBUG__,G=globalThis,Ii=`10.42.0`;function Li(){return Ri(G),G}function Ri(e){let t=e.__SENTRY__=e.__SENTRY__||{};return t.version=t.version||Ii,t[Ii]=t[Ii]||{}}function zi(e,t,n=G){let r=n.__SENTRY__=n.__SENTRY__||{},i=r[Ii]=r[Ii]||{};return i[e]||(i[e]=t())}const Bi=[`debug`,`info`,`warn`,`error`,`log`,`assert`,`trace`],Vi={};function Hi(e){if(!(`console`in G))return e();let t=G.console,n={},r=Object.keys(Vi);r.forEach(e=>{let r=Vi[e];n[e]=t[e],t[e]=r});try{return e()}finally{r.forEach(e=>{t[e]=n[e]})}}function Ui(){Xi().enabled=!0}function Wi(){Xi().enabled=!1}function Gi(){return Xi().enabled}function Ki(...e){Yi(`log`,...e)}function qi(...e){Yi(`warn`,...e)}function Ji(...e){Yi(`error`,...e)}function Yi(e,...t){W&&Gi()&&Hi(()=>{G.console[e](`Sentry Logger [${e}]:`,...t)})}function Xi(){return W?zi(`loggerSettings`,()=>({enabled:!1})):{enabled:!1}}const K={enable:Ui,disable:Wi,isEnabled:Gi,log:Ki,warn:qi,error:Ji},Zi=/\(error: (.*)\)/,Qi=/captureMessage|captureException/;function $i(...e){let t=e.sort((e,t)=>e[0]-t[0]).map(e=>e[1]);return(e,n=0,r=0)=>{let i=[],a=e.split(`
324
- `);for(let e=n;e<a.length;e++){let n=a[e];n.length>1024&&(n=n.slice(0,1024));let o=Zi.test(n)?n.replace(Zi,`$1`):n;if(!o.match(/\S*Error: /)){for(let e of t){let t=e(o);if(t){i.push(t);break}}if(i.length>=50+r)break}}return ta(i.slice(r))}}function ea(e){return Array.isArray(e)?$i(...e):e}function ta(e){if(!e.length)return[];let t=Array.from(e);return/sentryWrapped/.test(na(t).function||``)&&t.pop(),t.reverse(),Qi.test(na(t).function||``)&&(t.pop(),Qi.test(na(t).function||``)&&t.pop()),t.slice(0,50).map(e=>({...e,filename:e.filename||na(t).filename,function:e.function||`?`}))}function na(e){return e[e.length-1]||{}}const ra=`<anonymous>`;function ia(e){try{return!e||typeof e!=`function`?ra:e.name||ra}catch{return ra}}function aa(e){return`__v_isVNode`in e&&e.__v_isVNode?`[VueVNode]`:`[VueViewModel]`}function oa(e){let t=e?.startsWith(`file://`)?e.slice(7):e;return t?.match(/\/[A-Z]:/)&&(t=t.slice(1)),t}const sa={},ca={};function la(e,t){sa[e]=sa[e]||[],sa[e].push(t)}function ua(e,t){if(!ca[e]){ca[e]=!0;try{t()}catch(t){W&&K.error(`Error while instrumenting ${e}`,t)}}}function da(e,t){let n=e&&sa[e];if(n)for(let r of n)try{r(t)}catch(t){W&&K.error(`Error while triggering instrumentation handler.\nType: ${e}\nName: ${ia(r)}\nError:`,t)}}let fa=null;function pa(e){let t=`error`;la(t,e),ua(t,ma)}function ma(){fa=G.onerror,G.onerror=function(e,t,n,r,i){return da(`error`,{column:r,error:i,line:n,msg:e,url:t}),fa?fa.apply(this,arguments):!1},G.onerror.__SENTRY_INSTRUMENTED__=!0}let ha=null;function ga(e){let t=`unhandledrejection`;la(t,e),ua(t,_a)}function _a(){ha=G.onunhandledrejection,G.onunhandledrejection=function(e){return da(`unhandledrejection`,e),ha?ha.apply(this,arguments):!0},G.onunhandledrejection.__SENTRY_INSTRUMENTED__=!0}const va=Object.prototype.toString;function ya(e){switch(va.call(e)){case`[object Error]`:case`[object Exception]`:case`[object DOMException]`:case`[object WebAssembly.Exception]`:return!0;default:return ja(e,Error)}}function ba(e,t){return va.call(e)===`[object ${t}]`}function xa(e){return ba(e,`ErrorEvent`)}function Sa(e){return ba(e,`String`)}function Ca(e){return typeof e==`object`&&!!e&&`__sentry_template_string__`in e&&`__sentry_template_values__`in e}function wa(e){return e===null||Ca(e)||typeof e!=`object`&&typeof e!=`function`}function Ta(e){return ba(e,`Object`)}function Ea(e){return typeof Event<`u`&&ja(e,Event)}function Da(e){return typeof Element<`u`&&ja(e,Element)}function Oa(e){return ba(e,`RegExp`)}function ka(e){return!!(e?.then&&typeof e.then==`function`)}function Aa(e){return Ta(e)&&`nativeEvent`in e&&`preventDefault`in e&&`stopPropagation`in e}function ja(e,t){try{return e instanceof t}catch{return!1}}function Ma(e){return!!(typeof e==`object`&&e&&(e.__isVue||e._isVue||e.__v_isVNode))}const Na=G;function Pa(e,t={}){if(!e)return`<unknown>`;try{let n=e,r=[],i=0,a=0,o,s=Array.isArray(t)?t:t.keyAttrs,c=!Array.isArray(t)&&t.maxStringLength||80;for(;n&&i++<5&&(o=Fa(n,s),!(o===`html`||i>1&&a+r.length*3+o.length>=c));)r.push(o),a+=o.length,n=n.parentNode;return r.reverse().join(` > `)}catch{return`<unknown>`}}function Fa(e,t){let n=e,r=[];if(!n?.tagName)return``;if(Na.HTMLElement&&n instanceof HTMLElement&&n.dataset){if(n.dataset.sentryComponent)return n.dataset.sentryComponent;if(n.dataset.sentryElement)return n.dataset.sentryElement}r.push(n.tagName.toLowerCase());let i=t?.length?t.filter(e=>n.getAttribute(e)).map(e=>[e,n.getAttribute(e)]):null;if(i?.length)i.forEach(e=>{r.push(`[${e[0]}="${e[1]}"]`)});else{n.id&&r.push(`#${n.id}`);let e=n.className;if(e&&Sa(e)){let t=e.split(/\s+/);for(let e of t)r.push(`.${e}`)}}for(let e of[`aria-label`,`type`,`name`,`title`,`alt`]){let t=n.getAttribute(e);t&&r.push(`[${e}="${t}"]`)}return r.join(``)}function Ia(e,t,n){if(!(t in e))return;let r=e[t];if(typeof r!=`function`)return;let i=n(r);typeof i==`function`&&Ra(i,r);try{e[t]=i}catch{W&&K.log(`Failed to replace method "${t}" in object`,e)}}function La(e,t,n){try{Object.defineProperty(e,t,{value:n,writable:!0,configurable:!0})}catch{W&&K.log(`Failed to add non-enumerable property "${t}" to object`,e)}}function Ra(e,t){try{e.prototype=t.prototype=t.prototype||{},La(e,`__sentry_original__`,t)}catch{}}function za(e){return e.__sentry_original__}function Ba(e){if(ya(e))return{message:e.message,name:e.name,stack:e.stack,...Ha(e)};if(Ea(e)){let t={type:e.type,target:Va(e.target),currentTarget:Va(e.currentTarget),...Ha(e)};return typeof CustomEvent<`u`&&ja(e,CustomEvent)&&(t.detail=e.detail),t}else return e}function Va(e){try{return Da(e)?Pa(e):Object.prototype.toString.call(e)}catch{return`<unknown>`}}function Ha(e){if(typeof e==`object`&&e){let t={};for(let n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t}else return{}}function Ua(e){let t=Object.keys(Ba(e));return t.sort(),t[0]?t.join(`, `):`[object has no keys]`}let Wa;function Ga(e){if(Wa!==void 0)return Wa?Wa(e):e();let t=Symbol.for(`__SENTRY_SAFE_RANDOM_ID_WRAPPER__`),n=G;return t in n&&typeof n[t]==`function`?(Wa=n[t],Wa(e)):(Wa=null,e())}function Ka(){return Ga(()=>Math.random())}function qa(){return Ga(()=>Date.now())}function Ja(e,t=0){return typeof e!=`string`||t===0||e.length<=t?e:`${e.slice(0,t)}...`}function Ya(e,t){let n=e,r=n.length;if(r<=150)return n;t>r&&(t=r);let i=Math.max(t-60,0);i<5&&(i=0);let a=Math.min(i+140,r);return a>r-5&&(a=r),a===r&&(i=Math.max(a-140,0)),n=n.slice(i,a),i>0&&(n=`'{snip} ${n}`),a<r&&(n+=` {snip}`),n}function Xa(e,t){if(!Array.isArray(e))return``;let n=[];for(let t=0;t<e.length;t++){let r=e[t];try{Ma(r)?n.push(aa(r)):n.push(String(r))}catch{n.push(`[value cannot be serialized]`)}}return n.join(t)}function Za(e,t,n=!1){return Sa(e)?Oa(t)?t.test(e):Sa(t)?n?e===t:e.includes(t):!1:!1}function Qa(e,t=[],n=!1){return t.some(t=>Za(e,t,n))}function $a(){let e=G;return e.crypto||e.msCrypto}let eo;function to(){return Ka()*16}function q(e=$a()){try{if(e?.randomUUID)return Ga(()=>e.randomUUID()).replace(/-/g,``)}catch{}return eo||=`10000000100040008000100000000000`,eo.replace(/[018]/g,e=>(e^(to()&15)>>e/4).toString(16))}function no(e){return e.exception?.values?.[0]}function ro(e){let{message:t,event_id:n}=e;if(t)return t;let r=no(e);return r?r.type&&r.value?`${r.type}: ${r.value}`:r.type||r.value||n||`<unknown>`:n||`<unknown>`}function io(e,t,n){let r=e.exception=e.exception||{},i=r.values=r.values||[],a=i[0]=i[0]||{};a.value||=t||``,a.type||=n||`Error`}function ao(e,t){let n=no(e);if(!n)return;let r={type:`generic`,handled:!0},i=n.mechanism;if(n.mechanism={...r,...i,...t},t&&`data`in t){let e={...i?.data,...t.data};n.mechanism.data=e}}const oo=/^(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/;function so(e){return parseInt(e||``,10)}function co(e){let t=e.match(oo)||[],n=so(t[1]),r=so(t[2]),i=so(t[3]);return{buildmetadata:t[5],major:isNaN(n)?void 0:n,minor:isNaN(r)?void 0:r,patch:isNaN(i)?void 0:i,prerelease:t[4]}}function lo(e){if(uo(e))return!0;try{La(e,`__sentry_captured__`,!0)}catch{}return!1}function uo(e){try{return e.__sentry_captured__}catch{}}const fo=1e3;function po(){return qa()/fo}function mo(){let{performance:e}=G;if(!e?.now||!e.timeOrigin)return po;let t=e.timeOrigin;return()=>(t+Ga(()=>e.now()))/fo}let ho;function go(){return(ho??=mo())()}function _o(e){let t=go(),n={sid:q(),init:!0,timestamp:t,started:t,duration:0,status:`ok`,errors:0,ignoreDuration:!1,toJSON:()=>bo(n)};return e&&vo(n,e),n}function vo(e,t={}){if(t.user&&(!e.ipAddress&&t.user.ip_address&&(e.ipAddress=t.user.ip_address),!e.did&&!t.did&&(e.did=t.user.id||t.user.email||t.user.username)),e.timestamp=t.timestamp||go(),t.abnormal_mechanism&&(e.abnormal_mechanism=t.abnormal_mechanism),t.ignoreDuration&&(e.ignoreDuration=t.ignoreDuration),t.sid&&(e.sid=t.sid.length===32?t.sid:q()),t.init!==void 0&&(e.init=t.init),!e.did&&t.did&&(e.did=`${t.did}`),typeof t.started==`number`&&(e.started=t.started),e.ignoreDuration)e.duration=void 0;else if(typeof t.duration==`number`)e.duration=t.duration;else{let t=e.timestamp-e.started;e.duration=t>=0?t:0}t.release&&(e.release=t.release),t.environment&&(e.environment=t.environment),!e.ipAddress&&t.ipAddress&&(e.ipAddress=t.ipAddress),!e.userAgent&&t.userAgent&&(e.userAgent=t.userAgent),typeof t.errors==`number`&&(e.errors=t.errors),t.status&&(e.status=t.status)}function yo(e,t){let n={};t?n={status:t}:e.status===`ok`&&(n={status:`exited`}),vo(e,n)}function bo(e){return{sid:`${e.sid}`,init:e.init,started:new Date(e.started*1e3).toISOString(),timestamp:new Date(e.timestamp*1e3).toISOString(),status:e.status,errors:e.errors,did:typeof e.did==`number`||typeof e.did==`string`?`${e.did}`:void 0,duration:e.duration,abnormal_mechanism:e.abnormal_mechanism,attrs:{release:e.release,environment:e.environment,ip_address:e.ipAddress,user_agent:e.userAgent}}}function xo(e,t,n=2){if(!t||typeof t!=`object`||n<=0)return t;if(e&&Object.keys(t).length===0)return e;let r={...e};for(let e in t)Object.prototype.hasOwnProperty.call(t,e)&&(r[e]=xo(r[e],t[e],n-1));return r}function So(){return q()}function Co(){return q().substring(16)}const wo=`_sentrySpan`;function To(e,t){t?La(e,wo,t):delete e[wo]}function Eo(e){return e[wo]}var Do=class e{constructor(){this._notifyingListeners=!1,this._scopeListeners=[],this._eventProcessors=[],this._breadcrumbs=[],this._attachments=[],this._user={},this._tags={},this._attributes={},this._extra={},this._contexts={},this._sdkProcessingMetadata={},this._propagationContext={traceId:So(),sampleRand:Ka()}}clone(){let t=new e;return t._breadcrumbs=[...this._breadcrumbs],t._tags={...this._tags},t._attributes={...this._attributes},t._extra={...this._extra},t._contexts={...this._contexts},this._contexts.flags&&(t._contexts.flags={values:[...this._contexts.flags.values]}),t._user=this._user,t._level=this._level,t._session=this._session,t._transactionName=this._transactionName,t._fingerprint=this._fingerprint,t._eventProcessors=[...this._eventProcessors],t._attachments=[...this._attachments],t._sdkProcessingMetadata={...this._sdkProcessingMetadata},t._propagationContext={...this._propagationContext},t._client=this._client,t._lastEventId=this._lastEventId,t._conversationId=this._conversationId,To(t,Eo(this)),t}setClient(e){this._client=e}setLastEventId(e){this._lastEventId=e}getClient(){return this._client}lastEventId(){return this._lastEventId}addScopeListener(e){this._scopeListeners.push(e)}addEventProcessor(e){return this._eventProcessors.push(e),this}setUser(e){return this._user=e||{email:void 0,id:void 0,ip_address:void 0,username:void 0},this._session&&vo(this._session,{user:e}),this._notifyScopeListeners(),this}getUser(){return this._user}setConversationId(e){return this._conversationId=e||void 0,this._notifyScopeListeners(),this}setTags(e){return this._tags={...this._tags,...e},this._notifyScopeListeners(),this}setTag(e,t){return this.setTags({[e]:t})}setAttributes(e){return this._attributes={...this._attributes,...e},this._notifyScopeListeners(),this}setAttribute(e,t){return this.setAttributes({[e]:t})}removeAttribute(e){return e in this._attributes&&(delete this._attributes[e],this._notifyScopeListeners()),this}setExtras(e){return this._extra={...this._extra,...e},this._notifyScopeListeners(),this}setExtra(e,t){return this._extra={...this._extra,[e]:t},this._notifyScopeListeners(),this}setFingerprint(e){return this._fingerprint=e,this._notifyScopeListeners(),this}setLevel(e){return this._level=e,this._notifyScopeListeners(),this}setTransactionName(e){return this._transactionName=e,this._notifyScopeListeners(),this}setContext(e,t){return t===null?delete this._contexts[e]:this._contexts[e]=t,this._notifyScopeListeners(),this}setSession(e){return e?this._session=e:delete this._session,this._notifyScopeListeners(),this}getSession(){return this._session}update(t){if(!t)return this;let n=typeof t==`function`?t(this):t,{tags:r,attributes:i,extra:a,user:o,contexts:s,level:c,fingerprint:l=[],propagationContext:u,conversationId:d}=(n instanceof e?n.getScopeData():Ta(n)?t:void 0)||{};return this._tags={...this._tags,...r},this._attributes={...this._attributes,...i},this._extra={...this._extra,...a},this._contexts={...this._contexts,...s},o&&Object.keys(o).length&&(this._user=o),c&&(this._level=c),l.length&&(this._fingerprint=l),u&&(this._propagationContext=u),d&&(this._conversationId=d),this}clear(){return this._breadcrumbs=[],this._tags={},this._attributes={},this._extra={},this._user={},this._contexts={},this._level=void 0,this._transactionName=void 0,this._fingerprint=void 0,this._session=void 0,this._conversationId=void 0,To(this,void 0),this._attachments=[],this.setPropagationContext({traceId:So(),sampleRand:Ka()}),this._notifyScopeListeners(),this}addBreadcrumb(e,t){let n=typeof t==`number`?t:100;if(n<=0)return this;let r={timestamp:po(),...e,message:e.message?Ja(e.message,2048):e.message};return this._breadcrumbs.push(r),this._breadcrumbs.length>n&&(this._breadcrumbs=this._breadcrumbs.slice(-n),this._client?.recordDroppedEvent(`buffer_overflow`,`log_item`)),this._notifyScopeListeners(),this}getLastBreadcrumb(){return this._breadcrumbs[this._breadcrumbs.length-1]}clearBreadcrumbs(){return this._breadcrumbs=[],this._notifyScopeListeners(),this}addAttachment(e){return this._attachments.push(e),this}clearAttachments(){return this._attachments=[],this}getScopeData(){return{breadcrumbs:this._breadcrumbs,attachments:this._attachments,contexts:this._contexts,tags:this._tags,attributes:this._attributes,extra:this._extra,user:this._user,level:this._level,fingerprint:this._fingerprint||[],eventProcessors:this._eventProcessors,propagationContext:this._propagationContext,sdkProcessingMetadata:this._sdkProcessingMetadata,transactionName:this._transactionName,span:Eo(this),conversationId:this._conversationId}}setSDKProcessingMetadata(e){return this._sdkProcessingMetadata=xo(this._sdkProcessingMetadata,e,2),this}setPropagationContext(e){return this._propagationContext=e,this}getPropagationContext(){return this._propagationContext}captureException(e,t){let n=t?.event_id||q();if(!this._client)return W&&K.warn(`No client configured on scope - will not capture exception!`),n;let r=Error(`Sentry syntheticException`);return this._client.captureException(e,{originalException:e,syntheticException:r,...t,event_id:n},this),n}captureMessage(e,t,n){let r=n?.event_id||q();if(!this._client)return W&&K.warn(`No client configured on scope - will not capture message!`),r;let i=n?.syntheticException??Error(e);return this._client.captureMessage(e,t,{originalException:e,syntheticException:i,...n,event_id:r},this),r}captureEvent(e,t){let n=e.event_id||t?.event_id||q();return this._client?(this._client.captureEvent(e,{...t,event_id:n},this),n):(W&&K.warn(`No client configured on scope - will not capture event!`),n)}_notifyScopeListeners(){this._notifyingListeners||=(this._notifyingListeners=!0,this._scopeListeners.forEach(e=>{e(this)}),!1)}};function Oo(){return zi(`defaultCurrentScope`,()=>new Do)}function ko(){return zi(`defaultIsolationScope`,()=>new Do)}var Ao=class{constructor(e,t){let n;n=e||new Do;let r;r=t||new Do,this._stack=[{scope:n}],this._isolationScope=r}withScope(e){let t=this._pushScope(),n;try{n=e(t)}catch(e){throw this._popScope(),e}return ka(n)?n.then(e=>(this._popScope(),e),e=>{throw this._popScope(),e}):(this._popScope(),n)}getClient(){return this.getStackTop().client}getScope(){return this.getStackTop().scope}getIsolationScope(){return this._isolationScope}getStackTop(){return this._stack[this._stack.length-1]}_pushScope(){let e=this.getScope().clone();return this._stack.push({client:this.getClient(),scope:e}),e}_popScope(){return this._stack.length<=1?!1:!!this._stack.pop()}};function jo(){let e=Ri(Li());return e.stack=e.stack||new Ao(Oo(),ko())}function Mo(e){return jo().withScope(e)}function No(e,t){let n=jo();return n.withScope(()=>(n.getStackTop().scope=e,t(e)))}function Po(e){return jo().withScope(()=>e(jo().getIsolationScope()))}function Fo(){return{withIsolationScope:Po,withScope:Mo,withSetScope:No,withSetIsolationScope:(e,t)=>Po(t),getCurrentScope:()=>jo().getScope(),getIsolationScope:()=>jo().getIsolationScope()}}function Io(e){let t=Ri(Li());t.acs=e}function Lo(e){let t=Ri(e);return t.acs?t.acs:Fo()}function J(){return Lo(Li()).getCurrentScope()}function Y(){return Lo(Li()).getIsolationScope()}function Ro(){return zi(`globalScope`,()=>new Do)}function zo(...e){let t=Lo(Li());if(e.length===2){let[n,r]=e;return n?t.withSetScope(n,r):t.withScope(r)}return t.withScope(e[0])}function Bo(...e){let t=Lo(Li());if(e.length===2){let[n,r]=e;return n?t.withSetIsolationScope(n,r):t.withIsolationScope(r)}return t.withIsolationScope(e[0])}function X(){return J().getClient()}function Vo(e){let{traceId:t,parentSpanId:n,propagationSpanId:r}=e.getPropagationContext(),i={trace_id:t,span_id:r||Co()};return n&&(i.parent_span_id=n),i}const Ho=`sentry.profile_id`,Uo=`sentry.exclusive_time`;function Wo(e){if(e){if(typeof e==`object`&&`deref`in e&&typeof e.deref==`function`)try{return e.deref()}catch{return}return e}}function Go(e){let t=e;return{scope:t._sentryScope,isolationScope:Wo(t._sentryIsolationScope)}}const Ko=/^sentry-/;function qo(e){let t=Yo(e);if(!t)return;let n=Object.entries(t).reduce((e,[t,n])=>{if(t.match(Ko)){let r=t.slice(7);e[r]=n}return e},{});if(Object.keys(n).length>0)return n}function Jo(e){if(e)return Zo(Object.entries(e).reduce((e,[t,n])=>(n&&(e[`sentry-${t}`]=n),e),{}))}function Yo(e){if(!(!e||!Sa(e)&&!Array.isArray(e)))return Array.isArray(e)?e.reduce((e,t)=>{let n=Xo(t);return Object.entries(n).forEach(([t,n])=>{e[t]=n}),e},{}):Xo(e)}function Xo(e){return e.split(`,`).map(e=>{let t=e.indexOf(`=`);return t===-1?[]:[e.slice(0,t),e.slice(t+1)].map(e=>{try{return decodeURIComponent(e.trim())}catch{return}})}).reduce((e,[t,n])=>(t&&n&&(e[t]=n),e),{})}function Zo(e){if(Object.keys(e).length!==0)return Object.entries(e).reduce((e,[t,n],r)=>{let i=`${encodeURIComponent(t)}=${encodeURIComponent(n)}`,a=r===0?i:`${e},${i}`;return a.length>8192?(W&&K.warn(`Not adding key: ${t} with val: ${n} to baggage header due to exceeding baggage size limits.`),e):a},``)}const Qo=/^o(\d+)\./,$o=/^(?:(\w+):)\/\/(?:(\w+)(?::(\w+)?)?@)((?:\[[:.%\w]+\]|[\w.-]+))(?::(\d+))?\/(.+)/;function es(e){return e===`http`||e===`https`}function ts(e,t=!1){let{host:n,path:r,pass:i,port:a,projectId:o,protocol:s,publicKey:c}=e;return`${s}://${c}${t&&i?`:${i}`:``}@${n}${a?`:${a}`:``}/${r&&`${r}/`}${o}`}function ns(e){let t=$o.exec(e);if(!t){Hi(()=>{console.error(`Invalid Sentry Dsn: ${e}`)});return}let[n,r,i=``,a=``,o=``,s=``]=t.slice(1),c=``,l=s,u=l.split(`/`);if(u.length>1&&(c=u.slice(0,-1).join(`/`),l=u.pop()),l){let e=l.match(/^\d+/);e&&(l=e[0])}return rs({host:a,pass:i,path:c,projectId:l,port:o,protocol:n,publicKey:r})}function rs(e){return{protocol:e.protocol,publicKey:e.publicKey||``,pass:e.pass||``,host:e.host,port:e.port||``,path:e.path||``,projectId:e.projectId}}function is(e){if(!W)return!0;let{port:t,projectId:n,protocol:r}=e;return[`protocol`,`publicKey`,`host`,`projectId`].find(t=>e[t]?!1:(K.error(`Invalid Sentry Dsn: ${t} missing`),!0))?!1:n.match(/^\d+$/)?es(r)?t&&isNaN(parseInt(t,10))?(K.error(`Invalid Sentry Dsn: Invalid port ${t}`),!1):!0:(K.error(`Invalid Sentry Dsn: Invalid protocol ${r}`),!1):(K.error(`Invalid Sentry Dsn: Invalid projectId ${n}`),!1)}function as(e){return e.match(Qo)?.[1]}function os(e){let t=e.getOptions(),{host:n}=e.getDsn()||{},r;return t.orgId?r=String(t.orgId):n&&(r=as(n)),r}function ss(e){let t=typeof e==`string`?ns(e):rs(e);if(!(!t||!is(t)))return t}function cs(e){if(typeof e==`boolean`)return Number(e);let t=typeof e==`string`?parseFloat(e):e;if(!(typeof t!=`number`||isNaN(t)||t<0||t>1))return t}const ls=RegExp(`^[ \\t]*([0-9a-f]{32})?-?([0-9a-f]{16})?-?([01])?[ \\t]*$`);function us(e){if(!e)return;let t=e.match(ls);if(!t)return;let n;return t[3]===`1`?n=!0:t[3]===`0`&&(n=!1),{traceId:t[1],parentSampled:n,parentSpanId:t[2]}}function ds(e,t){let n=us(e),r=qo(t);if(!n?.traceId)return{traceId:So(),sampleRand:Ka()};let i=ms(n,r);r&&(r.sample_rand=i.toString());let{traceId:a,parentSpanId:o,parentSampled:s}=n;return{traceId:a,parentSpanId:o,sampled:s,dsc:r||{},sampleRand:i}}function fs(e=So(),t=Co(),n){let r=``;return n!==void 0&&(r=n?`-1`:`-0`),`${e}-${t}${r}`}function ps(e=So(),t=Co(),n){return`00-${e}-${t}-${n?`01`:`00`}`}function ms(e,t){let n=cs(t?.sample_rand);if(n!==void 0)return n;let r=cs(t?.sample_rate);return r&&e?.parentSampled!==void 0?e.parentSampled?Ka()*r:r+Ka()*(1-r):Ka()}function hs(e,t){let n=os(e);return t&&n&&t!==n?(K.log(`Won't continue trace because org IDs don't match (incoming baggage: ${t}, SDK options: ${n})`),!1):e.getOptions().strictTraceContinuation&&(t&&!n||!t&&n)?(K.log(`Starting a new trace because strict trace continuation is enabled but one org ID is missing (incoming baggage: ${t}, Sentry client: ${n})`),!1):!0}let gs=!1;function _s(e){let{spanId:t,traceId:n,isRemote:r}=e.spanContext(),i=r?t:Cs(e).parent_span_id,a=Go(e).scope;return{parent_span_id:i,span_id:r?a?.getPropagationContext().propagationSpanId||Co():t,trace_id:n}}function vs(e){let{traceId:t,spanId:n}=e.spanContext();return fs(t,n,Es(e))}function ys(e){let{traceId:t,spanId:n}=e.spanContext();return ps(t,n,Es(e))}function bs(e){if(e&&e.length>0)return e.map(({context:{spanId:e,traceId:t,traceFlags:n,...r},attributes:i})=>({span_id:e,trace_id:t,sampled:n===1,attributes:i,...r}))}function xs(e){return typeof e==`number`?Ss(e):Array.isArray(e)?e[0]+e[1]/1e9:e instanceof Date?Ss(e.getTime()):go()}function Ss(e){return e>9999999999?e/1e3:e}function Cs(e){if(Ts(e))return e.getSpanJSON();let{spanId:t,traceId:n}=e.spanContext();if(ws(e)){let{attributes:r,startTime:i,name:a,endTime:o,status:s,links:c}=e;return{span_id:t,trace_id:n,data:r,description:a,parent_span_id:`parentSpanId`in e?e.parentSpanId:`parentSpanContext`in e?e.parentSpanContext?.spanId:void 0,start_timestamp:xs(i),timestamp:xs(o)||void 0,status:Ds(s),op:r[`sentry.op`],origin:r[`sentry.origin`],links:bs(c)}}return{span_id:t,trace_id:n,start_timestamp:0,data:{}}}function ws(e){let t=e;return!!t.attributes&&!!t.startTime&&!!t.name&&!!t.endTime&&!!t.status}function Ts(e){return typeof e.getSpanJSON==`function`}function Es(e){let{traceFlags:t}=e.spanContext();return t===1}function Ds(e){if(!(!e||e.code===0))return e.code===1?`ok`:e.message||`internal_error`}function Os(e){return e._sentryRootSpan||e}function ks(){let e=Lo(Li());return e.getActiveSpan?e.getActiveSpan():Eo(J())}function As(){gs||=(Hi(()=>{console.warn("[Sentry] Returning null from `beforeSendSpan` is disallowed. To drop certain spans, configure the respective integrations directly or use `ignoreSpans`.")}),!0)}let js=!1;function Ms(){if(js)return;function e(){let e=ks(),t=e&&Os(e);if(t){let e=`internal_error`;W&&K.log(`[Tracing] Root span: ${e} -> Global error occurred`),t.setStatus({code:2,message:e})}}e.tag=`sentry_tracingErrorCallback`,js=!0,pa(e),ga(e)}function Ns(e){if(typeof __SENTRY_TRACING__==`boolean`&&!__SENTRY_TRACING__)return!1;let t=e||X()?.getOptions();return!!t&&(t.tracesSampleRate!=null||!!t.tracesSampler)}function Ps(e){K.log(`Ignoring span ${e.op} - ${e.description} because it matches \`ignoreSpans\`.`)}function Fs(e,t){if(!t?.length||!e.description)return!1;for(let n of t){if(Ls(n)){if(Za(e.description,n))return W&&Ps(e),!0;continue}if(!n.name&&!n.op)continue;let t=n.name?Za(e.description,n.name):!0,r=n.op?e.op&&Za(e.op,n.op):!0;if(t&&r)return W&&Ps(e),!0}return!1}function Is(e,t){let n=t.parent_span_id,r=t.span_id;if(n)for(let t of e)t.parent_span_id===r&&(t.parent_span_id=n)}function Ls(e){return typeof e==`string`||e instanceof RegExp}const Rs=`production`;function zs(e,t){let n=t.getOptions(),{publicKey:r}=t.getDsn()||{},i={environment:n.environment||Rs,release:n.release,public_key:r,trace_id:e,org_id:os(t)};return t.emit(`createDsc`,i),i}function Bs(e,t){let n=t.getPropagationContext();return n.dsc||zs(n.traceId,e)}function Vs(e){let t=X();if(!t)return{};let n=Os(e),r=Cs(n),i=r.data,a=n.spanContext().traceState,o=a?.get(`sentry.sample_rate`)??i[`sentry.sample_rate`]??i[`sentry.previous_trace_sample_rate`];function s(e){return(typeof o==`number`||typeof o==`string`)&&(e.sample_rate=`${o}`),e}let c=n._frozenDsc;if(c)return s(c);let l=a?.get(`sentry.dsc`),u=l&&qo(l);if(u)return s(u);let d=zs(e.spanContext().traceId,t),f=i[`sentry.source`],p=r.description;return f!==`url`&&p&&(d.transaction=p),Ns()&&(d.sampled=String(Es(n)),d.sample_rand=a?.get(`sentry.sample_rand`)??Go(n).scope?.getPropagationContext().sampleRand.toString()),s(d),t.emit(`createDsc`,d,n),d}function Hs(e,t=100,n=1/0){try{return Ws(``,e,t,n)}catch(e){return{ERROR:`**non-serializable** (${e})`}}}function Us(e,t=3,n=100*1024){let r=Hs(e,t);return Js(r)>n?Us(e,t-1,n):r}function Ws(e,t,n=1/0,r=1/0,i=Ys()){let[a,o]=i;if(t==null||[`boolean`,`string`].includes(typeof t)||typeof t==`number`&&Number.isFinite(t))return t;let s=Gs(e,t);if(!s.startsWith(`[object `))return s;if(t.__sentry_skip_normalization__)return t;let c=typeof t.__sentry_override_normalization_depth__==`number`?t.__sentry_override_normalization_depth__:n;if(c===0)return s.replace(`object `,``);if(a(t))return`[Circular ~]`;let l=t;if(l&&typeof l.toJSON==`function`)try{return Ws(``,l.toJSON(),c-1,r,i)}catch{}let u=Array.isArray(t)?[]:{},d=0,f=Ba(t);for(let e in f){if(!Object.prototype.hasOwnProperty.call(f,e))continue;if(d>=r){u[e]=`[MaxProperties ~]`;break}let t=f[e];u[e]=Ws(e,t,c-1,r,i),d++}return o(t),u}function Gs(e,t){try{if(e===`domain`&&t&&typeof t==`object`&&t._events)return`[Domain]`;if(e===`domainEmitter`)return`[DomainEmitter]`;if(typeof global<`u`&&t===global)return`[Global]`;if(typeof window<`u`&&t===window)return`[Window]`;if(typeof document<`u`&&t===document)return`[Document]`;if(Ma(t))return aa(t);if(Aa(t))return`[SyntheticEvent]`;if(typeof t==`number`&&!Number.isFinite(t))return`[${t}]`;if(typeof t==`function`)return`[Function: ${ia(t)}]`;if(typeof t==`symbol`)return`[${String(t)}]`;if(typeof t==`bigint`)return`[BigInt: ${String(t)}]`;let n=Ks(t);return/^HTML(\w*)Element$/.test(n)?`[HTMLElement: ${n}]`:`[object ${n}]`}catch(e){return`**non-serializable** (${e})`}}function Ks(e){let t=Object.getPrototypeOf(e);return t?.constructor?t.constructor.name:`null prototype`}function qs(e){return~-encodeURI(e).split(/%..|./).length}function Js(e){return qs(JSON.stringify(e))}function Ys(){let e=new WeakSet;function t(t){return e.has(t)?!0:(e.add(t),!1)}function n(t){e.delete(t)}return[t,n]}function Xs(e,t=[]){return[e,t]}function Zs(e,t){let[n,r]=e;return[n,[...r,t]]}function Qs(e,t){let n=e[1];for(let e of n){let n=e[0].type;if(t(e,n))return!0}return!1}function $s(e,t){return Qs(e,(e,n)=>t.includes(n))}function ec(e){let t=Ri(G);return t.encodePolyfill?t.encodePolyfill(e):new TextEncoder().encode(e)}function tc(e){let[t,n]=e,r=JSON.stringify(t);function i(e){typeof r==`string`?r=typeof e==`string`?r+e:[ec(r),e]:r.push(typeof e==`string`?ec(e):e)}for(let e of n){let[t,n]=e;if(i(`\n${JSON.stringify(t)}\n`),typeof n==`string`||n instanceof Uint8Array)i(n);else{let e;try{e=JSON.stringify(n)}catch{e=JSON.stringify(Hs(n))}i(e)}}return typeof r==`string`?r:nc(r)}function nc(e){let t=e.reduce((e,t)=>e+t.length,0),n=new Uint8Array(t),r=0;for(let t of e)n.set(t,r),r+=t.length;return n}function rc(e){let t=typeof e.data==`string`?ec(e.data):e.data;return[{type:`attachment`,length:t.length,filename:e.filename,content_type:e.contentType,attachment_type:e.attachmentType},t]}const ic={session:`session`,sessions:`session`,attachment:`attachment`,transaction:`transaction`,event:`error`,client_report:`internal`,user_report:`default`,profile:`profile`,profile_chunk:`profile`,replay_event:`replay`,replay_recording:`replay`,check_in:`monitor`,feedback:`feedback`,span:`span`,raw_security:`security`,log:`log_item`,metric:`metric`,trace_metric:`metric`};function ac(e){return ic[e]}function oc(e){if(!e?.sdk)return;let{name:t,version:n}=e.sdk;return{name:t,version:n}}function sc(e,t,n,r){let i=e.sdkProcessingMetadata?.dynamicSamplingContext;return{event_id:e.event_id,sent_at:new Date().toISOString(),...t&&{sdk:t},...!!n&&r&&{dsn:ts(r)},...i&&{trace:i}}}function cc(e,t){if(!t)return e;let n=e.sdk||{};return e.sdk={...n,name:n.name||t.name,version:n.version||t.version,integrations:[...e.sdk?.integrations||[],...t.integrations||[]],packages:[...e.sdk?.packages||[],...t.packages||[]],settings:e.sdk?.settings||t.settings?{...e.sdk?.settings,...t.settings}:void 0},e}function lc(e,t,n,r){let i=oc(n);return Xs({sent_at:new Date().toISOString(),...i&&{sdk:i},...!!r&&t&&{dsn:ts(t)}},[`aggregates`in e?[{type:`sessions`},e]:[{type:`session`},e.toJSON()]])}function uc(e,t,n,r){let i=oc(n),a=e.type&&e.type!==`replay_event`?e.type:`event`;cc(e,n?.sdk);let o=sc(e,i,r,t);return delete e.sdkProcessingMetadata,Xs(o,[[{type:a},e]])}const dc=`__SENTRY_SUPPRESS_TRACING__`,fc=(e,t)=>{let n=Lo(Li());if(n.continueTrace)return n.continueTrace(e,t);let{sentryTrace:r,baggage:i}=e,a=X(),o=qo(i);return a&&!hs(a,o?.org_id)?hc(t):zo(e=>{let n=ds(r,i);return e.setPropagationContext(n),To(e,void 0),t()})};function pc(e,t){let n=gc();return n.withActiveSpan?n.withActiveSpan(e,t):zo(n=>(To(n,e||void 0),t(n)))}function mc(e){let t=gc();return t.suppressTracing?t.suppressTracing(e):zo(t=>{t.setSDKProcessingMetadata({[dc]:!0});let n=e();return t.setSDKProcessingMetadata({[dc]:void 0}),n})}function hc(e){return zo(t=>(t.setPropagationContext({traceId:So(),sampleRand:Ka()}),W&&K.log(`Starting a new trace with id ${t.getPropagationContext().traceId}`),pc(null,e)))}function gc(){return Lo(Li())}function _c(e){return new yc(t=>{t(e)})}function vc(e){return new yc((t,n)=>{n(e)})}var yc=class e{constructor(e){this._state=0,this._handlers=[],this._runExecutor(e)}then(t,n){return new e((e,r)=>{this._handlers.push([!1,n=>{if(!t)e(n);else try{e(t(n))}catch(e){r(e)}},t=>{if(!n)r(t);else try{e(n(t))}catch(e){r(e)}}]),this._executeHandlers()})}catch(e){return this.then(e=>e,e)}finally(t){return new e((e,n)=>{let r,i;return this.then(e=>{i=!1,r=e,t&&t()},e=>{i=!0,r=e,t&&t()}).then(()=>{if(i){n(r);return}e(r)})})}_executeHandlers(){if(this._state===0)return;let e=this._handlers.slice();this._handlers=[],e.forEach(e=>{e[0]||=(this._state===1&&e[1](this._value),this._state===2&&e[2](this._value),!0)})}_runExecutor(e){let t=(e,t)=>{if(this._state===0){if(ka(t)){t.then(n,r);return}this._state=e,this._value=t,this._executeHandlers()}},n=e=>{t(1,e)},r=e=>{t(2,e)};try{e(n,r)}catch(e){r(e)}}};function bc(e,t,n,r=0){try{let i=xc(t,n,e,r);return ka(i)?i:_c(i)}catch(e){return vc(e)}}function xc(e,t,n,r){let i=n[r];if(!e||!i)return e;let a=i({...e},t);return W&&a===null&&K.log(`Event processor "${i.id||`?`}" dropped event`),ka(a)?a.then(e=>xc(e,t,n,r+1)):xc(a,t,n,r+1)}let Sc,Cc,wc,Tc;function Ec(e){let t=G._sentryDebugIds,n=G._debugIds;if(!t&&!n)return{};let r=t?Object.keys(t):[],i=n?Object.keys(n):[];if(Tc&&r.length===Cc&&i.length===wc)return Tc;Cc=r.length,wc=i.length,Tc={},Sc||={};let a=(t,n)=>{for(let r of t){let t=n[r],i=Sc?.[r];if(i&&Tc&&t)Tc[i[0]]=t,Sc&&(Sc[r]=[i[0],t]);else if(t){let n=e(r);for(let e=n.length-1;e>=0;e--){let i=n[e]?.filename;if(i&&Tc&&Sc){Tc[i]=t,Sc[r]=[i,t];break}}}}};return t&&a(r,t),n&&a(i,n),Tc}function Dc(e,t){let{fingerprint:n,span:r,breadcrumbs:i,sdkProcessingMetadata:a}=t;jc(e,t),r&&Pc(e,r),Fc(e,n),Mc(e,i),Nc(e,a)}function Oc(e,t){let{extra:n,tags:r,attributes:i,user:a,contexts:o,level:s,sdkProcessingMetadata:c,breadcrumbs:l,fingerprint:u,eventProcessors:d,attachments:f,propagationContext:p,transactionName:m,span:h}=t;kc(e,`extra`,n),kc(e,`tags`,r),kc(e,`attributes`,i),kc(e,`user`,a),kc(e,`contexts`,o),e.sdkProcessingMetadata=xo(e.sdkProcessingMetadata,c,2),s&&(e.level=s),m&&(e.transactionName=m),h&&(e.span=h),l.length&&(e.breadcrumbs=[...e.breadcrumbs,...l]),u.length&&(e.fingerprint=[...e.fingerprint,...u]),d.length&&(e.eventProcessors=[...e.eventProcessors,...d]),f.length&&(e.attachments=[...e.attachments,...f]),e.propagationContext={...e.propagationContext,...p}}function kc(e,t,n){e[t]=xo(e[t],n,1)}function Ac(e,t){let n=Ro().getScopeData();return e&&Oc(n,e.getScopeData()),t&&Oc(n,t.getScopeData()),n}function jc(e,t){let{extra:n,tags:r,user:i,contexts:a,level:o,transactionName:s}=t;Object.keys(n).length&&(e.extra={...n,...e.extra}),Object.keys(r).length&&(e.tags={...r,...e.tags}),Object.keys(i).length&&(e.user={...i,...e.user}),Object.keys(a).length&&(e.contexts={...a,...e.contexts}),o&&(e.level=o),s&&e.type!==`transaction`&&(e.transaction=s)}function Mc(e,t){let n=[...e.breadcrumbs||[],...t];e.breadcrumbs=n.length?n:void 0}function Nc(e,t){e.sdkProcessingMetadata={...e.sdkProcessingMetadata,...t}}function Pc(e,t){e.contexts={trace:_s(t),...e.contexts},e.sdkProcessingMetadata={dynamicSamplingContext:Vs(t),...e.sdkProcessingMetadata};let n=Cs(Os(t)).description;n&&!e.transaction&&e.type===`transaction`&&(e.transaction=n)}function Fc(e,t){e.fingerprint=e.fingerprint?Array.isArray(e.fingerprint)?e.fingerprint:[e.fingerprint]:[],t&&(e.fingerprint=e.fingerprint.concat(t)),e.fingerprint.length||delete e.fingerprint}function Ic(e,t,n,r,i,a){let{normalizeDepth:o=3,normalizeMaxBreadth:s=1e3}=e,c={...t,event_id:t.event_id||n.event_id||q(),timestamp:t.timestamp||po()},l=n.integrations||e.integrations.map(e=>e.name);Lc(c,e),Bc(c,l),i&&i.emit(`applyFrameMetadata`,t),t.type===void 0&&Rc(c,e.stackParser);let u=Hc(r,n.captureContext);n.mechanism&&ao(c,n.mechanism);let d=i?i.getEventProcessors():[],f=Ac(a,u),p=[...n.attachments||[],...f.attachments];p.length&&(n.attachments=p),Dc(c,f);let m=[...d,...f.eventProcessors];return(n.data&&n.data.__sentry__===!0?_c(c):bc(m,c,n)).then(e=>(e&&zc(e),typeof o==`number`&&o>0?Vc(e,o,s):e))}function Lc(e,t){let{environment:n,release:r,dist:i,maxValueLength:a}=t;e.environment=e.environment||n||Rs,!e.release&&r&&(e.release=r),!e.dist&&i&&(e.dist=i);let o=e.request;o?.url&&a&&(o.url=Ja(o.url,a)),a&&e.exception?.values?.forEach(e=>{e.value&&=Ja(e.value,a)})}function Rc(e,t){let n=Ec(t);e.exception?.values?.forEach(e=>{e.stacktrace?.frames?.forEach(e=>{e.filename&&(e.debug_id=n[e.filename])})})}function zc(e){let t={};if(e.exception?.values?.forEach(e=>{e.stacktrace?.frames?.forEach(e=>{e.debug_id&&(e.abs_path?t[e.abs_path]=e.debug_id:e.filename&&(t[e.filename]=e.debug_id),delete e.debug_id)})}),Object.keys(t).length===0)return;e.debug_meta=e.debug_meta||{},e.debug_meta.images=e.debug_meta.images||[];let n=e.debug_meta.images;Object.entries(t).forEach(([e,t])=>{n.push({type:`sourcemap`,code_file:e,debug_id:t})})}function Bc(e,t){t.length>0&&(e.sdk=e.sdk||{},e.sdk.integrations=[...e.sdk.integrations||[],...t])}function Vc(e,t,n){if(!e)return null;let r={...e,...e.breadcrumbs&&{breadcrumbs:e.breadcrumbs.map(e=>({...e,...e.data&&{data:Hs(e.data,t,n)}}))},...e.user&&{user:Hs(e.user,t,n)},...e.contexts&&{contexts:Hs(e.contexts,t,n)},...e.extra&&{extra:Hs(e.extra,t,n)}};return e.contexts?.trace&&r.contexts&&(r.contexts.trace=e.contexts.trace,e.contexts.trace.data&&(r.contexts.trace.data=Hs(e.contexts.trace.data,t,n))),e.spans&&(r.spans=e.spans.map(e=>({...e,...e.data&&{data:Hs(e.data,t,n)}}))),e.contexts?.flags&&r.contexts&&(r.contexts.flags=Hs(e.contexts.flags,3,n)),r}function Hc(e,t){if(!t)return e;let n=e?e.clone():new Do;return n.update(t),n}function Uc(e){if(e)return Wc(e)||Kc(e)?{captureContext:e}:e}function Wc(e){return e instanceof Do||typeof e==`function`}const Gc=[`user`,`level`,`extra`,`contexts`,`tags`,`fingerprint`,`propagationContext`];function Kc(e){return Object.keys(e).some(e=>Gc.includes(e))}function qc(e,t){return J().captureException(e,Uc(t))}function Jc(e,t){Y().setContext(e,t)}function Yc(e,t){Y().setTag(e,t)}function Xc(e){Y().setUser(e)}async function Zc(e){let t=X();return t?t.flush(e):(W&&K.warn(`Cannot flush events. No client defined.`),Promise.resolve(!1))}function Qc(){let e=X();return e?.getOptions().enabled!==!1&&!!e?.getTransport()}function $c(e){let t=Y(),{user:n}=Ac(t,J()),{userAgent:r}=G.navigator||{},i=_o({user:n,...r&&{userAgent:r},...e}),a=t.getSession();return a?.status===`ok`&&vo(a,{status:`exited`}),el(),t.setSession(i),i}function el(){let e=Y(),t=J().getSession()||e.getSession();t&&yo(t),tl(),e.setSession()}function tl(){let e=Y(),t=X(),n=e.getSession();n&&t&&t.captureSession(n)}function nl(e){let t=e.protocol?`${e.protocol}:`:``,n=e.port?`:${e.port}`:``;return`${t}//${e.host}${n}${e.path?`/${e.path}`:``}/api/`}function rl(e){return`${nl(e)}${e.projectId}/envelope/`}function il(e,t){let n={sentry_version:`7`};return e.publicKey&&(n.sentry_key=e.publicKey),t&&(n.sentry_client=`${t.name}/${t.version}`),new URLSearchParams(n).toString()}function al(e,t,n){return t||`${rl(e)}?${il(e,n)}`}const ol=[];function sl(e){let t={};return e.forEach(e=>{let{name:n}=e,r=t[n];r&&!r.isDefaultInstance&&e.isDefaultInstance||(t[n]=e)}),Object.values(t)}function cl(e){let t=e.defaultIntegrations||[],n=e.integrations;t.forEach(e=>{e.isDefaultInstance=!0});let r;if(Array.isArray(n))r=[...t,...n];else if(typeof n==`function`){let e=n(t);r=Array.isArray(e)?e:[e]}else r=t;return sl(r)}function ll(e,t){let n={};return t.forEach(t=>{t&&dl(e,t,n)}),n}function ul(e,t){for(let n of t)n?.afterAllSetup&&n.afterAllSetup(e)}function dl(e,t,n){if(n[t.name]){W&&K.log(`Integration skipped because it was already installed: ${t.name}`);return}if(n[t.name]=t,!ol.includes(t.name)&&typeof t.setupOnce==`function`&&(t.setupOnce(),ol.push(t.name)),t.setup&&typeof t.setup==`function`&&t.setup(e),typeof t.preprocessEvent==`function`){let n=t.preprocessEvent.bind(t);e.on(`preprocessEvent`,(t,r)=>n(t,r,e))}if(typeof t.processEvent==`function`){let n=t.processEvent.bind(t),r=Object.assign((t,r)=>n(t,r,e),{id:t.name});e.addEventProcessor(r)}W&&K.log(`Integration installed: ${t.name}`)}function Z(e){return e}function fl(e,t){return t?zo(t,()=>{let n=ks(),r=n?_s(n):Vo(t);return[n?Vs(n):Bs(e,t),r]}):[void 0,void 0]}function pl(e){return[{type:`log`,item_count:e.length,content_type:`application/vnd.sentry.items.log+json`},{items:e}]}function ml(e,t,n,r){let i={};return t?.sdk&&(i.sdk={name:t.sdk.name,version:t.sdk.version}),n&&r&&(i.dsn=ts(r)),Xs(i,[pl(e)])}function hl(e,t){let n=t??gl(e)??[];if(n.length===0)return;let r=e.getOptions(),i=ml(n,r._metadata,r.tunnel,e.getDsn());_l().set(e,[]),e.emit(`flushLogs`),e.sendEnvelope(i)}function gl(e){return _l().get(e)}function _l(){return zi(`clientToLogBufferMap`,()=>new WeakMap)}function vl(e){return[{type:`trace_metric`,item_count:e.length,content_type:`application/vnd.sentry.items.trace-metric+json`},{items:e}]}function yl(e,t,n,r){let i={};return t?.sdk&&(i.sdk={name:t.sdk.name,version:t.sdk.version}),n&&r&&(i.dsn=ts(r)),Xs(i,[vl(e)])}function bl(e,t){let n=t??xl(e)??[];if(n.length===0)return;let r=e.getOptions(),i=yl(n,r._metadata,r.tunnel,e.getDsn());Sl().set(e,[]),e.emit(`flushMetrics`),e.sendEnvelope(i)}function xl(e){return Sl().get(e)}function Sl(){return zi(`clientToMetricBufferMap`,()=>new WeakMap)}function Cl(e){return typeof e==`object`&&typeof e.unref==`function`&&e.unref(),e}const wl=Symbol.for(`SentryBufferFullError`);function Tl(e=100){let t=new Set;function n(){return t.size<e}function r(e){t.delete(e)}function i(e){if(!n())return vc(wl);let i=e();return t.add(i),i.then(()=>r(i),()=>r(i)),i}function a(e){if(!t.size)return _c(!0);let n=Promise.allSettled(Array.from(t)).then(()=>!0);if(!e)return n;let r=[n,new Promise(t=>Cl(setTimeout(()=>t(!1),e)))];return Promise.race(r)}return{get $(){return Array.from(t)},add:i,drain:a}}function El(e,t=qa()){let n=parseInt(`${e}`,10);if(!isNaN(n))return n*1e3;let r=Date.parse(`${e}`);return isNaN(r)?6e4:r-t}function Dl(e,t){return e[t]||e.all||0}function Ol(e,t,n=qa()){return Dl(e,t)>n}function kl(e,{statusCode:t,headers:n},r=qa()){let i={...e},a=n?.[`x-sentry-rate-limits`],o=n?.[`retry-after`];if(a)for(let e of a.trim().split(`,`)){let[t,n,,,a]=e.split(`:`,5),o=parseInt(t,10),s=(isNaN(o)?60:o)*1e3;if(!n)i.all=r+s;else for(let e of n.split(`;`))e===`metric_bucket`?(!a||a.split(`;`).includes(`custom`))&&(i[e]=r+s):i[e]=r+s}else o?i.all=r+El(o,r):t===429&&(i.all=r+60*1e3);return i}function Al(e,t,n=Tl(e.bufferSize||64)){let r={},i=e=>n.drain(e);function a(i){let a=[];if(Qs(i,(t,n)=>{let i=ac(n);Ol(r,i)?e.recordDroppedEvent(`ratelimit_backoff`,i):a.push(t)}),a.length===0)return Promise.resolve({});let o=Xs(i[0],a),s=t=>{if($s(o,[`client_report`])){W&&K.warn(`Dropping client report. Will not send outcomes (reason: ${t}).`);return}Qs(o,(n,r)=>{e.recordDroppedEvent(t,ac(r))})};return n.add(()=>t({body:tc(o)}).then(e=>e.statusCode===413?(W&&K.error(`Sentry responded with status code 413. Envelope was discarded due to exceeding size limits.`),s(`send_error`),e):(W&&e.statusCode!==void 0&&(e.statusCode<200||e.statusCode>=300)&&K.warn(`Sentry responded with status code ${e.statusCode} to sent event.`),r=kl(r,e),e),e=>{throw s(`network_error`),W&&K.error(`Encountered error running transport request:`,e),e})).then(e=>e,e=>{if(e===wl)return W&&K.error(`Skipped sending event because buffer is full.`),s(`queue_overflow`),Promise.resolve({});throw e})}return{send:a,flush:i}}function jl(e,t,n){let r=[{type:`client_report`},{timestamp:n||po(),discarded_events:e}];return Xs(t?{dsn:t}:{},[r])}function Ml(e){let t=[];e.message&&t.push(e.message);try{let n=e.exception.values[e.exception.values.length-1];n?.value&&(t.push(n.value),n.type&&t.push(`${n.type}: ${n.value}`))}catch{}return t}function Nl(e){let{trace_id:t,parent_span_id:n,span_id:r,status:i,origin:a,data:o,op:s}=e.contexts?.trace??{};return{data:o??{},description:e.transaction,op:s,parent_span_id:n,span_id:r??``,start_timestamp:e.start_timestamp??0,status:i,timestamp:e.timestamp,trace_id:t??``,origin:a,profile_id:o?.[Ho],exclusive_time:o?.[Uo],measurements:e.measurements,is_segment:!0}}function Pl(e){return{type:`transaction`,timestamp:e.timestamp,start_timestamp:e.start_timestamp,transaction:e.description,contexts:{trace:{trace_id:e.trace_id,span_id:e.span_id,parent_span_id:e.parent_span_id,op:e.op,status:e.status,origin:e.origin,data:{...e.data,...e.profile_id&&{[Ho]:e.profile_id},...e.exclusive_time&&{[Uo]:e.exclusive_time}}}},measurements:e.measurements}}const Fl=`Not capturing exception because it's already been captured.`,Il=`Discarded session because of missing or non-string release`,Ll=Symbol.for(`SentryInternalError`),Rl=Symbol.for(`SentryDoNotSendEventError`);function zl(e){return{message:e,[Ll]:!0}}function Bl(e){return{message:e,[Rl]:!0}}function Vl(e){return!!e&&typeof e==`object`&&Ll in e}function Hl(e){return!!e&&typeof e==`object`&&Rl in e}function Ul(e,t,n,r,i){let a=0,o,s=!1;e.on(n,()=>{a=0,clearTimeout(o),s=!1}),e.on(t,t=>{a+=r(t),a>=8e5?i(e):s||(s=!0,o=Cl(setTimeout(()=>{i(e)},5e3)))}),e.on(`flush`,()=>{i(e)})}var Wl=class{constructor(e){if(this._options=e,this._integrations={},this._numProcessing=0,this._outcomes={},this._hooks={},this._eventProcessors=[],this._promiseBuffer=Tl(e.transportOptions?.bufferSize??64),e.dsn?this._dsn=ss(e.dsn):W&&K.warn(`No DSN provided, client will not send events.`),this._dsn){let t=al(this._dsn,e.tunnel,e._metadata?e._metadata.sdk:void 0);this._transport=e.transport({tunnel:this._options.tunnel,recordDroppedEvent:this.recordDroppedEvent.bind(this),...e.transportOptions,url:t})}this._options.enableLogs=this._options.enableLogs??this._options._experiments?.enableLogs,this._options.enableLogs&&Ul(this,`afterCaptureLog`,`flushLogs`,Zl,hl),(this._options.enableMetrics??this._options._experiments?.enableMetrics??!0)&&Ul(this,`afterCaptureMetric`,`flushMetrics`,Xl,bl)}captureException(e,t,n){let r=q();if(lo(e))return W&&K.log(Fl),r;let i={event_id:r,...t};return this._process(()=>this.eventFromException(e,i).then(e=>this._captureEvent(e,i,n)).then(e=>e),`error`),i.event_id}captureMessage(e,t,n,r){let i={event_id:q(),...n},a=Ca(e)?e:String(e),o=wa(e),s=o?this.eventFromMessage(a,t,i):this.eventFromException(e,i);return this._process(()=>s.then(e=>this._captureEvent(e,i,r)),o?`unknown`:`error`),i.event_id}captureEvent(e,t,n){let r=q();if(t?.originalException&&lo(t.originalException))return W&&K.log(Fl),r;let i={event_id:r,...t},a=e.sdkProcessingMetadata||{},o=a.capturedSpanScope,s=a.capturedSpanIsolationScope,c=Gl(e.type);return this._process(()=>this._captureEvent(e,i,o||n,s),c),i.event_id}captureSession(e){this.sendSession(e),vo(e,{init:!1})}getDsn(){return this._dsn}getOptions(){return this._options}getSdkMetadata(){return this._options._metadata}getTransport(){return this._transport}async flush(e){let t=this._transport;if(!t)return!0;this.emit(`flush`);let n=await this._isClientDoneProcessing(e),r=await t.flush(e);return n&&r}async close(e){hl(this);let t=await this.flush(e);return this.getOptions().enabled=!1,this.emit(`close`),t}getEventProcessors(){return this._eventProcessors}addEventProcessor(e){this._eventProcessors.push(e)}init(){(this._isEnabled()||this._options.integrations.some(({name:e})=>e.startsWith(`Spotlight`)))&&this._setupIntegrations()}getIntegrationByName(e){return this._integrations[e]}addIntegration(e){let t=this._integrations[e.name];dl(this,e,this._integrations),t||ul(this,[e])}sendEvent(e,t={}){this.emit(`beforeSendEvent`,e,t);let n=uc(e,this._dsn,this._options._metadata,this._options.tunnel);for(let e of t.attachments||[])n=Zs(n,rc(e));this.sendEnvelope(n).then(t=>this.emit(`afterSendEvent`,e,t))}sendSession(e){let{release:t,environment:n=Rs}=this._options;if(`aggregates`in e){let r=e.attrs||{};if(!r.release&&!t){W&&K.warn(Il);return}r.release=r.release||t,r.environment=r.environment||n,e.attrs=r}else{if(!e.release&&!t){W&&K.warn(Il);return}e.release=e.release||t,e.environment=e.environment||n}this.emit(`beforeSendSession`,e);let r=lc(e,this._dsn,this._options._metadata,this._options.tunnel);this.sendEnvelope(r)}recordDroppedEvent(e,t,n=1){if(this._options.sendClientReports){let r=`${e}:${t}`;W&&K.log(`Recording outcome: "${r}"${n>1?` (${n} times)`:``}`),this._outcomes[r]=(this._outcomes[r]||0)+n}}on(e,t){let n=this._hooks[e]=this._hooks[e]||new Set,r=(...e)=>t(...e);return n.add(r),()=>{n.delete(r)}}emit(e,...t){let n=this._hooks[e];n&&n.forEach(e=>e(...t))}async sendEnvelope(e){if(this.emit(`beforeEnvelope`,e),this._isEnabled()&&this._transport)try{return await this._transport.send(e)}catch(e){return W&&K.error(`Error while sending envelope:`,e),{}}return W&&K.error(`Transport disabled`),{}}dispose(){}_setupIntegrations(){let{integrations:e}=this._options;this._integrations=ll(this,e),ul(this,e)}_updateSessionFromEvent(e,t){let n=t.level===`fatal`,r=!1,i=t.exception?.values;if(i){r=!0,n=!1;for(let e of i)if(e.mechanism?.handled===!1){n=!0;break}}let a=e.status===`ok`;(a&&e.errors===0||a&&n)&&(vo(e,{...n&&{status:`crashed`},errors:e.errors||Number(r||n)}),this.captureSession(e))}async _isClientDoneProcessing(e){let t=0;for(;!e||t<e;){if(await new Promise(e=>setTimeout(e,1)),!this._numProcessing)return!0;t++}return!1}_isEnabled(){return this.getOptions().enabled!==!1&&this._transport!==void 0}_prepareEvent(e,t,n,r){let i=this.getOptions(),a=Object.keys(this._integrations);return!t.integrations&&a?.length&&(t.integrations=a),this.emit(`preprocessEvent`,e,t),e.type||r.setLastEventId(e.event_id||t.event_id),Ic(i,e,t,n,this,r).then(e=>e===null?e:(this.emit(`postprocessEvent`,e,t),e.contexts={trace:Vo(n),...e.contexts},e.sdkProcessingMetadata={dynamicSamplingContext:Bs(this,n),...e.sdkProcessingMetadata},e))}_captureEvent(e,t={},n=J(),r=Y()){return W&&Jl(e)&&K.log(`Captured error event \`${Ml(e)[0]||`<unknown>`}\``),this._processEvent(e,t,n,r).then(e=>e.event_id,e=>{W&&(Hl(e)?K.log(e.message):Vl(e)?K.warn(e.message):K.warn(e))})}_processEvent(e,t,n,r){let i=this.getOptions(),{sampleRate:a}=i,o=Yl(e),s=Jl(e),c=`before send for type \`${e.type||`error`}\``,l=a===void 0?void 0:cs(a);if(s&&typeof l==`number`&&Ka()>l)return this.recordDroppedEvent(`sample_rate`,`error`),vc(Bl(`Discarding event because it's not included in the random sample (sampling rate = ${a})`));let u=Gl(e.type);return this._prepareEvent(e,t,n,r).then(e=>{if(e===null)throw this.recordDroppedEvent(`event_processor`,u),Bl("An event processor returned `null`, will not send event.");return t.data&&t.data.__sentry__===!0?e:Kl(ql(this,i,e,t),c)}).then(i=>{if(i===null){if(this.recordDroppedEvent(`before_send`,u),o){let t=1+(e.spans||[]).length;this.recordDroppedEvent(`before_send`,`span`,t)}throw Bl(`${c} returned \`null\`, will not send event.`)}let a=n.getSession()||r.getSession();if(s&&a&&this._updateSessionFromEvent(a,i),o){let e=(i.sdkProcessingMetadata?.spanCountBeforeProcessing||0)-(i.spans?i.spans.length:0);e>0&&this.recordDroppedEvent(`before_send`,`span`,e)}let l=i.transaction_info;return o&&l&&i.transaction!==e.transaction&&(i.transaction_info={...l,source:`custom`}),this.sendEvent(i,t),i}).then(null,e=>{throw Hl(e)||Vl(e)?e:(this.captureException(e,{mechanism:{handled:!1,type:`internal`},data:{__sentry__:!0},originalException:e}),zl(`Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\nReason: ${e}`))})}_process(e,t){this._numProcessing++,this._promiseBuffer.add(e).then(e=>(this._numProcessing--,e),e=>(this._numProcessing--,e===wl&&this.recordDroppedEvent(`queue_overflow`,t),e))}_clearOutcomes(){let e=this._outcomes;return this._outcomes={},Object.entries(e).map(([e,t])=>{let[n,r]=e.split(`:`);return{reason:n,category:r,quantity:t}})}_flushOutcomes(){W&&K.log(`Flushing outcomes...`);let e=this._clearOutcomes();if(e.length===0){W&&K.log(`No outcomes to send`);return}if(!this._dsn){W&&K.log(`No dsn provided, will not send outcomes`);return}W&&K.log(`Sending outcomes:`,e);let t=jl(e,this._options.tunnel&&ts(this._dsn));this.sendEnvelope(t)}};function Gl(e){return e===`replay_event`?`replay`:e||`error`}function Kl(e,t){let n=`${t} must return \`null\` or a valid event.`;if(ka(e))return e.then(e=>{if(!Ta(e)&&e!==null)throw zl(n);return e},e=>{throw zl(`${t} rejected with ${e}`)});if(!Ta(e)&&e!==null)throw zl(n);return e}function ql(e,t,n,r){let{beforeSend:i,beforeSendTransaction:a,beforeSendSpan:o,ignoreSpans:s}=t,c=n;if(Jl(c)&&i)return i(c,r);if(Yl(c)){if(o||s){let t=Nl(c);if(s?.length&&Fs(t,s))return null;if(o){let e=o(t);e?c=xo(n,Pl(e)):As()}if(c.spans){let t=[],n=c.spans;for(let e of n){if(s?.length&&Fs(e,s)){Is(n,e);continue}if(o){let n=o(e);n?t.push(n):(As(),t.push(e))}else t.push(e)}let r=c.spans.length-t.length;r&&e.recordDroppedEvent(`before_send`,`span`,r),c.spans=t}}if(a){if(c.spans){let e=c.spans.length;c.sdkProcessingMetadata={...n.sdkProcessingMetadata,spanCountBeforeProcessing:e}}return a(c,r)}}return c}function Jl(e){return e.type===void 0}function Yl(e){return e.type===`transaction`}function Xl(e){let t=0;return e.name&&(t+=e.name.length*2),t+=8,t+Ql(e.attributes)}function Zl(e){let t=0;return e.message&&(t+=e.message.length*2),t+Ql(e.attributes)}function Ql(e){if(!e)return 0;let t=0;return Object.values(e).forEach(e=>{Array.isArray(e)?t+=e.length*$l(e[0]):wa(e)?t+=$l(e):t+=100}),t}function $l(e){return typeof e==`string`?e.length*2:typeof e==`number`?8:typeof e==`boolean`?4:0}function eu(e,t,n,r,i){let a={sent_at:new Date().toISOString()};return n?.sdk&&(a.sdk={name:n.sdk.name,version:n.sdk.version}),r&&i&&(a.dsn=ts(i)),t&&(a.trace=t),Xs(a,[tu(e)])}function tu(e){return[{type:`check_in`},e]}function nu(e){let t=e._metadata?.sdk,n=t?.name&&t?.version?`${t?.name}/${t?.version}`:void 0;e.transportOptions={...e.transportOptions,headers:{...n&&{"user-agent":n},...e.transportOptions?.headers}}}function ru(e,t){return e(t.stack||``,1)}function iu(e){return ya(e)&&`__sentry_fetch_url_host__`in e&&typeof e.__sentry_fetch_url_host__==`string`}function au(e){return iu(e)?`${e.message} (${e.__sentry_fetch_url_host__})`:e.message}function ou(e,t){let n={type:t.name||t.constructor.name,value:au(t)},r=ru(e,t);return r.length&&(n.stacktrace={frames:r}),n}function su(e){for(let t in e)if(Object.prototype.hasOwnProperty.call(e,t)){let n=e[t];if(n instanceof Error)return n}}function cu(e){if(`name`in e&&typeof e.name==`string`){let t=`'${e.name}' captured as exception`;return`message`in e&&typeof e.message==`string`&&(t+=` with message '${e.message}'`),t}else if(`message`in e&&typeof e.message==`string`)return e.message;let t=Ua(e);if(xa(e))return`Event \`ErrorEvent\` captured as exception with message \`${e.message}\``;let n=lu(e);return`${n&&n!==`Object`?`'${n}'`:`Object`} captured as exception with keys: ${t}`}function lu(e){try{let t=Object.getPrototypeOf(e);return t?t.constructor.name:void 0}catch{}}function uu(e,t,n,r){if(ya(n))return[n,void 0];if(t.synthetic=!0,Ta(n)){let t=e?.getOptions().normalizeDepth,i={__serialized__:Us(n,t)},a=su(n);if(a)return[a,i];let o=cu(n),s=r?.syntheticException||Error(o);return s.message=o,[s,i]}let i=r?.syntheticException||Error(n);return i.message=`${n}`,[i,void 0]}function du(e,t,n,r){let i=r?.data&&r.data.mechanism||{handled:!0,type:`generic`},[a,o]=uu(e,i,n,r),s={exception:{values:[ou(t,a)]}};return o&&(s.extra=o),io(s,void 0,void 0),ao(s,i),{...s,event_id:r?.event_id}}function fu(e,t,n=`info`,r,i){let a={event_id:r?.event_id,level:n};if(i&&r?.syntheticException){let n=ru(e,r.syntheticException);n.length&&(a.exception={values:[{value:t,stacktrace:{frames:n}}]},ao(a,{synthetic:!0}))}if(Ca(t)){let{__sentry_template_string__:e,__sentry_template_values__:n}=t;return a.logentry={message:e,params:n},a}return a.message=t,a}var pu=class extends Wl{constructor(e){Ms(),nu(e),super(e),this._setUpMetricsProcessing()}eventFromException(e,t){let n=du(this,this._options.stackParser,e,t);return n.level=`error`,_c(n)}eventFromMessage(e,t=`info`,n){return _c(fu(this._options.stackParser,e,t,n,this._options.attachStacktrace))}captureException(e,t,n){return mu(t),super.captureException(e,t,n)}captureEvent(e,t,n){return!e.type&&e.exception?.values&&e.exception.values.length>0&&mu(t),super.captureEvent(e,t,n)}captureCheckIn(e,t,n){let r=`checkInId`in e&&e.checkInId?e.checkInId:q();if(!this._isEnabled())return W&&K.warn(`SDK not enabled, will not capture check-in.`),r;let{release:i,environment:a,tunnel:o}=this.getOptions(),s={check_in_id:r,monitor_slug:e.monitorSlug,status:e.status,release:i,environment:a};`duration`in e&&(s.duration=e.duration),t&&(s.monitor_config={schedule:t.schedule,checkin_margin:t.checkinMargin,max_runtime:t.maxRuntime,timezone:t.timezone,failure_issue_threshold:t.failureIssueThreshold,recovery_threshold:t.recoveryThreshold});let[c,l]=fl(this,n);l&&(s.contexts={trace:l});let u=eu(s,c,this.getSdkMetadata(),o,this.getDsn());return W&&K.log(`Sending checkin:`,e.monitorSlug,e.status),this.sendEnvelope(u),r}dispose(){W&&K.log(`Disposing client...`);for(let e of Object.keys(this._hooks))this._hooks[e]?.clear();this._hooks={},this._eventProcessors.length=0,this._integrations={},this._outcomes={},this._transport=void 0,this._promiseBuffer=Tl(64)}_prepareEvent(e,t,n,r){return this._options.platform&&(e.platform=e.platform||this._options.platform),this._options.runtime&&(e.contexts={...e.contexts,runtime:e.contexts?.runtime||this._options.runtime}),this._options.serverName&&(e.server_name=e.server_name||this._options.serverName),super._prepareEvent(e,t,n,r)}_setUpMetricsProcessing(){this.on(`processMetric`,e=>{this._options.serverName&&(e.attributes={"server.address":this._options.serverName,...e.attributes})})}};function mu(e){let t=Y().getScopeData().sdkProcessingMetadata.requestSession;if(t){let n=e?.mechanism?.handled??!0;n&&t.status!==`crashed`?t.status=`errored`:n||(t.status=`crashed`)}}const hu=new Set([`false`,`f`,`n`,`no`,`off`,`0`]),gu=new Set([`true`,`t`,`y`,`yes`,`on`,`1`]);function _u(e,t){let n=String(e).toLowerCase();return hu.has(n)?!1:gu.has(n)?!0:t?.strict?null:!!e}function vu(e){if(!e)return{};let t=e.match(/^(([^:/?#]+):)?(\/\/([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?$/);if(!t)return{};let n=t[6]||``,r=t[8]||``;return{host:t[4],path:t[5],protocol:t[2],search:n,hash:r,relative:t[5]+n+r}}function yu(e){return e.split(/[?#]/,1)[0]}function bu(e){let{protocol:t,host:n,path:r}=e,i=n?.replace(/^.*@/,`[filtered]:[filtered]@`).replace(/(:80)$/,``).replace(/(:443)$/,``)||``;return`${t?`${t}://`:``}${i}${r}`}function xu(e,t,n=[t],r=`npm`){let i=(e._metadata=e._metadata||{}).sdk=e._metadata.sdk||{};i.name||(i.name=`sentry.javascript.${t}`,i.packages=n.map(e=>({name:`${r}:@sentry/${e}`,version:Ii})),i.version=Ii)}function Su(e={}){let t=e.client||X();if(!Qc()||!t)return{};let n=Lo(Li());if(n.getTraceData)return n.getTraceData(e);let r=e.scope||J(),i=e.span||ks(),a=i?vs(i):Cu(r),o=Jo(i?Vs(i):Bs(t,r));if(!ls.test(a))return K.warn(`Invalid sentry-trace data. Cannot generate trace data`),{};let s={"sentry-trace":a,baggage:o};return e.propagateTraceparent&&(s.traceparent=i?ys(i):wu(r)),s}function Cu(e){let{traceId:t,sampled:n,propagationSpanId:r}=e.getPropagationContext();return fs(t,r,n)}function wu(e){let{traceId:t,sampled:n,propagationSpanId:r}=e.getPropagationContext();return ps(t,r,n)}const Tu=`[Tracing] Not injecting trace data for url because it does not match tracePropagationTargets:`;function Eu(e,t,n){if(typeof e!=`string`||!t)return!0;let r=n?.get(e);if(r!==void 0)return W&&!r&&K.log(Tu,e),r;let i=Qa(e,t);return n?.set(e,i),W&&!i&&K.log(Tu,e),i}function Du(e){let t=Object.create(null);try{Object.entries(e).forEach(([e,n])=>{typeof n==`string`&&(t[e]=n)})}catch{}return t}function Ou(e){let t=e.headers||{},n=(typeof t[`x-forwarded-host`]==`string`?t[`x-forwarded-host`]:void 0)||(typeof t.host==`string`?t.host:void 0),r=(typeof t[`x-forwarded-proto`]==`string`?t[`x-forwarded-proto`]:void 0)||e.protocol||(e.socket?.encrypted?`https`:`http`),i=e.url||``,a=ku({url:i,host:n,protocol:r}),o=e.body||void 0,s=e.cookies;return{url:a,method:e.method,query_string:Au(i),headers:Du(t),cookies:s,data:o}}function ku({url:e,protocol:t,host:n}){if(e?.startsWith(`http`))return e;if(e&&n)return`${t}://${n}${e}`}function Au(e){if(e)try{let t=new URL(e,`http://s.io`).search.slice(1);return t.length?t:void 0}catch{return}}function ju(e,t){let n=X(),r=Y();if(!n)return;let{beforeBreadcrumb:i=null,maxBreadcrumbs:a=100}=n.getOptions();if(a<=0)return;let o={timestamp:po(),...e},s=i?Hi(()=>i(o,t)):o;s!==null&&(n.emit&&n.emit(`beforeAddBreadcrumb`,s,t),r.addBreadcrumb(s,a))}let Mu;const Nu=new WeakMap,Pu=Z((()=>({name:`FunctionToString`,setupOnce(){Mu=Function.prototype.toString;try{Function.prototype.toString=function(...e){let t=za(this),n=Nu.has(X())&&t!==void 0?t:this;return Mu.apply(n,e)}}catch{}},setup(e){Nu.set(e,!0)}}))),Fu=[/^Script error\.?$/,/^Javascript error: Script error\.? on line 0$/,/^ResizeObserver loop completed with undelivered notifications.$/,/^Cannot redefine property: googletag$/,/^Can't find variable: gmo$/,/^undefined is not an object \(evaluating 'a\.[A-Z]'\)$/,`can't redefine non-configurable property "solana"`,`vv().getRestrictions is not a function. (In 'vv().getRestrictions(1,a)', 'vv().getRestrictions' is undefined)`,`Can't find variable: _AutofillCallbackHandler`,/^Non-Error promise rejection captured with value: Object Not Found Matching Id:\d+, MethodName:simulateEvent, ParamCount:\d+$/,/^Java exception was raised during method invocation$/],Iu=Z((e={})=>{let t;return{name:`EventFilters`,setup(n){t=Lu(e,n.getOptions())},processEvent(n,r,i){return t||=Lu(e,i.getOptions()),Ru(n,t)?null:n}}});function Lu(e={},t={}){return{allowUrls:[...e.allowUrls||[],...t.allowUrls||[]],denyUrls:[...e.denyUrls||[],...t.denyUrls||[]],ignoreErrors:[...e.ignoreErrors||[],...t.ignoreErrors||[],...e.disableErrorDefaults?[]:Fu],ignoreTransactions:[...e.ignoreTransactions||[],...t.ignoreTransactions||[]]}}function Ru(e,t){if(e.type){if(e.type===`transaction`&&Bu(e,t.ignoreTransactions))return W&&K.warn(`Event dropped due to being matched by \`ignoreTransactions\` option.\nEvent: ${ro(e)}`),!0}else{if(zu(e,t.ignoreErrors))return W&&K.warn(`Event dropped due to being matched by \`ignoreErrors\` option.\nEvent: ${ro(e)}`),!0;if(Gu(e))return W&&K.warn(`Event dropped due to not having an error message, error type or stacktrace.\nEvent: ${ro(e)}`),!0;if(Vu(e,t.denyUrls))return W&&K.warn(`Event dropped due to being matched by \`denyUrls\` option.\nEvent: ${ro(e)}.\nUrl: ${Wu(e)}`),!0;if(!Hu(e,t.allowUrls))return W&&K.warn(`Event dropped due to not being matched by \`allowUrls\` option.\nEvent: ${ro(e)}.\nUrl: ${Wu(e)}`),!0}return!1}function zu(e,t){return t?.length?Ml(e).some(e=>Qa(e,t)):!1}function Bu(e,t){if(!t?.length)return!1;let n=e.transaction;return n?Qa(n,t):!1}function Vu(e,t){if(!t?.length)return!1;let n=Wu(e);return n?Qa(n,t):!1}function Hu(e,t){if(!t?.length)return!0;let n=Wu(e);return n?Qa(n,t):!0}function Uu(e=[]){for(let t=e.length-1;t>=0;t--){let n=e[t];if(n&&n.filename!==`<anonymous>`&&n.filename!==`[native code]`)return n.filename||null}return null}function Wu(e){try{let t=[...e.exception?.values??[]].reverse().find(e=>e.mechanism?.parent_id===void 0&&e.stacktrace?.frames?.length)?.stacktrace?.frames;return t?Uu(t):null}catch{return W&&K.error(`Cannot extract url for event ${ro(e)}`),null}}function Gu(e){return e.exception?.values?.length?!e.message&&!e.exception.values.some(e=>e.stacktrace||e.type&&e.type!==`Error`||e.value):!1}function Ku(e,t,n,r,i,a){if(!i.exception?.values||!a||!ja(a.originalException,Error))return;let o=i.exception.values.length>0?i.exception.values[i.exception.values.length-1]:void 0;o&&(i.exception.values=qu(e,t,r,a.originalException,n,i.exception.values,o,0))}function qu(e,t,n,r,i,a,o,s){if(a.length>=n+1)return a;let c=[...a];if(ja(r[i],Error)){Yu(o,s,r);let a=e(t,r[i]),l=c.length;Xu(a,i,l,s),c=qu(e,t,n,r[i],i,[a,...c],a,l)}return Ju(r)&&r.errors.forEach((a,l)=>{if(ja(a,Error)){Yu(o,s,r);let u=e(t,a),d=c.length;Xu(u,`errors[${l}]`,d,s),c=qu(e,t,n,a,i,[u,...c],u,d)}}),c}function Ju(e){return Array.isArray(e.errors)}function Yu(e,t,n){e.mechanism={handled:!0,type:`auto.core.linked_errors`,...Ju(n)&&{is_exception_group:!0},...e.mechanism,exception_id:t}}function Xu(e,t,n,r){e.mechanism={handled:!0,...e.mechanism,type:`chained`,source:t,exception_id:n,parent_id:r}}const Zu=Z(((e={})=>{let t=e.limit||5,n=e.key||`cause`;return{name:`LinkedErrors`,preprocessEvent(e,r,i){Ku(ou,i.getOptions().stackParser,n,t,e,r)}}}));function Qu(e){let t={},n=0;for(;n<e.length;){let r=e.indexOf(`=`,n);if(r===-1)break;let i=e.indexOf(`;`,n);if(i===-1)i=e.length;else if(i<r){n=e.lastIndexOf(`;`,r-1)+1;continue}let a=e.slice(n,r).trim();if(t[a]===void 0){let n=e.slice(r+1,i).trim();n.charCodeAt(0)===34&&(n=n.slice(1,-1));try{t[a]=n.indexOf(`%`)===-1?n:decodeURIComponent(n)}catch{t[a]=n}}n=i+1}return t}const $u=[`X-Client-IP`,`X-Forwarded-For`,`Fly-Client-IP`,`CF-Connecting-IP`,`Fastly-Client-Ip`,`True-Client-Ip`,`X-Real-IP`,`X-Cluster-Client-IP`,`X-Forwarded`,`Forwarded-For`,`Forwarded`,`X-Vercel-Forwarded-For`];function ed(e){let t={};for(let n of Object.keys(e))t[n.toLowerCase()]=e[n];return $u.map(e=>{let n=t[e.toLowerCase()],r=Array.isArray(n)?n.join(`;`):n;return e===`Forwarded`?td(r):r?.split(`,`).map(e=>e.trim())}).reduce((e,t)=>t?e.concat(t):e,[]).find(e=>e!==null&&nd(e))||null}function td(e){if(!e)return null;for(let t of e.split(`;`))if(t.startsWith(`for=`))return t.slice(4);return null}function nd(e){return/(?:^(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}$)|(?:^(?:(?:[a-fA-F\d]{1,4}:){7}(?:[a-fA-F\d]{1,4}|:)|(?:[a-fA-F\d]{1,4}:){6}(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|:[a-fA-F\d]{1,4}|:)|(?:[a-fA-F\d]{1,4}:){5}(?::(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,2}|:)|(?:[a-fA-F\d]{1,4}:){4}(?:(?::[a-fA-F\d]{1,4}){0,1}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,3}|:)|(?:[a-fA-F\d]{1,4}:){3}(?:(?::[a-fA-F\d]{1,4}){0,2}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,4}|:)|(?:[a-fA-F\d]{1,4}:){2}(?:(?::[a-fA-F\d]{1,4}){0,3}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,5}|:)|(?:[a-fA-F\d]{1,4}:){1}(?:(?::[a-fA-F\d]{1,4}){0,4}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,6}|:)|(?::(?:(?::[a-fA-F\d]{1,4}){0,5}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,7}|:)))(?:%[0-9a-zA-Z]{1,})?$)/.test(e)}const rd={cookies:!0,data:!0,headers:!0,query_string:!0,url:!0},id=Z(((e={})=>{let t={...rd,...e.include};return{name:`RequestData`,processEvent(e,n,r){let{sdkProcessingMetadata:i={}}=e,{normalizedRequest:a,ipAddress:o}=i,s={...t,ip:t.ip??r.getOptions().sendDefaultPii};return a&&ad(e,a,{ipAddress:o},s),e}}}));function ad(e,t,n,r){if(e.request={...e.request,...od(t,r)},r.ip){let r=t.headers&&ed(t.headers)||n.ipAddress;r&&(e.user={...e.user,ip_address:r})}}function od(e,t){let n={},r={...e.headers};return t.headers&&(n.headers=r,t.cookies||delete r.cookie,t.ip||$u.forEach(e=>{delete r[e]})),n.method=e.method,t.url&&(n.url=e.url),t.cookies&&(n.cookies=e.cookies||(r?.cookie?Qu(r.cookie):void 0)||{}),t.query_string&&(n.query_string=e.query_string),t.data&&(n.data=e.data),n}function sd(e){let t=`console`;la(t,e),ua(t,cd)}function cd(){`console`in G&&Bi.forEach(function(e){e in G.console&&Ia(G.console,e,function(t){return Vi[e]=t,function(...t){da(`console`,{args:t,level:e}),Vi[e]?.apply(G.console,t)}})})}function ld(e){return e===`warn`?`warning`:[`fatal`,`error`,`warning`,`log`,`info`,`debug`].includes(e)?e:`log`}const ud=/^(\S+:\\|\/?)([\s\S]*?)((?:\.{1,2}|[^/\\]+?|)(\.[^./\\]*|))(?:[/\\]*)$/;function dd(e){let t=e.length>1024?`<truncated>${e.slice(-1024)}`:e,n=ud.exec(t);return n?n.slice(1):[]}function fd(e){let t=dd(e),n=t[0]||``,r=t[1];return!n&&!r?`.`:(r&&=r.slice(0,r.length-1),n+r)}const pd=Z((e={})=>{let t=new Set(e.levels||Bi);return{name:`Console`,setup(e){sd(({args:n,level:r})=>{X()!==e||!t.has(r)||md(r,n)})}}});function md(e,t){let n={category:`console`,data:{arguments:t,logger:`console`},level:ld(e),message:hd(t)};if(e===`assert`)if(t[0]===!1){let e=t.slice(1);n.message=e.length>0?`Assertion failed: ${hd(e)}`:`Assertion failed`,n.data.arguments=e}else return;ju(n,{input:t,level:e})}function hd(e){return`util`in G&&typeof G.util.format==`function`?G.util.format(...e):Xa(e,` `)}function gd(e){if(e!==void 0){if(e>=400&&e<500)return`warning`;if(e>=500)return`error`}}function _d(e,t=!1){return!(t||e&&!e.startsWith(`/`)&&!e.match(/^[A-Z]:/)&&!e.startsWith(`.`)&&!e.match(/^[a-zA-Z]([a-zA-Z0-9.\-+])*:\/\//))&&e!==void 0&&!e.includes(`node_modules/`)}function vd(e){let t=/^\s*[-]{4,}$/,n=/at (?:async )?(?:(.+?)\s+\()?(?:(.+):(\d+):(\d+)?|([^)]+))\)?/,r=/at (?:async )?(.+?) \(data:(.*?),/;return i=>{let a=i.match(r);if(a)return{filename:`<data:${a[2]}>`,function:a[1]};let o=i.match(n);if(o){let t,n,r,i,a;if(o[1]){r=o[1];let e=r.lastIndexOf(`.`);if(r[e-1]===`.`&&e--,e>0){t=r.slice(0,e),n=r.slice(e+1);let i=t.indexOf(`.Module`);i>0&&(r=r.slice(i+1),t=t.slice(0,i))}i=void 0}n&&(i=t,a=n),n===`<anonymous>`&&(a=void 0,r=void 0),r===void 0&&(a||=`?`,r=i?`${i}.${a}`:a);let s=oa(o[2]),c=o[5]===`native`;!s&&o[5]&&!c&&(s=o[5]);let l=s?xd(s):void 0;return{filename:l??s,module:l&&e?.(l),function:r,lineno:bd(o[3]),colno:bd(o[4]),in_app:_d(s||``,c)}}if(i.match(t))return{filename:i}}}function yd(e){return[90,vd(e)]}function bd(e){return parseInt(e||``,10)||void 0}function xd(e){try{return decodeURI(e)}catch{return}}var Sd=class{constructor(e){this._maxSize=e,this._cache=new Map}get size(){return this._cache.size}get(e){let t=this._cache.get(e);if(t!==void 0)return this._cache.delete(e),this._cache.set(e,t),t}set(e,t){if(this._cache.size>=this._maxSize){let e=this._cache.keys().next().value;this._cache.delete(e)}this._cache.set(e,t)}remove(e){let t=this._cache.get(e);return t&&this._cache.delete(e),t}clear(){this._cache.clear()}keys(){return Array.from(this._cache.keys())}values(){let e=[];return this._cache.forEach(t=>e.push(t)),e}};const Q=typeof __SENTRY_DEBUG__>`u`||__SENTRY_DEBUG__;var Cd=class extends pu{constructor(e){let t=e.includeServerName===!1?void 0:e.serverName||global.process.env.SENTRY_NAME||j.hostname(),n={...e,platform:`node`,runtime:{name:`node`,version:global.process.version},serverName:t};xu(n,`node-light`,[`node-core`]),K.log(`Initializing Sentry: process: ${process.pid}, thread: ${at?`main`:`worker-${ot}`}.`),super(n),this.getOptions().enableLogs&&(this._logOnExitFlushListener=()=>{hl(this)},t&&this.on(`beforeCaptureLog`,e=>{e.attributes={...e.attributes,"server.address":t}}),process.on(`beforeExit`,this._logOnExitFlushListener))}async flush(e){return this.getOptions().sendClientReports&&this._flushOutcomes(),super.flush(e)}async close(e){return this._clientReportInterval&&clearInterval(this._clientReportInterval),this._clientReportOnExitFlushListener&&process.off(`beforeExit`,this._clientReportOnExitFlushListener),this._logOnExitFlushListener&&process.off(`beforeExit`,this._logOnExitFlushListener),super.close(e)}startClientReportTracking(){let e=this.getOptions();e.sendClientReports&&(this._clientReportOnExitFlushListener=()=>{this._flushOutcomes()},this._clientReportInterval=setInterval(()=>{Q&&K.log(`Flushing client reports based on interval.`),this._flushOutcomes()},e.clientReportFlushInterval??6e4).unref(),process.on(`beforeExit`,this._clientReportOnExitFlushListener))}};const wd=Z((e={})=>({name:`ChildProcess`,setup(){st.channel(`child_process`).subscribe(t=>{t&&typeof t==`object`&&`process`in t&&Td(t.process,e)}),st.channel(`worker_threads`).subscribe(t=>{t&&typeof t==`object`&&`worker`in t&&Ed(t.worker,e)})}}));function Td(e,t){let n=!1,r;e.on(`spawn`,()=>{if(e.spawnfile===`/usr/bin/sw_vers`){n=!0;return}r={spawnfile:e.spawnfile},t.includeChildProcessArgs&&(r.spawnargs=e.spawnargs)}).on(`exit`,e=>{n||(n=!0,e!==null&&e!==0&&ju({category:`child_process`,message:`Child process exited with code '${e}'`,level:e===0?`info`:`warning`,data:r}))}).on(`error`,e=>{n||(n=!0,ju({category:`child_process`,message:`Child process errored with '${e.message}'`,level:`error`,data:r}))})}function Ed(e,t){let n;e.on(`online`,()=>{n=e.threadId}).on(`error`,e=>{t.captureWorkerErrors===!1?ju({category:`worker_thread`,message:`Worker thread errored with '${e.message}'`,level:`error`,data:{threadId:n}}):qc(e,{mechanism:{type:`auto.child_process.worker_thread`,handled:!1,data:{threadId:String(n)}}})})}const Dd=Ue(dt),Od=Ue(pt),kd=Z(((e={})=>{let t,n={app:!0,os:!0,device:!0,culture:!0,cloudResource:!0,...e};async function r(e){t===void 0&&(t=i());let n=Ad(await t);return e.contexts={...e.contexts,app:{...n.app,...e.contexts?.app},os:{...n.os,...e.contexts?.os},device:{...n.device,...e.contexts?.device},culture:{...n.culture,...e.contexts?.culture},cloud_resource:{...n.cloud_resource,...e.contexts?.cloud_resource}},e}async function i(){let e={};if(n.os&&(e.os=await jd()),n.app&&(e.app=Nd()),n.device&&(e.device=Pd(n.device)),n.culture){let t=Md();t&&(e.culture=t)}return n.cloudResource&&(e.cloud_resource=Hd()),e}return{name:`Context`,processEvent(e){return r(e)}}}));function Ad(e){if(e.app?.app_memory&&(e.app.app_memory=process.memoryUsage().rss),e.app?.free_memory&&typeof process.availableMemory==`function`){let t=process.availableMemory?.();t!=null&&(e.app.free_memory=t)}return e.device?.free_memory&&(e.device.free_memory=j.freemem()),e}async function jd(){let e=j.platform();switch(e){case`darwin`:return zd();case`linux`:return Vd();default:return{name:Fd[e]||e,version:j.release()}}}function Md(){try{if(typeof process.versions.icu!=`string`)return;let e=new Date(9e8);if(new Intl.DateTimeFormat(`es`,{month:`long`}).format(e)===`enero`){let e=Intl.DateTimeFormat().resolvedOptions();return{locale:e.locale,timezone:e.timeZone}}}catch{}}function Nd(){let e=process.memoryUsage().rss,t={app_start_time:new Date(Date.now()-process.uptime()*1e3).toISOString(),app_memory:e};if(typeof process.availableMemory==`function`){let e=process.availableMemory?.();e!=null&&(t.free_memory=e)}return t}function Pd(e){let t={},n;try{n=j.uptime()}catch{}if(typeof n==`number`&&(t.boot_time=new Date(Date.now()-n*1e3).toISOString()),t.arch=j.arch(),(e===!0||e.memory)&&(t.memory_size=j.totalmem(),t.free_memory=j.freemem()),e===!0||e.cpu){let e=j.cpus(),n=e?.[0];n&&(t.processor_count=e.length,t.cpu_description=n.model,t.processor_frequency=n.speed)}return t}const Fd={aix:`IBM AIX`,freebsd:`FreeBSD`,openbsd:`OpenBSD`,sunos:`SunOS`,win32:`Windows`,ohos:`OpenHarmony`,android:`Android`},Id=[{name:`fedora-release`,distros:[`Fedora`]},{name:`redhat-release`,distros:[`Red Hat Linux`,`Centos`]},{name:`redhat_version`,distros:[`Red Hat Linux`]},{name:`SuSE-release`,distros:[`SUSE Linux`]},{name:`lsb-release`,distros:[`Ubuntu Linux`,`Arch Linux`]},{name:`debian_version`,distros:[`Debian`]},{name:`debian_release`,distros:[`Debian`]},{name:`arch-release`,distros:[`Arch Linux`]},{name:`gentoo-release`,distros:[`Gentoo Linux`]},{name:`novell-release`,distros:[`SUSE Linux`]},{name:`alpine-release`,distros:[`Alpine Linux`]}],Ld={alpine:e=>e,arch:e=>Rd(/distrib_release=(.*)/,e),centos:e=>Rd(/release ([^ ]+)/,e),debian:e=>e,fedora:e=>Rd(/release (..)/,e),mint:e=>Rd(/distrib_release=(.*)/,e),red:e=>Rd(/release ([^ ]+)/,e),suse:e=>Rd(/VERSION = (.*)\n/,e),ubuntu:e=>Rd(/distrib_release=(.*)/,e)};function Rd(e,t){let n=e.exec(t);return n?n[1]:void 0}async function zd(){let e={kernel_version:j.release(),name:`Mac OS X`,version:`10.${Number(j.release().split(`.`)[0])-4}`};try{let t=await new Promise((e,t)=>{$e(`/usr/bin/sw_vers`,(n,r)=>{if(n){t(n);return}e(r)})});e.name=Rd(/^ProductName:\s+(.*)$/m,t),e.version=Rd(/^ProductVersion:\s+(.*)$/m,t),e.build=Rd(/^BuildVersion:\s+(.*)$/m,t)}catch{}return e}function Bd(e){return e.split(` `)[0].toLowerCase()}async function Vd(){let e={kernel_version:j.release(),name:`Linux`};try{let t=await Od(`/etc`),n=Id.find(e=>t.includes(e.name));if(!n)return e;let r=(await Dd(Ye(`/etc`,n.name),{encoding:`utf-8`})).toLowerCase(),{distros:i}=n;e.name=i.find(e=>r.indexOf(Bd(e))>=0)||i[0],e.version=Ld[Bd(e.name)]?.(r)}catch{}return e}function Hd(){if(process.env.VERCEL)return{"cloud.provider":`vercel`,"cloud.region":process.env.VERCEL_REGION};if(process.env.AWS_REGION)return{"cloud.provider":`aws`,"cloud.region":process.env.AWS_REGION,"cloud.platform":process.env.AWS_EXECUTION_ENV};if(process.env.GCP_PROJECT)return{"cloud.provider":`gcp`};if(process.env.ALIYUN_REGION_ID)return{"cloud.provider":`alibaba_cloud`,"cloud.region":process.env.ALIYUN_REGION_ID};if(process.env.WEBSITE_SITE_NAME&&process.env.REGION_NAME)return{"cloud.provider":`azure`,"cloud.region":process.env.REGION_NAME};if(process.env.IBM_CLOUD_REGION)return{"cloud.provider":`ibm_cloud`,"cloud.region":process.env.IBM_CLOUD_REGION};if(process.env.TENCENTCLOUD_REGION)return{"cloud.provider":`tencent_cloud`,"cloud.region":process.env.TENCENTCLOUD_REGION,"cloud.account.id":process.env.TENCENTCLOUD_APPID,"cloud.availability_zone":process.env.TENCENTCLOUD_ZONE};if(process.env.NETLIFY)return{"cloud.provider":`netlify`};if(process.env.FLY_REGION)return{"cloud.provider":`fly.io`,"cloud.region":process.env.FLY_REGION};if(process.env.DYNO)return{"cloud.provider":`heroku`}}const Ud=new Sd(10),Wd=new Sd(20);function Gd(e,t,n){let r=e.get(t);return r===void 0?(e.set(t,n),n):r}function Kd(e){return!!(e.startsWith(`node:`)||e.endsWith(`.min.js`)||e.endsWith(`.min.cjs`)||e.endsWith(`.min.mjs`)||e.startsWith(`data:`))}function qd(e){return e.lineno!==void 0&&e.lineno>1e4||e.colno!==void 0&&e.colno>1e3}function Jd(e,t){let n=Ud.get(e);if(n===void 0)return!1;for(let e=t[0];e<=t[1];e++)if(n[e]===void 0)return!1;return!0}function Yd(e,t){if(!e.length)return[];let n=0,r=e[0];if(typeof r!=`number`)return[];let i=rf(r,t),a=[];for(;;){if(n===e.length-1){a.push(i);break}let r=e[n+1];if(typeof r!=`number`)break;r<=i[1]?i[1]=r+t:(a.push(i),i=rf(r,t)),n++}return a}function Xd(e,t,n){return new Promise((r,i)=>{let a=lt(e),o=tt({input:a});function s(){a.destroy(),r()}let c=0,l=0,u=t[l];if(u===void 0){s();return}let d=u[0],f=u[1];function p(t){Wd.set(e,1),Q&&K.error(`Failed to read file: ${e}. Error: ${t}`),o.close(),o.removeAllListeners(),s()}a.on(`error`,p),o.on(`error`,p),o.on(`close`,s),o.on(`line`,e=>{if(c++,!(c<d)&&(n[c]=Ya(e,0),c>=f)){if(l===t.length-1){o.close(),o.removeAllListeners();return}l++;let e=t[l];if(e===void 0){o.close(),o.removeAllListeners();return}d=e[0],f=e[1]}})})}async function Zd(e,t){let n={};if(t>0&&e.exception?.values){for(let t of e.exception.values)if(t.stacktrace?.frames?.length)for(let e=t.stacktrace.frames.length-1;e>=0;e--){let r=t.stacktrace.frames[e],i=r?.filename;!r||typeof i!=`string`||typeof r.lineno!=`number`||Kd(i)||qd(r)||(n[i]||(n[i]=[]),n[i].push(r.lineno))}}let r=Object.keys(n);if(r.length==0)return e;let i=[];for(let e of r){if(Wd.get(e))continue;let r=n[e];if(!r)continue;r.sort((e,t)=>e-t);let a=Yd(r,t);if(a.every(t=>Jd(e,t)))continue;let o=Gd(Ud,e,{});i.push(Xd(e,a,o))}if(await Promise.all(i).catch(()=>{Q&&K.log(`Failed to read one or more source files and resolve context lines`)}),t>0&&e.exception?.values)for(let n of e.exception.values)n.stacktrace?.frames&&n.stacktrace.frames.length>0&&Qd(n.stacktrace.frames,t,Ud);return e}function Qd(e,t,n){for(let r of e)if(r.filename&&r.context_line===void 0&&typeof r.lineno==`number`){let e=n.get(r.filename);if(e===void 0)continue;ef(r.lineno,r,t,e)}}function $d(e){delete e.pre_context,delete e.context_line,delete e.post_context}function ef(e,t,n,r){if(t.lineno===void 0||r===void 0){Q&&K.error(`Cannot resolve context for frame with no lineno or file contents`);return}t.pre_context=[];for(let i=tf(e,n);i<e;i++){let e=r[i];if(e===void 0){$d(t),Q&&K.error(`Could not find line ${i} in file ${t.filename}`);return}t.pre_context.push(e)}if(r[e]===void 0){$d(t),Q&&K.error(`Could not find line ${e} in file ${t.filename}`);return}t.context_line=r[e];let i=nf(e,n);t.post_context=[];for(let n=e+1;n<=i;n++){let e=r[n];if(e===void 0)break;t.post_context.push(e)}}function tf(e,t){return Math.max(1,e-t)}function nf(e,t){return e+t}function rf(e,t){return[tf(e,t),nf(e,t)]}const af=Z(((e={})=>{let t=e.frameContextLines===void 0?7:e.frameContextLines;return{name:`ContextLines`,processEvent(e){return Zd(e,t)}}})),of=co(process.versions.node),sf=of.major;of.minor;let cf;async function lf(){if(cf===void 0)try{cf=!!(await import(`node:inspector`)).url()}catch{cf=!1}return cf}const uf=`__SENTRY_ERROR_LOCAL_VARIABLES__`;function df(e,t,n){let r=0,i=5,a=0;return setInterval(()=>{a===0?r>e&&(i*=2,n(i),i>86400&&(i=86400),a=i):(--a,a===0&&t()),r=0},1e3).unref(),()=>{r+=1}}function ff(e){return e!==void 0&&(e.length===0||e===`?`||e===`<anonymous>`)}function pf(e,t){return e===t||`Object.${e}`===t||e===`Object.${t}`||ff(e)&&ff(t)}function mf(...e){K.log(`[LocalVariables]`,...e)}const hf=Z(((e={})=>{function t(t,n){let r=(t.stacktrace?.frames||[]).filter(e=>e.function!==`new Promise`);for(let t=0;t<r.length;t++){let i=r.length-t-1,a=n[t],o=r[i];if(!o||!a)break;a.vars===void 0||o.in_app===!1&&e.includeOutOfAppFrames!==!0||!pf(o.function,a.function)||(o.vars=a.vars)}}function n(e,n){if(n.originalException&&typeof n.originalException==`object`&&uf in n.originalException&&Array.isArray(n.originalException[uf])){for(let r of e.exception?.values||[])t(r,n.originalException[uf]);n.originalException[uf]=void 0}return e}async function r(){let e=await import(`node:inspector`);e.url()||e.open(0)}function i(e){let t=new mt(new URL(`data:application/javascript;base64,LyohIEBzZW50cnkvbm9kZS1jb3JlIDEwLjQyLjAgKDA3YzkxOTApIHwgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdCAqLwppbXBvcnR7U2Vzc2lvbiBhcyBlfWZyb20ibm9kZTppbnNwZWN0b3IvcHJvbWlzZXMiO2ltcG9ydHt3b3JrZXJEYXRhIGFzIHR9ZnJvbSJub2RlOndvcmtlcl90aHJlYWRzIjtjb25zdCBuPWdsb2JhbFRoaXMsaT17fTtjb25zdCBvPSJfX1NFTlRSWV9FUlJPUl9MT0NBTF9WQVJJQUJMRVNfXyI7Y29uc3QgYT10O2Z1bmN0aW9uIHMoLi4uZSl7YS5kZWJ1ZyYmZnVuY3Rpb24oZSl7aWYoISgiY29uc29sZSJpbiBuKSlyZXR1cm4gZSgpO2NvbnN0IHQ9bi5jb25zb2xlLG89e30sYT1PYmplY3Qua2V5cyhpKTthLmZvckVhY2goZT0+e2NvbnN0IG49aVtlXTtvW2VdPXRbZV0sdFtlXT1ufSk7dHJ5e3JldHVybiBlKCl9ZmluYWxseXthLmZvckVhY2goZT0+e3RbZV09b1tlXX0pfX0oKCk9PmNvbnNvbGUubG9nKCJbTG9jYWxWYXJpYWJsZXMgV29ya2VyXSIsLi4uZSkpfWFzeW5jIGZ1bmN0aW9uIGMoZSx0LG4saSl7Y29uc3Qgbz1hd2FpdCBlLnBvc3QoIlJ1bnRpbWUuZ2V0UHJvcGVydGllcyIse29iamVjdElkOnQsb3duUHJvcGVydGllczohMH0pO2lbbl09by5yZXN1bHQuZmlsdGVyKGU9PiJsZW5ndGgiIT09ZS5uYW1lJiYhaXNOYU4ocGFyc2VJbnQoZS5uYW1lLDEwKSkpLnNvcnQoKGUsdCk9PnBhcnNlSW50KGUubmFtZSwxMCktcGFyc2VJbnQodC5uYW1lLDEwKSkubWFwKGU9PmUudmFsdWU/LnZhbHVlKX1hc3luYyBmdW5jdGlvbiByKGUsdCxuLGkpe2NvbnN0IG89YXdhaXQgZS5wb3N0KCJSdW50aW1lLmdldFByb3BlcnRpZXMiLHtvYmplY3RJZDp0LG93blByb3BlcnRpZXM6ITB9KTtpW25dPW8ucmVzdWx0Lm1hcChlPT5bZS5uYW1lLGUudmFsdWU/LnZhbHVlXSkucmVkdWNlKChlLFt0LG5dKT0+KGVbdF09bixlKSx7fSl9ZnVuY3Rpb24gdShlLHQpe2UudmFsdWUmJigidmFsdWUiaW4gZS52YWx1ZT92b2lkIDA9PT1lLnZhbHVlLnZhbHVlfHxudWxsPT09ZS52YWx1ZS52YWx1ZT90W2UubmFtZV09YDwke2UudmFsdWUudmFsdWV9PmA6dFtlLm5hbWVdPWUudmFsdWUudmFsdWU6ImRlc2NyaXB0aW9uImluIGUudmFsdWUmJiJmdW5jdGlvbiIhPT1lLnZhbHVlLnR5cGU/dFtlLm5hbWVdPWA8JHtlLnZhbHVlLmRlc2NyaXB0aW9ufT5gOiJ1bmRlZmluZWQiPT09ZS52YWx1ZS50eXBlJiYodFtlLm5hbWVdPSI8dW5kZWZpbmVkPiIpKX1hc3luYyBmdW5jdGlvbiBsKGUsdCl7Y29uc3Qgbj1hd2FpdCBlLnBvc3QoIlJ1bnRpbWUuZ2V0UHJvcGVydGllcyIse29iamVjdElkOnQsb3duUHJvcGVydGllczohMH0pLGk9e307Zm9yKGNvbnN0IHQgb2Ygbi5yZXN1bHQpaWYodC52YWx1ZT8ub2JqZWN0SWQmJiJBcnJheSI9PT10LnZhbHVlLmNsYXNzTmFtZSl7Y29uc3Qgbj10LnZhbHVlLm9iamVjdElkO2F3YWl0IGMoZSxuLHQubmFtZSxpKX1lbHNlIGlmKHQudmFsdWU/Lm9iamVjdElkJiYiT2JqZWN0Ij09PXQudmFsdWUuY2xhc3NOYW1lKXtjb25zdCBuPXQudmFsdWUub2JqZWN0SWQ7YXdhaXQgcihlLG4sdC5uYW1lLGkpfWVsc2UgdC52YWx1ZSYmdSh0LGkpO3JldHVybiBpfWxldCBmOyhhc3luYyBmdW5jdGlvbigpe2NvbnN0IHQ9bmV3IGU7dC5jb25uZWN0VG9NYWluVGhyZWFkKCkscygiQ29ubmVjdGVkIHRvIG1haW4gdGhyZWFkIik7bGV0IG49ITE7dC5vbigiRGVidWdnZXIucmVzdW1lZCIsKCk9PntuPSExfSksdC5vbigiRGVidWdnZXIucGF1c2VkIixlPT57bj0hMCxhc3luYyBmdW5jdGlvbihlLHtyZWFzb246dCxkYXRhOntvYmplY3RJZDpufSxjYWxsRnJhbWVzOml9KXtpZigiZXhjZXB0aW9uIiE9PXQmJiJwcm9taXNlUmVqZWN0aW9uIiE9PXQpcmV0dXJuO2lmKGY/LigpLG51bGw9PW4pcmV0dXJuO2NvbnN0IGE9W107Zm9yKGxldCB0PTA7dDxpLmxlbmd0aDt0Kyspe2NvbnN0e3Njb3BlQ2hhaW46bixmdW5jdGlvbk5hbWU6byx0aGlzOnN9PWlbdF0sYz1uLmZpbmQoZT0+ImxvY2FsIj09PWUudHlwZSkscj0iZ2xvYmFsIiE9PXMuY2xhc3NOYW1lJiZzLmNsYXNzTmFtZT9gJHtzLmNsYXNzTmFtZX0uJHtvfWA6bztpZih2b2lkIDA9PT1jPy5vYmplY3Qub2JqZWN0SWQpYVt0XT17ZnVuY3Rpb246cn07ZWxzZXtjb25zdCBuPWF3YWl0IGwoZSxjLm9iamVjdC5vYmplY3RJZCk7YVt0XT17ZnVuY3Rpb246cix2YXJzOm59fX1hd2FpdCBlLnBvc3QoIlJ1bnRpbWUuY2FsbEZ1bmN0aW9uT24iLHtmdW5jdGlvbkRlY2xhcmF0aW9uOmBmdW5jdGlvbigpIHsgdGhpcy4ke299ID0gdGhpcy4ke299IHx8ICR7SlNPTi5zdHJpbmdpZnkoYSl9OyB9YCxzaWxlbnQ6ITAsb2JqZWN0SWQ6bn0pLGF3YWl0IGUucG9zdCgiUnVudGltZS5yZWxlYXNlT2JqZWN0Iix7b2JqZWN0SWQ6bn0pfSh0LGUucGFyYW1zKS50aGVuKGFzeW5jKCk9PntuJiZhd2FpdCB0LnBvc3QoIkRlYnVnZ2VyLnJlc3VtZSIpfSxhc3luYyBlPT57biYmYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5yZXN1bWUiKX0pfSksYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5lbmFibGUiKTtjb25zdCBpPSExIT09YS5jYXB0dXJlQWxsRXhjZXB0aW9ucztpZihhd2FpdCB0LnBvc3QoIkRlYnVnZ2VyLnNldFBhdXNlT25FeGNlcHRpb25zIix7c3RhdGU6aT8iYWxsIjoidW5jYXVnaHQifSksaSl7Y29uc3QgZT1hLm1heEV4Y2VwdGlvbnNQZXJTZWNvbmR8fDUwO2Y9ZnVuY3Rpb24oZSx0LG4pe2xldCBpPTAsbz01LGE9MDtyZXR1cm4gc2V0SW50ZXJ2YWwoKCk9PnswPT09YT9pPmUmJihvKj0yLG4obyksbz44NjQwMCYmKG89ODY0MDApLGE9byk6KGEtPTEsMD09PWEmJnQoKSksaT0wfSwxZTMpLnVucmVmKCksKCk9PntpKz0xfX0oZSxhc3luYygpPT57cygiUmF0ZS1saW1pdCBsaWZ0ZWQuIiksYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5zZXRQYXVzZU9uRXhjZXB0aW9ucyIse3N0YXRlOiJhbGwifSl9LGFzeW5jIGU9PntzKGBSYXRlLWxpbWl0IGV4Y2VlZGVkLiBEaXNhYmxpbmcgY2FwdHVyaW5nIG9mIGNhdWdodCBleGNlcHRpb25zIGZvciAke2V9IHNlY29uZHMuYCksYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5zZXRQYXVzZU9uRXhjZXB0aW9ucyIse3N0YXRlOiJ1bmNhdWdodCJ9KX0pfX0pKCkuY2F0Y2goZT0+e3MoIkZhaWxlZCB0byBzdGFydCBkZWJ1Z2dlciIsZSl9KSxzZXRJbnRlcnZhbCgoKT0+e30sMWU0KTs=`),{workerData:e,execArgv:[],env:{...process.env,NODE_OPTIONS:void 0}});process.on(`exit`,()=>{t.terminate()}),t.once(`error`,e=>{mf(`Worker error`,e)}),t.once(`exit`,e=>{mf(`Worker exit`,e)}),t.unref()}return{name:`LocalVariablesAsync`,async setup(t){if(!t.getOptions().includeLocalVariables)return;if(await lf()){K.warn(`Local variables capture has been disabled because the debugger was already enabled`);return}let n={...e,debug:K.isEnabled()};r().then(()=>{try{i(n)}catch(e){K.error(`Failed to start worker`,e)}},e=>{K.error(`Failed to start inspector`,e)})},processEvent(e,t){return n(e,t)}}}));function gf(e){if(e!==void 0)return e.slice(-10).reduce((e,t)=>`${e},${t.function},${t.lineno},${t.colno}`,``)}function _f(e,t){if(t!==void 0)return gf(e(t,1))}function vf(e){let t=[],n=!1;function r(r){t=[],!n&&(n=!0,e(r))}t.push(r);function i(e){t.push(e)}function a(e){let n=t.pop()||r;try{n(e)}catch{r(e)}}return{add:i,next:a}}var yf=class e{constructor(e){this._session=e}static async create(t){return t||new e(new(await(import(`node:inspector`))).Session)}configureAndConnect(e,t){this._session.connect(),this._session.on(`Debugger.paused`,t=>{e(t,()=>{this._session.post(`Debugger.resume`)})}),this._session.post(`Debugger.enable`),this._session.post(`Debugger.setPauseOnExceptions`,{state:t?`all`:`uncaught`})}setPauseOnExceptions(e){this._session.post(`Debugger.setPauseOnExceptions`,{state:e?`all`:`uncaught`})}getLocalVariables(e,t){this._getProperties(e,e=>{let{add:n,next:r}=vf(t);for(let t of e)if(t.value?.objectId&&t.value.className===`Array`){let e=t.value.objectId;n(n=>this._unrollArray(e,t.name,n,r))}else if(t.value?.objectId&&t.value.className===`Object`){let e=t.value.objectId;n(n=>this._unrollObject(e,t.name,n,r))}else t.value&&n(e=>this._unrollOther(t,e,r));r({})})}_getProperties(e,t){this._session.post(`Runtime.getProperties`,{objectId:e,ownProperties:!0},(e,n)=>{t(e?[]:n.result)})}_unrollArray(e,t,n,r){this._getProperties(e,e=>{n[t]=e.filter(e=>e.name!==`length`&&!isNaN(parseInt(e.name,10))).sort((e,t)=>parseInt(e.name,10)-parseInt(t.name,10)).map(e=>e.value?.value),r(n)})}_unrollObject(e,t,n,r){this._getProperties(e,e=>{n[t]=e.map(e=>[e.name,e.value?.value]).reduce((e,[t,n])=>(e[t]=n,e),{}),r(n)})}_unrollOther(e,t,n){e.value&&(`value`in e.value?e.value.value===void 0||e.value.value===null?t[e.name]=`<${e.value.value}>`:t[e.name]=e.value.value:`description`in e.value&&e.value.type!==`function`?t[e.name]=`<${e.value.description}>`:e.value.type===`undefined`&&(t[e.name]=`<undefined>`)),n(t)}};const bf=Z(((e={},t)=>{let n=new Sd(20),r,i=!1;function a(t){let r=gf(t.stacktrace?.frames);if(r===void 0)return;let i=n.remove(r);if(i===void 0)return;let a=(t.stacktrace?.frames||[]).filter(e=>e.function!==`new Promise`);for(let t=0;t<a.length;t++){let n=a.length-t-1,r=i[t],o=a[n];if(!o||!r)break;r.vars===void 0||o.in_app===!1&&e.includeOutOfAppFrames!==!0||!pf(o.function,r.function)||(o.vars=r.vars)}}function o(e){for(let t of e.exception?.values||[])a(t);return e}let s;async function c(){let a=X()?.getOptions();if(a?.includeLocalVariables){if(sf<18){K.log("The `LocalVariables` integration is only supported on Node >= v18.");return}if(await lf()){K.warn(`Local variables capture has been disabled because the debugger was already enabled`);return}try{let o=await yf.create(t),s=(e,{params:{reason:t,data:i,callFrames:a}},s)=>{if(t!==`exception`&&t!==`promiseRejection`){s();return}r?.();let c=_f(e,i.description);if(c==null){s();return}let{add:l,next:u}=vf(e=>{n.set(c,e),s()});for(let e=0;e<Math.min(a.length,5);e++){let{scopeChain:t,functionName:n,this:r}=a[e],i=t.find(e=>e.type===`local`),s=r.className===`global`||!r.className?n:`${r.className}.${n}`;if(i?.object.objectId===void 0)l(t=>{t[e]={function:s},u(t)});else{let t=i.object.objectId;l(n=>o.getLocalVariables(t,t=>{n[e]={function:s,vars:t},u(n)}))}}u([])},c=e.captureAllExceptions!==!1;o.configureAndConnect((e,t)=>s(a.stackParser,e,t),c),c&&(r=df(e.maxExceptionsPerSecond||50,()=>{K.log(`Local variables rate-limit lifted.`),o.setPauseOnExceptions(!0)},e=>{K.log(`Local variables rate-limit exceeded. Disabling capturing of caught exceptions for ${e} seconds.`),o.setPauseOnExceptions(!1)})),i=!0}catch(e){K.log("The `LocalVariables` integration failed to start.",e)}}}return{name:`LocalVariables`,setupOnce(){s=c()},async processEvent(e){return await s,i?o(e):e},_getCachedFramesCount(){return n.size},_getFirstCachedFrame(){return n.values()[0]}}})),xf=(e={})=>of.major<19?bf(e):hf(e);function Sf(){try{return typeof module<`u`&&module.exports!==void 0}catch{return!1}}let Cf;const wf=typeof __SENTRY_SERVER_MODULES__>`u`?{}:__SENTRY_SERVER_MODULES__,Tf=(()=>({name:`Modules`,processEvent(e){return e.modules={...e.modules,...kf()},e},getModules:kf}));function Ef(){try{return i.cache?Object.keys(i.cache):[]}catch{return[]}}function Df(){return{...wf,...jf(),...Sf()?Of():{}}}function Of(){let e=i.main?.paths||[],t=Ef(),n={},r=new Set;return t.forEach(t=>{let i=t,a=()=>{let t=i;if(i=Je(t),!i||t===i||r.has(t))return;if(e.indexOf(i)<0)return a();let o=Ye(t,`package.json`);if(r.add(t),!ut(o))return a();try{let e=JSON.parse(ft(o,`utf8`));n[e.name]=e.version}catch{}};a()}),n}function kf(){return Cf||=Df(),Cf}function Af(){try{let e=Ye(process.cwd(),`package.json`);return JSON.parse(ft(e,`utf8`))}catch{return{}}}function jf(){let e=Af();return{...e.dependencies,...e.devDependencies}}function Mf(e){Hi(()=>{console.error(e)});let t=X();if(t===void 0){Q&&K.warn(`No NodeClient was defined, we are exiting the process now.`),global.process.exit(1);return}let n=t.getOptions(),r=n?.shutdownTimeout&&n.shutdownTimeout>0?n.shutdownTimeout:2e3;t.close(r).then(e=>{e||Q&&K.warn(`We reached the timeout for emptying the request buffer, still exiting now!`),global.process.exit(1)},e=>{Q&&K.error(e)})}const Nf=Z((e={})=>{let t={exitEvenIfOtherHandlersAreRegistered:!1,...e};return{name:`OnUncaughtException`,setup(e){at&&global.process.on(`uncaughtException`,Pf(e,t))}}});function Pf(e,t){let n=!1,r=!1,i=!1,a,o=e.getOptions();return Object.assign(s=>{let c=Mf;t.onFatalError?c=t.onFatalError:o.onFatalError&&(c=o.onFatalError);let l=global.process.listeners(`uncaughtException`).filter(e=>e.name!==`domainUncaughtExceptionClear`&&e.tag!==`sentry_tracingErrorCallback`&&e._errorHandler!==!0).length===0,u=t.exitEvenIfOtherHandlersAreRegistered||l;n?u&&(i?(Q&&K.warn(`uncaught exception after calling fatal error shutdown callback - this is bad! forcing shutdown`),Mf(s)):r||(r=!0,setTimeout(()=>{i||(i=!0,c(a,s))},2e3))):(a=s,n=!0,X()===e&&qc(s,{originalException:s,captureContext:{level:`fatal`},mechanism:{handled:!1,type:`auto.node.onuncaughtexception`}}),!i&&u&&(i=!0,c(s)))},{_errorHandler:!0})}const Ff=[{name:`AI_NoOutputGeneratedError`},{name:`AbortError`}],If=Z(((e={})=>{let t={mode:e.mode??`warn`,ignore:[...Ff,...e.ignore??[]]};return{name:`OnUnhandledRejection`,setup(e){global.process.on(`unhandledRejection`,Bf(e,t))}}}));function Lf(e){if(typeof e!=`object`||!e)return{name:``,message:String(e??``)};let t=e;return{name:typeof t.name==`string`?t.name:``,message:typeof t.message==`string`?t.message:String(e)}}function Rf(e,t){let n=e.name===void 0||Za(t.name,e.name,!0),r=e.message===void 0||Za(t.message,e.message);return n&&r}function zf(e,t){let n=Lf(t);return e.some(e=>Rf(e,n))}function Bf(e,t){return function(n,r){if(X()!==e||zf(t.ignore??[],n))return;let i=t.mode===`strict`?`fatal`:`error`,a=n&&typeof n==`object`?n._sentry_active_span:void 0;(a?e=>pc(a,e):e=>e())(()=>{qc(n,{originalException:r,captureContext:{extra:{unhandledPromiseRejection:!0},level:i},mechanism:{handled:!1,type:`auto.node.onunhandledrejection`}})}),Vf(n,t.mode)}}function Vf(e,t){let n=`This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason:`;t===`warn`?Hi(()=>{console.warn(n),console.error(e&&typeof e==`object`&&`stack`in e?e.stack:e)}):t===`strict`&&(Hi(()=>{console.warn(n)}),Mf(e))}const Hf=Z(()=>({name:`ProcessSession`,setupOnce(){$c(),process.on(`beforeExit`,()=>{Y().getSession()?.status!==`ok`&&el()})}})),Uf=`Spotlight`,Wf=Z(((e={})=>{let t={sidecarUrl:e.sidecarUrl||`http://localhost:8969/stream`};return{name:Uf,setup(e){try{process.env.NODE_ENV&&process.env.NODE_ENV!==`development`&&K.warn(`[Spotlight] It seems you're not in dev mode. Do you really want to have Spotlight enabled?`)}catch{}Gf(e,t)}}}));function Gf(e,t){let n=Kf(t.sidecarUrl);if(!n)return;let r=0;e.on(`beforeEnvelope`,e=>{if(r>3){K.warn(`[Spotlight] Disabled Sentry -> Spotlight integration due to too many failed requests`);return}let t=tc(e);mc(()=>{let e=nt.request({method:`POST`,path:n.pathname,hostname:n.hostname,port:n.port,headers:{"Content-Type":`application/x-sentry-envelope`}},e=>{e.statusCode&&e.statusCode>=200&&e.statusCode<400&&(r=0),e.on(`data`,()=>{}),e.on(`end`,()=>{}),e.setEncoding(`utf8`)});e.on(`error`,()=>{r++,K.warn(`[Spotlight] Failed to send envelope to Spotlight Sidecar`)}),e.write(t),e.end()})})}function Kf(e){try{return new URL(`${e}`)}catch{K.warn(`[Spotlight] Invalid sidecar URL: ${e}`);return}}function qf(e){return!(e instanceof Error)||!(`errno`in e)||typeof e.errno!=`number`?!1:Ve.getSystemErrorMap().has(e.errno)}const Jf=Z((e={})=>({name:`NodeSystemError`,processEvent:(t,n,r)=>{if(!qf(n.originalException))return t;let i=n.originalException,a={...i};!r.getOptions().sendDefaultPii&&e.includePaths!==!0&&(delete a.path,delete a.dest),t.contexts={...t.contexts,node_system_error:a};for(let e of t.exception?.values||[])e.value&&(i.path&&e.value.includes(i.path)&&(e.value=e.value.replace(`'${i.path}'`,``).trim()),i.dest&&e.value.includes(i.dest)&&(e.value=e.value.replace(`'${i.dest}'`,``).trim()));return t}}));function Yf(e){return e.replace(/^[A-Z]:/,``).replace(/\\/g,`/`)}function Xf(e=process.argv[1]?fd(process.argv[1]):process.cwd(),t=Ze===`\\`){let n=t?Yf(e):e;return e=>{if(!e)return;let r=t?Yf(e):e,{dir:i,base:a,ext:o}=Xe.parse(r);(o===`.js`||o===`.mjs`||o===`.cjs`)&&(a=a.slice(0,o.length*-1));let s=decodeURIComponent(a);i||=`.`;let c=i.lastIndexOf(`/node_modules`);if(c>-1)return`${i.slice(c+14).replace(/\//g,`.`)}:${s}`;if(i.startsWith(n)){let e=i.slice(n.length+1).replace(/\//g,`.`);return e?`${e}:${s}`:s}return s}}function Zf(e){if(process.env.SENTRY_RELEASE)return process.env.SENTRY_RELEASE;if(G.SENTRY_RELEASE?.id)return G.SENTRY_RELEASE.id;let t=process.env.GITHUB_SHA||process.env.CI_MERGE_REQUEST_SOURCE_BRANCH_SHA||process.env.CI_BUILD_REF||process.env.CI_COMMIT_SHA||process.env.BITBUCKET_COMMIT,n=process.env.APPVEYOR_PULL_REQUEST_HEAD_COMMIT||process.env.APPVEYOR_REPO_COMMIT||process.env.CODEBUILD_RESOLVED_SOURCE_VERSION||process.env.AWS_COMMIT_ID||process.env.BUILD_SOURCEVERSION||process.env.GIT_CLONE_COMMIT_HASH||process.env.BUDDY_EXECUTION_REVISION||process.env.BUILDKITE_COMMIT||process.env.CIRCLE_SHA1||process.env.CIRRUS_CHANGE_IN_REPO||process.env.CF_REVISION||process.env.CM_COMMIT||process.env.CF_PAGES_COMMIT_SHA||process.env.DRONE_COMMIT_SHA||process.env.FC_GIT_COMMIT_SHA||process.env.HEROKU_TEST_RUN_COMMIT_VERSION||process.env.HEROKU_SLUG_COMMIT||process.env.RAILWAY_GIT_COMMIT_SHA||process.env.RENDER_GIT_COMMIT||process.env.SEMAPHORE_GIT_SHA||process.env.TRAVIS_PULL_REQUEST_SHA||process.env.VERCEL_GIT_COMMIT_SHA||process.env.VERCEL_GITHUB_COMMIT_SHA||process.env.VERCEL_GITLAB_COMMIT_SHA||process.env.VERCEL_BITBUCKET_COMMIT_SHA||process.env.ZEIT_GITHUB_COMMIT_SHA||process.env.ZEIT_GITLAB_COMMIT_SHA||process.env.ZEIT_BITBUCKET_COMMIT_SHA,r=process.env.CI_COMMIT_ID||process.env.SOURCE_COMMIT||process.env.SOURCE_VERSION||process.env.GIT_COMMIT||process.env.COMMIT_REF||process.env.BUILD_VCS_NUMBER||process.env.CI_COMMIT_SHA;return t||n||r||e}const Qf=$i(yd(Xf())),$f=Symbol(`AgentBaseInternalState`);var ep=class extends nt.Agent{constructor(e){super(e),this[$f]={}}isSecureEndpoint(e){if(e){if(typeof e.secureEndpoint==`boolean`)return e.secureEndpoint;if(typeof e.protocol==`string`)return e.protocol===`https:`}let{stack:t}=Error();return typeof t==`string`?t.split(`
325
- `).some(e=>e.indexOf(`(https.js:`)!==-1||e.indexOf(`node:https:`)!==-1):!1}createSocket(e,t,n){let r={...t,secureEndpoint:this.isSecureEndpoint(t)};Promise.resolve().then(()=>this.connect(e,r)).then(i=>{if(i instanceof nt.Agent)return i.addRequest(e,r);this[$f].currentSocket=i,super.createSocket(e,t,n)},n)}createConnection(){let e=this[$f].currentSocket;if(this[$f].currentSocket=void 0,!e)throw Error("No socket was returned in the `connect()` function");return e}get defaultPort(){return this[$f].defaultPort??(this.protocol===`https:`?443:80)}set defaultPort(e){this[$f]&&(this[$f].defaultPort=e)}get protocol(){return this[$f].protocol??(this.isSecureEndpoint()?`https:`:`http:`)}set protocol(e){this[$f]&&(this[$f].protocol=e)}};function tp(...e){K.log(`[https-proxy-agent:parse-proxy-response]`,...e)}function np(e){return new Promise((t,n)=>{let r=0,i=[];function a(){let t=e.read();t?l(t):e.once(`readable`,a)}function o(){e.removeListener(`end`,s),e.removeListener(`error`,c),e.removeListener(`readable`,a)}function s(){o(),tp(`onend`),n(Error(`Proxy connection ended before receiving CONNECT response`))}function c(e){o(),tp(`onerror %o`,e),n(e)}function l(s){i.push(s),r+=s.length;let c=Buffer.concat(i,r),l=c.indexOf(`\r
323
+ `,positionals:{url:{description:`Webhook URL`,required:!0}},options:{repo:{type:`string`,short:`r`,description:`Repository domain`},env:{type:`string`,short:`e`,description:`Environment domain`}}},async({positionals:e,values:t})=>{let[n]=e,{repo:r=await S(),env:i}=t,a=await k(),o=await A(),s=i?await H(i,{repo:r,token:a,host:o}):r,c;try{c=await Rn({repo:s,token:a,host:o})}catch(e){throw e instanceof w?new P(`Failed to fetch webhook details: ${await e.text()}`):e}let l=c.find(e=>e.config.url===n);if(!l)throw new P(`Webhook not found: ${n}`);let{config:u}=l;console.info(`URL: ${u.url}`),console.info(`Name: ${u.name||`(none)`}`),console.info(`Status: ${u.active?`enabled`:`disabled`}`),console.info(`Secret: ${u.secret?`(set)`:`(none)`}`);let d=[];for(let e of In)u[e]&&d.push(e);if(console.info(`Triggers: ${d.length>0?d.join(`, `):`(none)`}`),Object.keys(u.headers).length>0){console.info(`Headers:`);for(let[e,t]of Object.entries(u.headers))console.info(` ${e}: ${t}`)}else console.info(`Headers: (none)`)}),Ni=N({name:`prismic webhook`,description:`Manage webhooks in a Prismic repository.`,commands:{list:{handler:ki,description:`List all webhooks`},create:{handler:Ei,description:`Create a new webhook`},view:{handler:Mi,description:`View webhook details`},remove:{handler:Ai,description:`Delete a webhook`},enable:{handler:Oi,description:`Enable a webhook`},disable:{handler:Di,description:`Disable a webhook`},"set-triggers":{handler:ji,description:`Update webhook triggers`}}}),Pi=M({name:`prismic whoami`,description:`Show the currently logged in user.`},async()=>{let e=await y({token:await k(),host:await A()});console.info(e.email)});const Fi=me({exp:de(Ee())});function Ii(e){try{let[,t]=e.split(`.`);return t?fe(Fi,JSON.parse(Buffer.from(t,`base64url`).toString())):void 0}catch{return}}const W=typeof __SENTRY_DEBUG__>`u`||__SENTRY_DEBUG__,G=globalThis,Li=`10.42.0`;function Ri(){return zi(G),G}function zi(e){let t=e.__SENTRY__=e.__SENTRY__||{};return t.version=t.version||Li,t[Li]=t[Li]||{}}function Bi(e,t,n=G){let r=n.__SENTRY__=n.__SENTRY__||{},i=r[Li]=r[Li]||{};return i[e]||(i[e]=t())}const Vi=[`debug`,`info`,`warn`,`error`,`log`,`assert`,`trace`],Hi={};function Ui(e){if(!(`console`in G))return e();let t=G.console,n={},r=Object.keys(Hi);r.forEach(e=>{let r=Hi[e];n[e]=t[e],t[e]=r});try{return e()}finally{r.forEach(e=>{t[e]=n[e]})}}function Wi(){Zi().enabled=!0}function Gi(){Zi().enabled=!1}function Ki(){return Zi().enabled}function qi(...e){Xi(`log`,...e)}function Ji(...e){Xi(`warn`,...e)}function Yi(...e){Xi(`error`,...e)}function Xi(e,...t){W&&Ki()&&Ui(()=>{G.console[e](`Sentry Logger [${e}]:`,...t)})}function Zi(){return W?Bi(`loggerSettings`,()=>({enabled:!1})):{enabled:!1}}const K={enable:Wi,disable:Gi,isEnabled:Ki,log:qi,warn:Ji,error:Yi},Qi=/\(error: (.*)\)/,$i=/captureMessage|captureException/;function ea(...e){let t=e.sort((e,t)=>e[0]-t[0]).map(e=>e[1]);return(e,n=0,r=0)=>{let i=[],a=e.split(`
324
+ `);for(let e=n;e<a.length;e++){let n=a[e];n.length>1024&&(n=n.slice(0,1024));let o=Qi.test(n)?n.replace(Qi,`$1`):n;if(!o.match(/\S*Error: /)){for(let e of t){let t=e(o);if(t){i.push(t);break}}if(i.length>=50+r)break}}return na(i.slice(r))}}function ta(e){return Array.isArray(e)?ea(...e):e}function na(e){if(!e.length)return[];let t=Array.from(e);return/sentryWrapped/.test(ra(t).function||``)&&t.pop(),t.reverse(),$i.test(ra(t).function||``)&&(t.pop(),$i.test(ra(t).function||``)&&t.pop()),t.slice(0,50).map(e=>({...e,filename:e.filename||ra(t).filename,function:e.function||`?`}))}function ra(e){return e[e.length-1]||{}}const ia=`<anonymous>`;function aa(e){try{return!e||typeof e!=`function`?ia:e.name||ia}catch{return ia}}function oa(e){return`__v_isVNode`in e&&e.__v_isVNode?`[VueVNode]`:`[VueViewModel]`}function sa(e){let t=e?.startsWith(`file://`)?e.slice(7):e;return t?.match(/\/[A-Z]:/)&&(t=t.slice(1)),t}const ca={},la={};function ua(e,t){ca[e]=ca[e]||[],ca[e].push(t)}function da(e,t){if(!la[e]){la[e]=!0;try{t()}catch(t){W&&K.error(`Error while instrumenting ${e}`,t)}}}function fa(e,t){let n=e&&ca[e];if(n)for(let r of n)try{r(t)}catch(t){W&&K.error(`Error while triggering instrumentation handler.\nType: ${e}\nName: ${aa(r)}\nError:`,t)}}let pa=null;function ma(e){let t=`error`;ua(t,e),da(t,ha)}function ha(){pa=G.onerror,G.onerror=function(e,t,n,r,i){return fa(`error`,{column:r,error:i,line:n,msg:e,url:t}),pa?pa.apply(this,arguments):!1},G.onerror.__SENTRY_INSTRUMENTED__=!0}let ga=null;function _a(e){let t=`unhandledrejection`;ua(t,e),da(t,va)}function va(){ga=G.onunhandledrejection,G.onunhandledrejection=function(e){return fa(`unhandledrejection`,e),ga?ga.apply(this,arguments):!0},G.onunhandledrejection.__SENTRY_INSTRUMENTED__=!0}const ya=Object.prototype.toString;function ba(e){switch(ya.call(e)){case`[object Error]`:case`[object Exception]`:case`[object DOMException]`:case`[object WebAssembly.Exception]`:return!0;default:return Ma(e,Error)}}function xa(e,t){return ya.call(e)===`[object ${t}]`}function Sa(e){return xa(e,`ErrorEvent`)}function Ca(e){return xa(e,`String`)}function wa(e){return typeof e==`object`&&!!e&&`__sentry_template_string__`in e&&`__sentry_template_values__`in e}function Ta(e){return e===null||wa(e)||typeof e!=`object`&&typeof e!=`function`}function Ea(e){return xa(e,`Object`)}function Da(e){return typeof Event<`u`&&Ma(e,Event)}function Oa(e){return typeof Element<`u`&&Ma(e,Element)}function ka(e){return xa(e,`RegExp`)}function Aa(e){return!!(e?.then&&typeof e.then==`function`)}function ja(e){return Ea(e)&&`nativeEvent`in e&&`preventDefault`in e&&`stopPropagation`in e}function Ma(e,t){try{return e instanceof t}catch{return!1}}function Na(e){return!!(typeof e==`object`&&e&&(e.__isVue||e._isVue||e.__v_isVNode))}const Pa=G;function Fa(e,t={}){if(!e)return`<unknown>`;try{let n=e,r=[],i=0,a=0,o,s=Array.isArray(t)?t:t.keyAttrs,c=!Array.isArray(t)&&t.maxStringLength||80;for(;n&&i++<5&&(o=Ia(n,s),!(o===`html`||i>1&&a+r.length*3+o.length>=c));)r.push(o),a+=o.length,n=n.parentNode;return r.reverse().join(` > `)}catch{return`<unknown>`}}function Ia(e,t){let n=e,r=[];if(!n?.tagName)return``;if(Pa.HTMLElement&&n instanceof HTMLElement&&n.dataset){if(n.dataset.sentryComponent)return n.dataset.sentryComponent;if(n.dataset.sentryElement)return n.dataset.sentryElement}r.push(n.tagName.toLowerCase());let i=t?.length?t.filter(e=>n.getAttribute(e)).map(e=>[e,n.getAttribute(e)]):null;if(i?.length)i.forEach(e=>{r.push(`[${e[0]}="${e[1]}"]`)});else{n.id&&r.push(`#${n.id}`);let e=n.className;if(e&&Ca(e)){let t=e.split(/\s+/);for(let e of t)r.push(`.${e}`)}}for(let e of[`aria-label`,`type`,`name`,`title`,`alt`]){let t=n.getAttribute(e);t&&r.push(`[${e}="${t}"]`)}return r.join(``)}function La(e,t,n){if(!(t in e))return;let r=e[t];if(typeof r!=`function`)return;let i=n(r);typeof i==`function`&&za(i,r);try{e[t]=i}catch{W&&K.log(`Failed to replace method "${t}" in object`,e)}}function Ra(e,t,n){try{Object.defineProperty(e,t,{value:n,writable:!0,configurable:!0})}catch{W&&K.log(`Failed to add non-enumerable property "${t}" to object`,e)}}function za(e,t){try{e.prototype=t.prototype=t.prototype||{},Ra(e,`__sentry_original__`,t)}catch{}}function Ba(e){return e.__sentry_original__}function Va(e){if(ba(e))return{message:e.message,name:e.name,stack:e.stack,...Ua(e)};if(Da(e)){let t={type:e.type,target:Ha(e.target),currentTarget:Ha(e.currentTarget),...Ua(e)};return typeof CustomEvent<`u`&&Ma(e,CustomEvent)&&(t.detail=e.detail),t}else return e}function Ha(e){try{return Oa(e)?Fa(e):Object.prototype.toString.call(e)}catch{return`<unknown>`}}function Ua(e){if(typeof e==`object`&&e){let t={};for(let n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t}else return{}}function Wa(e){let t=Object.keys(Va(e));return t.sort(),t[0]?t.join(`, `):`[object has no keys]`}let Ga;function Ka(e){if(Ga!==void 0)return Ga?Ga(e):e();let t=Symbol.for(`__SENTRY_SAFE_RANDOM_ID_WRAPPER__`),n=G;return t in n&&typeof n[t]==`function`?(Ga=n[t],Ga(e)):(Ga=null,e())}function qa(){return Ka(()=>Math.random())}function Ja(){return Ka(()=>Date.now())}function Ya(e,t=0){return typeof e!=`string`||t===0||e.length<=t?e:`${e.slice(0,t)}...`}function Xa(e,t){let n=e,r=n.length;if(r<=150)return n;t>r&&(t=r);let i=Math.max(t-60,0);i<5&&(i=0);let a=Math.min(i+140,r);return a>r-5&&(a=r),a===r&&(i=Math.max(a-140,0)),n=n.slice(i,a),i>0&&(n=`'{snip} ${n}`),a<r&&(n+=` {snip}`),n}function Za(e,t){if(!Array.isArray(e))return``;let n=[];for(let t=0;t<e.length;t++){let r=e[t];try{Na(r)?n.push(oa(r)):n.push(String(r))}catch{n.push(`[value cannot be serialized]`)}}return n.join(t)}function Qa(e,t,n=!1){return Ca(e)?ka(t)?t.test(e):Ca(t)?n?e===t:e.includes(t):!1:!1}function $a(e,t=[],n=!1){return t.some(t=>Qa(e,t,n))}function eo(){let e=G;return e.crypto||e.msCrypto}let to;function no(){return qa()*16}function q(e=eo()){try{if(e?.randomUUID)return Ka(()=>e.randomUUID()).replace(/-/g,``)}catch{}return to||=`10000000100040008000100000000000`,to.replace(/[018]/g,e=>(e^(no()&15)>>e/4).toString(16))}function ro(e){return e.exception?.values?.[0]}function io(e){let{message:t,event_id:n}=e;if(t)return t;let r=ro(e);return r?r.type&&r.value?`${r.type}: ${r.value}`:r.type||r.value||n||`<unknown>`:n||`<unknown>`}function ao(e,t,n){let r=e.exception=e.exception||{},i=r.values=r.values||[],a=i[0]=i[0]||{};a.value||=t||``,a.type||=n||`Error`}function oo(e,t){let n=ro(e);if(!n)return;let r={type:`generic`,handled:!0},i=n.mechanism;if(n.mechanism={...r,...i,...t},t&&`data`in t){let e={...i?.data,...t.data};n.mechanism.data=e}}const so=/^(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/;function co(e){return parseInt(e||``,10)}function lo(e){let t=e.match(so)||[],n=co(t[1]),r=co(t[2]),i=co(t[3]);return{buildmetadata:t[5],major:isNaN(n)?void 0:n,minor:isNaN(r)?void 0:r,patch:isNaN(i)?void 0:i,prerelease:t[4]}}function uo(e){if(fo(e))return!0;try{Ra(e,`__sentry_captured__`,!0)}catch{}return!1}function fo(e){try{return e.__sentry_captured__}catch{}}const po=1e3;function mo(){return Ja()/po}function ho(){let{performance:e}=G;if(!e?.now||!e.timeOrigin)return mo;let t=e.timeOrigin;return()=>(t+Ka(()=>e.now()))/po}let go;function _o(){return(go??=ho())()}function vo(e){let t=_o(),n={sid:q(),init:!0,timestamp:t,started:t,duration:0,status:`ok`,errors:0,ignoreDuration:!1,toJSON:()=>xo(n)};return e&&yo(n,e),n}function yo(e,t={}){if(t.user&&(!e.ipAddress&&t.user.ip_address&&(e.ipAddress=t.user.ip_address),!e.did&&!t.did&&(e.did=t.user.id||t.user.email||t.user.username)),e.timestamp=t.timestamp||_o(),t.abnormal_mechanism&&(e.abnormal_mechanism=t.abnormal_mechanism),t.ignoreDuration&&(e.ignoreDuration=t.ignoreDuration),t.sid&&(e.sid=t.sid.length===32?t.sid:q()),t.init!==void 0&&(e.init=t.init),!e.did&&t.did&&(e.did=`${t.did}`),typeof t.started==`number`&&(e.started=t.started),e.ignoreDuration)e.duration=void 0;else if(typeof t.duration==`number`)e.duration=t.duration;else{let t=e.timestamp-e.started;e.duration=t>=0?t:0}t.release&&(e.release=t.release),t.environment&&(e.environment=t.environment),!e.ipAddress&&t.ipAddress&&(e.ipAddress=t.ipAddress),!e.userAgent&&t.userAgent&&(e.userAgent=t.userAgent),typeof t.errors==`number`&&(e.errors=t.errors),t.status&&(e.status=t.status)}function bo(e,t){let n={};t?n={status:t}:e.status===`ok`&&(n={status:`exited`}),yo(e,n)}function xo(e){return{sid:`${e.sid}`,init:e.init,started:new Date(e.started*1e3).toISOString(),timestamp:new Date(e.timestamp*1e3).toISOString(),status:e.status,errors:e.errors,did:typeof e.did==`number`||typeof e.did==`string`?`${e.did}`:void 0,duration:e.duration,abnormal_mechanism:e.abnormal_mechanism,attrs:{release:e.release,environment:e.environment,ip_address:e.ipAddress,user_agent:e.userAgent}}}function So(e,t,n=2){if(!t||typeof t!=`object`||n<=0)return t;if(e&&Object.keys(t).length===0)return e;let r={...e};for(let e in t)Object.prototype.hasOwnProperty.call(t,e)&&(r[e]=So(r[e],t[e],n-1));return r}function Co(){return q()}function wo(){return q().substring(16)}const To=`_sentrySpan`;function Eo(e,t){t?Ra(e,To,t):delete e[To]}function Do(e){return e[To]}var Oo=class e{constructor(){this._notifyingListeners=!1,this._scopeListeners=[],this._eventProcessors=[],this._breadcrumbs=[],this._attachments=[],this._user={},this._tags={},this._attributes={},this._extra={},this._contexts={},this._sdkProcessingMetadata={},this._propagationContext={traceId:Co(),sampleRand:qa()}}clone(){let t=new e;return t._breadcrumbs=[...this._breadcrumbs],t._tags={...this._tags},t._attributes={...this._attributes},t._extra={...this._extra},t._contexts={...this._contexts},this._contexts.flags&&(t._contexts.flags={values:[...this._contexts.flags.values]}),t._user=this._user,t._level=this._level,t._session=this._session,t._transactionName=this._transactionName,t._fingerprint=this._fingerprint,t._eventProcessors=[...this._eventProcessors],t._attachments=[...this._attachments],t._sdkProcessingMetadata={...this._sdkProcessingMetadata},t._propagationContext={...this._propagationContext},t._client=this._client,t._lastEventId=this._lastEventId,t._conversationId=this._conversationId,Eo(t,Do(this)),t}setClient(e){this._client=e}setLastEventId(e){this._lastEventId=e}getClient(){return this._client}lastEventId(){return this._lastEventId}addScopeListener(e){this._scopeListeners.push(e)}addEventProcessor(e){return this._eventProcessors.push(e),this}setUser(e){return this._user=e||{email:void 0,id:void 0,ip_address:void 0,username:void 0},this._session&&yo(this._session,{user:e}),this._notifyScopeListeners(),this}getUser(){return this._user}setConversationId(e){return this._conversationId=e||void 0,this._notifyScopeListeners(),this}setTags(e){return this._tags={...this._tags,...e},this._notifyScopeListeners(),this}setTag(e,t){return this.setTags({[e]:t})}setAttributes(e){return this._attributes={...this._attributes,...e},this._notifyScopeListeners(),this}setAttribute(e,t){return this.setAttributes({[e]:t})}removeAttribute(e){return e in this._attributes&&(delete this._attributes[e],this._notifyScopeListeners()),this}setExtras(e){return this._extra={...this._extra,...e},this._notifyScopeListeners(),this}setExtra(e,t){return this._extra={...this._extra,[e]:t},this._notifyScopeListeners(),this}setFingerprint(e){return this._fingerprint=e,this._notifyScopeListeners(),this}setLevel(e){return this._level=e,this._notifyScopeListeners(),this}setTransactionName(e){return this._transactionName=e,this._notifyScopeListeners(),this}setContext(e,t){return t===null?delete this._contexts[e]:this._contexts[e]=t,this._notifyScopeListeners(),this}setSession(e){return e?this._session=e:delete this._session,this._notifyScopeListeners(),this}getSession(){return this._session}update(t){if(!t)return this;let n=typeof t==`function`?t(this):t,{tags:r,attributes:i,extra:a,user:o,contexts:s,level:c,fingerprint:l=[],propagationContext:u,conversationId:d}=(n instanceof e?n.getScopeData():Ea(n)?t:void 0)||{};return this._tags={...this._tags,...r},this._attributes={...this._attributes,...i},this._extra={...this._extra,...a},this._contexts={...this._contexts,...s},o&&Object.keys(o).length&&(this._user=o),c&&(this._level=c),l.length&&(this._fingerprint=l),u&&(this._propagationContext=u),d&&(this._conversationId=d),this}clear(){return this._breadcrumbs=[],this._tags={},this._attributes={},this._extra={},this._user={},this._contexts={},this._level=void 0,this._transactionName=void 0,this._fingerprint=void 0,this._session=void 0,this._conversationId=void 0,Eo(this,void 0),this._attachments=[],this.setPropagationContext({traceId:Co(),sampleRand:qa()}),this._notifyScopeListeners(),this}addBreadcrumb(e,t){let n=typeof t==`number`?t:100;if(n<=0)return this;let r={timestamp:mo(),...e,message:e.message?Ya(e.message,2048):e.message};return this._breadcrumbs.push(r),this._breadcrumbs.length>n&&(this._breadcrumbs=this._breadcrumbs.slice(-n),this._client?.recordDroppedEvent(`buffer_overflow`,`log_item`)),this._notifyScopeListeners(),this}getLastBreadcrumb(){return this._breadcrumbs[this._breadcrumbs.length-1]}clearBreadcrumbs(){return this._breadcrumbs=[],this._notifyScopeListeners(),this}addAttachment(e){return this._attachments.push(e),this}clearAttachments(){return this._attachments=[],this}getScopeData(){return{breadcrumbs:this._breadcrumbs,attachments:this._attachments,contexts:this._contexts,tags:this._tags,attributes:this._attributes,extra:this._extra,user:this._user,level:this._level,fingerprint:this._fingerprint||[],eventProcessors:this._eventProcessors,propagationContext:this._propagationContext,sdkProcessingMetadata:this._sdkProcessingMetadata,transactionName:this._transactionName,span:Do(this),conversationId:this._conversationId}}setSDKProcessingMetadata(e){return this._sdkProcessingMetadata=So(this._sdkProcessingMetadata,e,2),this}setPropagationContext(e){return this._propagationContext=e,this}getPropagationContext(){return this._propagationContext}captureException(e,t){let n=t?.event_id||q();if(!this._client)return W&&K.warn(`No client configured on scope - will not capture exception!`),n;let r=Error(`Sentry syntheticException`);return this._client.captureException(e,{originalException:e,syntheticException:r,...t,event_id:n},this),n}captureMessage(e,t,n){let r=n?.event_id||q();if(!this._client)return W&&K.warn(`No client configured on scope - will not capture message!`),r;let i=n?.syntheticException??Error(e);return this._client.captureMessage(e,t,{originalException:e,syntheticException:i,...n,event_id:r},this),r}captureEvent(e,t){let n=e.event_id||t?.event_id||q();return this._client?(this._client.captureEvent(e,{...t,event_id:n},this),n):(W&&K.warn(`No client configured on scope - will not capture event!`),n)}_notifyScopeListeners(){this._notifyingListeners||=(this._notifyingListeners=!0,this._scopeListeners.forEach(e=>{e(this)}),!1)}};function ko(){return Bi(`defaultCurrentScope`,()=>new Oo)}function Ao(){return Bi(`defaultIsolationScope`,()=>new Oo)}var jo=class{constructor(e,t){let n;n=e||new Oo;let r;r=t||new Oo,this._stack=[{scope:n}],this._isolationScope=r}withScope(e){let t=this._pushScope(),n;try{n=e(t)}catch(e){throw this._popScope(),e}return Aa(n)?n.then(e=>(this._popScope(),e),e=>{throw this._popScope(),e}):(this._popScope(),n)}getClient(){return this.getStackTop().client}getScope(){return this.getStackTop().scope}getIsolationScope(){return this._isolationScope}getStackTop(){return this._stack[this._stack.length-1]}_pushScope(){let e=this.getScope().clone();return this._stack.push({client:this.getClient(),scope:e}),e}_popScope(){return this._stack.length<=1?!1:!!this._stack.pop()}};function Mo(){let e=zi(Ri());return e.stack=e.stack||new jo(ko(),Ao())}function No(e){return Mo().withScope(e)}function Po(e,t){let n=Mo();return n.withScope(()=>(n.getStackTop().scope=e,t(e)))}function Fo(e){return Mo().withScope(()=>e(Mo().getIsolationScope()))}function Io(){return{withIsolationScope:Fo,withScope:No,withSetScope:Po,withSetIsolationScope:(e,t)=>Fo(t),getCurrentScope:()=>Mo().getScope(),getIsolationScope:()=>Mo().getIsolationScope()}}function Lo(e){let t=zi(Ri());t.acs=e}function Ro(e){let t=zi(e);return t.acs?t.acs:Io()}function J(){return Ro(Ri()).getCurrentScope()}function Y(){return Ro(Ri()).getIsolationScope()}function zo(){return Bi(`globalScope`,()=>new Oo)}function Bo(...e){let t=Ro(Ri());if(e.length===2){let[n,r]=e;return n?t.withSetScope(n,r):t.withScope(r)}return t.withScope(e[0])}function Vo(...e){let t=Ro(Ri());if(e.length===2){let[n,r]=e;return n?t.withSetIsolationScope(n,r):t.withIsolationScope(r)}return t.withIsolationScope(e[0])}function X(){return J().getClient()}function Ho(e){let{traceId:t,parentSpanId:n,propagationSpanId:r}=e.getPropagationContext(),i={trace_id:t,span_id:r||wo()};return n&&(i.parent_span_id=n),i}const Uo=`sentry.profile_id`,Wo=`sentry.exclusive_time`;function Go(e){if(e){if(typeof e==`object`&&`deref`in e&&typeof e.deref==`function`)try{return e.deref()}catch{return}return e}}function Ko(e){let t=e;return{scope:t._sentryScope,isolationScope:Go(t._sentryIsolationScope)}}const qo=/^sentry-/;function Jo(e){let t=Xo(e);if(!t)return;let n=Object.entries(t).reduce((e,[t,n])=>{if(t.match(qo)){let r=t.slice(7);e[r]=n}return e},{});if(Object.keys(n).length>0)return n}function Yo(e){if(e)return Qo(Object.entries(e).reduce((e,[t,n])=>(n&&(e[`sentry-${t}`]=n),e),{}))}function Xo(e){if(!(!e||!Ca(e)&&!Array.isArray(e)))return Array.isArray(e)?e.reduce((e,t)=>{let n=Zo(t);return Object.entries(n).forEach(([t,n])=>{e[t]=n}),e},{}):Zo(e)}function Zo(e){return e.split(`,`).map(e=>{let t=e.indexOf(`=`);return t===-1?[]:[e.slice(0,t),e.slice(t+1)].map(e=>{try{return decodeURIComponent(e.trim())}catch{return}})}).reduce((e,[t,n])=>(t&&n&&(e[t]=n),e),{})}function Qo(e){if(Object.keys(e).length!==0)return Object.entries(e).reduce((e,[t,n],r)=>{let i=`${encodeURIComponent(t)}=${encodeURIComponent(n)}`,a=r===0?i:`${e},${i}`;return a.length>8192?(W&&K.warn(`Not adding key: ${t} with val: ${n} to baggage header due to exceeding baggage size limits.`),e):a},``)}const $o=/^o(\d+)\./,es=/^(?:(\w+):)\/\/(?:(\w+)(?::(\w+)?)?@)((?:\[[:.%\w]+\]|[\w.-]+))(?::(\d+))?\/(.+)/;function ts(e){return e===`http`||e===`https`}function ns(e,t=!1){let{host:n,path:r,pass:i,port:a,projectId:o,protocol:s,publicKey:c}=e;return`${s}://${c}${t&&i?`:${i}`:``}@${n}${a?`:${a}`:``}/${r&&`${r}/`}${o}`}function rs(e){let t=es.exec(e);if(!t){Ui(()=>{console.error(`Invalid Sentry Dsn: ${e}`)});return}let[n,r,i=``,a=``,o=``,s=``]=t.slice(1),c=``,l=s,u=l.split(`/`);if(u.length>1&&(c=u.slice(0,-1).join(`/`),l=u.pop()),l){let e=l.match(/^\d+/);e&&(l=e[0])}return is({host:a,pass:i,path:c,projectId:l,port:o,protocol:n,publicKey:r})}function is(e){return{protocol:e.protocol,publicKey:e.publicKey||``,pass:e.pass||``,host:e.host,port:e.port||``,path:e.path||``,projectId:e.projectId}}function as(e){if(!W)return!0;let{port:t,projectId:n,protocol:r}=e;return[`protocol`,`publicKey`,`host`,`projectId`].find(t=>e[t]?!1:(K.error(`Invalid Sentry Dsn: ${t} missing`),!0))?!1:n.match(/^\d+$/)?ts(r)?t&&isNaN(parseInt(t,10))?(K.error(`Invalid Sentry Dsn: Invalid port ${t}`),!1):!0:(K.error(`Invalid Sentry Dsn: Invalid protocol ${r}`),!1):(K.error(`Invalid Sentry Dsn: Invalid projectId ${n}`),!1)}function os(e){return e.match($o)?.[1]}function ss(e){let t=e.getOptions(),{host:n}=e.getDsn()||{},r;return t.orgId?r=String(t.orgId):n&&(r=os(n)),r}function cs(e){let t=typeof e==`string`?rs(e):is(e);if(!(!t||!as(t)))return t}function ls(e){if(typeof e==`boolean`)return Number(e);let t=typeof e==`string`?parseFloat(e):e;if(!(typeof t!=`number`||isNaN(t)||t<0||t>1))return t}const us=RegExp(`^[ \\t]*([0-9a-f]{32})?-?([0-9a-f]{16})?-?([01])?[ \\t]*$`);function ds(e){if(!e)return;let t=e.match(us);if(!t)return;let n;return t[3]===`1`?n=!0:t[3]===`0`&&(n=!1),{traceId:t[1],parentSampled:n,parentSpanId:t[2]}}function fs(e,t){let n=ds(e),r=Jo(t);if(!n?.traceId)return{traceId:Co(),sampleRand:qa()};let i=hs(n,r);r&&(r.sample_rand=i.toString());let{traceId:a,parentSpanId:o,parentSampled:s}=n;return{traceId:a,parentSpanId:o,sampled:s,dsc:r||{},sampleRand:i}}function ps(e=Co(),t=wo(),n){let r=``;return n!==void 0&&(r=n?`-1`:`-0`),`${e}-${t}${r}`}function ms(e=Co(),t=wo(),n){return`00-${e}-${t}-${n?`01`:`00`}`}function hs(e,t){let n=ls(t?.sample_rand);if(n!==void 0)return n;let r=ls(t?.sample_rate);return r&&e?.parentSampled!==void 0?e.parentSampled?qa()*r:r+qa()*(1-r):qa()}function gs(e,t){let n=ss(e);return t&&n&&t!==n?(K.log(`Won't continue trace because org IDs don't match (incoming baggage: ${t}, SDK options: ${n})`),!1):e.getOptions().strictTraceContinuation&&(t&&!n||!t&&n)?(K.log(`Starting a new trace because strict trace continuation is enabled but one org ID is missing (incoming baggage: ${t}, Sentry client: ${n})`),!1):!0}let _s=!1;function vs(e){let{spanId:t,traceId:n,isRemote:r}=e.spanContext(),i=r?t:ws(e).parent_span_id,a=Ko(e).scope;return{parent_span_id:i,span_id:r?a?.getPropagationContext().propagationSpanId||wo():t,trace_id:n}}function ys(e){let{traceId:t,spanId:n}=e.spanContext();return ps(t,n,Ds(e))}function bs(e){let{traceId:t,spanId:n}=e.spanContext();return ms(t,n,Ds(e))}function xs(e){if(e&&e.length>0)return e.map(({context:{spanId:e,traceId:t,traceFlags:n,...r},attributes:i})=>({span_id:e,trace_id:t,sampled:n===1,attributes:i,...r}))}function Ss(e){return typeof e==`number`?Cs(e):Array.isArray(e)?e[0]+e[1]/1e9:e instanceof Date?Cs(e.getTime()):_o()}function Cs(e){return e>9999999999?e/1e3:e}function ws(e){if(Es(e))return e.getSpanJSON();let{spanId:t,traceId:n}=e.spanContext();if(Ts(e)){let{attributes:r,startTime:i,name:a,endTime:o,status:s,links:c}=e;return{span_id:t,trace_id:n,data:r,description:a,parent_span_id:`parentSpanId`in e?e.parentSpanId:`parentSpanContext`in e?e.parentSpanContext?.spanId:void 0,start_timestamp:Ss(i),timestamp:Ss(o)||void 0,status:Os(s),op:r[`sentry.op`],origin:r[`sentry.origin`],links:xs(c)}}return{span_id:t,trace_id:n,start_timestamp:0,data:{}}}function Ts(e){let t=e;return!!t.attributes&&!!t.startTime&&!!t.name&&!!t.endTime&&!!t.status}function Es(e){return typeof e.getSpanJSON==`function`}function Ds(e){let{traceFlags:t}=e.spanContext();return t===1}function Os(e){if(!(!e||e.code===0))return e.code===1?`ok`:e.message||`internal_error`}function ks(e){return e._sentryRootSpan||e}function As(){let e=Ro(Ri());return e.getActiveSpan?e.getActiveSpan():Do(J())}function js(){_s||=(Ui(()=>{console.warn("[Sentry] Returning null from `beforeSendSpan` is disallowed. To drop certain spans, configure the respective integrations directly or use `ignoreSpans`.")}),!0)}let Ms=!1;function Ns(){if(Ms)return;function e(){let e=As(),t=e&&ks(e);if(t){let e=`internal_error`;W&&K.log(`[Tracing] Root span: ${e} -> Global error occurred`),t.setStatus({code:2,message:e})}}e.tag=`sentry_tracingErrorCallback`,Ms=!0,ma(e),_a(e)}function Ps(e){if(typeof __SENTRY_TRACING__==`boolean`&&!__SENTRY_TRACING__)return!1;let t=e||X()?.getOptions();return!!t&&(t.tracesSampleRate!=null||!!t.tracesSampler)}function Fs(e){K.log(`Ignoring span ${e.op} - ${e.description} because it matches \`ignoreSpans\`.`)}function Is(e,t){if(!t?.length||!e.description)return!1;for(let n of t){if(Rs(n)){if(Qa(e.description,n))return W&&Fs(e),!0;continue}if(!n.name&&!n.op)continue;let t=n.name?Qa(e.description,n.name):!0,r=n.op?e.op&&Qa(e.op,n.op):!0;if(t&&r)return W&&Fs(e),!0}return!1}function Ls(e,t){let n=t.parent_span_id,r=t.span_id;if(n)for(let t of e)t.parent_span_id===r&&(t.parent_span_id=n)}function Rs(e){return typeof e==`string`||e instanceof RegExp}const zs=`production`;function Bs(e,t){let n=t.getOptions(),{publicKey:r}=t.getDsn()||{},i={environment:n.environment||zs,release:n.release,public_key:r,trace_id:e,org_id:ss(t)};return t.emit(`createDsc`,i),i}function Vs(e,t){let n=t.getPropagationContext();return n.dsc||Bs(n.traceId,e)}function Hs(e){let t=X();if(!t)return{};let n=ks(e),r=ws(n),i=r.data,a=n.spanContext().traceState,o=a?.get(`sentry.sample_rate`)??i[`sentry.sample_rate`]??i[`sentry.previous_trace_sample_rate`];function s(e){return(typeof o==`number`||typeof o==`string`)&&(e.sample_rate=`${o}`),e}let c=n._frozenDsc;if(c)return s(c);let l=a?.get(`sentry.dsc`),u=l&&Jo(l);if(u)return s(u);let d=Bs(e.spanContext().traceId,t),f=i[`sentry.source`],p=r.description;return f!==`url`&&p&&(d.transaction=p),Ps()&&(d.sampled=String(Ds(n)),d.sample_rand=a?.get(`sentry.sample_rand`)??Ko(n).scope?.getPropagationContext().sampleRand.toString()),s(d),t.emit(`createDsc`,d,n),d}function Us(e,t=100,n=1/0){try{return Gs(``,e,t,n)}catch(e){return{ERROR:`**non-serializable** (${e})`}}}function Ws(e,t=3,n=100*1024){let r=Us(e,t);return Ys(r)>n?Ws(e,t-1,n):r}function Gs(e,t,n=1/0,r=1/0,i=Xs()){let[a,o]=i;if(t==null||[`boolean`,`string`].includes(typeof t)||typeof t==`number`&&Number.isFinite(t))return t;let s=Ks(e,t);if(!s.startsWith(`[object `))return s;if(t.__sentry_skip_normalization__)return t;let c=typeof t.__sentry_override_normalization_depth__==`number`?t.__sentry_override_normalization_depth__:n;if(c===0)return s.replace(`object `,``);if(a(t))return`[Circular ~]`;let l=t;if(l&&typeof l.toJSON==`function`)try{return Gs(``,l.toJSON(),c-1,r,i)}catch{}let u=Array.isArray(t)?[]:{},d=0,f=Va(t);for(let e in f){if(!Object.prototype.hasOwnProperty.call(f,e))continue;if(d>=r){u[e]=`[MaxProperties ~]`;break}let t=f[e];u[e]=Gs(e,t,c-1,r,i),d++}return o(t),u}function Ks(e,t){try{if(e===`domain`&&t&&typeof t==`object`&&t._events)return`[Domain]`;if(e===`domainEmitter`)return`[DomainEmitter]`;if(typeof global<`u`&&t===global)return`[Global]`;if(typeof window<`u`&&t===window)return`[Window]`;if(typeof document<`u`&&t===document)return`[Document]`;if(Na(t))return oa(t);if(ja(t))return`[SyntheticEvent]`;if(typeof t==`number`&&!Number.isFinite(t))return`[${t}]`;if(typeof t==`function`)return`[Function: ${aa(t)}]`;if(typeof t==`symbol`)return`[${String(t)}]`;if(typeof t==`bigint`)return`[BigInt: ${String(t)}]`;let n=qs(t);return/^HTML(\w*)Element$/.test(n)?`[HTMLElement: ${n}]`:`[object ${n}]`}catch(e){return`**non-serializable** (${e})`}}function qs(e){let t=Object.getPrototypeOf(e);return t?.constructor?t.constructor.name:`null prototype`}function Js(e){return~-encodeURI(e).split(/%..|./).length}function Ys(e){return Js(JSON.stringify(e))}function Xs(){let e=new WeakSet;function t(t){return e.has(t)?!0:(e.add(t),!1)}function n(t){e.delete(t)}return[t,n]}function Zs(e,t=[]){return[e,t]}function Qs(e,t){let[n,r]=e;return[n,[...r,t]]}function $s(e,t){let n=e[1];for(let e of n){let n=e[0].type;if(t(e,n))return!0}return!1}function ec(e,t){return $s(e,(e,n)=>t.includes(n))}function tc(e){let t=zi(G);return t.encodePolyfill?t.encodePolyfill(e):new TextEncoder().encode(e)}function nc(e){let[t,n]=e,r=JSON.stringify(t);function i(e){typeof r==`string`?r=typeof e==`string`?r+e:[tc(r),e]:r.push(typeof e==`string`?tc(e):e)}for(let e of n){let[t,n]=e;if(i(`\n${JSON.stringify(t)}\n`),typeof n==`string`||n instanceof Uint8Array)i(n);else{let e;try{e=JSON.stringify(n)}catch{e=JSON.stringify(Us(n))}i(e)}}return typeof r==`string`?r:rc(r)}function rc(e){let t=e.reduce((e,t)=>e+t.length,0),n=new Uint8Array(t),r=0;for(let t of e)n.set(t,r),r+=t.length;return n}function ic(e){let t=typeof e.data==`string`?tc(e.data):e.data;return[{type:`attachment`,length:t.length,filename:e.filename,content_type:e.contentType,attachment_type:e.attachmentType},t]}const ac={session:`session`,sessions:`session`,attachment:`attachment`,transaction:`transaction`,event:`error`,client_report:`internal`,user_report:`default`,profile:`profile`,profile_chunk:`profile`,replay_event:`replay`,replay_recording:`replay`,check_in:`monitor`,feedback:`feedback`,span:`span`,raw_security:`security`,log:`log_item`,metric:`metric`,trace_metric:`metric`};function oc(e){return ac[e]}function sc(e){if(!e?.sdk)return;let{name:t,version:n}=e.sdk;return{name:t,version:n}}function cc(e,t,n,r){let i=e.sdkProcessingMetadata?.dynamicSamplingContext;return{event_id:e.event_id,sent_at:new Date().toISOString(),...t&&{sdk:t},...!!n&&r&&{dsn:ns(r)},...i&&{trace:i}}}function lc(e,t){if(!t)return e;let n=e.sdk||{};return e.sdk={...n,name:n.name||t.name,version:n.version||t.version,integrations:[...e.sdk?.integrations||[],...t.integrations||[]],packages:[...e.sdk?.packages||[],...t.packages||[]],settings:e.sdk?.settings||t.settings?{...e.sdk?.settings,...t.settings}:void 0},e}function uc(e,t,n,r){let i=sc(n);return Zs({sent_at:new Date().toISOString(),...i&&{sdk:i},...!!r&&t&&{dsn:ns(t)}},[`aggregates`in e?[{type:`sessions`},e]:[{type:`session`},e.toJSON()]])}function dc(e,t,n,r){let i=sc(n),a=e.type&&e.type!==`replay_event`?e.type:`event`;lc(e,n?.sdk);let o=cc(e,i,r,t);return delete e.sdkProcessingMetadata,Zs(o,[[{type:a},e]])}const fc=`__SENTRY_SUPPRESS_TRACING__`,pc=(e,t)=>{let n=Ro(Ri());if(n.continueTrace)return n.continueTrace(e,t);let{sentryTrace:r,baggage:i}=e,a=X(),o=Jo(i);return a&&!gs(a,o?.org_id)?gc(t):Bo(e=>{let n=fs(r,i);return e.setPropagationContext(n),Eo(e,void 0),t()})};function mc(e,t){let n=_c();return n.withActiveSpan?n.withActiveSpan(e,t):Bo(n=>(Eo(n,e||void 0),t(n)))}function hc(e){let t=_c();return t.suppressTracing?t.suppressTracing(e):Bo(t=>{t.setSDKProcessingMetadata({[fc]:!0});let n=e();return t.setSDKProcessingMetadata({[fc]:void 0}),n})}function gc(e){return Bo(t=>(t.setPropagationContext({traceId:Co(),sampleRand:qa()}),W&&K.log(`Starting a new trace with id ${t.getPropagationContext().traceId}`),mc(null,e)))}function _c(){return Ro(Ri())}function vc(e){return new bc(t=>{t(e)})}function yc(e){return new bc((t,n)=>{n(e)})}var bc=class e{constructor(e){this._state=0,this._handlers=[],this._runExecutor(e)}then(t,n){return new e((e,r)=>{this._handlers.push([!1,n=>{if(!t)e(n);else try{e(t(n))}catch(e){r(e)}},t=>{if(!n)r(t);else try{e(n(t))}catch(e){r(e)}}]),this._executeHandlers()})}catch(e){return this.then(e=>e,e)}finally(t){return new e((e,n)=>{let r,i;return this.then(e=>{i=!1,r=e,t&&t()},e=>{i=!0,r=e,t&&t()}).then(()=>{if(i){n(r);return}e(r)})})}_executeHandlers(){if(this._state===0)return;let e=this._handlers.slice();this._handlers=[],e.forEach(e=>{e[0]||=(this._state===1&&e[1](this._value),this._state===2&&e[2](this._value),!0)})}_runExecutor(e){let t=(e,t)=>{if(this._state===0){if(Aa(t)){t.then(n,r);return}this._state=e,this._value=t,this._executeHandlers()}},n=e=>{t(1,e)},r=e=>{t(2,e)};try{e(n,r)}catch(e){r(e)}}};function xc(e,t,n,r=0){try{let i=Sc(t,n,e,r);return Aa(i)?i:vc(i)}catch(e){return yc(e)}}function Sc(e,t,n,r){let i=n[r];if(!e||!i)return e;let a=i({...e},t);return W&&a===null&&K.log(`Event processor "${i.id||`?`}" dropped event`),Aa(a)?a.then(e=>Sc(e,t,n,r+1)):Sc(a,t,n,r+1)}let Cc,wc,Tc,Ec;function Dc(e){let t=G._sentryDebugIds,n=G._debugIds;if(!t&&!n)return{};let r=t?Object.keys(t):[],i=n?Object.keys(n):[];if(Ec&&r.length===wc&&i.length===Tc)return Ec;wc=r.length,Tc=i.length,Ec={},Cc||={};let a=(t,n)=>{for(let r of t){let t=n[r],i=Cc?.[r];if(i&&Ec&&t)Ec[i[0]]=t,Cc&&(Cc[r]=[i[0],t]);else if(t){let n=e(r);for(let e=n.length-1;e>=0;e--){let i=n[e]?.filename;if(i&&Ec&&Cc){Ec[i]=t,Cc[r]=[i,t];break}}}}};return t&&a(r,t),n&&a(i,n),Ec}function Oc(e,t){let{fingerprint:n,span:r,breadcrumbs:i,sdkProcessingMetadata:a}=t;Mc(e,t),r&&Fc(e,r),Ic(e,n),Nc(e,i),Pc(e,a)}function kc(e,t){let{extra:n,tags:r,attributes:i,user:a,contexts:o,level:s,sdkProcessingMetadata:c,breadcrumbs:l,fingerprint:u,eventProcessors:d,attachments:f,propagationContext:p,transactionName:m,span:h}=t;Ac(e,`extra`,n),Ac(e,`tags`,r),Ac(e,`attributes`,i),Ac(e,`user`,a),Ac(e,`contexts`,o),e.sdkProcessingMetadata=So(e.sdkProcessingMetadata,c,2),s&&(e.level=s),m&&(e.transactionName=m),h&&(e.span=h),l.length&&(e.breadcrumbs=[...e.breadcrumbs,...l]),u.length&&(e.fingerprint=[...e.fingerprint,...u]),d.length&&(e.eventProcessors=[...e.eventProcessors,...d]),f.length&&(e.attachments=[...e.attachments,...f]),e.propagationContext={...e.propagationContext,...p}}function Ac(e,t,n){e[t]=So(e[t],n,1)}function jc(e,t){let n=zo().getScopeData();return e&&kc(n,e.getScopeData()),t&&kc(n,t.getScopeData()),n}function Mc(e,t){let{extra:n,tags:r,user:i,contexts:a,level:o,transactionName:s}=t;Object.keys(n).length&&(e.extra={...n,...e.extra}),Object.keys(r).length&&(e.tags={...r,...e.tags}),Object.keys(i).length&&(e.user={...i,...e.user}),Object.keys(a).length&&(e.contexts={...a,...e.contexts}),o&&(e.level=o),s&&e.type!==`transaction`&&(e.transaction=s)}function Nc(e,t){let n=[...e.breadcrumbs||[],...t];e.breadcrumbs=n.length?n:void 0}function Pc(e,t){e.sdkProcessingMetadata={...e.sdkProcessingMetadata,...t}}function Fc(e,t){e.contexts={trace:vs(t),...e.contexts},e.sdkProcessingMetadata={dynamicSamplingContext:Hs(t),...e.sdkProcessingMetadata};let n=ws(ks(t)).description;n&&!e.transaction&&e.type===`transaction`&&(e.transaction=n)}function Ic(e,t){e.fingerprint=e.fingerprint?Array.isArray(e.fingerprint)?e.fingerprint:[e.fingerprint]:[],t&&(e.fingerprint=e.fingerprint.concat(t)),e.fingerprint.length||delete e.fingerprint}function Lc(e,t,n,r,i,a){let{normalizeDepth:o=3,normalizeMaxBreadth:s=1e3}=e,c={...t,event_id:t.event_id||n.event_id||q(),timestamp:t.timestamp||mo()},l=n.integrations||e.integrations.map(e=>e.name);Rc(c,e),Vc(c,l),i&&i.emit(`applyFrameMetadata`,t),t.type===void 0&&zc(c,e.stackParser);let u=Uc(r,n.captureContext);n.mechanism&&oo(c,n.mechanism);let d=i?i.getEventProcessors():[],f=jc(a,u),p=[...n.attachments||[],...f.attachments];p.length&&(n.attachments=p),Oc(c,f);let m=[...d,...f.eventProcessors];return(n.data&&n.data.__sentry__===!0?vc(c):xc(m,c,n)).then(e=>(e&&Bc(e),typeof o==`number`&&o>0?Hc(e,o,s):e))}function Rc(e,t){let{environment:n,release:r,dist:i,maxValueLength:a}=t;e.environment=e.environment||n||zs,!e.release&&r&&(e.release=r),!e.dist&&i&&(e.dist=i);let o=e.request;o?.url&&a&&(o.url=Ya(o.url,a)),a&&e.exception?.values?.forEach(e=>{e.value&&=Ya(e.value,a)})}function zc(e,t){let n=Dc(t);e.exception?.values?.forEach(e=>{e.stacktrace?.frames?.forEach(e=>{e.filename&&(e.debug_id=n[e.filename])})})}function Bc(e){let t={};if(e.exception?.values?.forEach(e=>{e.stacktrace?.frames?.forEach(e=>{e.debug_id&&(e.abs_path?t[e.abs_path]=e.debug_id:e.filename&&(t[e.filename]=e.debug_id),delete e.debug_id)})}),Object.keys(t).length===0)return;e.debug_meta=e.debug_meta||{},e.debug_meta.images=e.debug_meta.images||[];let n=e.debug_meta.images;Object.entries(t).forEach(([e,t])=>{n.push({type:`sourcemap`,code_file:e,debug_id:t})})}function Vc(e,t){t.length>0&&(e.sdk=e.sdk||{},e.sdk.integrations=[...e.sdk.integrations||[],...t])}function Hc(e,t,n){if(!e)return null;let r={...e,...e.breadcrumbs&&{breadcrumbs:e.breadcrumbs.map(e=>({...e,...e.data&&{data:Us(e.data,t,n)}}))},...e.user&&{user:Us(e.user,t,n)},...e.contexts&&{contexts:Us(e.contexts,t,n)},...e.extra&&{extra:Us(e.extra,t,n)}};return e.contexts?.trace&&r.contexts&&(r.contexts.trace=e.contexts.trace,e.contexts.trace.data&&(r.contexts.trace.data=Us(e.contexts.trace.data,t,n))),e.spans&&(r.spans=e.spans.map(e=>({...e,...e.data&&{data:Us(e.data,t,n)}}))),e.contexts?.flags&&r.contexts&&(r.contexts.flags=Us(e.contexts.flags,3,n)),r}function Uc(e,t){if(!t)return e;let n=e?e.clone():new Oo;return n.update(t),n}function Wc(e){if(e)return Gc(e)||qc(e)?{captureContext:e}:e}function Gc(e){return e instanceof Oo||typeof e==`function`}const Kc=[`user`,`level`,`extra`,`contexts`,`tags`,`fingerprint`,`propagationContext`];function qc(e){return Object.keys(e).some(e=>Kc.includes(e))}function Jc(e,t){return J().captureException(e,Wc(t))}function Yc(e,t){Y().setContext(e,t)}function Xc(e,t){Y().setTag(e,t)}function Zc(e){Y().setUser(e)}async function Qc(e){let t=X();return t?t.flush(e):(W&&K.warn(`Cannot flush events. No client defined.`),Promise.resolve(!1))}function $c(){let e=X();return e?.getOptions().enabled!==!1&&!!e?.getTransport()}function el(e){let t=Y(),{user:n}=jc(t,J()),{userAgent:r}=G.navigator||{},i=vo({user:n,...r&&{userAgent:r},...e}),a=t.getSession();return a?.status===`ok`&&yo(a,{status:`exited`}),tl(),t.setSession(i),i}function tl(){let e=Y(),t=J().getSession()||e.getSession();t&&bo(t),nl(),e.setSession()}function nl(){let e=Y(),t=X(),n=e.getSession();n&&t&&t.captureSession(n)}function rl(e){let t=e.protocol?`${e.protocol}:`:``,n=e.port?`:${e.port}`:``;return`${t}//${e.host}${n}${e.path?`/${e.path}`:``}/api/`}function il(e){return`${rl(e)}${e.projectId}/envelope/`}function al(e,t){let n={sentry_version:`7`};return e.publicKey&&(n.sentry_key=e.publicKey),t&&(n.sentry_client=`${t.name}/${t.version}`),new URLSearchParams(n).toString()}function ol(e,t,n){return t||`${il(e)}?${al(e,n)}`}const sl=[];function cl(e){let t={};return e.forEach(e=>{let{name:n}=e,r=t[n];r&&!r.isDefaultInstance&&e.isDefaultInstance||(t[n]=e)}),Object.values(t)}function ll(e){let t=e.defaultIntegrations||[],n=e.integrations;t.forEach(e=>{e.isDefaultInstance=!0});let r;if(Array.isArray(n))r=[...t,...n];else if(typeof n==`function`){let e=n(t);r=Array.isArray(e)?e:[e]}else r=t;return cl(r)}function ul(e,t){let n={};return t.forEach(t=>{t&&fl(e,t,n)}),n}function dl(e,t){for(let n of t)n?.afterAllSetup&&n.afterAllSetup(e)}function fl(e,t,n){if(n[t.name]){W&&K.log(`Integration skipped because it was already installed: ${t.name}`);return}if(n[t.name]=t,!sl.includes(t.name)&&typeof t.setupOnce==`function`&&(t.setupOnce(),sl.push(t.name)),t.setup&&typeof t.setup==`function`&&t.setup(e),typeof t.preprocessEvent==`function`){let n=t.preprocessEvent.bind(t);e.on(`preprocessEvent`,(t,r)=>n(t,r,e))}if(typeof t.processEvent==`function`){let n=t.processEvent.bind(t),r=Object.assign((t,r)=>n(t,r,e),{id:t.name});e.addEventProcessor(r)}W&&K.log(`Integration installed: ${t.name}`)}function Z(e){return e}function pl(e,t){return t?Bo(t,()=>{let n=As(),r=n?vs(n):Ho(t);return[n?Hs(n):Vs(e,t),r]}):[void 0,void 0]}function ml(e){return[{type:`log`,item_count:e.length,content_type:`application/vnd.sentry.items.log+json`},{items:e}]}function hl(e,t,n,r){let i={};return t?.sdk&&(i.sdk={name:t.sdk.name,version:t.sdk.version}),n&&r&&(i.dsn=ns(r)),Zs(i,[ml(e)])}function gl(e,t){let n=t??_l(e)??[];if(n.length===0)return;let r=e.getOptions(),i=hl(n,r._metadata,r.tunnel,e.getDsn());vl().set(e,[]),e.emit(`flushLogs`),e.sendEnvelope(i)}function _l(e){return vl().get(e)}function vl(){return Bi(`clientToLogBufferMap`,()=>new WeakMap)}function yl(e){return[{type:`trace_metric`,item_count:e.length,content_type:`application/vnd.sentry.items.trace-metric+json`},{items:e}]}function bl(e,t,n,r){let i={};return t?.sdk&&(i.sdk={name:t.sdk.name,version:t.sdk.version}),n&&r&&(i.dsn=ns(r)),Zs(i,[yl(e)])}function xl(e,t){let n=t??Sl(e)??[];if(n.length===0)return;let r=e.getOptions(),i=bl(n,r._metadata,r.tunnel,e.getDsn());Cl().set(e,[]),e.emit(`flushMetrics`),e.sendEnvelope(i)}function Sl(e){return Cl().get(e)}function Cl(){return Bi(`clientToMetricBufferMap`,()=>new WeakMap)}function wl(e){return typeof e==`object`&&typeof e.unref==`function`&&e.unref(),e}const Tl=Symbol.for(`SentryBufferFullError`);function El(e=100){let t=new Set;function n(){return t.size<e}function r(e){t.delete(e)}function i(e){if(!n())return yc(Tl);let i=e();return t.add(i),i.then(()=>r(i),()=>r(i)),i}function a(e){if(!t.size)return vc(!0);let n=Promise.allSettled(Array.from(t)).then(()=>!0);if(!e)return n;let r=[n,new Promise(t=>wl(setTimeout(()=>t(!1),e)))];return Promise.race(r)}return{get $(){return Array.from(t)},add:i,drain:a}}function Dl(e,t=Ja()){let n=parseInt(`${e}`,10);if(!isNaN(n))return n*1e3;let r=Date.parse(`${e}`);return isNaN(r)?6e4:r-t}function Ol(e,t){return e[t]||e.all||0}function kl(e,t,n=Ja()){return Ol(e,t)>n}function Al(e,{statusCode:t,headers:n},r=Ja()){let i={...e},a=n?.[`x-sentry-rate-limits`],o=n?.[`retry-after`];if(a)for(let e of a.trim().split(`,`)){let[t,n,,,a]=e.split(`:`,5),o=parseInt(t,10),s=(isNaN(o)?60:o)*1e3;if(!n)i.all=r+s;else for(let e of n.split(`;`))e===`metric_bucket`?(!a||a.split(`;`).includes(`custom`))&&(i[e]=r+s):i[e]=r+s}else o?i.all=r+Dl(o,r):t===429&&(i.all=r+60*1e3);return i}function jl(e,t,n=El(e.bufferSize||64)){let r={},i=e=>n.drain(e);function a(i){let a=[];if($s(i,(t,n)=>{let i=oc(n);kl(r,i)?e.recordDroppedEvent(`ratelimit_backoff`,i):a.push(t)}),a.length===0)return Promise.resolve({});let o=Zs(i[0],a),s=t=>{if(ec(o,[`client_report`])){W&&K.warn(`Dropping client report. Will not send outcomes (reason: ${t}).`);return}$s(o,(n,r)=>{e.recordDroppedEvent(t,oc(r))})};return n.add(()=>t({body:nc(o)}).then(e=>e.statusCode===413?(W&&K.error(`Sentry responded with status code 413. Envelope was discarded due to exceeding size limits.`),s(`send_error`),e):(W&&e.statusCode!==void 0&&(e.statusCode<200||e.statusCode>=300)&&K.warn(`Sentry responded with status code ${e.statusCode} to sent event.`),r=Al(r,e),e),e=>{throw s(`network_error`),W&&K.error(`Encountered error running transport request:`,e),e})).then(e=>e,e=>{if(e===Tl)return W&&K.error(`Skipped sending event because buffer is full.`),s(`queue_overflow`),Promise.resolve({});throw e})}return{send:a,flush:i}}function Ml(e,t,n){let r=[{type:`client_report`},{timestamp:n||mo(),discarded_events:e}];return Zs(t?{dsn:t}:{},[r])}function Nl(e){let t=[];e.message&&t.push(e.message);try{let n=e.exception.values[e.exception.values.length-1];n?.value&&(t.push(n.value),n.type&&t.push(`${n.type}: ${n.value}`))}catch{}return t}function Pl(e){let{trace_id:t,parent_span_id:n,span_id:r,status:i,origin:a,data:o,op:s}=e.contexts?.trace??{};return{data:o??{},description:e.transaction,op:s,parent_span_id:n,span_id:r??``,start_timestamp:e.start_timestamp??0,status:i,timestamp:e.timestamp,trace_id:t??``,origin:a,profile_id:o?.[Uo],exclusive_time:o?.[Wo],measurements:e.measurements,is_segment:!0}}function Fl(e){return{type:`transaction`,timestamp:e.timestamp,start_timestamp:e.start_timestamp,transaction:e.description,contexts:{trace:{trace_id:e.trace_id,span_id:e.span_id,parent_span_id:e.parent_span_id,op:e.op,status:e.status,origin:e.origin,data:{...e.data,...e.profile_id&&{[Uo]:e.profile_id},...e.exclusive_time&&{[Wo]:e.exclusive_time}}}},measurements:e.measurements}}const Il=`Not capturing exception because it's already been captured.`,Ll=`Discarded session because of missing or non-string release`,Rl=Symbol.for(`SentryInternalError`),zl=Symbol.for(`SentryDoNotSendEventError`);function Bl(e){return{message:e,[Rl]:!0}}function Vl(e){return{message:e,[zl]:!0}}function Hl(e){return!!e&&typeof e==`object`&&Rl in e}function Ul(e){return!!e&&typeof e==`object`&&zl in e}function Wl(e,t,n,r,i){let a=0,o,s=!1;e.on(n,()=>{a=0,clearTimeout(o),s=!1}),e.on(t,t=>{a+=r(t),a>=8e5?i(e):s||(s=!0,o=wl(setTimeout(()=>{i(e)},5e3)))}),e.on(`flush`,()=>{i(e)})}var Gl=class{constructor(e){if(this._options=e,this._integrations={},this._numProcessing=0,this._outcomes={},this._hooks={},this._eventProcessors=[],this._promiseBuffer=El(e.transportOptions?.bufferSize??64),e.dsn?this._dsn=cs(e.dsn):W&&K.warn(`No DSN provided, client will not send events.`),this._dsn){let t=ol(this._dsn,e.tunnel,e._metadata?e._metadata.sdk:void 0);this._transport=e.transport({tunnel:this._options.tunnel,recordDroppedEvent:this.recordDroppedEvent.bind(this),...e.transportOptions,url:t})}this._options.enableLogs=this._options.enableLogs??this._options._experiments?.enableLogs,this._options.enableLogs&&Wl(this,`afterCaptureLog`,`flushLogs`,Ql,gl),(this._options.enableMetrics??this._options._experiments?.enableMetrics??!0)&&Wl(this,`afterCaptureMetric`,`flushMetrics`,Zl,xl)}captureException(e,t,n){let r=q();if(uo(e))return W&&K.log(Il),r;let i={event_id:r,...t};return this._process(()=>this.eventFromException(e,i).then(e=>this._captureEvent(e,i,n)).then(e=>e),`error`),i.event_id}captureMessage(e,t,n,r){let i={event_id:q(),...n},a=wa(e)?e:String(e),o=Ta(e),s=o?this.eventFromMessage(a,t,i):this.eventFromException(e,i);return this._process(()=>s.then(e=>this._captureEvent(e,i,r)),o?`unknown`:`error`),i.event_id}captureEvent(e,t,n){let r=q();if(t?.originalException&&uo(t.originalException))return W&&K.log(Il),r;let i={event_id:r,...t},a=e.sdkProcessingMetadata||{},o=a.capturedSpanScope,s=a.capturedSpanIsolationScope,c=Kl(e.type);return this._process(()=>this._captureEvent(e,i,o||n,s),c),i.event_id}captureSession(e){this.sendSession(e),yo(e,{init:!1})}getDsn(){return this._dsn}getOptions(){return this._options}getSdkMetadata(){return this._options._metadata}getTransport(){return this._transport}async flush(e){let t=this._transport;if(!t)return!0;this.emit(`flush`);let n=await this._isClientDoneProcessing(e),r=await t.flush(e);return n&&r}async close(e){gl(this);let t=await this.flush(e);return this.getOptions().enabled=!1,this.emit(`close`),t}getEventProcessors(){return this._eventProcessors}addEventProcessor(e){this._eventProcessors.push(e)}init(){(this._isEnabled()||this._options.integrations.some(({name:e})=>e.startsWith(`Spotlight`)))&&this._setupIntegrations()}getIntegrationByName(e){return this._integrations[e]}addIntegration(e){let t=this._integrations[e.name];fl(this,e,this._integrations),t||dl(this,[e])}sendEvent(e,t={}){this.emit(`beforeSendEvent`,e,t);let n=dc(e,this._dsn,this._options._metadata,this._options.tunnel);for(let e of t.attachments||[])n=Qs(n,ic(e));this.sendEnvelope(n).then(t=>this.emit(`afterSendEvent`,e,t))}sendSession(e){let{release:t,environment:n=zs}=this._options;if(`aggregates`in e){let r=e.attrs||{};if(!r.release&&!t){W&&K.warn(Ll);return}r.release=r.release||t,r.environment=r.environment||n,e.attrs=r}else{if(!e.release&&!t){W&&K.warn(Ll);return}e.release=e.release||t,e.environment=e.environment||n}this.emit(`beforeSendSession`,e);let r=uc(e,this._dsn,this._options._metadata,this._options.tunnel);this.sendEnvelope(r)}recordDroppedEvent(e,t,n=1){if(this._options.sendClientReports){let r=`${e}:${t}`;W&&K.log(`Recording outcome: "${r}"${n>1?` (${n} times)`:``}`),this._outcomes[r]=(this._outcomes[r]||0)+n}}on(e,t){let n=this._hooks[e]=this._hooks[e]||new Set,r=(...e)=>t(...e);return n.add(r),()=>{n.delete(r)}}emit(e,...t){let n=this._hooks[e];n&&n.forEach(e=>e(...t))}async sendEnvelope(e){if(this.emit(`beforeEnvelope`,e),this._isEnabled()&&this._transport)try{return await this._transport.send(e)}catch(e){return W&&K.error(`Error while sending envelope:`,e),{}}return W&&K.error(`Transport disabled`),{}}dispose(){}_setupIntegrations(){let{integrations:e}=this._options;this._integrations=ul(this,e),dl(this,e)}_updateSessionFromEvent(e,t){let n=t.level===`fatal`,r=!1,i=t.exception?.values;if(i){r=!0,n=!1;for(let e of i)if(e.mechanism?.handled===!1){n=!0;break}}let a=e.status===`ok`;(a&&e.errors===0||a&&n)&&(yo(e,{...n&&{status:`crashed`},errors:e.errors||Number(r||n)}),this.captureSession(e))}async _isClientDoneProcessing(e){let t=0;for(;!e||t<e;){if(await new Promise(e=>setTimeout(e,1)),!this._numProcessing)return!0;t++}return!1}_isEnabled(){return this.getOptions().enabled!==!1&&this._transport!==void 0}_prepareEvent(e,t,n,r){let i=this.getOptions(),a=Object.keys(this._integrations);return!t.integrations&&a?.length&&(t.integrations=a),this.emit(`preprocessEvent`,e,t),e.type||r.setLastEventId(e.event_id||t.event_id),Lc(i,e,t,n,this,r).then(e=>e===null?e:(this.emit(`postprocessEvent`,e,t),e.contexts={trace:Ho(n),...e.contexts},e.sdkProcessingMetadata={dynamicSamplingContext:Vs(this,n),...e.sdkProcessingMetadata},e))}_captureEvent(e,t={},n=J(),r=Y()){return W&&Yl(e)&&K.log(`Captured error event \`${Nl(e)[0]||`<unknown>`}\``),this._processEvent(e,t,n,r).then(e=>e.event_id,e=>{W&&(Ul(e)?K.log(e.message):Hl(e)?K.warn(e.message):K.warn(e))})}_processEvent(e,t,n,r){let i=this.getOptions(),{sampleRate:a}=i,o=Xl(e),s=Yl(e),c=`before send for type \`${e.type||`error`}\``,l=a===void 0?void 0:ls(a);if(s&&typeof l==`number`&&qa()>l)return this.recordDroppedEvent(`sample_rate`,`error`),yc(Vl(`Discarding event because it's not included in the random sample (sampling rate = ${a})`));let u=Kl(e.type);return this._prepareEvent(e,t,n,r).then(e=>{if(e===null)throw this.recordDroppedEvent(`event_processor`,u),Vl("An event processor returned `null`, will not send event.");return t.data&&t.data.__sentry__===!0?e:ql(Jl(this,i,e,t),c)}).then(i=>{if(i===null){if(this.recordDroppedEvent(`before_send`,u),o){let t=1+(e.spans||[]).length;this.recordDroppedEvent(`before_send`,`span`,t)}throw Vl(`${c} returned \`null\`, will not send event.`)}let a=n.getSession()||r.getSession();if(s&&a&&this._updateSessionFromEvent(a,i),o){let e=(i.sdkProcessingMetadata?.spanCountBeforeProcessing||0)-(i.spans?i.spans.length:0);e>0&&this.recordDroppedEvent(`before_send`,`span`,e)}let l=i.transaction_info;return o&&l&&i.transaction!==e.transaction&&(i.transaction_info={...l,source:`custom`}),this.sendEvent(i,t),i}).then(null,e=>{throw Ul(e)||Hl(e)?e:(this.captureException(e,{mechanism:{handled:!1,type:`internal`},data:{__sentry__:!0},originalException:e}),Bl(`Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\nReason: ${e}`))})}_process(e,t){this._numProcessing++,this._promiseBuffer.add(e).then(e=>(this._numProcessing--,e),e=>(this._numProcessing--,e===Tl&&this.recordDroppedEvent(`queue_overflow`,t),e))}_clearOutcomes(){let e=this._outcomes;return this._outcomes={},Object.entries(e).map(([e,t])=>{let[n,r]=e.split(`:`);return{reason:n,category:r,quantity:t}})}_flushOutcomes(){W&&K.log(`Flushing outcomes...`);let e=this._clearOutcomes();if(e.length===0){W&&K.log(`No outcomes to send`);return}if(!this._dsn){W&&K.log(`No dsn provided, will not send outcomes`);return}W&&K.log(`Sending outcomes:`,e);let t=Ml(e,this._options.tunnel&&ns(this._dsn));this.sendEnvelope(t)}};function Kl(e){return e===`replay_event`?`replay`:e||`error`}function ql(e,t){let n=`${t} must return \`null\` or a valid event.`;if(Aa(e))return e.then(e=>{if(!Ea(e)&&e!==null)throw Bl(n);return e},e=>{throw Bl(`${t} rejected with ${e}`)});if(!Ea(e)&&e!==null)throw Bl(n);return e}function Jl(e,t,n,r){let{beforeSend:i,beforeSendTransaction:a,beforeSendSpan:o,ignoreSpans:s}=t,c=n;if(Yl(c)&&i)return i(c,r);if(Xl(c)){if(o||s){let t=Pl(c);if(s?.length&&Is(t,s))return null;if(o){let e=o(t);e?c=So(n,Fl(e)):js()}if(c.spans){let t=[],n=c.spans;for(let e of n){if(s?.length&&Is(e,s)){Ls(n,e);continue}if(o){let n=o(e);n?t.push(n):(js(),t.push(e))}else t.push(e)}let r=c.spans.length-t.length;r&&e.recordDroppedEvent(`before_send`,`span`,r),c.spans=t}}if(a){if(c.spans){let e=c.spans.length;c.sdkProcessingMetadata={...n.sdkProcessingMetadata,spanCountBeforeProcessing:e}}return a(c,r)}}return c}function Yl(e){return e.type===void 0}function Xl(e){return e.type===`transaction`}function Zl(e){let t=0;return e.name&&(t+=e.name.length*2),t+=8,t+$l(e.attributes)}function Ql(e){let t=0;return e.message&&(t+=e.message.length*2),t+$l(e.attributes)}function $l(e){if(!e)return 0;let t=0;return Object.values(e).forEach(e=>{Array.isArray(e)?t+=e.length*eu(e[0]):Ta(e)?t+=eu(e):t+=100}),t}function eu(e){return typeof e==`string`?e.length*2:typeof e==`number`?8:typeof e==`boolean`?4:0}function tu(e,t,n,r,i){let a={sent_at:new Date().toISOString()};return n?.sdk&&(a.sdk={name:n.sdk.name,version:n.sdk.version}),r&&i&&(a.dsn=ns(i)),t&&(a.trace=t),Zs(a,[nu(e)])}function nu(e){return[{type:`check_in`},e]}function ru(e){let t=e._metadata?.sdk,n=t?.name&&t?.version?`${t?.name}/${t?.version}`:void 0;e.transportOptions={...e.transportOptions,headers:{...n&&{"user-agent":n},...e.transportOptions?.headers}}}function iu(e,t){return e(t.stack||``,1)}function au(e){return ba(e)&&`__sentry_fetch_url_host__`in e&&typeof e.__sentry_fetch_url_host__==`string`}function ou(e){return au(e)?`${e.message} (${e.__sentry_fetch_url_host__})`:e.message}function su(e,t){let n={type:t.name||t.constructor.name,value:ou(t)},r=iu(e,t);return r.length&&(n.stacktrace={frames:r}),n}function cu(e){for(let t in e)if(Object.prototype.hasOwnProperty.call(e,t)){let n=e[t];if(n instanceof Error)return n}}function lu(e){if(`name`in e&&typeof e.name==`string`){let t=`'${e.name}' captured as exception`;return`message`in e&&typeof e.message==`string`&&(t+=` with message '${e.message}'`),t}else if(`message`in e&&typeof e.message==`string`)return e.message;let t=Wa(e);if(Sa(e))return`Event \`ErrorEvent\` captured as exception with message \`${e.message}\``;let n=uu(e);return`${n&&n!==`Object`?`'${n}'`:`Object`} captured as exception with keys: ${t}`}function uu(e){try{let t=Object.getPrototypeOf(e);return t?t.constructor.name:void 0}catch{}}function du(e,t,n,r){if(ba(n))return[n,void 0];if(t.synthetic=!0,Ea(n)){let t=e?.getOptions().normalizeDepth,i={__serialized__:Ws(n,t)},a=cu(n);if(a)return[a,i];let o=lu(n),s=r?.syntheticException||Error(o);return s.message=o,[s,i]}let i=r?.syntheticException||Error(n);return i.message=`${n}`,[i,void 0]}function fu(e,t,n,r){let i=r?.data&&r.data.mechanism||{handled:!0,type:`generic`},[a,o]=du(e,i,n,r),s={exception:{values:[su(t,a)]}};return o&&(s.extra=o),ao(s,void 0,void 0),oo(s,i),{...s,event_id:r?.event_id}}function pu(e,t,n=`info`,r,i){let a={event_id:r?.event_id,level:n};if(i&&r?.syntheticException){let n=iu(e,r.syntheticException);n.length&&(a.exception={values:[{value:t,stacktrace:{frames:n}}]},oo(a,{synthetic:!0}))}if(wa(t)){let{__sentry_template_string__:e,__sentry_template_values__:n}=t;return a.logentry={message:e,params:n},a}return a.message=t,a}var mu=class extends Gl{constructor(e){Ns(),ru(e),super(e),this._setUpMetricsProcessing()}eventFromException(e,t){let n=fu(this,this._options.stackParser,e,t);return n.level=`error`,vc(n)}eventFromMessage(e,t=`info`,n){return vc(pu(this._options.stackParser,e,t,n,this._options.attachStacktrace))}captureException(e,t,n){return hu(t),super.captureException(e,t,n)}captureEvent(e,t,n){return!e.type&&e.exception?.values&&e.exception.values.length>0&&hu(t),super.captureEvent(e,t,n)}captureCheckIn(e,t,n){let r=`checkInId`in e&&e.checkInId?e.checkInId:q();if(!this._isEnabled())return W&&K.warn(`SDK not enabled, will not capture check-in.`),r;let{release:i,environment:a,tunnel:o}=this.getOptions(),s={check_in_id:r,monitor_slug:e.monitorSlug,status:e.status,release:i,environment:a};`duration`in e&&(s.duration=e.duration),t&&(s.monitor_config={schedule:t.schedule,checkin_margin:t.checkinMargin,max_runtime:t.maxRuntime,timezone:t.timezone,failure_issue_threshold:t.failureIssueThreshold,recovery_threshold:t.recoveryThreshold});let[c,l]=pl(this,n);l&&(s.contexts={trace:l});let u=tu(s,c,this.getSdkMetadata(),o,this.getDsn());return W&&K.log(`Sending checkin:`,e.monitorSlug,e.status),this.sendEnvelope(u),r}dispose(){W&&K.log(`Disposing client...`);for(let e of Object.keys(this._hooks))this._hooks[e]?.clear();this._hooks={},this._eventProcessors.length=0,this._integrations={},this._outcomes={},this._transport=void 0,this._promiseBuffer=El(64)}_prepareEvent(e,t,n,r){return this._options.platform&&(e.platform=e.platform||this._options.platform),this._options.runtime&&(e.contexts={...e.contexts,runtime:e.contexts?.runtime||this._options.runtime}),this._options.serverName&&(e.server_name=e.server_name||this._options.serverName),super._prepareEvent(e,t,n,r)}_setUpMetricsProcessing(){this.on(`processMetric`,e=>{this._options.serverName&&(e.attributes={"server.address":this._options.serverName,...e.attributes})})}};function hu(e){let t=Y().getScopeData().sdkProcessingMetadata.requestSession;if(t){let n=e?.mechanism?.handled??!0;n&&t.status!==`crashed`?t.status=`errored`:n||(t.status=`crashed`)}}const gu=new Set([`false`,`f`,`n`,`no`,`off`,`0`]),_u=new Set([`true`,`t`,`y`,`yes`,`on`,`1`]);function vu(e,t){let n=String(e).toLowerCase();return gu.has(n)?!1:_u.has(n)?!0:t?.strict?null:!!e}function yu(e){if(!e)return{};let t=e.match(/^(([^:/?#]+):)?(\/\/([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?$/);if(!t)return{};let n=t[6]||``,r=t[8]||``;return{host:t[4],path:t[5],protocol:t[2],search:n,hash:r,relative:t[5]+n+r}}function bu(e){return e.split(/[?#]/,1)[0]}function xu(e){let{protocol:t,host:n,path:r}=e,i=n?.replace(/^.*@/,`[filtered]:[filtered]@`).replace(/(:80)$/,``).replace(/(:443)$/,``)||``;return`${t?`${t}://`:``}${i}${r}`}function Su(e,t,n=[t],r=`npm`){let i=(e._metadata=e._metadata||{}).sdk=e._metadata.sdk||{};i.name||(i.name=`sentry.javascript.${t}`,i.packages=n.map(e=>({name:`${r}:@sentry/${e}`,version:Li})),i.version=Li)}function Cu(e={}){let t=e.client||X();if(!$c()||!t)return{};let n=Ro(Ri());if(n.getTraceData)return n.getTraceData(e);let r=e.scope||J(),i=e.span||As(),a=i?ys(i):wu(r),o=Yo(i?Hs(i):Vs(t,r));if(!us.test(a))return K.warn(`Invalid sentry-trace data. Cannot generate trace data`),{};let s={"sentry-trace":a,baggage:o};return e.propagateTraceparent&&(s.traceparent=i?bs(i):Tu(r)),s}function wu(e){let{traceId:t,sampled:n,propagationSpanId:r}=e.getPropagationContext();return ps(t,r,n)}function Tu(e){let{traceId:t,sampled:n,propagationSpanId:r}=e.getPropagationContext();return ms(t,r,n)}const Eu=`[Tracing] Not injecting trace data for url because it does not match tracePropagationTargets:`;function Du(e,t,n){if(typeof e!=`string`||!t)return!0;let r=n?.get(e);if(r!==void 0)return W&&!r&&K.log(Eu,e),r;let i=$a(e,t);return n?.set(e,i),W&&!i&&K.log(Eu,e),i}function Ou(e){let t=Object.create(null);try{Object.entries(e).forEach(([e,n])=>{typeof n==`string`&&(t[e]=n)})}catch{}return t}function ku(e){let t=e.headers||{},n=(typeof t[`x-forwarded-host`]==`string`?t[`x-forwarded-host`]:void 0)||(typeof t.host==`string`?t.host:void 0),r=(typeof t[`x-forwarded-proto`]==`string`?t[`x-forwarded-proto`]:void 0)||e.protocol||(e.socket?.encrypted?`https`:`http`),i=e.url||``,a=Au({url:i,host:n,protocol:r}),o=e.body||void 0,s=e.cookies;return{url:a,method:e.method,query_string:ju(i),headers:Ou(t),cookies:s,data:o}}function Au({url:e,protocol:t,host:n}){if(e?.startsWith(`http`))return e;if(e&&n)return`${t}://${n}${e}`}function ju(e){if(e)try{let t=new URL(e,`http://s.io`).search.slice(1);return t.length?t:void 0}catch{return}}function Mu(e,t){let n=X(),r=Y();if(!n)return;let{beforeBreadcrumb:i=null,maxBreadcrumbs:a=100}=n.getOptions();if(a<=0)return;let o={timestamp:mo(),...e},s=i?Ui(()=>i(o,t)):o;s!==null&&(n.emit&&n.emit(`beforeAddBreadcrumb`,s,t),r.addBreadcrumb(s,a))}let Nu;const Pu=new WeakMap,Fu=Z((()=>({name:`FunctionToString`,setupOnce(){Nu=Function.prototype.toString;try{Function.prototype.toString=function(...e){let t=Ba(this),n=Pu.has(X())&&t!==void 0?t:this;return Nu.apply(n,e)}}catch{}},setup(e){Pu.set(e,!0)}}))),Iu=[/^Script error\.?$/,/^Javascript error: Script error\.? on line 0$/,/^ResizeObserver loop completed with undelivered notifications.$/,/^Cannot redefine property: googletag$/,/^Can't find variable: gmo$/,/^undefined is not an object \(evaluating 'a\.[A-Z]'\)$/,`can't redefine non-configurable property "solana"`,`vv().getRestrictions is not a function. (In 'vv().getRestrictions(1,a)', 'vv().getRestrictions' is undefined)`,`Can't find variable: _AutofillCallbackHandler`,/^Non-Error promise rejection captured with value: Object Not Found Matching Id:\d+, MethodName:simulateEvent, ParamCount:\d+$/,/^Java exception was raised during method invocation$/],Lu=Z((e={})=>{let t;return{name:`EventFilters`,setup(n){t=Ru(e,n.getOptions())},processEvent(n,r,i){return t||=Ru(e,i.getOptions()),zu(n,t)?null:n}}});function Ru(e={},t={}){return{allowUrls:[...e.allowUrls||[],...t.allowUrls||[]],denyUrls:[...e.denyUrls||[],...t.denyUrls||[]],ignoreErrors:[...e.ignoreErrors||[],...t.ignoreErrors||[],...e.disableErrorDefaults?[]:Iu],ignoreTransactions:[...e.ignoreTransactions||[],...t.ignoreTransactions||[]]}}function zu(e,t){if(e.type){if(e.type===`transaction`&&Vu(e,t.ignoreTransactions))return W&&K.warn(`Event dropped due to being matched by \`ignoreTransactions\` option.\nEvent: ${io(e)}`),!0}else{if(Bu(e,t.ignoreErrors))return W&&K.warn(`Event dropped due to being matched by \`ignoreErrors\` option.\nEvent: ${io(e)}`),!0;if(Ku(e))return W&&K.warn(`Event dropped due to not having an error message, error type or stacktrace.\nEvent: ${io(e)}`),!0;if(Hu(e,t.denyUrls))return W&&K.warn(`Event dropped due to being matched by \`denyUrls\` option.\nEvent: ${io(e)}.\nUrl: ${Gu(e)}`),!0;if(!Uu(e,t.allowUrls))return W&&K.warn(`Event dropped due to not being matched by \`allowUrls\` option.\nEvent: ${io(e)}.\nUrl: ${Gu(e)}`),!0}return!1}function Bu(e,t){return t?.length?Nl(e).some(e=>$a(e,t)):!1}function Vu(e,t){if(!t?.length)return!1;let n=e.transaction;return n?$a(n,t):!1}function Hu(e,t){if(!t?.length)return!1;let n=Gu(e);return n?$a(n,t):!1}function Uu(e,t){if(!t?.length)return!0;let n=Gu(e);return n?$a(n,t):!0}function Wu(e=[]){for(let t=e.length-1;t>=0;t--){let n=e[t];if(n&&n.filename!==`<anonymous>`&&n.filename!==`[native code]`)return n.filename||null}return null}function Gu(e){try{let t=[...e.exception?.values??[]].reverse().find(e=>e.mechanism?.parent_id===void 0&&e.stacktrace?.frames?.length)?.stacktrace?.frames;return t?Wu(t):null}catch{return W&&K.error(`Cannot extract url for event ${io(e)}`),null}}function Ku(e){return e.exception?.values?.length?!e.message&&!e.exception.values.some(e=>e.stacktrace||e.type&&e.type!==`Error`||e.value):!1}function qu(e,t,n,r,i,a){if(!i.exception?.values||!a||!Ma(a.originalException,Error))return;let o=i.exception.values.length>0?i.exception.values[i.exception.values.length-1]:void 0;o&&(i.exception.values=Ju(e,t,r,a.originalException,n,i.exception.values,o,0))}function Ju(e,t,n,r,i,a,o,s){if(a.length>=n+1)return a;let c=[...a];if(Ma(r[i],Error)){Xu(o,s,r);let a=e(t,r[i]),l=c.length;Zu(a,i,l,s),c=Ju(e,t,n,r[i],i,[a,...c],a,l)}return Yu(r)&&r.errors.forEach((a,l)=>{if(Ma(a,Error)){Xu(o,s,r);let u=e(t,a),d=c.length;Zu(u,`errors[${l}]`,d,s),c=Ju(e,t,n,a,i,[u,...c],u,d)}}),c}function Yu(e){return Array.isArray(e.errors)}function Xu(e,t,n){e.mechanism={handled:!0,type:`auto.core.linked_errors`,...Yu(n)&&{is_exception_group:!0},...e.mechanism,exception_id:t}}function Zu(e,t,n,r){e.mechanism={handled:!0,...e.mechanism,type:`chained`,source:t,exception_id:n,parent_id:r}}const Qu=Z(((e={})=>{let t=e.limit||5,n=e.key||`cause`;return{name:`LinkedErrors`,preprocessEvent(e,r,i){qu(su,i.getOptions().stackParser,n,t,e,r)}}}));function $u(e){let t={},n=0;for(;n<e.length;){let r=e.indexOf(`=`,n);if(r===-1)break;let i=e.indexOf(`;`,n);if(i===-1)i=e.length;else if(i<r){n=e.lastIndexOf(`;`,r-1)+1;continue}let a=e.slice(n,r).trim();if(t[a]===void 0){let n=e.slice(r+1,i).trim();n.charCodeAt(0)===34&&(n=n.slice(1,-1));try{t[a]=n.indexOf(`%`)===-1?n:decodeURIComponent(n)}catch{t[a]=n}}n=i+1}return t}const ed=[`X-Client-IP`,`X-Forwarded-For`,`Fly-Client-IP`,`CF-Connecting-IP`,`Fastly-Client-Ip`,`True-Client-Ip`,`X-Real-IP`,`X-Cluster-Client-IP`,`X-Forwarded`,`Forwarded-For`,`Forwarded`,`X-Vercel-Forwarded-For`];function td(e){let t={};for(let n of Object.keys(e))t[n.toLowerCase()]=e[n];return ed.map(e=>{let n=t[e.toLowerCase()],r=Array.isArray(n)?n.join(`;`):n;return e===`Forwarded`?nd(r):r?.split(`,`).map(e=>e.trim())}).reduce((e,t)=>t?e.concat(t):e,[]).find(e=>e!==null&&rd(e))||null}function nd(e){if(!e)return null;for(let t of e.split(`;`))if(t.startsWith(`for=`))return t.slice(4);return null}function rd(e){return/(?:^(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}$)|(?:^(?:(?:[a-fA-F\d]{1,4}:){7}(?:[a-fA-F\d]{1,4}|:)|(?:[a-fA-F\d]{1,4}:){6}(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|:[a-fA-F\d]{1,4}|:)|(?:[a-fA-F\d]{1,4}:){5}(?::(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,2}|:)|(?:[a-fA-F\d]{1,4}:){4}(?:(?::[a-fA-F\d]{1,4}){0,1}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,3}|:)|(?:[a-fA-F\d]{1,4}:){3}(?:(?::[a-fA-F\d]{1,4}){0,2}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,4}|:)|(?:[a-fA-F\d]{1,4}:){2}(?:(?::[a-fA-F\d]{1,4}){0,3}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,5}|:)|(?:[a-fA-F\d]{1,4}:){1}(?:(?::[a-fA-F\d]{1,4}){0,4}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,6}|:)|(?::(?:(?::[a-fA-F\d]{1,4}){0,5}:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)(?:\\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d)){3}|(?::[a-fA-F\d]{1,4}){1,7}|:)))(?:%[0-9a-zA-Z]{1,})?$)/.test(e)}const id={cookies:!0,data:!0,headers:!0,query_string:!0,url:!0},ad=Z(((e={})=>{let t={...id,...e.include};return{name:`RequestData`,processEvent(e,n,r){let{sdkProcessingMetadata:i={}}=e,{normalizedRequest:a,ipAddress:o}=i,s={...t,ip:t.ip??r.getOptions().sendDefaultPii};return a&&od(e,a,{ipAddress:o},s),e}}}));function od(e,t,n,r){if(e.request={...e.request,...sd(t,r)},r.ip){let r=t.headers&&td(t.headers)||n.ipAddress;r&&(e.user={...e.user,ip_address:r})}}function sd(e,t){let n={},r={...e.headers};return t.headers&&(n.headers=r,t.cookies||delete r.cookie,t.ip||ed.forEach(e=>{delete r[e]})),n.method=e.method,t.url&&(n.url=e.url),t.cookies&&(n.cookies=e.cookies||(r?.cookie?$u(r.cookie):void 0)||{}),t.query_string&&(n.query_string=e.query_string),t.data&&(n.data=e.data),n}function cd(e){let t=`console`;ua(t,e),da(t,ld)}function ld(){`console`in G&&Vi.forEach(function(e){e in G.console&&La(G.console,e,function(t){return Hi[e]=t,function(...t){fa(`console`,{args:t,level:e}),Hi[e]?.apply(G.console,t)}})})}function ud(e){return e===`warn`?`warning`:[`fatal`,`error`,`warning`,`log`,`info`,`debug`].includes(e)?e:`log`}const dd=/^(\S+:\\|\/?)([\s\S]*?)((?:\.{1,2}|[^/\\]+?|)(\.[^./\\]*|))(?:[/\\]*)$/;function fd(e){let t=e.length>1024?`<truncated>${e.slice(-1024)}`:e,n=dd.exec(t);return n?n.slice(1):[]}function pd(e){let t=fd(e),n=t[0]||``,r=t[1];return!n&&!r?`.`:(r&&=r.slice(0,r.length-1),n+r)}const md=Z((e={})=>{let t=new Set(e.levels||Vi);return{name:`Console`,setup(e){cd(({args:n,level:r})=>{X()!==e||!t.has(r)||hd(r,n)})}}});function hd(e,t){let n={category:`console`,data:{arguments:t,logger:`console`},level:ud(e),message:gd(t)};if(e===`assert`)if(t[0]===!1){let e=t.slice(1);n.message=e.length>0?`Assertion failed: ${gd(e)}`:`Assertion failed`,n.data.arguments=e}else return;Mu(n,{input:t,level:e})}function gd(e){return`util`in G&&typeof G.util.format==`function`?G.util.format(...e):Za(e,` `)}function _d(e){if(e!==void 0){if(e>=400&&e<500)return`warning`;if(e>=500)return`error`}}function vd(e,t=!1){return!(t||e&&!e.startsWith(`/`)&&!e.match(/^[A-Z]:/)&&!e.startsWith(`.`)&&!e.match(/^[a-zA-Z]([a-zA-Z0-9.\-+])*:\/\//))&&e!==void 0&&!e.includes(`node_modules/`)}function yd(e){let t=/^\s*[-]{4,}$/,n=/at (?:async )?(?:(.+?)\s+\()?(?:(.+):(\d+):(\d+)?|([^)]+))\)?/,r=/at (?:async )?(.+?) \(data:(.*?),/;return i=>{let a=i.match(r);if(a)return{filename:`<data:${a[2]}>`,function:a[1]};let o=i.match(n);if(o){let t,n,r,i,a;if(o[1]){r=o[1];let e=r.lastIndexOf(`.`);if(r[e-1]===`.`&&e--,e>0){t=r.slice(0,e),n=r.slice(e+1);let i=t.indexOf(`.Module`);i>0&&(r=r.slice(i+1),t=t.slice(0,i))}i=void 0}n&&(i=t,a=n),n===`<anonymous>`&&(a=void 0,r=void 0),r===void 0&&(a||=`?`,r=i?`${i}.${a}`:a);let s=sa(o[2]),c=o[5]===`native`;!s&&o[5]&&!c&&(s=o[5]);let l=s?Sd(s):void 0;return{filename:l??s,module:l&&e?.(l),function:r,lineno:xd(o[3]),colno:xd(o[4]),in_app:vd(s||``,c)}}if(i.match(t))return{filename:i}}}function bd(e){return[90,yd(e)]}function xd(e){return parseInt(e||``,10)||void 0}function Sd(e){try{return decodeURI(e)}catch{return}}var Cd=class{constructor(e){this._maxSize=e,this._cache=new Map}get size(){return this._cache.size}get(e){let t=this._cache.get(e);if(t!==void 0)return this._cache.delete(e),this._cache.set(e,t),t}set(e,t){if(this._cache.size>=this._maxSize){let e=this._cache.keys().next().value;this._cache.delete(e)}this._cache.set(e,t)}remove(e){let t=this._cache.get(e);return t&&this._cache.delete(e),t}clear(){this._cache.clear()}keys(){return Array.from(this._cache.keys())}values(){let e=[];return this._cache.forEach(t=>e.push(t)),e}};const Q=typeof __SENTRY_DEBUG__>`u`||__SENTRY_DEBUG__;var wd=class extends mu{constructor(e){let t=e.includeServerName===!1?void 0:e.serverName||global.process.env.SENTRY_NAME||j.hostname(),n={...e,platform:`node`,runtime:{name:`node`,version:global.process.version},serverName:t};Su(n,`node-light`,[`node-core`]),K.log(`Initializing Sentry: process: ${process.pid}, thread: ${at?`main`:`worker-${ot}`}.`),super(n),this.getOptions().enableLogs&&(this._logOnExitFlushListener=()=>{gl(this)},t&&this.on(`beforeCaptureLog`,e=>{e.attributes={...e.attributes,"server.address":t}}),process.on(`beforeExit`,this._logOnExitFlushListener))}async flush(e){return this.getOptions().sendClientReports&&this._flushOutcomes(),super.flush(e)}async close(e){return this._clientReportInterval&&clearInterval(this._clientReportInterval),this._clientReportOnExitFlushListener&&process.off(`beforeExit`,this._clientReportOnExitFlushListener),this._logOnExitFlushListener&&process.off(`beforeExit`,this._logOnExitFlushListener),super.close(e)}startClientReportTracking(){let e=this.getOptions();e.sendClientReports&&(this._clientReportOnExitFlushListener=()=>{this._flushOutcomes()},this._clientReportInterval=setInterval(()=>{Q&&K.log(`Flushing client reports based on interval.`),this._flushOutcomes()},e.clientReportFlushInterval??6e4).unref(),process.on(`beforeExit`,this._clientReportOnExitFlushListener))}};const Td=Z((e={})=>({name:`ChildProcess`,setup(){st.channel(`child_process`).subscribe(t=>{t&&typeof t==`object`&&`process`in t&&Ed(t.process,e)}),st.channel(`worker_threads`).subscribe(t=>{t&&typeof t==`object`&&`worker`in t&&Dd(t.worker,e)})}}));function Ed(e,t){let n=!1,r;e.on(`spawn`,()=>{if(e.spawnfile===`/usr/bin/sw_vers`){n=!0;return}r={spawnfile:e.spawnfile},t.includeChildProcessArgs&&(r.spawnargs=e.spawnargs)}).on(`exit`,e=>{n||(n=!0,e!==null&&e!==0&&Mu({category:`child_process`,message:`Child process exited with code '${e}'`,level:e===0?`info`:`warning`,data:r}))}).on(`error`,e=>{n||(n=!0,Mu({category:`child_process`,message:`Child process errored with '${e.message}'`,level:`error`,data:r}))})}function Dd(e,t){let n;e.on(`online`,()=>{n=e.threadId}).on(`error`,e=>{t.captureWorkerErrors===!1?Mu({category:`worker_thread`,message:`Worker thread errored with '${e.message}'`,level:`error`,data:{threadId:n}}):Jc(e,{mechanism:{type:`auto.child_process.worker_thread`,handled:!1,data:{threadId:String(n)}}})})}const Od=Ue(dt),kd=Ue(pt),Ad=Z(((e={})=>{let t,n={app:!0,os:!0,device:!0,culture:!0,cloudResource:!0,...e};async function r(e){t===void 0&&(t=i());let n=jd(await t);return e.contexts={...e.contexts,app:{...n.app,...e.contexts?.app},os:{...n.os,...e.contexts?.os},device:{...n.device,...e.contexts?.device},culture:{...n.culture,...e.contexts?.culture},cloud_resource:{...n.cloud_resource,...e.contexts?.cloud_resource}},e}async function i(){let e={};if(n.os&&(e.os=await Md()),n.app&&(e.app=Pd()),n.device&&(e.device=Fd(n.device)),n.culture){let t=Nd();t&&(e.culture=t)}return n.cloudResource&&(e.cloud_resource=Ud()),e}return{name:`Context`,processEvent(e){return r(e)}}}));function jd(e){if(e.app?.app_memory&&(e.app.app_memory=process.memoryUsage().rss),e.app?.free_memory&&typeof process.availableMemory==`function`){let t=process.availableMemory?.();t!=null&&(e.app.free_memory=t)}return e.device?.free_memory&&(e.device.free_memory=j.freemem()),e}async function Md(){let e=j.platform();switch(e){case`darwin`:return Bd();case`linux`:return Hd();default:return{name:Id[e]||e,version:j.release()}}}function Nd(){try{if(typeof process.versions.icu!=`string`)return;let e=new Date(9e8);if(new Intl.DateTimeFormat(`es`,{month:`long`}).format(e)===`enero`){let e=Intl.DateTimeFormat().resolvedOptions();return{locale:e.locale,timezone:e.timeZone}}}catch{}}function Pd(){let e=process.memoryUsage().rss,t={app_start_time:new Date(Date.now()-process.uptime()*1e3).toISOString(),app_memory:e};if(typeof process.availableMemory==`function`){let e=process.availableMemory?.();e!=null&&(t.free_memory=e)}return t}function Fd(e){let t={},n;try{n=j.uptime()}catch{}if(typeof n==`number`&&(t.boot_time=new Date(Date.now()-n*1e3).toISOString()),t.arch=j.arch(),(e===!0||e.memory)&&(t.memory_size=j.totalmem(),t.free_memory=j.freemem()),e===!0||e.cpu){let e=j.cpus(),n=e?.[0];n&&(t.processor_count=e.length,t.cpu_description=n.model,t.processor_frequency=n.speed)}return t}const Id={aix:`IBM AIX`,freebsd:`FreeBSD`,openbsd:`OpenBSD`,sunos:`SunOS`,win32:`Windows`,ohos:`OpenHarmony`,android:`Android`},Ld=[{name:`fedora-release`,distros:[`Fedora`]},{name:`redhat-release`,distros:[`Red Hat Linux`,`Centos`]},{name:`redhat_version`,distros:[`Red Hat Linux`]},{name:`SuSE-release`,distros:[`SUSE Linux`]},{name:`lsb-release`,distros:[`Ubuntu Linux`,`Arch Linux`]},{name:`debian_version`,distros:[`Debian`]},{name:`debian_release`,distros:[`Debian`]},{name:`arch-release`,distros:[`Arch Linux`]},{name:`gentoo-release`,distros:[`Gentoo Linux`]},{name:`novell-release`,distros:[`SUSE Linux`]},{name:`alpine-release`,distros:[`Alpine Linux`]}],Rd={alpine:e=>e,arch:e=>zd(/distrib_release=(.*)/,e),centos:e=>zd(/release ([^ ]+)/,e),debian:e=>e,fedora:e=>zd(/release (..)/,e),mint:e=>zd(/distrib_release=(.*)/,e),red:e=>zd(/release ([^ ]+)/,e),suse:e=>zd(/VERSION = (.*)\n/,e),ubuntu:e=>zd(/distrib_release=(.*)/,e)};function zd(e,t){let n=e.exec(t);return n?n[1]:void 0}async function Bd(){let e={kernel_version:j.release(),name:`Mac OS X`,version:`10.${Number(j.release().split(`.`)[0])-4}`};try{let t=await new Promise((e,t)=>{$e(`/usr/bin/sw_vers`,(n,r)=>{if(n){t(n);return}e(r)})});e.name=zd(/^ProductName:\s+(.*)$/m,t),e.version=zd(/^ProductVersion:\s+(.*)$/m,t),e.build=zd(/^BuildVersion:\s+(.*)$/m,t)}catch{}return e}function Vd(e){return e.split(` `)[0].toLowerCase()}async function Hd(){let e={kernel_version:j.release(),name:`Linux`};try{let t=await kd(`/etc`),n=Ld.find(e=>t.includes(e.name));if(!n)return e;let r=(await Od(Ye(`/etc`,n.name),{encoding:`utf-8`})).toLowerCase(),{distros:i}=n;e.name=i.find(e=>r.indexOf(Vd(e))>=0)||i[0],e.version=Rd[Vd(e.name)]?.(r)}catch{}return e}function Ud(){if(process.env.VERCEL)return{"cloud.provider":`vercel`,"cloud.region":process.env.VERCEL_REGION};if(process.env.AWS_REGION)return{"cloud.provider":`aws`,"cloud.region":process.env.AWS_REGION,"cloud.platform":process.env.AWS_EXECUTION_ENV};if(process.env.GCP_PROJECT)return{"cloud.provider":`gcp`};if(process.env.ALIYUN_REGION_ID)return{"cloud.provider":`alibaba_cloud`,"cloud.region":process.env.ALIYUN_REGION_ID};if(process.env.WEBSITE_SITE_NAME&&process.env.REGION_NAME)return{"cloud.provider":`azure`,"cloud.region":process.env.REGION_NAME};if(process.env.IBM_CLOUD_REGION)return{"cloud.provider":`ibm_cloud`,"cloud.region":process.env.IBM_CLOUD_REGION};if(process.env.TENCENTCLOUD_REGION)return{"cloud.provider":`tencent_cloud`,"cloud.region":process.env.TENCENTCLOUD_REGION,"cloud.account.id":process.env.TENCENTCLOUD_APPID,"cloud.availability_zone":process.env.TENCENTCLOUD_ZONE};if(process.env.NETLIFY)return{"cloud.provider":`netlify`};if(process.env.FLY_REGION)return{"cloud.provider":`fly.io`,"cloud.region":process.env.FLY_REGION};if(process.env.DYNO)return{"cloud.provider":`heroku`}}const Wd=new Cd(10),Gd=new Cd(20);function Kd(e,t,n){let r=e.get(t);return r===void 0?(e.set(t,n),n):r}function qd(e){return!!(e.startsWith(`node:`)||e.endsWith(`.min.js`)||e.endsWith(`.min.cjs`)||e.endsWith(`.min.mjs`)||e.startsWith(`data:`))}function Jd(e){return e.lineno!==void 0&&e.lineno>1e4||e.colno!==void 0&&e.colno>1e3}function Yd(e,t){let n=Wd.get(e);if(n===void 0)return!1;for(let e=t[0];e<=t[1];e++)if(n[e]===void 0)return!1;return!0}function Xd(e,t){if(!e.length)return[];let n=0,r=e[0];if(typeof r!=`number`)return[];let i=af(r,t),a=[];for(;;){if(n===e.length-1){a.push(i);break}let r=e[n+1];if(typeof r!=`number`)break;r<=i[1]?i[1]=r+t:(a.push(i),i=af(r,t)),n++}return a}function Zd(e,t,n){return new Promise((r,i)=>{let a=lt(e),o=tt({input:a});function s(){a.destroy(),r()}let c=0,l=0,u=t[l];if(u===void 0){s();return}let d=u[0],f=u[1];function p(t){Gd.set(e,1),Q&&K.error(`Failed to read file: ${e}. Error: ${t}`),o.close(),o.removeAllListeners(),s()}a.on(`error`,p),o.on(`error`,p),o.on(`close`,s),o.on(`line`,e=>{if(c++,!(c<d)&&(n[c]=Xa(e,0),c>=f)){if(l===t.length-1){o.close(),o.removeAllListeners();return}l++;let e=t[l];if(e===void 0){o.close(),o.removeAllListeners();return}d=e[0],f=e[1]}})})}async function Qd(e,t){let n={};if(t>0&&e.exception?.values){for(let t of e.exception.values)if(t.stacktrace?.frames?.length)for(let e=t.stacktrace.frames.length-1;e>=0;e--){let r=t.stacktrace.frames[e],i=r?.filename;!r||typeof i!=`string`||typeof r.lineno!=`number`||qd(i)||Jd(r)||(n[i]||(n[i]=[]),n[i].push(r.lineno))}}let r=Object.keys(n);if(r.length==0)return e;let i=[];for(let e of r){if(Gd.get(e))continue;let r=n[e];if(!r)continue;r.sort((e,t)=>e-t);let a=Xd(r,t);if(a.every(t=>Yd(e,t)))continue;let o=Kd(Wd,e,{});i.push(Zd(e,a,o))}if(await Promise.all(i).catch(()=>{Q&&K.log(`Failed to read one or more source files and resolve context lines`)}),t>0&&e.exception?.values)for(let n of e.exception.values)n.stacktrace?.frames&&n.stacktrace.frames.length>0&&$d(n.stacktrace.frames,t,Wd);return e}function $d(e,t,n){for(let r of e)if(r.filename&&r.context_line===void 0&&typeof r.lineno==`number`){let e=n.get(r.filename);if(e===void 0)continue;tf(r.lineno,r,t,e)}}function ef(e){delete e.pre_context,delete e.context_line,delete e.post_context}function tf(e,t,n,r){if(t.lineno===void 0||r===void 0){Q&&K.error(`Cannot resolve context for frame with no lineno or file contents`);return}t.pre_context=[];for(let i=nf(e,n);i<e;i++){let e=r[i];if(e===void 0){ef(t),Q&&K.error(`Could not find line ${i} in file ${t.filename}`);return}t.pre_context.push(e)}if(r[e]===void 0){ef(t),Q&&K.error(`Could not find line ${e} in file ${t.filename}`);return}t.context_line=r[e];let i=rf(e,n);t.post_context=[];for(let n=e+1;n<=i;n++){let e=r[n];if(e===void 0)break;t.post_context.push(e)}}function nf(e,t){return Math.max(1,e-t)}function rf(e,t){return e+t}function af(e,t){return[nf(e,t),rf(e,t)]}const of=Z(((e={})=>{let t=e.frameContextLines===void 0?7:e.frameContextLines;return{name:`ContextLines`,processEvent(e){return Qd(e,t)}}})),sf=lo(process.versions.node),cf=sf.major;sf.minor;let lf;async function uf(){if(lf===void 0)try{lf=!!(await import(`node:inspector`)).url()}catch{lf=!1}return lf}const df=`__SENTRY_ERROR_LOCAL_VARIABLES__`;function ff(e,t,n){let r=0,i=5,a=0;return setInterval(()=>{a===0?r>e&&(i*=2,n(i),i>86400&&(i=86400),a=i):(--a,a===0&&t()),r=0},1e3).unref(),()=>{r+=1}}function pf(e){return e!==void 0&&(e.length===0||e===`?`||e===`<anonymous>`)}function mf(e,t){return e===t||`Object.${e}`===t||e===`Object.${t}`||pf(e)&&pf(t)}function hf(...e){K.log(`[LocalVariables]`,...e)}const gf=Z(((e={})=>{function t(t,n){let r=(t.stacktrace?.frames||[]).filter(e=>e.function!==`new Promise`);for(let t=0;t<r.length;t++){let i=r.length-t-1,a=n[t],o=r[i];if(!o||!a)break;a.vars===void 0||o.in_app===!1&&e.includeOutOfAppFrames!==!0||!mf(o.function,a.function)||(o.vars=a.vars)}}function n(e,n){if(n.originalException&&typeof n.originalException==`object`&&df in n.originalException&&Array.isArray(n.originalException[df])){for(let r of e.exception?.values||[])t(r,n.originalException[df]);n.originalException[df]=void 0}return e}async function r(){let e=await import(`node:inspector`);e.url()||e.open(0)}function i(e){let t=new mt(new URL(`data:application/javascript;base64,LyohIEBzZW50cnkvbm9kZS1jb3JlIDEwLjQyLjAgKDA3YzkxOTApIHwgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdCAqLwppbXBvcnR7U2Vzc2lvbiBhcyBlfWZyb20ibm9kZTppbnNwZWN0b3IvcHJvbWlzZXMiO2ltcG9ydHt3b3JrZXJEYXRhIGFzIHR9ZnJvbSJub2RlOndvcmtlcl90aHJlYWRzIjtjb25zdCBuPWdsb2JhbFRoaXMsaT17fTtjb25zdCBvPSJfX1NFTlRSWV9FUlJPUl9MT0NBTF9WQVJJQUJMRVNfXyI7Y29uc3QgYT10O2Z1bmN0aW9uIHMoLi4uZSl7YS5kZWJ1ZyYmZnVuY3Rpb24oZSl7aWYoISgiY29uc29sZSJpbiBuKSlyZXR1cm4gZSgpO2NvbnN0IHQ9bi5jb25zb2xlLG89e30sYT1PYmplY3Qua2V5cyhpKTthLmZvckVhY2goZT0+e2NvbnN0IG49aVtlXTtvW2VdPXRbZV0sdFtlXT1ufSk7dHJ5e3JldHVybiBlKCl9ZmluYWxseXthLmZvckVhY2goZT0+e3RbZV09b1tlXX0pfX0oKCk9PmNvbnNvbGUubG9nKCJbTG9jYWxWYXJpYWJsZXMgV29ya2VyXSIsLi4uZSkpfWFzeW5jIGZ1bmN0aW9uIGMoZSx0LG4saSl7Y29uc3Qgbz1hd2FpdCBlLnBvc3QoIlJ1bnRpbWUuZ2V0UHJvcGVydGllcyIse29iamVjdElkOnQsb3duUHJvcGVydGllczohMH0pO2lbbl09by5yZXN1bHQuZmlsdGVyKGU9PiJsZW5ndGgiIT09ZS5uYW1lJiYhaXNOYU4ocGFyc2VJbnQoZS5uYW1lLDEwKSkpLnNvcnQoKGUsdCk9PnBhcnNlSW50KGUubmFtZSwxMCktcGFyc2VJbnQodC5uYW1lLDEwKSkubWFwKGU9PmUudmFsdWU/LnZhbHVlKX1hc3luYyBmdW5jdGlvbiByKGUsdCxuLGkpe2NvbnN0IG89YXdhaXQgZS5wb3N0KCJSdW50aW1lLmdldFByb3BlcnRpZXMiLHtvYmplY3RJZDp0LG93blByb3BlcnRpZXM6ITB9KTtpW25dPW8ucmVzdWx0Lm1hcChlPT5bZS5uYW1lLGUudmFsdWU/LnZhbHVlXSkucmVkdWNlKChlLFt0LG5dKT0+KGVbdF09bixlKSx7fSl9ZnVuY3Rpb24gdShlLHQpe2UudmFsdWUmJigidmFsdWUiaW4gZS52YWx1ZT92b2lkIDA9PT1lLnZhbHVlLnZhbHVlfHxudWxsPT09ZS52YWx1ZS52YWx1ZT90W2UubmFtZV09YDwke2UudmFsdWUudmFsdWV9PmA6dFtlLm5hbWVdPWUudmFsdWUudmFsdWU6ImRlc2NyaXB0aW9uImluIGUudmFsdWUmJiJmdW5jdGlvbiIhPT1lLnZhbHVlLnR5cGU/dFtlLm5hbWVdPWA8JHtlLnZhbHVlLmRlc2NyaXB0aW9ufT5gOiJ1bmRlZmluZWQiPT09ZS52YWx1ZS50eXBlJiYodFtlLm5hbWVdPSI8dW5kZWZpbmVkPiIpKX1hc3luYyBmdW5jdGlvbiBsKGUsdCl7Y29uc3Qgbj1hd2FpdCBlLnBvc3QoIlJ1bnRpbWUuZ2V0UHJvcGVydGllcyIse29iamVjdElkOnQsb3duUHJvcGVydGllczohMH0pLGk9e307Zm9yKGNvbnN0IHQgb2Ygbi5yZXN1bHQpaWYodC52YWx1ZT8ub2JqZWN0SWQmJiJBcnJheSI9PT10LnZhbHVlLmNsYXNzTmFtZSl7Y29uc3Qgbj10LnZhbHVlLm9iamVjdElkO2F3YWl0IGMoZSxuLHQubmFtZSxpKX1lbHNlIGlmKHQudmFsdWU/Lm9iamVjdElkJiYiT2JqZWN0Ij09PXQudmFsdWUuY2xhc3NOYW1lKXtjb25zdCBuPXQudmFsdWUub2JqZWN0SWQ7YXdhaXQgcihlLG4sdC5uYW1lLGkpfWVsc2UgdC52YWx1ZSYmdSh0LGkpO3JldHVybiBpfWxldCBmOyhhc3luYyBmdW5jdGlvbigpe2NvbnN0IHQ9bmV3IGU7dC5jb25uZWN0VG9NYWluVGhyZWFkKCkscygiQ29ubmVjdGVkIHRvIG1haW4gdGhyZWFkIik7bGV0IG49ITE7dC5vbigiRGVidWdnZXIucmVzdW1lZCIsKCk9PntuPSExfSksdC5vbigiRGVidWdnZXIucGF1c2VkIixlPT57bj0hMCxhc3luYyBmdW5jdGlvbihlLHtyZWFzb246dCxkYXRhOntvYmplY3RJZDpufSxjYWxsRnJhbWVzOml9KXtpZigiZXhjZXB0aW9uIiE9PXQmJiJwcm9taXNlUmVqZWN0aW9uIiE9PXQpcmV0dXJuO2lmKGY/LigpLG51bGw9PW4pcmV0dXJuO2NvbnN0IGE9W107Zm9yKGxldCB0PTA7dDxpLmxlbmd0aDt0Kyspe2NvbnN0e3Njb3BlQ2hhaW46bixmdW5jdGlvbk5hbWU6byx0aGlzOnN9PWlbdF0sYz1uLmZpbmQoZT0+ImxvY2FsIj09PWUudHlwZSkscj0iZ2xvYmFsIiE9PXMuY2xhc3NOYW1lJiZzLmNsYXNzTmFtZT9gJHtzLmNsYXNzTmFtZX0uJHtvfWA6bztpZih2b2lkIDA9PT1jPy5vYmplY3Qub2JqZWN0SWQpYVt0XT17ZnVuY3Rpb246cn07ZWxzZXtjb25zdCBuPWF3YWl0IGwoZSxjLm9iamVjdC5vYmplY3RJZCk7YVt0XT17ZnVuY3Rpb246cix2YXJzOm59fX1hd2FpdCBlLnBvc3QoIlJ1bnRpbWUuY2FsbEZ1bmN0aW9uT24iLHtmdW5jdGlvbkRlY2xhcmF0aW9uOmBmdW5jdGlvbigpIHsgdGhpcy4ke299ID0gdGhpcy4ke299IHx8ICR7SlNPTi5zdHJpbmdpZnkoYSl9OyB9YCxzaWxlbnQ6ITAsb2JqZWN0SWQ6bn0pLGF3YWl0IGUucG9zdCgiUnVudGltZS5yZWxlYXNlT2JqZWN0Iix7b2JqZWN0SWQ6bn0pfSh0LGUucGFyYW1zKS50aGVuKGFzeW5jKCk9PntuJiZhd2FpdCB0LnBvc3QoIkRlYnVnZ2VyLnJlc3VtZSIpfSxhc3luYyBlPT57biYmYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5yZXN1bWUiKX0pfSksYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5lbmFibGUiKTtjb25zdCBpPSExIT09YS5jYXB0dXJlQWxsRXhjZXB0aW9ucztpZihhd2FpdCB0LnBvc3QoIkRlYnVnZ2VyLnNldFBhdXNlT25FeGNlcHRpb25zIix7c3RhdGU6aT8iYWxsIjoidW5jYXVnaHQifSksaSl7Y29uc3QgZT1hLm1heEV4Y2VwdGlvbnNQZXJTZWNvbmR8fDUwO2Y9ZnVuY3Rpb24oZSx0LG4pe2xldCBpPTAsbz01LGE9MDtyZXR1cm4gc2V0SW50ZXJ2YWwoKCk9PnswPT09YT9pPmUmJihvKj0yLG4obyksbz44NjQwMCYmKG89ODY0MDApLGE9byk6KGEtPTEsMD09PWEmJnQoKSksaT0wfSwxZTMpLnVucmVmKCksKCk9PntpKz0xfX0oZSxhc3luYygpPT57cygiUmF0ZS1saW1pdCBsaWZ0ZWQuIiksYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5zZXRQYXVzZU9uRXhjZXB0aW9ucyIse3N0YXRlOiJhbGwifSl9LGFzeW5jIGU9PntzKGBSYXRlLWxpbWl0IGV4Y2VlZGVkLiBEaXNhYmxpbmcgY2FwdHVyaW5nIG9mIGNhdWdodCBleGNlcHRpb25zIGZvciAke2V9IHNlY29uZHMuYCksYXdhaXQgdC5wb3N0KCJEZWJ1Z2dlci5zZXRQYXVzZU9uRXhjZXB0aW9ucyIse3N0YXRlOiJ1bmNhdWdodCJ9KX0pfX0pKCkuY2F0Y2goZT0+e3MoIkZhaWxlZCB0byBzdGFydCBkZWJ1Z2dlciIsZSl9KSxzZXRJbnRlcnZhbCgoKT0+e30sMWU0KTs=`),{workerData:e,execArgv:[],env:{...process.env,NODE_OPTIONS:void 0}});process.on(`exit`,()=>{t.terminate()}),t.once(`error`,e=>{hf(`Worker error`,e)}),t.once(`exit`,e=>{hf(`Worker exit`,e)}),t.unref()}return{name:`LocalVariablesAsync`,async setup(t){if(!t.getOptions().includeLocalVariables)return;if(await uf()){K.warn(`Local variables capture has been disabled because the debugger was already enabled`);return}let n={...e,debug:K.isEnabled()};r().then(()=>{try{i(n)}catch(e){K.error(`Failed to start worker`,e)}},e=>{K.error(`Failed to start inspector`,e)})},processEvent(e,t){return n(e,t)}}}));function _f(e){if(e!==void 0)return e.slice(-10).reduce((e,t)=>`${e},${t.function},${t.lineno},${t.colno}`,``)}function vf(e,t){if(t!==void 0)return _f(e(t,1))}function yf(e){let t=[],n=!1;function r(r){t=[],!n&&(n=!0,e(r))}t.push(r);function i(e){t.push(e)}function a(e){let n=t.pop()||r;try{n(e)}catch{r(e)}}return{add:i,next:a}}var bf=class e{constructor(e){this._session=e}static async create(t){return t||new e(new(await(import(`node:inspector`))).Session)}configureAndConnect(e,t){this._session.connect(),this._session.on(`Debugger.paused`,t=>{e(t,()=>{this._session.post(`Debugger.resume`)})}),this._session.post(`Debugger.enable`),this._session.post(`Debugger.setPauseOnExceptions`,{state:t?`all`:`uncaught`})}setPauseOnExceptions(e){this._session.post(`Debugger.setPauseOnExceptions`,{state:e?`all`:`uncaught`})}getLocalVariables(e,t){this._getProperties(e,e=>{let{add:n,next:r}=yf(t);for(let t of e)if(t.value?.objectId&&t.value.className===`Array`){let e=t.value.objectId;n(n=>this._unrollArray(e,t.name,n,r))}else if(t.value?.objectId&&t.value.className===`Object`){let e=t.value.objectId;n(n=>this._unrollObject(e,t.name,n,r))}else t.value&&n(e=>this._unrollOther(t,e,r));r({})})}_getProperties(e,t){this._session.post(`Runtime.getProperties`,{objectId:e,ownProperties:!0},(e,n)=>{t(e?[]:n.result)})}_unrollArray(e,t,n,r){this._getProperties(e,e=>{n[t]=e.filter(e=>e.name!==`length`&&!isNaN(parseInt(e.name,10))).sort((e,t)=>parseInt(e.name,10)-parseInt(t.name,10)).map(e=>e.value?.value),r(n)})}_unrollObject(e,t,n,r){this._getProperties(e,e=>{n[t]=e.map(e=>[e.name,e.value?.value]).reduce((e,[t,n])=>(e[t]=n,e),{}),r(n)})}_unrollOther(e,t,n){e.value&&(`value`in e.value?e.value.value===void 0||e.value.value===null?t[e.name]=`<${e.value.value}>`:t[e.name]=e.value.value:`description`in e.value&&e.value.type!==`function`?t[e.name]=`<${e.value.description}>`:e.value.type===`undefined`&&(t[e.name]=`<undefined>`)),n(t)}};const xf=Z(((e={},t)=>{let n=new Cd(20),r,i=!1;function a(t){let r=_f(t.stacktrace?.frames);if(r===void 0)return;let i=n.remove(r);if(i===void 0)return;let a=(t.stacktrace?.frames||[]).filter(e=>e.function!==`new Promise`);for(let t=0;t<a.length;t++){let n=a.length-t-1,r=i[t],o=a[n];if(!o||!r)break;r.vars===void 0||o.in_app===!1&&e.includeOutOfAppFrames!==!0||!mf(o.function,r.function)||(o.vars=r.vars)}}function o(e){for(let t of e.exception?.values||[])a(t);return e}let s;async function c(){let a=X()?.getOptions();if(a?.includeLocalVariables){if(cf<18){K.log("The `LocalVariables` integration is only supported on Node >= v18.");return}if(await uf()){K.warn(`Local variables capture has been disabled because the debugger was already enabled`);return}try{let o=await bf.create(t),s=(e,{params:{reason:t,data:i,callFrames:a}},s)=>{if(t!==`exception`&&t!==`promiseRejection`){s();return}r?.();let c=vf(e,i.description);if(c==null){s();return}let{add:l,next:u}=yf(e=>{n.set(c,e),s()});for(let e=0;e<Math.min(a.length,5);e++){let{scopeChain:t,functionName:n,this:r}=a[e],i=t.find(e=>e.type===`local`),s=r.className===`global`||!r.className?n:`${r.className}.${n}`;if(i?.object.objectId===void 0)l(t=>{t[e]={function:s},u(t)});else{let t=i.object.objectId;l(n=>o.getLocalVariables(t,t=>{n[e]={function:s,vars:t},u(n)}))}}u([])},c=e.captureAllExceptions!==!1;o.configureAndConnect((e,t)=>s(a.stackParser,e,t),c),c&&(r=ff(e.maxExceptionsPerSecond||50,()=>{K.log(`Local variables rate-limit lifted.`),o.setPauseOnExceptions(!0)},e=>{K.log(`Local variables rate-limit exceeded. Disabling capturing of caught exceptions for ${e} seconds.`),o.setPauseOnExceptions(!1)})),i=!0}catch(e){K.log("The `LocalVariables` integration failed to start.",e)}}}return{name:`LocalVariables`,setupOnce(){s=c()},async processEvent(e){return await s,i?o(e):e},_getCachedFramesCount(){return n.size},_getFirstCachedFrame(){return n.values()[0]}}})),Sf=(e={})=>sf.major<19?xf(e):gf(e);function Cf(){try{return typeof module<`u`&&module.exports!==void 0}catch{return!1}}let wf;const Tf=typeof __SENTRY_SERVER_MODULES__>`u`?{}:__SENTRY_SERVER_MODULES__,Ef=(()=>({name:`Modules`,processEvent(e){return e.modules={...e.modules,...Af()},e},getModules:Af}));function Df(){try{return i.cache?Object.keys(i.cache):[]}catch{return[]}}function Of(){return{...Tf,...Mf(),...Cf()?kf():{}}}function kf(){let e=i.main?.paths||[],t=Df(),n={},r=new Set;return t.forEach(t=>{let i=t,a=()=>{let t=i;if(i=Je(t),!i||t===i||r.has(t))return;if(e.indexOf(i)<0)return a();let o=Ye(t,`package.json`);if(r.add(t),!ut(o))return a();try{let e=JSON.parse(ft(o,`utf8`));n[e.name]=e.version}catch{}};a()}),n}function Af(){return wf||=Of(),wf}function jf(){try{let e=Ye(process.cwd(),`package.json`);return JSON.parse(ft(e,`utf8`))}catch{return{}}}function Mf(){let e=jf();return{...e.dependencies,...e.devDependencies}}function Nf(e){Ui(()=>{console.error(e)});let t=X();if(t===void 0){Q&&K.warn(`No NodeClient was defined, we are exiting the process now.`),global.process.exit(1);return}let n=t.getOptions(),r=n?.shutdownTimeout&&n.shutdownTimeout>0?n.shutdownTimeout:2e3;t.close(r).then(e=>{e||Q&&K.warn(`We reached the timeout for emptying the request buffer, still exiting now!`),global.process.exit(1)},e=>{Q&&K.error(e)})}const Pf=Z((e={})=>{let t={exitEvenIfOtherHandlersAreRegistered:!1,...e};return{name:`OnUncaughtException`,setup(e){at&&global.process.on(`uncaughtException`,Ff(e,t))}}});function Ff(e,t){let n=!1,r=!1,i=!1,a,o=e.getOptions();return Object.assign(s=>{let c=Nf;t.onFatalError?c=t.onFatalError:o.onFatalError&&(c=o.onFatalError);let l=global.process.listeners(`uncaughtException`).filter(e=>e.name!==`domainUncaughtExceptionClear`&&e.tag!==`sentry_tracingErrorCallback`&&e._errorHandler!==!0).length===0,u=t.exitEvenIfOtherHandlersAreRegistered||l;n?u&&(i?(Q&&K.warn(`uncaught exception after calling fatal error shutdown callback - this is bad! forcing shutdown`),Nf(s)):r||(r=!0,setTimeout(()=>{i||(i=!0,c(a,s))},2e3))):(a=s,n=!0,X()===e&&Jc(s,{originalException:s,captureContext:{level:`fatal`},mechanism:{handled:!1,type:`auto.node.onuncaughtexception`}}),!i&&u&&(i=!0,c(s)))},{_errorHandler:!0})}const If=[{name:`AI_NoOutputGeneratedError`},{name:`AbortError`}],Lf=Z(((e={})=>{let t={mode:e.mode??`warn`,ignore:[...If,...e.ignore??[]]};return{name:`OnUnhandledRejection`,setup(e){global.process.on(`unhandledRejection`,Vf(e,t))}}}));function Rf(e){if(typeof e!=`object`||!e)return{name:``,message:String(e??``)};let t=e;return{name:typeof t.name==`string`?t.name:``,message:typeof t.message==`string`?t.message:String(e)}}function zf(e,t){let n=e.name===void 0||Qa(t.name,e.name,!0),r=e.message===void 0||Qa(t.message,e.message);return n&&r}function Bf(e,t){let n=Rf(t);return e.some(e=>zf(e,n))}function Vf(e,t){return function(n,r){if(X()!==e||Bf(t.ignore??[],n))return;let i=t.mode===`strict`?`fatal`:`error`,a=n&&typeof n==`object`?n._sentry_active_span:void 0;(a?e=>mc(a,e):e=>e())(()=>{Jc(n,{originalException:r,captureContext:{extra:{unhandledPromiseRejection:!0},level:i},mechanism:{handled:!1,type:`auto.node.onunhandledrejection`}})}),Hf(n,t.mode)}}function Hf(e,t){let n=`This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason:`;t===`warn`?Ui(()=>{console.warn(n),console.error(e&&typeof e==`object`&&`stack`in e?e.stack:e)}):t===`strict`&&(Ui(()=>{console.warn(n)}),Nf(e))}const Uf=Z(()=>({name:`ProcessSession`,setupOnce(){el(),process.on(`beforeExit`,()=>{Y().getSession()?.status!==`ok`&&tl()})}})),Wf=`Spotlight`,Gf=Z(((e={})=>{let t={sidecarUrl:e.sidecarUrl||`http://localhost:8969/stream`};return{name:Wf,setup(e){try{process.env.NODE_ENV&&process.env.NODE_ENV!==`development`&&K.warn(`[Spotlight] It seems you're not in dev mode. Do you really want to have Spotlight enabled?`)}catch{}Kf(e,t)}}}));function Kf(e,t){let n=qf(t.sidecarUrl);if(!n)return;let r=0;e.on(`beforeEnvelope`,e=>{if(r>3){K.warn(`[Spotlight] Disabled Sentry -> Spotlight integration due to too many failed requests`);return}let t=nc(e);hc(()=>{let e=nt.request({method:`POST`,path:n.pathname,hostname:n.hostname,port:n.port,headers:{"Content-Type":`application/x-sentry-envelope`}},e=>{e.statusCode&&e.statusCode>=200&&e.statusCode<400&&(r=0),e.on(`data`,()=>{}),e.on(`end`,()=>{}),e.setEncoding(`utf8`)});e.on(`error`,()=>{r++,K.warn(`[Spotlight] Failed to send envelope to Spotlight Sidecar`)}),e.write(t),e.end()})})}function qf(e){try{return new URL(`${e}`)}catch{K.warn(`[Spotlight] Invalid sidecar URL: ${e}`);return}}function Jf(e){return!(e instanceof Error)||!(`errno`in e)||typeof e.errno!=`number`?!1:Ve.getSystemErrorMap().has(e.errno)}const Yf=Z((e={})=>({name:`NodeSystemError`,processEvent:(t,n,r)=>{if(!Jf(n.originalException))return t;let i=n.originalException,a={...i};!r.getOptions().sendDefaultPii&&e.includePaths!==!0&&(delete a.path,delete a.dest),t.contexts={...t.contexts,node_system_error:a};for(let e of t.exception?.values||[])e.value&&(i.path&&e.value.includes(i.path)&&(e.value=e.value.replace(`'${i.path}'`,``).trim()),i.dest&&e.value.includes(i.dest)&&(e.value=e.value.replace(`'${i.dest}'`,``).trim()));return t}}));function Xf(e){return e.replace(/^[A-Z]:/,``).replace(/\\/g,`/`)}function Zf(e=process.argv[1]?pd(process.argv[1]):process.cwd(),t=Ze===`\\`){let n=t?Xf(e):e;return e=>{if(!e)return;let r=t?Xf(e):e,{dir:i,base:a,ext:o}=Xe.parse(r);(o===`.js`||o===`.mjs`||o===`.cjs`)&&(a=a.slice(0,o.length*-1));let s=decodeURIComponent(a);i||=`.`;let c=i.lastIndexOf(`/node_modules`);if(c>-1)return`${i.slice(c+14).replace(/\//g,`.`)}:${s}`;if(i.startsWith(n)){let e=i.slice(n.length+1).replace(/\//g,`.`);return e?`${e}:${s}`:s}return s}}function Qf(e){if(process.env.SENTRY_RELEASE)return process.env.SENTRY_RELEASE;if(G.SENTRY_RELEASE?.id)return G.SENTRY_RELEASE.id;let t=process.env.GITHUB_SHA||process.env.CI_MERGE_REQUEST_SOURCE_BRANCH_SHA||process.env.CI_BUILD_REF||process.env.CI_COMMIT_SHA||process.env.BITBUCKET_COMMIT,n=process.env.APPVEYOR_PULL_REQUEST_HEAD_COMMIT||process.env.APPVEYOR_REPO_COMMIT||process.env.CODEBUILD_RESOLVED_SOURCE_VERSION||process.env.AWS_COMMIT_ID||process.env.BUILD_SOURCEVERSION||process.env.GIT_CLONE_COMMIT_HASH||process.env.BUDDY_EXECUTION_REVISION||process.env.BUILDKITE_COMMIT||process.env.CIRCLE_SHA1||process.env.CIRRUS_CHANGE_IN_REPO||process.env.CF_REVISION||process.env.CM_COMMIT||process.env.CF_PAGES_COMMIT_SHA||process.env.DRONE_COMMIT_SHA||process.env.FC_GIT_COMMIT_SHA||process.env.HEROKU_TEST_RUN_COMMIT_VERSION||process.env.HEROKU_SLUG_COMMIT||process.env.RAILWAY_GIT_COMMIT_SHA||process.env.RENDER_GIT_COMMIT||process.env.SEMAPHORE_GIT_SHA||process.env.TRAVIS_PULL_REQUEST_SHA||process.env.VERCEL_GIT_COMMIT_SHA||process.env.VERCEL_GITHUB_COMMIT_SHA||process.env.VERCEL_GITLAB_COMMIT_SHA||process.env.VERCEL_BITBUCKET_COMMIT_SHA||process.env.ZEIT_GITHUB_COMMIT_SHA||process.env.ZEIT_GITLAB_COMMIT_SHA||process.env.ZEIT_BITBUCKET_COMMIT_SHA,r=process.env.CI_COMMIT_ID||process.env.SOURCE_COMMIT||process.env.SOURCE_VERSION||process.env.GIT_COMMIT||process.env.COMMIT_REF||process.env.BUILD_VCS_NUMBER||process.env.CI_COMMIT_SHA;return t||n||r||e}const $f=ea(bd(Zf())),ep=Symbol(`AgentBaseInternalState`);var tp=class extends nt.Agent{constructor(e){super(e),this[ep]={}}isSecureEndpoint(e){if(e){if(typeof e.secureEndpoint==`boolean`)return e.secureEndpoint;if(typeof e.protocol==`string`)return e.protocol===`https:`}let{stack:t}=Error();return typeof t==`string`?t.split(`
325
+ `).some(e=>e.indexOf(`(https.js:`)!==-1||e.indexOf(`node:https:`)!==-1):!1}createSocket(e,t,n){let r={...t,secureEndpoint:this.isSecureEndpoint(t)};Promise.resolve().then(()=>this.connect(e,r)).then(i=>{if(i instanceof nt.Agent)return i.addRequest(e,r);this[ep].currentSocket=i,super.createSocket(e,t,n)},n)}createConnection(){let e=this[ep].currentSocket;if(this[ep].currentSocket=void 0,!e)throw Error("No socket was returned in the `connect()` function");return e}get defaultPort(){return this[ep].defaultPort??(this.protocol===`https:`?443:80)}set defaultPort(e){this[ep]&&(this[ep].defaultPort=e)}get protocol(){return this[ep].protocol??(this.isSecureEndpoint()?`https:`:`http:`)}set protocol(e){this[ep]&&(this[ep].protocol=e)}};function np(...e){K.log(`[https-proxy-agent:parse-proxy-response]`,...e)}function rp(e){return new Promise((t,n)=>{let r=0,i=[];function a(){let t=e.read();t?l(t):e.once(`readable`,a)}function o(){e.removeListener(`end`,s),e.removeListener(`error`,c),e.removeListener(`readable`,a)}function s(){o(),np(`onend`),n(Error(`Proxy connection ended before receiving CONNECT response`))}function c(e){o(),np(`onerror %o`,e),n(e)}function l(s){i.push(s),r+=s.length;let c=Buffer.concat(i,r),l=c.indexOf(`\r
326
326
  \r
327
- `);if(l===-1){tp(`have not received end of HTTP headers yet...`),a();return}let u=c.subarray(0,l).toString(`ascii`).split(`\r
328
- `),d=u.shift();if(!d)return e.destroy(),n(Error(`No header received from proxy CONNECT response`));let f=d.split(` `),p=+(f[1]||0),m=f.slice(2).join(` `),h={};for(let t of u){if(!t)continue;let r=t.indexOf(`:`);if(r===-1)return e.destroy(),n(Error(`Invalid header from proxy CONNECT response: "${t}"`));let i=t.slice(0,r).toLowerCase(),a=t.slice(r+1).trimStart(),o=h[i];typeof o==`string`?h[i]=[o,a]:Array.isArray(o)?o.push(a):h[i]=a}tp(`got proxy server response: %o %o`,d,h),o(),t({connect:{statusCode:p,statusText:m,headers:h},buffered:c})}e.on(`error`,c),e.on(`end`,s),a()})}function rp(...e){K.log(`[https-proxy-agent]`,...e)}var ip=class extends ep{static __initStatic(){this.protocols=[`http`,`https`]}constructor(e,t){super(t),this.options={},this.proxy=typeof e==`string`?new URL(e):e,this.proxyHeaders=t?.headers??{},rp(`Creating new HttpsProxyAgent instance: %o`,this.proxy.href);let n=(this.proxy.hostname||this.proxy.host).replace(/^\[|\]$/g,``),r=this.proxy.port?parseInt(this.proxy.port,10):this.proxy.protocol===`https:`?443:80;this.connectOpts={ALPNProtocols:[`http/1.1`],...t?op(t,`headers`):null,host:n,port:r}}async connect(e,t){let{proxy:n}=this;if(!t.host)throw TypeError(`No "host" provided`);let r;if(n.protocol===`https:`){rp("Creating `tls.Socket`: %o",this.connectOpts);let e=this.connectOpts.servername||this.connectOpts.host;r=vt.connect({...this.connectOpts,servername:e&&_t.isIP(e)?void 0:e})}else rp("Creating `net.Socket`: %o",this.connectOpts),r=_t.connect(this.connectOpts);let i=typeof this.proxyHeaders==`function`?this.proxyHeaders():{...this.proxyHeaders},a=_t.isIPv6(t.host)?`[${t.host}]`:t.host,o=`CONNECT ${a}:${t.port} HTTP/1.1\r\n`;if(n.username||n.password){let e=`${decodeURIComponent(n.username)}:${decodeURIComponent(n.password)}`;i[`Proxy-Authorization`]=`Basic ${Buffer.from(e).toString(`base64`)}`}i.Host=`${a}:${t.port}`,i[`Proxy-Connection`]||=this.keepAlive?`Keep-Alive`:`close`;for(let e of Object.keys(i))o+=`${e}: ${i[e]}\r\n`;let s=np(r);r.write(`${o}\r\n`);let{connect:c,buffered:l}=await s;if(e.emit(`proxyConnect`,c),this.emit(`proxyConnect`,c,e),c.statusCode===200){if(e.once(`socket`,ap),t.secureEndpoint){rp(`Upgrading socket connection to TLS`);let e=t.servername||t.host;return vt.connect({...op(t,`host`,`path`,`port`),socket:r,servername:_t.isIP(e)?void 0:e})}return r}r.destroy();let u=new _t.Socket({writable:!1});return u.readable=!0,e.once(`socket`,e=>{rp(`Replaying proxy buffer for failed request`),e.push(l),e.push(null)}),u}};ip.__initStatic();function ap(e){e.resume()}function op(e,...t){let n={},r;for(r in e)t.includes(r)||(n[r]=e[r]);return n}function sp(e){return new et({read(){this.push(e),this.push(null)}})}function cp(e){let t;try{t=new URL(e.url)}catch{return Hi(()=>{console.warn(`[@sentry/node]: Invalid dsn or tunnel option, will not send any events. The tunnel option must be a full URL when used.`)}),Al(e,()=>Promise.resolve({}))}let n=t.protocol===`https:`,r=lp(t,e.proxy||(n?process.env.https_proxy:void 0)||process.env.http_proxy),i=n?ht:nt,a=e.keepAlive===void 0?!1:e.keepAlive,o=r?new ip(r):new i.Agent({keepAlive:a,maxSockets:30,timeout:2e3});return Al(e,up(e,e.httpModule??i,o))}function lp(e,t){let{no_proxy:n}=process.env;if(!n?.split(`,`).some(t=>e.host.endsWith(t)||e.hostname.endsWith(t)))return t}function up(e,t,n){let{hostname:r,pathname:i,port:a,protocol:o,search:s}=new URL(e.url);return function(c){return new Promise((l,u)=>{mc(()=>{let d=sp(c.body),f={...e.headers};c.body.length>32768&&(f[`content-encoding`]=`gzip`,d=d.pipe(gt()));let p=r.startsWith(`[`),m=t.request({method:`POST`,agent:n,headers:f,hostname:p?r.slice(1,-1):r,path:`${i}${s}`,port:a,protocol:o,ca:e.caCerts},e=>{e.on(`data`,()=>{}),e.on(`end`,()=>{}),e.setEncoding(`utf8`);let t=e.headers[`retry-after`]??null,n=e.headers[`x-sentry-rate-limits`]??null;l({statusCode:e.statusCode,headers:{"retry-after":t,"x-sentry-rate-limits":Array.isArray(n)?n[0]||null:n}})});m.on(`error`,u),d.pipe(m)})})}}function dp(e){if(e===!1)return!1;if(typeof e==`string`)return e;let t=_u(process.env.SENTRY_SPOTLIGHT,{strict:!0}),n=t===null&&process.env.SENTRY_SPOTLIGHT?process.env.SENTRY_SPOTLIGHT:void 0;return e===!0?n??!0:t??n}function fp(){let e=new yt;function t(){return e.getStore()||{scope:Oo(),isolationScope:ko()}}function n(n){let r=t().scope.clone(),i=t().isolationScope;return e.run({scope:r,isolationScope:i},()=>n(r))}function r(n,r){let i=t().isolationScope.clone();return e.run({scope:n,isolationScope:i},()=>r(n))}function i(n){let r=t().scope.clone(),i=t().isolationScope.clone();return e.run({scope:r,isolationScope:i},()=>n(i))}function a(n,r){let i=t().scope.clone();return e.run({scope:i,isolationScope:n},()=>r(n))}function o(e){return n(t=>(t.setSDKProcessingMetadata({__SENTRY_SUPPRESS_TRACING__:!0}),e()))}Io({suppressTracing:o,withScope:n,withSetScope:r,withIsolationScope:i,withSetIsolationScope:a,getCurrentScope:()=>t().scope,getIsolationScope:()=>t().isolationScope})}function pp(e,t,n,r){let i=0,a=[];Q&&K.log(r,`Patching request.on`);let o=new WeakMap,s=n===`small`?1e3:n===`medium`?1e4:1048576;try{e.on=new Proxy(e.on,{apply:(e,t,n)=>{let[c,l,...u]=n;if(c===`data`){Q&&K.log(r,`Handling request.on("data") with maximum body size of ${s}b`);let n=new Proxy(l,{apply:(e,t,n)=>{try{let e=n[0],t=Buffer.from(e);i<s?(a.push(t),i+=t.byteLength):Q&&K.log(r,`Dropping request body chunk because maximum body length of ${s}b is exceeded.`)}catch{Q&&K.error(r,`Encountered error while storing body chunk.`)}return Reflect.apply(e,t,n)}});return o.set(l,n),Reflect.apply(e,t,[c,n,...u])}return Reflect.apply(e,t,n)}}),e.off=new Proxy(e.off,{apply:(e,t,n)=>{let[,r]=n,i=o.get(r);if(i){o.delete(r);let a=n.slice();return a[1]=i,Reflect.apply(e,t,a)}return Reflect.apply(e,t,n)}}),e.on(`end`,()=>{try{let e=Buffer.concat(a).toString(`utf-8`);if(e){let n=Buffer.byteLength(e,`utf-8`)>s?`${Buffer.from(e).subarray(0,s-3).toString(`utf-8`)}...`:e;t.setSDKProcessingMetadata({normalizedRequest:{data:n}})}}catch(e){Q&&K.error(r,`Error building captured request body`,e)}})}catch(e){Q&&K.error(r,`Error patching request to capture body`,e)}}function mp(e,t){if(!e)return t;let n=Yo(e),r=Yo(t);if(!r)return e;let i={...n};return Object.entries(r).forEach(([e,t])=>{i[e]||(i[e]=t)}),Zo(i)}const hp=`@sentry/instrumentation-http`;function gp(e,t){let n=vp(e),r=t?.statusCode,i=gd(r);ju({category:`http`,data:{status_code:r,...n},type:`http`,level:i},{event:`response`,request:e,response:t})}function _p(e,t){let n=bp(e),{tracePropagationTargets:r,propagateTraceparent:i}=X()?.getOptions()||{},a=Eu(n,r,t)?Su({propagateTraceparent:i}):void 0;if(!a)return;let{"sentry-trace":o,baggage:s,traceparent:c}=a;if(o&&!e.getHeader(`sentry-trace`))try{e.setHeader(`sentry-trace`,o),Q&&K.log(hp,`Added sentry-trace header to outgoing request`)}catch(e){Q&&K.error(hp,`Failed to add sentry-trace header to outgoing request:`,ya(e)?e.message:`Unknown error`)}if(c&&!e.getHeader(`traceparent`))try{e.setHeader(`traceparent`,c),Q&&K.log(hp,`Added traceparent header to outgoing request`)}catch(e){Q&&K.error(hp,`Failed to add traceparent header to outgoing request:`,ya(e)?e.message:`Unknown error`)}if(s){let t=mp(e.getHeader(`baggage`),s);if(t)try{e.setHeader(`baggage`,t),Q&&K.log(hp,`Added baggage header to outgoing request`)}catch(e){Q&&K.error(hp,`Failed to add baggage header to outgoing request:`,ya(e)?e.message:`Unknown error`)}}}function vp(e){try{let t=e.getHeader(`host`)||e.host,n=vu(new URL(e.path,`${e.protocol}//${t}`).toString()),r={url:bu(n),"http.method":e.method||`GET`};return n.search&&(r[`http.query`]=n.search),n.hash&&(r[`http.fragment`]=n.hash),r}catch{return{}}}function yp(e){return{method:e.method,protocol:e.protocol,host:e.host,hostname:e.host,path:e.path,headers:e.getHeaders()}}function bp(e){let t=e.getHeader(`host`)||e.host;return`${e.protocol}//${t}${e.path}`}const xp=`Http`,Sp=new WeakSet,Cp=((e={})=>{let t={maxRequestBodySize:e.maxRequestBodySize??`medium`,ignoreRequestBody:e.ignoreRequestBody,breadcrumbs:e.breadcrumbs??!0,ignoreOutgoingRequests:e.ignoreOutgoingRequests},n=new Sd(100),r=new WeakMap;return{name:xp,setupOnce(){ct(`http.server.request.start`,(e=>{wp(e.server,t)})),ct(`http.client.request.created`,(e=>{Tp(e.request,t,n,r)})),ct(`http.client.response.finish`,(e=>{let n=e;Ep(n.request,n.response,t,r)})),ct(`http.client.request.error`,(e=>{Ep(e.request,void 0,t,r)}))}}});function wp(e,{ignoreRequestBody:t,maxRequestBodySize:n}){let r=e.emit;if(Sp.has(r))return;let i=new Proxy(r,{apply(e,r,i){if(i[0]!==`request`||!J().getClient())return e.apply(r,i);Q&&K.log(xp,`Handling incoming request`);let a=Y().clone(),o=i[1],s=Ou(o),c=o.ip||o.socket?.remoteAddress,l=o.url||`/`;n!==`none`&&!t?.(l,o)&&pp(o,a,n,xp),a.setSDKProcessingMetadata({normalizedRequest:s,ipAddress:c});let u=`${(o.method||`GET`).toUpperCase()} ${yu(l)}`;return a.setTransactionName(u),Bo(a,()=>{let t=s.headers?.[`sentry-trace`],n=s.headers?.baggage;return fc({sentryTrace:Array.isArray(t)?t[0]:t,baggage:Array.isArray(n)?n[0]:n},()=>(J().getPropagationContext().propagationSpanId=Co(),e.apply(r,i)))})}});Sp.add(i),e.emit=i}function Tp(e,t,n,r){let i=Dp(e,t);r.set(e,i),!i&&_p(e,n)}function Ep(e,t,n,r){n.breadcrumbs&&((r.get(e)??Dp(e,n))||gp(e,t))}function Dp(e,t){if(J().getScopeData().sdkProcessingMetadata.__SENTRY_SUPPRESS_TRACING__)return!0;let{ignoreOutgoingRequests:n}=t;return n?n(`${e.protocol}//${e.getHeader(`host`)||e.host}${e.path}`,yp(e)):!1}const Op=`sentry-trace`,kp=`baggage`,Ap=/baggage: (.*)\r\n/;function jp(e,t){let n=Pp(e.origin,e.path),{tracePropagationTargets:r,propagateTraceparent:i}=X()?.getOptions()||{},a=Eu(n,r,t)?Su({propagateTraceparent:i}):void 0;if(!a)return;let{"sentry-trace":o,baggage:s,traceparent:c}=a;if(Array.isArray(e.headers)){let t=e.headers;o&&!t.includes(Op)&&t.push(Op,o),c&&!t.includes(`traceparent`)&&t.push(`traceparent`,c);let n=t.findIndex(e=>e===kp);if(s&&n===-1)t.push(kp,s);else if(s){let e=t[n+1],r=mp(e,s);r&&(t[n+1]=r)}}else{let t=e.headers;o&&!t.includes(`${Op}:`)&&(e.headers+=`${Op}: ${o}\r\n`),c&&!t.includes(`traceparent:`)&&(e.headers+=`traceparent: ${c}\r\n`);let n=e.headers.match(Ap)?.[1];if(s&&!n)e.headers+=`${kp}: ${s}\r\n`;else if(s){let t=mp(n,s);t&&(e.headers=e.headers.replace(Ap,`baggage: ${t}\r\n`))}}}function Mp(e,t){let n=Np(e),r=t.statusCode,i=gd(r);ju({category:`http`,data:{status_code:r,...n},type:`http`,level:i},{event:`response`,request:e,response:t})}function Np(e){try{let t=vu(Pp(e.origin,e.path)),n={url:bu(t),"http.method":e.method||`GET`};return t.search&&(n[`http.query`]=t.search),t.hash&&(n[`http.fragment`]=t.hash),n}catch{return{}}}function Pp(e,t=`/`){try{return new URL(t,e).toString()}catch{let n=`${e}`;return n.endsWith(`/`)&&t.startsWith(`/`)?`${n}${t.slice(1)}`:!n.endsWith(`/`)&&!t.startsWith(`/`)?`${n}/${t}`:`${n}${t}`}}const Fp=((e={})=>{let t={breadcrumbs:e.breadcrumbs??!0,ignoreOutgoingRequests:e.ignoreOutgoingRequests},n=new Sd(100),r=new WeakMap;return{name:`NodeFetch`,setupOnce(){ct(`undici:request:create`,(e=>{Ip(e.request,t,n,r)})),ct(`undici:request:headers`,(e=>{let n=e;Lp(n.request,n.response,t,r)}))}}});function Ip(e,t,n,r){let i=Rp(e,t);r.set(e,i),!i&&jp(e,n)}function Lp(e,t,n,r){n.breadcrumbs&&(r.get(e)||Mp(e,t))}function Rp(e,t){if(J().getScopeData().sdkProcessingMetadata.__SENTRY_SUPPRESS_TRACING__)return!0;let{ignoreOutgoingRequests:n}=t;return n?n(Pp(e.origin,e.path)):!1}function zp(){return[Iu(),Pu(),Zu(),id(),Jf(),pd(),Cp(),Fp(),Nf(),If(),af(),xf(),kd(),wd(),Hf(),Tf()]}function Bp(e={}){return Vp(e,zp)}function Vp(e={},t){let n=Hp(e,t);n.debug===!0&&(Q?K.enable():Hi(()=>{console.warn("[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.")})),fp(),J().update(n.initialScope),n.spotlight&&!n.integrations.some(({name:e})=>e===Uf)&&n.integrations.push(Wf({sidecarUrl:typeof n.spotlight==`string`?n.spotlight:void 0})),xu(n,`node-light`,[`node-core`]);let r=new Cd(n);return J().setClient(r),r.init(),K.log(`SDK initialized from ${Sf()?`CommonJS`:`ESM`} (light mode)`),r.startClientReportTracking(),Gp(),process.env.VERCEL&&process.on(`SIGTERM`,async()=>{await r.flush(200)}),r}function Hp(e,t){let n=Up(e.release),r=dp(e.spotlight),i=Wp(e.tracesSampleRate),a={...e,dsn:e.dsn??process.env.SENTRY_DSN,environment:e.environment??process.env.SENTRY_ENVIRONMENT,sendClientReports:e.sendClientReports??!0,transport:e.transport??cp,stackParser:ea(e.stackParser||Qf),release:n,tracesSampleRate:i,spotlight:r,debug:_u(e.debug??process.env.SENTRY_DEBUG)},o=e.integrations,s=e.defaultIntegrations??t(a);return{...a,integrations:cl({defaultIntegrations:s,integrations:o})}}function Up(e){if(e!==void 0)return e;let t=Zf();if(t!==void 0)return t}function Wp(e){if(e!==void 0)return e;let t=process.env.SENTRY_TRACES_SAMPLE_RATE;if(!t)return;let n=parseFloat(t);return isFinite(n)?n:void 0}function Gp(){if(_u(process.env.SENTRY_USE_ENVIRONMENT)!==!1){let e=process.env.SENTRY_TRACE,t=process.env.SENTRY_BAGGAGE,n=ds(e,t);J().setPropagationContext(n)}}function Kp(){return Me.PRISMIC_SENTRY_ENABLED??Me.PROD}function qp(){if(Me.PRISMIC_SENTRY_ENVIRONMENT)return Me.PRISMIC_SENTRY_ENVIRONMENT;let e=ce.match(/-(.+?)\./);return e?e[1]:`production`}function Jp(){try{if(!Kp())return;Bp({dsn:Me.PRISMIC_SENTRY_DSN,release:ce,environment:qp(),defaultIntegrations:!1,integrations:[],maxValueLength:2500}),Jc(`Process`,{command:process.argv.join(` `),cwd:process.cwd()})}catch{}}async function Yp(e){try{if(!Kp())return;qc(e,e instanceof Error?{extra:{cause:e.cause,fullCommand:process.argv.join(` `)}}:{}),await Zc()}catch{}}const Xp=Xc,Zp=Yc,Qp=Jc,$=[`login`,`logout`,`whoami`,`sync`,`docs`,`status`],$p=N({name:`prismic`,description:`Prismic CLI for managing repositories and configurations.`,sections:{DOCUMENTATION:"\n Run `prismic docs list` to browse available documentation topics.\n Run `prismic docs view <path>` to read a topic.\n "},commands:{init:{handler:fr,description:`Initialize a Prismic project`},docs:{handler:Ft,description:`Browse Prismic documentation`},gen:{handler:vn,description:`Generate files from local models`},pull:{handler:Nr,description:`Pull types and slices from Prismic`},push:{handler:Pr,description:`Push types and slices to Prismic`},sync:{handler:ui,description:`Sync types and slices from Prismic`},status:{handler:ei,description:`Show local vs remote model differences`},locale:{handler:Cr,description:`Manage locales`},repo:{handler:Hr,description:`Manage repositories`},type:{handler:wi,description:`Manage content types`},field:{handler:hn,description:`Manage fields`},slice:{handler:$r,description:`Manage slices`},preview:{handler:Ar,description:`Manage preview configurations`},token:{handler:hi,description:`Manage API tokens`},webhook:{handler:Mi,description:`Manage webhooks`},login:{handler:wr,description:`Log in to Prismic`},logout:{handler:Tr,description:`Log out of Prismic`},whoami:{handler:Ni,description:`Show the currently logged in user`}}});await em();async function em(){await Be({npmPackageName:le,statePath:je}),Ie().catch(()=>{});let{positionals:[e],values:{version:t,help:r,repo:i=await n()}}=He({options:{version:{type:`boolean`,short:`v`},help:{type:`boolean`,short:`h`},repo:{type:`string`,short:`r`}},allowPositionals:!0,strict:!1});if(t){console.info(ce);return}if(typeof i!=`string`&&(i=``),!r){let t=await A();Jp(),await ri({host:t}),i&&(ii(i),Zp(`repository`,i),Qp(`Repository Data`,{name:i}));try{Zp(`framework`,(await m()).id)}catch{}let n=await k();if(n){let e=Fi(n)?.exp,r=Date.now()/1e3;(!e||e-r<=3600)&&process.on(`exit`,()=>Fe()),(!e||e>r)&&y({token:n,host:t}).then(e=>{ai(e),Xp({id:e.shortId})}).catch(()=>{})}e&&!$.includes(e)&&oi(e)}try{await $p(),e&&!$.includes(e)&&U(e)}catch(t){if(process.exitCode=1,t instanceof P){$.includes(e)||U(e),console.error(f(t.message));return}if(t instanceof p){$.includes(e)||U(e,{error:t}),console.error(t.message);return}if(t instanceof vr){if($.includes(e)||U(e),t.availableEnvironments.length===1&&t.repo===t.availableEnvironments[0].domain)console.error(`No environments available on repository "${t.repo}".`);else{let e=t.availableEnvironments.map(e=>e.domain).join(`
327
+ `);if(l===-1){np(`have not received end of HTTP headers yet...`),a();return}let u=c.subarray(0,l).toString(`ascii`).split(`\r
328
+ `),d=u.shift();if(!d)return e.destroy(),n(Error(`No header received from proxy CONNECT response`));let f=d.split(` `),p=+(f[1]||0),m=f.slice(2).join(` `),h={};for(let t of u){if(!t)continue;let r=t.indexOf(`:`);if(r===-1)return e.destroy(),n(Error(`Invalid header from proxy CONNECT response: "${t}"`));let i=t.slice(0,r).toLowerCase(),a=t.slice(r+1).trimStart(),o=h[i];typeof o==`string`?h[i]=[o,a]:Array.isArray(o)?o.push(a):h[i]=a}np(`got proxy server response: %o %o`,d,h),o(),t({connect:{statusCode:p,statusText:m,headers:h},buffered:c})}e.on(`error`,c),e.on(`end`,s),a()})}function ip(...e){K.log(`[https-proxy-agent]`,...e)}var ap=class extends tp{static __initStatic(){this.protocols=[`http`,`https`]}constructor(e,t){super(t),this.options={},this.proxy=typeof e==`string`?new URL(e):e,this.proxyHeaders=t?.headers??{},ip(`Creating new HttpsProxyAgent instance: %o`,this.proxy.href);let n=(this.proxy.hostname||this.proxy.host).replace(/^\[|\]$/g,``),r=this.proxy.port?parseInt(this.proxy.port,10):this.proxy.protocol===`https:`?443:80;this.connectOpts={ALPNProtocols:[`http/1.1`],...t?sp(t,`headers`):null,host:n,port:r}}async connect(e,t){let{proxy:n}=this;if(!t.host)throw TypeError(`No "host" provided`);let r;if(n.protocol===`https:`){ip("Creating `tls.Socket`: %o",this.connectOpts);let e=this.connectOpts.servername||this.connectOpts.host;r=vt.connect({...this.connectOpts,servername:e&&_t.isIP(e)?void 0:e})}else ip("Creating `net.Socket`: %o",this.connectOpts),r=_t.connect(this.connectOpts);let i=typeof this.proxyHeaders==`function`?this.proxyHeaders():{...this.proxyHeaders},a=_t.isIPv6(t.host)?`[${t.host}]`:t.host,o=`CONNECT ${a}:${t.port} HTTP/1.1\r\n`;if(n.username||n.password){let e=`${decodeURIComponent(n.username)}:${decodeURIComponent(n.password)}`;i[`Proxy-Authorization`]=`Basic ${Buffer.from(e).toString(`base64`)}`}i.Host=`${a}:${t.port}`,i[`Proxy-Connection`]||=this.keepAlive?`Keep-Alive`:`close`;for(let e of Object.keys(i))o+=`${e}: ${i[e]}\r\n`;let s=rp(r);r.write(`${o}\r\n`);let{connect:c,buffered:l}=await s;if(e.emit(`proxyConnect`,c),this.emit(`proxyConnect`,c,e),c.statusCode===200){if(e.once(`socket`,op),t.secureEndpoint){ip(`Upgrading socket connection to TLS`);let e=t.servername||t.host;return vt.connect({...sp(t,`host`,`path`,`port`),socket:r,servername:_t.isIP(e)?void 0:e})}return r}r.destroy();let u=new _t.Socket({writable:!1});return u.readable=!0,e.once(`socket`,e=>{ip(`Replaying proxy buffer for failed request`),e.push(l),e.push(null)}),u}};ap.__initStatic();function op(e){e.resume()}function sp(e,...t){let n={},r;for(r in e)t.includes(r)||(n[r]=e[r]);return n}function cp(e){return new et({read(){this.push(e),this.push(null)}})}function lp(e){let t;try{t=new URL(e.url)}catch{return Ui(()=>{console.warn(`[@sentry/node]: Invalid dsn or tunnel option, will not send any events. The tunnel option must be a full URL when used.`)}),jl(e,()=>Promise.resolve({}))}let n=t.protocol===`https:`,r=up(t,e.proxy||(n?process.env.https_proxy:void 0)||process.env.http_proxy),i=n?ht:nt,a=e.keepAlive===void 0?!1:e.keepAlive,o=r?new ap(r):new i.Agent({keepAlive:a,maxSockets:30,timeout:2e3});return jl(e,dp(e,e.httpModule??i,o))}function up(e,t){let{no_proxy:n}=process.env;if(!n?.split(`,`).some(t=>e.host.endsWith(t)||e.hostname.endsWith(t)))return t}function dp(e,t,n){let{hostname:r,pathname:i,port:a,protocol:o,search:s}=new URL(e.url);return function(c){return new Promise((l,u)=>{hc(()=>{let d=cp(c.body),f={...e.headers};c.body.length>32768&&(f[`content-encoding`]=`gzip`,d=d.pipe(gt()));let p=r.startsWith(`[`),m=t.request({method:`POST`,agent:n,headers:f,hostname:p?r.slice(1,-1):r,path:`${i}${s}`,port:a,protocol:o,ca:e.caCerts},e=>{e.on(`data`,()=>{}),e.on(`end`,()=>{}),e.setEncoding(`utf8`);let t=e.headers[`retry-after`]??null,n=e.headers[`x-sentry-rate-limits`]??null;l({statusCode:e.statusCode,headers:{"retry-after":t,"x-sentry-rate-limits":Array.isArray(n)?n[0]||null:n}})});m.on(`error`,u),d.pipe(m)})})}}function fp(e){if(e===!1)return!1;if(typeof e==`string`)return e;let t=vu(process.env.SENTRY_SPOTLIGHT,{strict:!0}),n=t===null&&process.env.SENTRY_SPOTLIGHT?process.env.SENTRY_SPOTLIGHT:void 0;return e===!0?n??!0:t??n}function pp(){let e=new yt;function t(){return e.getStore()||{scope:ko(),isolationScope:Ao()}}function n(n){let r=t().scope.clone(),i=t().isolationScope;return e.run({scope:r,isolationScope:i},()=>n(r))}function r(n,r){let i=t().isolationScope.clone();return e.run({scope:n,isolationScope:i},()=>r(n))}function i(n){let r=t().scope.clone(),i=t().isolationScope.clone();return e.run({scope:r,isolationScope:i},()=>n(i))}function a(n,r){let i=t().scope.clone();return e.run({scope:i,isolationScope:n},()=>r(n))}function o(e){return n(t=>(t.setSDKProcessingMetadata({__SENTRY_SUPPRESS_TRACING__:!0}),e()))}Lo({suppressTracing:o,withScope:n,withSetScope:r,withIsolationScope:i,withSetIsolationScope:a,getCurrentScope:()=>t().scope,getIsolationScope:()=>t().isolationScope})}function mp(e,t,n,r){let i=0,a=[];Q&&K.log(r,`Patching request.on`);let o=new WeakMap,s=n===`small`?1e3:n===`medium`?1e4:1048576;try{e.on=new Proxy(e.on,{apply:(e,t,n)=>{let[c,l,...u]=n;if(c===`data`){Q&&K.log(r,`Handling request.on("data") with maximum body size of ${s}b`);let n=new Proxy(l,{apply:(e,t,n)=>{try{let e=n[0],t=Buffer.from(e);i<s?(a.push(t),i+=t.byteLength):Q&&K.log(r,`Dropping request body chunk because maximum body length of ${s}b is exceeded.`)}catch{Q&&K.error(r,`Encountered error while storing body chunk.`)}return Reflect.apply(e,t,n)}});return o.set(l,n),Reflect.apply(e,t,[c,n,...u])}return Reflect.apply(e,t,n)}}),e.off=new Proxy(e.off,{apply:(e,t,n)=>{let[,r]=n,i=o.get(r);if(i){o.delete(r);let a=n.slice();return a[1]=i,Reflect.apply(e,t,a)}return Reflect.apply(e,t,n)}}),e.on(`end`,()=>{try{let e=Buffer.concat(a).toString(`utf-8`);if(e){let n=Buffer.byteLength(e,`utf-8`)>s?`${Buffer.from(e).subarray(0,s-3).toString(`utf-8`)}...`:e;t.setSDKProcessingMetadata({normalizedRequest:{data:n}})}}catch(e){Q&&K.error(r,`Error building captured request body`,e)}})}catch(e){Q&&K.error(r,`Error patching request to capture body`,e)}}function hp(e,t){if(!e)return t;let n=Xo(e),r=Xo(t);if(!r)return e;let i={...n};return Object.entries(r).forEach(([e,t])=>{i[e]||(i[e]=t)}),Qo(i)}const gp=`@sentry/instrumentation-http`;function _p(e,t){let n=yp(e),r=t?.statusCode,i=_d(r);Mu({category:`http`,data:{status_code:r,...n},type:`http`,level:i},{event:`response`,request:e,response:t})}function vp(e,t){let n=xp(e),{tracePropagationTargets:r,propagateTraceparent:i}=X()?.getOptions()||{},a=Du(n,r,t)?Cu({propagateTraceparent:i}):void 0;if(!a)return;let{"sentry-trace":o,baggage:s,traceparent:c}=a;if(o&&!e.getHeader(`sentry-trace`))try{e.setHeader(`sentry-trace`,o),Q&&K.log(gp,`Added sentry-trace header to outgoing request`)}catch(e){Q&&K.error(gp,`Failed to add sentry-trace header to outgoing request:`,ba(e)?e.message:`Unknown error`)}if(c&&!e.getHeader(`traceparent`))try{e.setHeader(`traceparent`,c),Q&&K.log(gp,`Added traceparent header to outgoing request`)}catch(e){Q&&K.error(gp,`Failed to add traceparent header to outgoing request:`,ba(e)?e.message:`Unknown error`)}if(s){let t=hp(e.getHeader(`baggage`),s);if(t)try{e.setHeader(`baggage`,t),Q&&K.log(gp,`Added baggage header to outgoing request`)}catch(e){Q&&K.error(gp,`Failed to add baggage header to outgoing request:`,ba(e)?e.message:`Unknown error`)}}}function yp(e){try{let t=e.getHeader(`host`)||e.host,n=yu(new URL(e.path,`${e.protocol}//${t}`).toString()),r={url:xu(n),"http.method":e.method||`GET`};return n.search&&(r[`http.query`]=n.search),n.hash&&(r[`http.fragment`]=n.hash),r}catch{return{}}}function bp(e){return{method:e.method,protocol:e.protocol,host:e.host,hostname:e.host,path:e.path,headers:e.getHeaders()}}function xp(e){let t=e.getHeader(`host`)||e.host;return`${e.protocol}//${t}${e.path}`}const Sp=`Http`,Cp=new WeakSet,wp=((e={})=>{let t={maxRequestBodySize:e.maxRequestBodySize??`medium`,ignoreRequestBody:e.ignoreRequestBody,breadcrumbs:e.breadcrumbs??!0,ignoreOutgoingRequests:e.ignoreOutgoingRequests},n=new Cd(100),r=new WeakMap;return{name:Sp,setupOnce(){ct(`http.server.request.start`,(e=>{Tp(e.server,t)})),ct(`http.client.request.created`,(e=>{Ep(e.request,t,n,r)})),ct(`http.client.response.finish`,(e=>{let n=e;Dp(n.request,n.response,t,r)})),ct(`http.client.request.error`,(e=>{Dp(e.request,void 0,t,r)}))}}});function Tp(e,{ignoreRequestBody:t,maxRequestBodySize:n}){let r=e.emit;if(Cp.has(r))return;let i=new Proxy(r,{apply(e,r,i){if(i[0]!==`request`||!J().getClient())return e.apply(r,i);Q&&K.log(Sp,`Handling incoming request`);let a=Y().clone(),o=i[1],s=ku(o),c=o.ip||o.socket?.remoteAddress,l=o.url||`/`;n!==`none`&&!t?.(l,o)&&mp(o,a,n,Sp),a.setSDKProcessingMetadata({normalizedRequest:s,ipAddress:c});let u=`${(o.method||`GET`).toUpperCase()} ${bu(l)}`;return a.setTransactionName(u),Vo(a,()=>{let t=s.headers?.[`sentry-trace`],n=s.headers?.baggage;return pc({sentryTrace:Array.isArray(t)?t[0]:t,baggage:Array.isArray(n)?n[0]:n},()=>(J().getPropagationContext().propagationSpanId=wo(),e.apply(r,i)))})}});Cp.add(i),e.emit=i}function Ep(e,t,n,r){let i=Op(e,t);r.set(e,i),!i&&vp(e,n)}function Dp(e,t,n,r){n.breadcrumbs&&((r.get(e)??Op(e,n))||_p(e,t))}function Op(e,t){if(J().getScopeData().sdkProcessingMetadata.__SENTRY_SUPPRESS_TRACING__)return!0;let{ignoreOutgoingRequests:n}=t;return n?n(`${e.protocol}//${e.getHeader(`host`)||e.host}${e.path}`,bp(e)):!1}const kp=`sentry-trace`,Ap=`baggage`,jp=/baggage: (.*)\r\n/;function Mp(e,t){let n=Fp(e.origin,e.path),{tracePropagationTargets:r,propagateTraceparent:i}=X()?.getOptions()||{},a=Du(n,r,t)?Cu({propagateTraceparent:i}):void 0;if(!a)return;let{"sentry-trace":o,baggage:s,traceparent:c}=a;if(Array.isArray(e.headers)){let t=e.headers;o&&!t.includes(kp)&&t.push(kp,o),c&&!t.includes(`traceparent`)&&t.push(`traceparent`,c);let n=t.findIndex(e=>e===Ap);if(s&&n===-1)t.push(Ap,s);else if(s){let e=t[n+1],r=hp(e,s);r&&(t[n+1]=r)}}else{let t=e.headers;o&&!t.includes(`${kp}:`)&&(e.headers+=`${kp}: ${o}\r\n`),c&&!t.includes(`traceparent:`)&&(e.headers+=`traceparent: ${c}\r\n`);let n=e.headers.match(jp)?.[1];if(s&&!n)e.headers+=`${Ap}: ${s}\r\n`;else if(s){let t=hp(n,s);t&&(e.headers=e.headers.replace(jp,`baggage: ${t}\r\n`))}}}function Np(e,t){let n=Pp(e),r=t.statusCode,i=_d(r);Mu({category:`http`,data:{status_code:r,...n},type:`http`,level:i},{event:`response`,request:e,response:t})}function Pp(e){try{let t=yu(Fp(e.origin,e.path)),n={url:xu(t),"http.method":e.method||`GET`};return t.search&&(n[`http.query`]=t.search),t.hash&&(n[`http.fragment`]=t.hash),n}catch{return{}}}function Fp(e,t=`/`){try{return new URL(t,e).toString()}catch{let n=`${e}`;return n.endsWith(`/`)&&t.startsWith(`/`)?`${n}${t.slice(1)}`:!n.endsWith(`/`)&&!t.startsWith(`/`)?`${n}/${t}`:`${n}${t}`}}const Ip=((e={})=>{let t={breadcrumbs:e.breadcrumbs??!0,ignoreOutgoingRequests:e.ignoreOutgoingRequests},n=new Cd(100),r=new WeakMap;return{name:`NodeFetch`,setupOnce(){ct(`undici:request:create`,(e=>{Lp(e.request,t,n,r)})),ct(`undici:request:headers`,(e=>{let n=e;Rp(n.request,n.response,t,r)}))}}});function Lp(e,t,n,r){let i=zp(e,t);r.set(e,i),!i&&Mp(e,n)}function Rp(e,t,n,r){n.breadcrumbs&&(r.get(e)||Np(e,t))}function zp(e,t){if(J().getScopeData().sdkProcessingMetadata.__SENTRY_SUPPRESS_TRACING__)return!0;let{ignoreOutgoingRequests:n}=t;return n?n(Fp(e.origin,e.path)):!1}function Bp(){return[Lu(),Fu(),Qu(),ad(),Yf(),md(),wp(),Ip(),Pf(),Lf(),of(),Sf(),Ad(),Td(),Uf(),Ef()]}function Vp(e={}){return Hp(e,Bp)}function Hp(e={},t){let n=Up(e,t);n.debug===!0&&(Q?K.enable():Ui(()=>{console.warn("[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.")})),pp(),J().update(n.initialScope),n.spotlight&&!n.integrations.some(({name:e})=>e===Wf)&&n.integrations.push(Gf({sidecarUrl:typeof n.spotlight==`string`?n.spotlight:void 0})),Su(n,`node-light`,[`node-core`]);let r=new wd(n);return J().setClient(r),r.init(),K.log(`SDK initialized from ${Cf()?`CommonJS`:`ESM`} (light mode)`),r.startClientReportTracking(),Kp(),process.env.VERCEL&&process.on(`SIGTERM`,async()=>{await r.flush(200)}),r}function Up(e,t){let n=Wp(e.release),r=fp(e.spotlight),i=Gp(e.tracesSampleRate),a={...e,dsn:e.dsn??process.env.SENTRY_DSN,environment:e.environment??process.env.SENTRY_ENVIRONMENT,sendClientReports:e.sendClientReports??!0,transport:e.transport??lp,stackParser:ta(e.stackParser||$f),release:n,tracesSampleRate:i,spotlight:r,debug:vu(e.debug??process.env.SENTRY_DEBUG)},o=e.integrations,s=e.defaultIntegrations??t(a);return{...a,integrations:ll({defaultIntegrations:s,integrations:o})}}function Wp(e){if(e!==void 0)return e;let t=Qf();if(t!==void 0)return t}function Gp(e){if(e!==void 0)return e;let t=process.env.SENTRY_TRACES_SAMPLE_RATE;if(!t)return;let n=parseFloat(t);return isFinite(n)?n:void 0}function Kp(){if(vu(process.env.SENTRY_USE_ENVIRONMENT)!==!1){let e=process.env.SENTRY_TRACE,t=process.env.SENTRY_BAGGAGE,n=fs(e,t);J().setPropagationContext(n)}}function qp(){return Me.PRISMIC_SENTRY_ENABLED??Me.PROD}function Jp(){if(Me.PRISMIC_SENTRY_ENVIRONMENT)return Me.PRISMIC_SENTRY_ENVIRONMENT;let e=ce.match(/-(.+?)\./);return e?e[1]:`production`}function Yp(){try{if(!qp())return;Vp({dsn:Me.PRISMIC_SENTRY_DSN,release:ce,environment:Jp(),defaultIntegrations:!1,integrations:[],maxValueLength:2500}),Yc(`Process`,{command:process.argv.join(` `),cwd:process.cwd()})}catch{}}async function Xp(e){try{if(!qp())return;Jc(e,e instanceof Error?{extra:{cause:e.cause,fullCommand:process.argv.join(` `)}}:{}),await Qc()}catch{}}const Zp=Zc,Qp=Xc,$p=Yc,$=[`login`,`logout`,`whoami`,`sync`,`docs`,`status`],em=N({name:`prismic`,description:`Prismic CLI for managing repositories and configurations.`,sections:{DOCUMENTATION:"\n Run `prismic docs list` to browse available documentation topics.\n Run `prismic docs view <path>` to read a topic.\n "},commands:{init:{handler:pr,description:`Initialize a Prismic project`},docs:{handler:Ft,description:`Browse Prismic documentation`},gen:{handler:vn,description:`Generate files from local models`},pull:{handler:Pr,description:`Pull types and slices from Prismic`},push:{handler:Fr,description:`Push types and slices to Prismic`},sync:{handler:di,description:`Sync types and slices from Prismic`},status:{handler:ti,description:`Show local vs remote model differences`},locale:{handler:wr,description:`Manage locales`},repo:{handler:Ur,description:`Manage repositories`},type:{handler:Ti,description:`Manage content types`},field:{handler:hn,description:`Manage fields`},slice:{handler:ei,description:`Manage slices`},preview:{handler:jr,description:`Manage preview configurations`},token:{handler:gi,description:`Manage API tokens`},webhook:{handler:Ni,description:`Manage webhooks`},login:{handler:Tr,description:`Log in to Prismic`},logout:{handler:Er,description:`Log out of Prismic`},whoami:{handler:Pi,description:`Show the currently logged in user`}}});await tm();async function tm(){await Be({npmPackageName:le,statePath:je}),Ie().catch(()=>{});let{positionals:[e],values:{version:t,help:r,repo:i=await n()}}=He({options:{version:{type:`boolean`,short:`v`},help:{type:`boolean`,short:`h`},repo:{type:`string`,short:`r`}},allowPositionals:!0,strict:!1});if(t){console.info(ce);return}if(typeof i!=`string`&&(i=``),!r){let t=await A();Yp(),await ii({host:t}),i&&(ai(i),Qp(`repository`,i),$p(`Repository Data`,{name:i}));try{Qp(`framework`,(await m()).id)}catch{}let n=await k();if(n){let e=Ii(n)?.exp,r=Date.now()/1e3;(!e||e-r<=3600)&&process.on(`exit`,()=>Fe()),(!e||e>r)&&y({token:n,host:t}).then(e=>{oi(e),Zp({id:e.shortId})}).catch(()=>{})}e&&!$.includes(e)&&si(e)}try{await em(),e&&!$.includes(e)&&U(e)}catch(t){if(process.exitCode=1,t instanceof P){$.includes(e)||U(e),console.error(f(t.message));return}if(t instanceof p){$.includes(e)||U(e,{error:t}),console.error(t.message);return}if(t instanceof yr){if($.includes(e)||U(e),t.availableEnvironments.length===1&&t.repo===t.availableEnvironments[0].domain)console.error(`No environments available on repository "${t.repo}".`);else{let e=t.availableEnvironments.map(e=>e.domain).join(`
329
329
  `);console.error(f`
330
330
  Environment "${t.env}" not found on repository "${t.repo}".
331
331
 
@@ -345,4 +345,4 @@ Watch stopped. Goodbye!`),U(`sync`,{watch:!0}),process.exit(0)}),console.info(`W
345
345
  Slice Machine until your repository can upgrade.
346
346
 
347
347
  Learn more at https://prismic.io/docs/type-builder
348
- `);return}throw $.includes(e)||U(e,{error:t}),await Yp(t),t}}export{};
348
+ `);return}throw $.includes(e)||U(e,{error:t}),await Xp(t),t}}export{};