@arena-im/react-sdk-auth 1.14.0 → 1.15.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/config/index.d.ts +1 -0
- package/config/index.d.ts.map +1 -1
- package/config/runtime-environment.d.ts +4 -0
- package/config/runtime-environment.d.ts.map +1 -0
- package/context/anonymous-token-provider.d.ts.map +1 -1
- package/context/config-provider.d.ts.map +1 -1
- package/index.d.ts +1 -1
- package/index.esm.js +2 -2
- package/index.umd.js +2 -2
- package/package.json +1 -1
- package/services/auth/use-auth-services.d.ts +1 -0
- package/services/auth/use-auth-services.d.ts.map +1 -1
- package/utils/authenticated-request.d.ts.map +1 -1
package/index.esm.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{jsx as e,jsxs as t}from"react/jsx-runtime";import{createContext as n,useContext as o,useState as r,useRef as i,useEffect as s,useCallback as a}from"react";import{useMutation as c,QueryClient as u,QueryClientProvider as l}from"@tanstack/react-query";import{create as d}from"zustand";import{subscribeWithSelector as p}from"zustand/middleware";import h from"js-cookie";import{jwtDecode as k}from"jwt-decode";const f=n(void 0),T=({children:t})=>{const[n,o]=r(!1),[i,s]=r(void 0),[a,c]=r(void 0),[u,l]=r(void 0),[d,p]=r(void 0),[h,k]=r(void 0);return e(f.Provider,{value:{isOpen:n,appName:i,language:h,appDescription:a,trackOptions:d,onAuthCompleted:u,openDialog:({trackOptions:e,appName:t,language:n,appDescription:r,onAuthCompleted:i})=>{o(!0),p(e),s(t),k(n),c(r),l(i)},closeDialog:()=>o(!1),onOpenChange:e=>o(e)},children:t})},m=()=>{const e=o(f);if(!e)throw new Error("useAuthDialog must be used within an AuthDialogProvider");return e},g=e=>{const t="development"===e;return{profileServiceUrl:t?"https://profile-service-dev.arena.im":"https://profile-service-prd.arena.im",identityServiceUrl:t?"https://token-service-dev.arena.im":"https://token-service-prd.arena.im",refreshTokenApiKey:t?"AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk":"AIzaSyD_a4tNVdFVqgGbTfOGCaZ5pvUHErcE79c",authIframeUrl:t?"https://auth2.dev.arena.im":"https://auth2.arena.im",environment:e,debug:"development"===e}},y=n(void 0),U=({children:t,environment:n="development"})=>{const o=g(n);return e(y.Provider,{value:{config:o,environment:n},children:t})},w=()=>{const e=o(y);if(!e)throw new Error("useConfig must be used within a ConfigProvider");return e},S={"Content-Type":"application/json"};async function E(e,t,n={}){const o=await fetch(t,{...n,method:e,headers:{"Content-Type":"application/json",...n.headers}});if(!o.ok)throw new Error(`Error: ${o.statusText}`);return o.json()}var I,v;!function(e){e.ANONYMOUS="anonymous",e.GUEST="guest",e.PUBLIC="public",e.CUSTOM="custom"}(I||(I={})),function(e){e.PUBLIC_ID_TOKEN="arena-auth-public-id-token",e.PUBLIC_REFRESH_TOKEN="arena-auth-public-refresh-token",e.ANONYMOUS_ID_TOKEN="arena-auth-anonymous-id-token",e.GUEST_ID_TOKEN="arena-auth-guest-id-token",e.CUSTOM_ID_TOKEN="arena-auth-custom-id-token",e.CUSTOM_USER="arena-auth-custom-user"}(v||(v={}));const _="arena-auth-token-updated";function O(e,t){document.dispatchEvent(new CustomEvent(_,{detail:{...t,type:e}}))}const P={public:{idToken:h.get(v.PUBLIC_ID_TOKEN)||null,refreshToken:h.get(v.PUBLIC_REFRESH_TOKEN)||null},anonymous:{idToken:h.get(v.ANONYMOUS_ID_TOKEN)||null},guest:{idToken:h.get(v.GUEST_ID_TOKEN)||null},custom:{idToken:h.get(v.CUSTOM_ID_TOKEN)||null}},C=d()(p((e,t)=>{const n=(n,o,r=!0,i)=>{n===t().tokens.public.idToken&&o===t().tokens.public.refreshToken||(e(e=>({tokens:{...e.tokens,public:{idToken:n,refreshToken:o}}})),h.set(v.PUBLIC_ID_TOKEN,n,{expires:1/24}),h.set(v.PUBLIC_REFRESH_TOKEN,o,{expires:30}),r&&O(I.PUBLIC,{idToken:n,refreshToken:o,source:i}))},o=(n,o=!0,r)=>{n!==t().tokens.anonymous.idToken&&(e(e=>({tokens:{...e.tokens,anonymous:{idToken:n}}})),h.set(v.ANONYMOUS_ID_TOKEN,n,{expires:1/24}),o&&O(I.ANONYMOUS,{idToken:n,source:r}))},r=(n,o=!0,r)=>{n!==t().tokens.guest.idToken&&(e(e=>({tokens:{...e.tokens,guest:{idToken:n}}})),h.set(v.GUEST_ID_TOKEN,n,{expires:1/24}),o&&O(I.GUEST,{idToken:n,source:r}))},i=(n,o=!0,r)=>{n!==t().tokens.custom.idToken&&(e(e=>({tokens:{...e.tokens,custom:{idToken:n}}})),h.set(v.CUSTOM_ID_TOKEN,n),o&&O(I.CUSTOM,{idToken:n,source:r}))},s=(t=!0,n)=>{h.remove(v.PUBLIC_ID_TOKEN),h.remove(v.PUBLIC_REFRESH_TOKEN),e(e=>({tokens:{...e.tokens,public:{idToken:null,refreshToken:null}}})),t&&O(I.PUBLIC,{idToken:null,source:n})},a=(t=!0,n)=>{h.remove(v.ANONYMOUS_ID_TOKEN),e(e=>({tokens:{...e.tokens,anonymous:{idToken:null}}})),t&&O(I.ANONYMOUS,{idToken:null,source:n})},c=(t=!0,n)=>{h.remove(v.GUEST_ID_TOKEN),e(e=>({tokens:{...e.tokens,guest:{idToken:null}}})),t&&O(I.GUEST,{idToken:null,source:n})},u=(t=!0,n)=>{h.remove(v.CUSTOM_ID_TOKEN),localStorage.removeItem(v.CUSTOM_ID_TOKEN),localStorage.removeItem(v.CUSTOM_USER),e(e=>({tokens:{...e.tokens,custom:{idToken:null}}})),t&&O(I.CUSTOM,{idToken:null,source:n})};return{tokens:P,getToken:e=>t().tokens[e]?.idToken||null,getMostPrivilegedToken:(e=[I.PUBLIC,I.GUEST,I.ANONYMOUS])=>t().tokens.custom.idToken&&e.includes(I.CUSTOM)?{type:I.CUSTOM,idToken:t().tokens.custom.idToken}:t().tokens.public.idToken&&e.includes(I.PUBLIC)?{type:I.PUBLIC,idToken:t().tokens.public.idToken}:t().tokens.guest.idToken&&e.includes(I.GUEST)?{type:I.GUEST,idToken:t().tokens.guest.idToken}:t().tokens.anonymous.idToken&&e.includes(I.ANONYMOUS)?{type:I.ANONYMOUS,idToken:t().tokens.anonymous.idToken}:null,getRefreshToken:e=>t().tokens[e]?.refreshToken||null,updatePublicTokens:(e,t,o)=>{n(e,t,!0,o)},updateAnonymousToken:(e,t)=>{o(e,!0,t)},updateGuestTokens:(e,t)=>{r(e,!0,t)},updateCustomToken:(e,t)=>{i(e,!0,t)},clearTokens:e=>{s(!0,e),a(!0,e),c(!0,e),u(!0,e)},clearPublicTokens:e=>{s(!0,e)},clearAnonymousTokens:e=>{a(!0,e)},clearGuestTokens:e=>{c(!0,e)},clearCustomTokens:e=>{u(!0,e)},silentUpdatePublicTokens:(e,t)=>{n(e,t,!1)},silentUpdateAnonymousToken:e=>{o(e,!1)},silentUpdateGuestTokens:e=>{r(e,!1)},silentUpdateCustomToken:e=>{i(e,!1)},silentClearPublicTokens:()=>{s(!1)},silentClearAnonymousTokens:()=>{a(!1)},silentClearGuestTokens:()=>{c(!1)},silentClearCustomTokens:()=>{u(!1)}}}));function N(){const e=C(e=>e.silentUpdatePublicTokens),t=C(e=>e.silentUpdateAnonymousToken),n=C(e=>e.silentUpdateGuestTokens),o=C(e=>e.silentUpdateCustomToken),r=C(e=>e.clearTokens),a=C(e=>e.silentClearPublicTokens),c=C(e=>e.silentClearAnonymousTokens),u=C(e=>e.silentClearGuestTokens),l=C(e=>e.silentClearCustomTokens),d=i(`widget-${Math.random().toString(36).substr(2,9)}`);return s(()=>{const r=r=>{const{idToken:i,refreshToken:s,type:p,source:h}=r.detail;if(h!==d.current)switch(p){case I.PUBLIC:if(i){if(!s)throw new Error("Refresh token is required for public tokens");e(i,s)}else a();break;case I.ANONYMOUS:i?t(i):c();break;case I.GUEST:i?n(i):u();break;case I.CUSTOM:i?o(i):l()}};return document.addEventListener(_,r),()=>{document.removeEventListener(_,r)}},[e,t,n,o,r,a,c,u,l]),{eventSource:d.current}}function b(){const e=C(e=>e.getToken),t=C(e=>e.getMostPrivilegedToken),n=C(e=>e.getRefreshToken),o=C(e=>e.updatePublicTokens),r=C(e=>e.updateAnonymousToken),i=C(e=>e.updateGuestTokens),s=C(e=>e.updateCustomToken),a=C(e=>e.clearTokens),c=C(e=>e.clearPublicTokens),u=C(e=>e.clearCustomTokens),{eventSource:l}=N();return{getToken:e,getMostPrivilegedToken:t,getRefreshToken:n,updatePublicTokens:(e,t)=>o(e,t,l),updateAnonymousToken:e=>r(e,l),updateGuestTokens:e=>i(e,l),updateCustomToken:e=>s(e,l),clearTokens:()=>a(l),clearPublicTokens:()=>c(l),clearCustomTokens:()=>u(l)}}function A(e){return C(t=>t.tokens[e])}function x(e){return C(t=>t.tokens[e]?.idToken)}function L(e){return C(t=>t.tokens[e]?.refreshToken)}var D,R;function K(){const e=A(I.PUBLIC),{refreshPublicTokens:t}=F(),{config:n}=w(),o=n.profileServiceUrl;return{getPublicProfile:async function(e){const t=`${o}/public/users/${e}/profile?fields=bio,photoURL,displayName,location,handle`;return await E("GET",t)},updatePublicProfile:async function(r){const i=`${o}/me/profile/personal`;await async function(e){const{method:t,url:n,options:o={},token:r}=e;if(!r)throw new Error("No authentication token found");const i={...S,...o.headers,Authorization:`Bearer ${r}`},s={...o,method:t,headers:i},a=await fetch(n,s);if(!a.ok){const e=await a.text();if(!e)throw new Error(`Error to process request - ${a.status}`);const{errors:t}=JSON.parse(e)||{};throw new Error(t?.[0]||"Internal server error")}const c=a.headers.get("content-type");if(!c||!c.includes("application/json"))return a;const u=await a.text();if(!u)return null;try{return JSON.parse(u)}catch(e){throw console.error(e),new Error("Invalid JSON response from server")}}({method:"PUT",url:i,options:{body:JSON.stringify(r)},token:e.idToken}),t({refreshTokenApiKey:n.refreshTokenApiKey})}}}!function(e){e.AvatarProfile="avatar-profile",e.AvatarChat="avatar-chat",e.Comments="comments",e.GlobalProfile="global-profile",e.GroupChat="group-chat",e.Polls="polls",e.UniversalSnippet="universal-snippet"}(D||(D={})),function(e){e.AuthenticationCompleted="Authentication Completed",e.AuthenticationStarted="Authentication Started",e.AuthenticationViewed="Authentication Viewed"}(R||(R={}));const B=d()(p((e,t)=>({user:null,publicProfile:null,refreshedTokenLoaded:!1,setUser:t=>{e({user:t})},setPublicProfile:t=>{e({publicProfile:t})},setUserByTokenId:t=>{try{const n=k(t),o={uid:n.user_id,displayName:n.safeDisplayName,email:n.email,photoURL:n.safePhotoURL,handle:n.handle};e({user:o})}catch(e){console.error(e)}},logout:()=>{try{const t=C.getState();t.clearPublicTokens(),t.clearCustomTokens(),e({user:null}),document.dispatchEvent(new Event("arena-comments-logout"))}catch(e){console.error(e)}},refreshPublicTokens:async e=>{try{const n=h.get(v.PUBLIC_REFRESH_TOKEN);if(!n)throw new Error("No refresh token found");const o=`${"https://securetoken.googleapis.com/v1/token?key="}${e.refreshTokenApiKey}`,r=await fetch(o,{method:"POST",body:new URLSearchParams({refresh_token:n,grant_type:"refresh_token"})}),i=await r.json(),{setUserByTokenId:s}=t();s(i.id_token);C.getState().updatePublicTokens(i.id_token,i.refresh_token)}catch(e){console.error(e);const{logout:n}=t();n()}},loadStoredUser:async n=>{const o=h.get(v.PUBLIC_ID_TOKEN),r=h.get(v.PUBLIC_REFRESH_TOKEN),i=localStorage.getItem(v.CUSTOM_ID_TOKEN),s=localStorage.getItem(v.CUSTOM_USER);if(i&&s){const t=JSON.parse(s);e({user:t});C.getState().updateCustomToken(i)}else if(o){const{setUserByTokenId:e}=t();e(o)}else if(r&&n){const{refreshPublicTokens:e}=t();await e(n)}e({refreshedTokenLoaded:!0})},ssoV2Exchange:async(e,n,o)=>{try{const r=g(o??"production"),i=`${r.profileServiceUrl}/sso/sources/${e}/user`,s=await E("POST",i,{body:JSON.stringify({signedUserData:n})});if(s){const e=k(s.token),{setUser:n,setPublicProfile:o}=t();n({uid:e?.sub,email:e?.email,displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle}),o({displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle});C.getState().updateCustomToken(s.token)}return s}catch(e){throw console.error("SSO V2 Exchange failed:",e),e}}})));function M(){return B(e=>e.user)}function $(){return B(e=>e.publicProfile)}function G(){return B(e=>e.refreshedTokenLoaded)}function F(){return{setUser:B(e=>e.setUser),setPublicProfile:B(e=>e.setPublicProfile),logout:B(e=>e.logout),refreshPublicTokens:B(e=>e.refreshPublicTokens),setUserByTokenId:B(e=>e.setUserByTokenId),loadStoredUser:B(e=>e.loadStoredUser),ssoV2Exchange:B(e=>e.ssoV2Exchange)}}function J(){const{updatePublicProfile:e}=K();return{updatePublicProfile:e}}function j(){return{user:B(e=>e.user),publicProfile:B(e=>e.publicProfile),refreshedTokenLoaded:B(e=>e.refreshedTokenLoaded)}}function z({children:e}){const{config:t}=w(),n=M(),{setPublicProfile:o,loadStoredUser:r}=F(),{getPublicProfile:i}=K(),{mutateAsync:u}=c({mutationFn:i}),l=a(async()=>{if(n?.uid){const e=await u(n.uid);o(e)}},[n?.uid,u,o]);return s(()=>{l()},[l]),s(()=>{r(t)},[t,r]),e}const H="arenaAnonymousId",Y="rs_anonymous_id",V="rs_initial_referrer",q="rs_initial_referring_domain";function W(){const e=localStorage.getItem(Y);if(e)return e;const t=crypto.randomUUID();return localStorage.setItem(Y,t),t}function Z(e){const t={};return["utm_source","utm_medium","utm_campaign","utm_term","utm_content"].forEach(n=>{const o=e.searchParams.get(n);o&&(t[n]=o)}),Object.keys(t).length?t:void 0}function Q(){const e=window,t=document,n=window.screen,o=new URL(e.location.href);!function(){if(!localStorage.getItem(V)){const e=document.referrer||"$direct",t="$direct"!==e?new URL(e).hostname:"";localStorage.setItem(V,e),localStorage.setItem(q,t)}}();const r=localStorage.getItem(V)||"$direct",i=localStorage.getItem(q)||"";return{channel:"web",anonymousId:W(),locale:navigator.language,userAgent:navigator.userAgent,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,os:{name:navigator.platform,version:void 0},page:{path:o.pathname,referrer:t.referrer||"$direct",referring_domain:t.referrer?new URL(t.referrer).hostname:"",search:o.search,title:t.title,url:o.toString(),initial_referrer:r,initial_referring_domain:i},screen:{density:e.devicePixelRatio||1,height:n.height,width:n.width,innerHeight:e.innerHeight,innerWidth:e.innerWidth},campaign:Z(o)}}function X(e={}){const t={};e.userId&&(t.userId=e.userId);let n=null;try{n=localStorage.getItem(H)}catch(e){console.warn("Failed to access localStorage:",e)}if(e.anonymousId){t.anonymousId=e.anonymousId;try{localStorage.setItem(H,e.anonymousId)}catch(e){console.warn("Failed to save anonymousId to localStorage:",e)}}else if(n)t.anonymousId=n;else{const e="undefined"!=typeof crypto&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)});t.anonymousId=e;try{localStorage.setItem(H,e)}catch(e){console.warn("Failed to save new anonymousId to localStorage:",e)}}return t}function ee(){const e=document.querySelector('link[rel="canonical"]');return function(e){try{const t=new URL(e);return t.search="",t.href}catch(t){return console.error("Error clearing search params from URL:",t),e}}(e?.href||window.location.href)}function te(e,t,n){return{properties:{widget_type:e,url:window.location.href,domain:window.location.hostname,title:window.document.title,canonical_url:ee(),snippet_id:window.__ARENA__?.snippetId||null,...t},context:Q(),timestamp:(new Date).toISOString(),integrations:{All:!0},...X(n)}}function ne(e){return{"Content-Type":"application/json",Authorization:"Basic "+btoa(`${e}:`)}}function oe(e){return a((t,n,o)=>{if(!e)return;const r=(i=e.rsWriteKey,s=e.rsDataPlaneUrl,{page:async(e,t,n)=>{const o=await fetch(`${s}/v1/page`,{method:"POST",headers:ne(i),body:JSON.stringify({type:"page",...te(e,t,n)})});if(o.ok)return await o.text();throw new Error("Failed to send page event to Rudderstack")},track:async(e,t,n,o)=>{const r=await fetch(`${s}/v1/track`,{method:"POST",headers:ne(i),body:JSON.stringify({event:t,type:"track",...te(e,n,o)})});if(r.ok)return await r.text();throw new Error("Failed to send track event to Rudderstack")}});var i,s;const a={site_id:e.siteId,widget_id:e.widgetId,trigger:e.trigger,...o};r.track(e.widgetType,t,a,n?{userId:n}:void 0)},[e])}function re(){const{appName:t,appDescription:n,language:o,trackOptions:r,isOpen:i,closeDialog:a,onAuthCompleted:c}=m(),u=t||"Arena AI Chat",l=n||"Arena AI Chat",{setUser:d}=F(),{updatePublicTokens:p}=b(),{config:h}=w(),k=oe(r),f=`${h.authIframeUrl}/?app-name=${u}&app-description=${l}&language=${o??"en"}`;return s(()=>{const e=e=>{if("arena-authentication"===e.data?.source)if("canceled"!==e.data?.type)if("authentication-viewed"!==e.data?.type){if("authentication-started"===e.data?.type){const{authType:t}=e.data?.payload||{};return void k(R.AuthenticationStarted,void 0,{authType:t})}if("authentication-completed"===e.data?.type){const{idToken:t,refreshToken:n,user:o,authType:r,isSignup:i}=e.data?.payload||{};return o?(k(R.AuthenticationCompleted,o.uid,{is_signup:i,auth_type:r}),c?.(o),p(t,n),d(o),void a()):void console.error("Authentication completed but user data is missing")}}else k(R.AuthenticationViewed);else a()};return window.addEventListener("message",e),()=>window.removeEventListener("message",e)},[d,p,c,k,a]),i?e("iframe",{src:f,title:"Arena Authentication",style:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9999999999}}):null}function ie({children:e}){const t=C(e=>e.tokens),n=C(e=>e.updateAnonymousToken),{getAnonymousIdentityToken:o}=function(){const{config:e}=w(),t=e.identityServiceUrl;return{getAnonymousIdentityToken:async function(){const e=`${t}/anonymous-token`;return await E("POST",e)}}}();return s(()=>{t.anonymous.idToken||o().then(e=>{n(e.access_token)})},[t.anonymous.idToken,n,o]),e}function se({children:n,queryClient:o,environment:r}){return o=o||new u,e(l,{client:o,children:e(U,{environment:r,children:e(z,{children:e(T,{children:t(ie,{children:[n,e(re,{})]})})})})})}function ae(){const e="undefined"!=typeof process&&"production"===process.env?.NODE_ENV?"production":"development";return g(e).refreshTokenApiKey}const ce={"Content-Type":"application/json"};let ue=null;async function le(){if(ue)return ue;const e=B.getState();return ue=e.refreshPublicTokens({refreshTokenApiKey:ae()}).finally(()=>{ue=null}),ue}async function de(e,t,n={}){async function o(){const o=await async function(e,t,n={}){const o=h.get(v.PUBLIC_ID_TOKEN);if(!o)throw new Error("No authentication token found");const r={...ce,...n.headers,Authorization:`Bearer ${o}`},i={...n,method:e,headers:r};return fetch(t,i)}(e,t,n);if(o.ok)return async function(e){const t=e.headers.get("content-type");if(!t||!t.includes("application/json"))return e;const n=await e.text();if(!n)return null;try{return JSON.parse(n)}catch(e){throw console.error({error:e}),new Error("Invalid JSON response from server")}}(o);const r=await o.text();if(!r)throw new Error(`Failed to process request - ${o.status}`);if(401===o.status){const e=new Error("Unauthorized");throw e.status=401,e}!function(e,t){let n;try{const e=JSON.parse(t);n=e?.errors?.[0]||t||"Internal server error"}catch{n=t||"Internal server error"}throw new Error(n)}(0,r)}if(!h.get(v.PUBLIC_ID_TOKEN)){if(h.get(v.PUBLIC_REFRESH_TOKEN))return await le(),await o();throw new Error("No authentication token found")}try{return await o()}catch(e){if(!(e instanceof Error&&"status"in e&&401===e.status))throw e;if(!h.get(v.PUBLIC_REFRESH_TOKEN))throw new Error("Unauthorized");await le();try{return await o()}catch(e){if(e instanceof Error&&"status"in e&&401===e.status)throw new Error("Unauthorized");throw e}}}export{R as AnalyticsEvent,D as AnalyticsWidgetType,v as AuthCookie,se as AuthProvider,I as TokenType,de as authenticatedRequest,m as useAuthDialog,$ as usePublicProfile,L as useRefreshToken,G as useRefreshedTokenLoaded,A as useToken,N as useTokenEventListener,C as useTokenStore,x as useTokenValue,b as useTokens,J as useUpdateProfile,M as useUser,F as useUserActions,B as useUserStore,j as useUserWithProfile};
|
|
2
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.esm.js","sources":["../src/context/auth-dialog-provider.tsx","../src/config/index.ts","../src/context/config-provider.tsx","../src/utils/request.ts","../src/types/token.ts","../src/utils/dom-events.ts","../src/stores/token-store.ts","../src/hooks/use-token-event-listener.ts","../src/hooks/use-tokens.ts","../src/types/analytics.ts","../src/services/profile/use-profile-services.ts","../src/stores/user-store.ts","../src/hooks/use-user.ts","../src/context/user-provider.tsx","../src/utils/analytics.ts","../src/utils/url.ts","../src/hooks/use-track.ts","../src/dialog/index.tsx","../src/context/anonymous-token-provider.tsx","../src/services/auth/use-auth-services.ts","../src/context/index.tsx","../src/utils/authenticated-request.ts"],"sourcesContent":["import { createContext, useContext, useState, ReactNode } from 'react';\nimport { UserProps } from '../services/auth/types';\nimport { TrackOptions } from '../types/analytics';\n\ninterface AuthDialogContextType {\n  isOpen: boolean;\n  appName: string | undefined;\n  appDescription: string | undefined;\n  language: string | undefined;\n  trackOptions: TrackOptions | undefined;\n  onAuthCompleted: ((user: UserProps) => void) | undefined;\n  openDialog: (options: OpenDialogOptions) => void;\n  closeDialog: () => void;\n  onOpenChange: (open: boolean) => void;\n}\n\nconst AuthDialogContext = createContext<AuthDialogContextType | undefined>(\n  undefined\n);\n\ntype OpenDialogOptions = {\n  trackOptions: TrackOptions;\n  appName?: string;\n  language?: string;\n  appDescription?: string;\n  onAuthCompleted?: () => (user: UserProps) => void;\n};\n\nexport const AuthDialogProvider = ({ children }: { children: ReactNode }) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [appName, setAppName] = useState<string | undefined>(undefined);\n  const [appDescription, setAppDescription] = useState<string | undefined>(\n    undefined\n  );\n  const [onAuthCompleted, setOnAuthCompleted] = useState<\n    ((user: UserProps) => void) | undefined\n  >(undefined);\n  const [trackOptions, setTrackOptions] = useState<TrackOptions | undefined>(\n    undefined\n  );\n  const [language, setLanguage] = useState<string | undefined>(\n    undefined\n  );\n  const openDialog = ({\n    trackOptions,\n    appName,\n    language,\n    appDescription,\n    onAuthCompleted,\n  }: OpenDialogOptions) => {\n    setIsOpen(true);\n    setTrackOptions(trackOptions);\n    setAppName(appName);\n    setLanguage(language);\n    setAppDescription(appDescription);\n    setOnAuthCompleted(onAuthCompleted);\n  };\n\n  const closeDialog = () => setIsOpen(false);\n  const onOpenChange = (open: boolean) => setIsOpen(open);\n\n  return (\n    <AuthDialogContext.Provider\n      value={{\n        isOpen,\n        appName,\n        language,\n        appDescription,\n        trackOptions,\n        onAuthCompleted,\n        openDialog,\n        closeDialog,\n        onOpenChange,\n      }}\n    >\n      {children}\n    </AuthDialogContext.Provider>\n  );\n};\n\nexport const useAuthDialog = () => {\n  const context = useContext(AuthDialogContext);\n  if (!context) {\n    throw new Error('useAuthDialog must be used within an AuthDialogProvider');\n  }\n  return context;\n};\n","export interface Config {\n  profileServiceUrl: string;\n  identityServiceUrl: string;\n  refreshTokenApiKey: string;\n  authIframeUrl: string;\n  environment: 'development' | 'production';\n  debug: boolean;\n}\n\nexport type Environment = 'development' | 'production';\n\nexport const getConfig = (environment: Environment): Config => {\n  const isDev = environment === 'development';\n\n  return {\n    profileServiceUrl: isDev\n      ? process.env.PROFILE_SERVICE_URL_DEV ||\n        'https://profile-service-dev.arena.im'\n      : process.env.PROFILE_SERVICE_URL_PRD ||\n        'https://profile-service-prd.arena.im',\n    identityServiceUrl: isDev\n      ? process.env.IDENTITY_SERVICE_URL_DEV ||\n        'https://token-service-dev.arena.im'\n      : process.env.IDENTITY_SERVICE_URL_PRD ||\n        'https://token-service-prd.arena.im',\n    refreshTokenApiKey: isDev\n      ? process.env.FIREBASE_PUBLIC_API_KEY_DEV ||\n        'AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk'\n      : process.env.FIREBASE_PUBLIC_API_KEY_PRD ||\n        'AIzaSyD-9tSrQWn73S0qm6BqEH5-12Hq8L0eTsQ',\n    authIframeUrl: isDev\n      ? process.env.AUTH_IFRAME_URL_DEV || 'https://auth2.dev.arena.im'\n      : process.env.AUTH_IFRAME_URL_PRD || 'https://auth2.arena.im',\n    environment,\n    debug: environment === 'development',\n  };\n};\n","import { createContext, useContext, ReactNode } from 'react';\nimport { getConfig, Environment, Config } from '../config';\n\ninterface ConfigContextType {\n  config: Config;\n  environment: Environment;\n}\n\nconst ConfigContext = createContext<ConfigContextType | undefined>(undefined);\n\ninterface ConfigProviderProps {\n  children: ReactNode;\n  environment?: Environment;\n}\n\nexport const ConfigProvider = ({\n  children,\n  environment = 'development',\n}: ConfigProviderProps) => {\n  const config = getConfig(environment);\n\n  return (\n    <ConfigContext.Provider value={{ config, environment }}>\n      {children}\n    </ConfigContext.Provider>\n  );\n};\n\nexport const useConfig = () => {\n  const context = useContext(ConfigContext);\n  if (!context) {\n    throw new Error('useConfig must be used within a ConfigProvider');\n  }\n  return context;\n};\n","const defaultHeaders = {\n  'Content-Type': 'application/json',\n};\n\nexport async function request(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n) {\n  const response = await fetch(url, {\n    ...options,\n    method,\n    headers: {\n      'Content-Type': 'application/json',\n      ...options.headers,\n    },\n  });\n\n  if (!response.ok) {\n    throw new Error(`Error: ${response.statusText}`);\n  }\n\n  return response.json();\n}\n\nexport async function securedRequest(params: {\n  method: string;\n  url: string;\n  options: RequestInit;\n  token: string;\n}) {\n  const { method, url, options = {}, token } = params;\n  if (!token) {\n    throw new Error('No authentication token found');\n  }\n\n  const headers = {\n    ...defaultHeaders,\n    ...options.headers,\n    Authorization: `Bearer ${token}`,\n  };\n\n  const payload = {\n    ...options,\n    method,\n    headers,\n  };\n\n  const response = await fetch(url, payload);\n\n  if (!response.ok) {\n    const text = await response.text();\n    if (!text) {\n      throw new Error(`Error to process request - ${response.status}`);\n    }\n\n    const { errors } = JSON.parse(text) || {};\n    const errorMessage = errors?.[0] || 'Internal server error';\n    throw new Error(errorMessage);\n  }\n\n  const contentType = response.headers.get('content-type');\n  if (!contentType || !contentType.includes('application/json')) {\n    return response;\n  }\n\n  const text = await response.text();\n  if (!text) {\n    return null;\n  }\n\n  try {\n    return JSON.parse(text);\n  } catch (error) {\n    console.error(error);\n    throw new Error('Invalid JSON response from server');\n  }\n}\n","export enum TokenType {\n  ANONYMOUS = 'anonymous',\n  GUEST = 'guest',\n  PUBLIC = 'public',\n  CUSTOM = 'custom',\n}\n\nexport interface TokenPair {\n  idToken: string | null;\n  refreshToken?: string | null;\n}\n\nexport type TokensMap = Record<TokenType, TokenPair>;\n\nexport enum AuthCookie {\n  PUBLIC_ID_TOKEN = 'arena-auth-public-id-token',\n  PUBLIC_REFRESH_TOKEN = 'arena-auth-public-refresh-token',\n  ANONYMOUS_ID_TOKEN = 'arena-auth-anonymous-id-token',\n  GUEST_ID_TOKEN = 'arena-auth-guest-id-token',\n  CUSTOM_ID_TOKEN = 'arena-auth-custom-id-token',\n  CUSTOM_USER = 'arena-auth-custom-user',\n}\n","import { TokenType } from '../types/token';\n\nexport const TOKEN_UPDATED_EVENT = 'arena-auth-token-updated';\n\ninterface TokenEventParams {\n  idToken: string | null;\n  refreshToken?: string | null;\n  source?: string;\n}\n\nexport function dispatchTokenUpdatedEvent(\n  type: TokenType,\n  params: TokenEventParams\n) {\n  document.dispatchEvent(\n    new CustomEvent(TOKEN_UPDATED_EVENT, {\n      detail: { ...params, type },\n    })\n  );\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport { AuthCookie, TokensMap, TokenType } from '../types/token';\nimport { dispatchTokenUpdatedEvent } from '../utils/dom-events';\n\ninterface TokenStore {\n  tokens: TokensMap;\n  getToken: (type: TokenType) => string | null;\n  getMostPrivilegedToken: (\n    options?: Array<TokenType>\n  ) => { type: TokenType; idToken: string } | null;\n  getRefreshToken: (type: TokenType) => string | null;\n  updatePublicTokens: (\n    idToken: string,\n    refreshToken: string,\n    source?: string\n  ) => void;\n  updateAnonymousToken: (idToken: string, source?: string) => void;\n  updateGuestTokens: (idToken: string, source?: string) => void;\n  updateCustomToken: (idToken: string, source?: string) => void;\n  clearTokens: (source?: string) => void;\n  clearPublicTokens: (source?: string) => void;\n  clearAnonymousTokens: (source?: string) => void;\n  clearGuestTokens: (source?: string) => void;\n  clearCustomTokens: (source?: string) => void;\n  silentUpdatePublicTokens: (idToken: string, refreshToken: string) => void;\n  silentUpdateAnonymousToken: (idToken: string) => void;\n  silentUpdateGuestTokens: (idToken: string) => void;\n  silentUpdateCustomToken: (idToken: string) => void;\n  silentClearPublicTokens: () => void;\n  silentClearAnonymousTokens: () => void;\n  silentClearGuestTokens: () => void;\n  silentClearCustomTokens: () => void;\n}\n\nconst defaultTokens: TokensMap = {\n  public: {\n    idToken: Cookies.get(AuthCookie.PUBLIC_ID_TOKEN) || null,\n    refreshToken: Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN) || null,\n  },\n  anonymous: {\n    idToken: Cookies.get(AuthCookie.ANONYMOUS_ID_TOKEN) || null,\n  },\n  guest: {\n    idToken: Cookies.get(AuthCookie.GUEST_ID_TOKEN) || null,\n  },\n  custom: {\n    idToken: Cookies.get(AuthCookie.CUSTOM_ID_TOKEN) || null,\n  },\n};\n\nexport const useTokenStore = create<TokenStore>()(\n  subscribeWithSelector((set, get) => {\n    const updatePublicTokensHelper = (\n      idToken: string,\n      refreshToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (\n        idToken === get().tokens.public.idToken &&\n        refreshToken === get().tokens.public.refreshToken\n      ) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: {\n            idToken,\n            refreshToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.PUBLIC_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      Cookies.set(AuthCookie.PUBLIC_REFRESH_TOKEN, refreshToken, {\n        expires: 30,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, {\n          idToken,\n          refreshToken,\n          source,\n        });\n      }\n    };\n\n    const updateAnonymousTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.anonymous.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.ANONYMOUS_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, { idToken, source });\n      }\n    };\n\n    const updateGuestTokensHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.guest.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.GUEST_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken, source });\n      }\n    };\n\n    const updateCustomTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.custom.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken },\n        },\n      }));\n\n      Cookies.set(AuthCookie.CUSTOM_ID_TOKEN, idToken);\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken, source });\n      }\n    };\n\n    const clearPublicTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.PUBLIC_ID_TOKEN);\n      Cookies.remove(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: { idToken: null, refreshToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, { idToken: null, source });\n      }\n    };\n\n    const clearAnonymousTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.ANONYMOUS_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, {\n          idToken: null,\n          source,\n        });\n      }\n    };\n\n    const clearGuestTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.GUEST_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken: null, source });\n      }\n    };\n\n    const clearCustomTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_USER);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken: null, source });\n      }\n    };\n\n    return {\n      tokens: defaultTokens,\n\n      getToken: (type: TokenType) => {\n        return get().tokens[type]?.idToken || null;\n      },\n\n      getMostPrivilegedToken: (\n        options = [TokenType.PUBLIC, TokenType.GUEST, TokenType.ANONYMOUS]\n      ) => {\n        if (get().tokens.custom.idToken && options.includes(TokenType.CUSTOM)) {\n          return {\n            type: TokenType.CUSTOM,\n            idToken: get().tokens.custom.idToken!,\n          };\n        }\n        if (get().tokens.public.idToken && options.includes(TokenType.PUBLIC)) {\n          return {\n            type: TokenType.PUBLIC,\n            idToken: get().tokens.public.idToken!,\n          };\n        }\n        if (get().tokens.guest.idToken && options.includes(TokenType.GUEST)) {\n          return {\n            type: TokenType.GUEST,\n            idToken: get().tokens.guest.idToken!,\n          };\n        }\n        if (\n          get().tokens.anonymous.idToken &&\n          options.includes(TokenType.ANONYMOUS)\n        ) {\n          return {\n            type: TokenType.ANONYMOUS,\n            idToken: get().tokens.anonymous.idToken!,\n          };\n        }\n        return null;\n      },\n\n      getRefreshToken: (type: TokenType) => {\n        return get().tokens[type]?.refreshToken || null;\n      },\n\n      updatePublicTokens: (\n        idToken: string,\n        refreshToken: string,\n        source?: string\n      ) => {\n        updatePublicTokensHelper(idToken, refreshToken, true, source);\n      },\n\n      updateAnonymousToken: (idToken: string, source?: string) => {\n        updateAnonymousTokenHelper(idToken, true, source);\n      },\n\n      updateGuestTokens: (idToken: string, source?: string) => {\n        updateGuestTokensHelper(idToken, true, source);\n      },\n\n      updateCustomToken: (idToken: string, source?: string) => {\n        updateCustomTokenHelper(idToken, true, source);\n      },\n\n      clearTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n        clearAnonymousTokensHelper(true, source);\n        clearGuestTokensHelper(true, source);\n        clearCustomTokensHelper(true, source);\n      },\n\n      clearPublicTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n      },\n\n      clearAnonymousTokens: (source?: string) => {\n        clearAnonymousTokensHelper(true, source);\n      },\n\n      clearGuestTokens: (source?: string) => {\n        clearGuestTokensHelper(true, source);\n      },\n\n      clearCustomTokens: (source?: string) => {\n        clearCustomTokensHelper(true, source);\n      },\n\n      silentUpdatePublicTokens: (idToken: string, refreshToken: string) => {\n        updatePublicTokensHelper(idToken, refreshToken, false);\n      },\n\n      silentUpdateAnonymousToken: (idToken: string) => {\n        updateAnonymousTokenHelper(idToken, false);\n      },\n\n      silentUpdateGuestTokens: (idToken: string) => {\n        updateGuestTokensHelper(idToken, false);\n      },\n\n      silentUpdateCustomToken: (idToken: string) => {\n        updateCustomTokenHelper(idToken, false);\n      },\n\n      silentClearPublicTokens: () => {\n        clearPublicTokensHelper(false);\n      },\n\n      silentClearAnonymousTokens: () => {\n        clearAnonymousTokensHelper(false);\n      },\n\n      silentClearGuestTokens: () => {\n        clearGuestTokensHelper(false);\n      },\n\n      silentClearCustomTokens: () => {\n        clearCustomTokensHelper(false);\n      },\n    };\n  })\n);\n","import { useEffect, useRef } from 'react';\nimport { TokenType } from '../types/token';\nimport { useTokenStore } from '../stores/token-store';\nimport { TOKEN_UPDATED_EVENT } from '../utils/dom-events';\n\ninterface TokenUpdateEvent {\n  detail: {\n    idToken: string | null;\n    refreshToken?: string | null;\n    type: TokenType;\n    source?: string;\n  };\n}\n\nexport function useTokenEventListener() {\n  const updatePublicTokens = useTokenStore(\n    state => state.silentUpdatePublicTokens\n  );\n  const updateAnonymousToken = useTokenStore(\n    state => state.silentUpdateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(\n    state => state.silentUpdateGuestTokens\n  );\n  const updateCustomToken = useTokenStore(\n    state => state.silentUpdateCustomToken\n  );\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(\n    state => state.silentClearPublicTokens\n  );\n  const clearAnonymousTokens = useTokenStore(\n    state => state.silentClearAnonymousTokens\n  );\n  const clearGuestTokens = useTokenStore(state => state.silentClearGuestTokens);\n  const clearCustomTokens = useTokenStore(\n    state => state.silentClearCustomTokens\n  );\n\n  const eventSourceRef = useRef<string>(\n    `widget-${Math.random().toString(36).substr(2, 9)}`\n  );\n\n  useEffect(() => {\n    const handleTokenUpdate = (\n      event: CustomEvent<TokenUpdateEvent['detail']>\n    ) => {\n      const { idToken, refreshToken, type, source } = event.detail;\n\n      if (source === eventSourceRef.current) {\n        return;\n      }\n\n      switch (type) {\n        case TokenType.PUBLIC:\n          if (idToken) {\n            if (!refreshToken) {\n              throw new Error('Refresh token is required for public tokens');\n            }\n            updatePublicTokens(idToken, refreshToken);\n          } else {\n            clearPublicTokens();\n          }\n          break;\n\n        case TokenType.ANONYMOUS:\n          if (idToken) {\n            updateAnonymousToken(idToken);\n          } else {\n            clearAnonymousTokens();\n          }\n          break;\n\n        case TokenType.GUEST:\n          if (idToken) {\n            updateGuestTokens(idToken);\n          } else {\n            clearGuestTokens();\n          }\n          break;\n\n        case TokenType.CUSTOM:\n          if (idToken) {\n            updateCustomToken(idToken);\n          } else {\n            clearCustomTokens();\n          }\n          break;\n      }\n    };\n\n    document.addEventListener(\n      TOKEN_UPDATED_EVENT,\n      handleTokenUpdate as EventListener\n    );\n\n    return () => {\n      document.removeEventListener(\n        TOKEN_UPDATED_EVENT,\n        handleTokenUpdate as EventListener\n      );\n    };\n  }, [\n    updatePublicTokens,\n    updateAnonymousToken,\n    updateGuestTokens,\n    updateCustomToken,\n    clearTokens,\n    clearPublicTokens,\n    clearAnonymousTokens,\n    clearGuestTokens,\n    clearCustomTokens,\n  ]);\n\n  return {\n    eventSource: eventSourceRef.current,\n  };\n}\n","import { useTokenStore } from '../stores/token-store';\nimport { useTokenEventListener } from './use-token-event-listener';\n\nexport function useTokens() {\n  const getToken = useTokenStore(state => state.getToken);\n  const getMostPrivilegedToken = useTokenStore(\n    state => state.getMostPrivilegedToken\n  );\n  const getRefreshToken = useTokenStore(state => state.getRefreshToken);\n  const updatePublicTokens = useTokenStore(state => state.updatePublicTokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(state => state.updateGuestTokens);\n  const updateCustomToken = useTokenStore(state => state.updateCustomToken);\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(state => state.clearPublicTokens);\n  const clearCustomTokens = useTokenStore(state => state.clearCustomTokens);\n\n  const { eventSource } = useTokenEventListener();\n\n  return {\n    getToken,\n    getMostPrivilegedToken,\n    getRefreshToken,\n    updatePublicTokens: (idToken: string, refreshToken: string) =>\n      updatePublicTokens(idToken, refreshToken, eventSource),\n    updateAnonymousToken: (idToken: string) =>\n      updateAnonymousToken(idToken, eventSource),\n    updateGuestTokens: (idToken: string) =>\n      updateGuestTokens(idToken, eventSource),\n    updateCustomToken: (idToken: string) =>\n      updateCustomToken(idToken, eventSource),\n    clearTokens: () => clearTokens(eventSource),\n    clearPublicTokens: () => clearPublicTokens(eventSource),\n    clearCustomTokens: () => clearCustomTokens(eventSource),\n  };\n}\n\nexport function useToken(type: 'anonymous' | 'guest' | 'public' | 'custom') {\n  return useTokenStore(state => state.tokens[type]);\n}\n\nexport function useTokenValue(\n  type: 'anonymous' | 'guest' | 'public' | 'custom'\n) {\n  return useTokenStore(state => state.tokens[type]?.idToken);\n}\n\nexport function useRefreshToken(type: 'anonymous' | 'guest' | 'public') {\n  return useTokenStore(state => state.tokens[type]?.refreshToken);\n}\n","type Nullable<T> = T | null;\n\nexport enum AnalyticsWidgetType {\n  AvatarProfile = 'avatar-profile',\n  AvatarChat = 'avatar-chat',\n  Comments = 'comments',\n  GlobalProfile = 'global-profile',\n  GroupChat = 'group-chat',\n  Polls = 'polls',\n  UniversalSnippet = 'universal-snippet',\n}\n\nexport type TrackOptions = {\n  widgetId: string | null;\n  widgetType: AnalyticsWidgetType;\n  siteId: string;\n  rsWriteKey: string;\n  rsDataPlaneUrl: string;\n  trigger: string;\n};\n\nexport enum AnalyticsEvent {\n  AuthenticationCompleted = 'Authentication Completed',\n  AuthenticationStarted = 'Authentication Started',\n  AuthenticationViewed = 'Authentication Viewed',\n}\n\nexport type TrackProps = Nullable<Record<string, unknown>>;\n\nexport interface IdentityProps {\n  anonymousId?: string;\n  userId?: string;\n}\n\nexport interface RudderContext {\n  channel: 'web';\n  anonymousId?: string;\n  locale?: string;\n  userAgent?: string;\n  timezone?: string;\n  os?: { name: string; version?: string };\n  page?: {\n    path?: string;\n    referrer?: string;\n    referring_domain?: string;\n    search?: string;\n    title?: string;\n    url?: string;\n    initial_referrer?: string;\n    initial_referring_domain?: string;\n  };\n  screen?: {\n    density?: number;\n    height?: number;\n    width?: number;\n    innerHeight?: number;\n    innerWidth?: number;\n  };\n  campaign?: Record<string, string>;\n}\n","import { PublicProfile } from './types';\nimport { request, securedRequest } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\nimport { useToken } from '../../hooks/use-tokens';\nimport { TokenType } from '../../types';\nimport { useUserActions } from '../../hooks/use-user';\n\nexport function useProfileServices() {\n  const token = useToken(TokenType.PUBLIC);\n  const { refreshPublicTokens } = useUserActions();\n  const { config } = useConfig();\n  const profileUrl = config.profileServiceUrl;\n\n  async function getPublicProfile(userId?: string): Promise<PublicProfile> {\n    const fields = 'bio,photoURL,displayName,location,handle';\n    const url = `${profileUrl}/public/users/${userId}/profile?fields=${fields}`;\n    return await request('GET', url);\n  }\n\n  async function updatePublicProfile(\n    params: Omit<PublicProfile, 'metadata'>\n  ): Promise<void> {\n    const url = `${profileUrl}/me/profile/personal`;\n    await securedRequest({\n      method: 'PUT',\n      url,\n      options: {\n        body: JSON.stringify(params),\n      },\n      token: token.idToken!,\n    });\n    refreshPublicTokens({ refreshTokenApiKey: config.refreshTokenApiKey });\n  }\n  return {\n    getPublicProfile,\n    updatePublicProfile,\n  };\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport {\n  UserProps,\n  FirebaseUser,\n  SsoUserProps,\n  SsoV2ExchangeResponse,\n} from '../services/auth/types';\nimport { jwtDecode } from 'jwt-decode';\nimport { type PublicProfile } from '../services/profile/types';\nimport { useTokenStore } from './token-store';\nimport { AuthCookie } from '../types/token';\nimport { request } from '../utils/request';\nimport { Environment, getConfig } from '../config';\n\ninterface UserStore {\n  user: UserProps | null;\n  publicProfile: PublicProfile | null;\n  refreshedTokenLoaded: boolean;\n  setUser: (user: UserProps | null) => void;\n  setPublicProfile: (publicProfile: PublicProfile | null) => void;\n  logout: () => void;\n  refreshPublicTokens: (config: {\n    refreshTokenApiKey: string;\n  }) => Promise<void>;\n  setUserByTokenId: (idToken: string) => void;\n  loadStoredUser: (config?: { refreshTokenApiKey: string }) => Promise<void>;\n  ssoV2Exchange: (\n    ssoSourceID: string,\n    jwt: string,\n    env?: Environment\n  ) => Promise<SsoV2ExchangeResponse>;\n}\n\nexport const useUserStore = create<UserStore>()(\n  subscribeWithSelector((set, get) => ({\n    user: null,\n    publicProfile: null,\n    refreshedTokenLoaded: false,\n\n    setUser: (user: UserProps | null) => {\n      set({ user });\n    },\n\n    setPublicProfile: (publicProfile: PublicProfile | null) => {\n      set({ publicProfile });\n    },\n\n    setUserByTokenId: (idToken: string) => {\n      try {\n        const user = jwtDecode<FirebaseUser>(idToken);\n        const userProps: UserProps = {\n          uid: user.user_id,\n          displayName: user.safeDisplayName,\n          email: user.email,\n          photoURL: user.safePhotoURL,\n          handle: user.handle,\n        };\n        set({ user: userProps });\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    logout: () => {\n      try {\n        const tokenStore = useTokenStore.getState();\n        tokenStore.clearPublicTokens();\n        tokenStore.clearCustomTokens();\n        set({ user: null });\n        document.dispatchEvent(new Event('arena-comments-logout'));\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    refreshPublicTokens: async (config: { refreshTokenApiKey: string }) => {\n      try {\n        const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n        if (!refreshToken) {\n          throw new Error('No refresh token found');\n        }\n\n        const prefix = 'https://securetoken.googleapis.com/v1/token?key=';\n        const apiKey = config.refreshTokenApiKey;\n        const url = `${prefix}${apiKey}`;\n        const response = await fetch(url, {\n          method: 'POST',\n          body: new URLSearchParams({\n            refresh_token: refreshToken,\n            grant_type: 'refresh_token',\n          }),\n        });\n        const data = await response.json();\n\n        const { setUserByTokenId } = get();\n        setUserByTokenId(data.id_token);\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updatePublicTokens(data.id_token, data.refresh_token);\n      } catch (error) {\n        console.error(error);\n        const { logout } = get();\n        logout();\n      }\n    },\n\n    loadStoredUser: async (config?: { refreshTokenApiKey: string }) => {\n      const publicIdToken = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n      const publicRefreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n      const customIdToken = localStorage.getItem(AuthCookie.CUSTOM_ID_TOKEN);\n      const customUser = localStorage.getItem(AuthCookie.CUSTOM_USER);\n\n      if (!!customIdToken && !!customUser) {\n        const parsedUser = JSON.parse(customUser);\n\n        set({ user: parsedUser });\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updateCustomToken(customIdToken);\n      } else {\n        if (publicIdToken) {\n          const { setUserByTokenId } = get();\n          setUserByTokenId(publicIdToken);\n        } else if (publicRefreshToken && config) {\n          const { refreshPublicTokens } = get();\n          await refreshPublicTokens(config);\n        }\n      }\n\n      set({ refreshedTokenLoaded: true });\n    },\n\n    ssoV2Exchange: async (\n      ssoSourceID: string,\n      jwt: string,\n      env?: Environment\n    ) => {\n      try {\n        const config = getConfig(env ?? 'production');\n        const profileUrl = config.profileServiceUrl;\n\n        const url = `${profileUrl}/sso/sources/${ssoSourceID}/user`;\n        const response: SsoV2ExchangeResponse = await request('POST', url, {\n          body: JSON.stringify({ signedUserData: jwt }),\n        });\n\n        if (response) {\n          const decodedUser = jwtDecode<SsoUserProps>(response.token);\n\n          const { setUser, setPublicProfile } = get();\n\n          setUser({\n            uid: decodedUser?.sub,\n            email: decodedUser?.email,\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          setPublicProfile({\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          const tokenStore = useTokenStore.getState();\n          tokenStore.updateCustomToken(response.token);\n        }\n\n        return response;\n      } catch (error) {\n        console.error('SSO V2 Exchange failed:', error);\n        throw error;\n      }\n    },\n  }))\n);\n","import { useProfileServices } from '../services/profile/use-profile-services';\nimport { useUserStore } from '../stores/user-store';\n\nexport function useUser() {\n  return useUserStore(state => state.user);\n}\n\nexport function usePublicProfile() {\n  return useUserStore(state => state.publicProfile);\n}\n\nexport function useRefreshedTokenLoaded() {\n  return useUserStore(state => state.refreshedTokenLoaded);\n}\n\nexport function useUserActions() {\n  const setUser = useUserStore(state => state.setUser);\n  const setPublicProfile = useUserStore(state => state.setPublicProfile);\n  const logout = useUserStore(state => state.logout);\n  const refreshPublicTokens = useUserStore(state => state.refreshPublicTokens);\n  const setUserByTokenId = useUserStore(state => state.setUserByTokenId);\n  const loadStoredUser = useUserStore(state => state.loadStoredUser);\n  const ssoV2Exchange = useUserStore(state => state.ssoV2Exchange);\n  \n\n  return {\n    setUser,\n    setPublicProfile,\n    logout,\n    refreshPublicTokens,\n    setUserByTokenId,\n    loadStoredUser,\n    ssoV2Exchange,\n  };\n}\n\nexport function useUpdateProfile() {\n  const { updatePublicProfile } = useProfileServices();\n  return {\n    updatePublicProfile,\n  };\n}\n\nexport function useUserWithProfile() {\n  const user = useUserStore(state => state.user);\n  const publicProfile = useUserStore(state => state.publicProfile);\n  const refreshedTokenLoaded = useUserStore(\n    state => state.refreshedTokenLoaded\n  );\n\n  return {\n    user,\n    publicProfile,\n    refreshedTokenLoaded,\n  };\n}\n\n","import React, { useCallback, useEffect } from 'react';\nimport { useConfig } from './config-provider';\nimport { useUser, useUserActions } from '../hooks/use-user';\nimport { useMutation } from '@tanstack/react-query';\nimport { useProfileServices } from '../services/profile/use-profile-services';\n\nexport function UserProvider({ children }: { children: React.ReactNode }) {\n  const { config } = useConfig();\n  const user = useUser();\n  const { setPublicProfile, loadStoredUser } = useUserActions();\n  const { getPublicProfile: getPublicProfileService } = useProfileServices();\n  const { mutateAsync: getPublicProfile } = useMutation({\n    mutationFn: getPublicProfileService,\n  });\n\n  const loadPublicProfile = useCallback(async () => {\n    if (user?.uid) {\n      const profile = await getPublicProfile(user.uid);\n      setPublicProfile(profile);\n    }\n  }, [user?.uid, getPublicProfile, setPublicProfile]);\n\n  useEffect(() => {\n    loadPublicProfile();\n  }, [loadPublicProfile]);\n\n  useEffect(() => {\n    loadStoredUser(config);\n  }, [config, loadStoredUser]);\n\n  return children;\n}\n","import type {\n  AnalyticsWidgetType,\n  AnalyticsEvent,\n  IdentityProps,\n  RudderContext,\n  TrackProps,\n} from '../types/analytics';\n\nimport { removeParamsFromUrl } from '../utils/url';\n\nconst ANONYMOUS_ID_KEY = 'arenaAnonymousId';\n\nconst LS_KEYS = {\n  anon: 'rs_anonymous_id',\n  initReferrer: 'rs_initial_referrer',\n  initDomain: 'rs_initial_referring_domain',\n} as const;\n\nfunction generateUUID(): string {\n  if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n    return crypto.randomUUID();\n  }\n\n  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n    const r = (Math.random() * 16) | 0;\n    const v = c === 'x' ? r : (r & 0x3) | 0x8;\n    return v.toString(16);\n  });\n}\n\nfunction getOrSetAnonymousId(): string {\n  const existing = localStorage.getItem(LS_KEYS.anon);\n  if (existing) return existing;\n  const id = crypto.randomUUID();\n  localStorage.setItem(LS_KEYS.anon, id);\n  return id;\n}\n\nfunction rememberInitialReferrer(): void {\n  if (!localStorage.getItem(LS_KEYS.initReferrer)) {\n    const ref = document.referrer || '$direct';\n    const domain = ref && ref !== '$direct' ? new URL(ref).hostname : '';\n    localStorage.setItem(LS_KEYS.initReferrer, ref);\n    localStorage.setItem(LS_KEYS.initDomain, domain);\n  }\n}\n\nfunction parseCampaign(u: URL): Record<string, string> | undefined {\n  const keys = [\n    'utm_source',\n    'utm_medium',\n    'utm_campaign',\n    'utm_term',\n    'utm_content',\n  ];\n  const out: Record<string, string> = {};\n  keys.forEach(k => {\n    const v = u.searchParams.get(k);\n    if (v) out[k] = v;\n  });\n  return Object.keys(out).length ? out : undefined;\n}\n\nexport function buildRudderContext(): RudderContext {\n  const w = window;\n  const d = document;\n  const s = window.screen;\n  const url = new URL(w.location.href);\n\n  rememberInitialReferrer();\n\n  const initial_referrer =\n    localStorage.getItem(LS_KEYS.initReferrer) || '$direct';\n  const initial_referring_domain =\n    localStorage.getItem(LS_KEYS.initDomain) || '';\n\n  return {\n    channel: 'web',\n    anonymousId: getOrSetAnonymousId(),\n    locale: navigator.language,\n    userAgent: navigator.userAgent,\n    timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n    os: { name: navigator.platform, version: undefined },\n    page: {\n      path: url.pathname,\n      referrer: d.referrer || '$direct',\n      referring_domain: d.referrer ? new URL(d.referrer).hostname : '',\n      search: url.search,\n      title: d.title,\n      url: url.toString(),\n      initial_referrer,\n      initial_referring_domain,\n    },\n    screen: {\n      density: (w.devicePixelRatio || 1) ?? 1,\n      height: s.height,\n      width: s.width,\n      innerHeight: w.innerHeight,\n      innerWidth: w.innerWidth,\n    },\n    campaign: parseCampaign(url),\n  };\n}\n\nfunction getIdentifier(options: IdentityProps = {}): IdentityProps {\n  const identifier: IdentityProps = {};\n\n  if (options.userId) {\n    identifier.userId = options.userId;\n  }\n\n  let currentAnonymousId: string | null = null;\n\n  try {\n    currentAnonymousId = localStorage.getItem(ANONYMOUS_ID_KEY);\n  } catch (error) {\n    console.warn('Failed to access localStorage:', error);\n  }\n\n  if (options.anonymousId) {\n    identifier.anonymousId = options.anonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, options.anonymousId);\n    } catch (error) {\n      console.warn('Failed to save anonymousId to localStorage:', error);\n    }\n  } else if (currentAnonymousId) {\n    identifier.anonymousId = currentAnonymousId;\n  } else {\n    const newAnonymousId = generateUUID();\n    identifier.anonymousId = newAnonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, newAnonymousId);\n    } catch (error) {\n      console.warn('Failed to save new anonymousId to localStorage:', error);\n    }\n  }\n\n  return identifier;\n}\n\nfunction getCanonicalUrl(): string {\n  const canonicalMeta = document.querySelector(\n    'link[rel=\"canonical\"]'\n  ) as HTMLLinkElement;\n  const rawUrl = canonicalMeta?.href || window.location.href;\n  return removeParamsFromUrl(rawUrl);\n}\n\nfunction getEventProperties(\n  widgetType: string,\n  properties: TrackProps,\n  identity?: IdentityProps\n) {\n  return {\n    properties: {\n      widget_type: widgetType,\n      url: window.location.href,\n      domain: window.location.hostname,\n      title: window.document.title,\n      canonical_url: getCanonicalUrl(),\n      snippet_id: window.__ARENA__?.snippetId || null,\n      ...properties,\n    },\n    context: buildRudderContext(),\n    timestamp: new Date().toISOString(),\n    integrations: { All: true },\n    ...getIdentifier(identity),\n  };\n}\n\nfunction getEventHeaders(writeKey: string) {\n  return {\n    'Content-Type': 'application/json',\n    Authorization: 'Basic ' + btoa(`${writeKey}:`),\n  };\n}\n\nexport function getAnalytics(writeKey: string, dataPlaneUrl: string) {\n  return {\n    page: async (\n      widgetType: AnalyticsWidgetType,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/page`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          type: 'page',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send page event to Rudderstack');\n      }\n    },\n    track: async (\n      widgetType: AnalyticsWidgetType,\n      event: AnalyticsEvent,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/track`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          event,\n          type: 'track',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send track event to Rudderstack');\n      }\n    },\n  };\n}\n","export function removeParamsFromUrl(url: string): string {\n  try {\n    const urlObj = new URL(url);\n\n    urlObj.search = '';\n\n    return urlObj.href;\n  } catch (error) {\n    console.error('Error clearing search params from URL:', error);\n    return url;\n  }\n}\n","import { useCallback } from 'react';\nimport { getAnalytics } from '../utils/analytics';\nimport { AnalyticsEvent, TrackOptions } from '../types/analytics';\n\nexport function useTrack(trackOptions?: TrackOptions) {\n  const track = useCallback(\n    (\n      event: AnalyticsEvent,\n      userId?: string,\n      properties?: Record<string, string | null>\n    ) => {\n      if (!trackOptions) return;\n\n      const analytics = getAnalytics(\n        trackOptions.rsWriteKey,\n        trackOptions.rsDataPlaneUrl\n      );\n\n      const trackProperties: Record<string, string | null> = {\n        site_id: trackOptions.siteId,\n        widget_id: trackOptions.widgetId,\n        trigger: trackOptions.trigger,\n        ...properties,\n      };\n\n      analytics.track(\n        trackOptions.widgetType,\n        event,\n        trackProperties,\n        userId ? { userId } : undefined\n      );\n    },\n    [trackOptions]\n  );\n\n  return track;\n}\n","import { useAuthDialog } from '../context/auth-dialog-provider';\nimport { useEffect } from 'react';\nimport { useUserActions } from '../hooks/use-user';\nimport { useConfig } from '../context/config-provider';\nimport { useTokens } from '../hooks/use-tokens';\nimport { AnalyticsEvent } from '../types/analytics';\nimport { useTrack } from '../hooks/use-track';\n\nexport default function AuthDialog() {\n  const {\n    appName,\n    appDescription,\n    language,\n    trackOptions,\n    isOpen,\n    closeDialog,\n    onAuthCompleted,\n  } = useAuthDialog();\n  const frameAppName = appName || 'Arena AI Chat';\n  const frameAppDescription = appDescription || 'Arena AI Chat';\n  const { setUser } = useUserActions();\n  const { updatePublicTokens } = useTokens();\n  const { config } = useConfig();\n\n  const track = useTrack(trackOptions);\n\n  const iframeUrl = `${config.authIframeUrl}/?app-name=${frameAppName}&app-description=${frameAppDescription}&language=${language ?? 'en'}`;\n\n  useEffect(() => {\n    const handler = (message: MessageEvent) => {\n      if (message.data?.source !== 'arena-authentication') return;\n\n      if (message.data?.type === 'canceled') {\n        closeDialog();\n        return;\n      }\n\n      if (message.data?.type === 'authentication-viewed') {\n        track(AnalyticsEvent.AuthenticationViewed);\n        return;\n      }\n\n      if (message.data?.type === 'authentication-started') {\n        const { authType } = message.data?.payload || {};\n        track(AnalyticsEvent.AuthenticationStarted, undefined, {\n          authType: authType,\n        });\n        return;\n      }\n\n      if (message.data?.type === 'authentication-completed') {\n        const { idToken, refreshToken, user, authType, isSignup } =\n          message.data?.payload || {};\n\n        if (!user) {\n          console.error('Authentication completed but user data is missing');\n          return;\n        }\n\n        track(AnalyticsEvent.AuthenticationCompleted, user.uid, {\n          is_signup: isSignup,\n          auth_type: authType,\n        });\n        onAuthCompleted?.(user);\n        updatePublicTokens(idToken, refreshToken);\n        setUser(user);\n        closeDialog();\n        return;\n      }\n    };\n\n    window.addEventListener('message', handler);\n\n    return () => window.removeEventListener('message', handler);\n  }, [setUser, updatePublicTokens, onAuthCompleted, track, closeDialog]);\n\n  return isOpen ? (\n    <iframe\n      src={iframeUrl}\n      title=\"Arena Authentication\"\n      style={{\n        position: 'fixed',\n        top: 0,\n        left: 0,\n        width: '100vw',\n        height: '100vh',\n        zIndex: 9999999999,\n      }}\n    ></iframe>\n  ) : null;\n}\n","import React, { useEffect } from 'react';\nimport { useTokenStore } from '../stores/token-store';\nimport { useAuthServices } from '../services/auth/use-auth-services';\nimport { ExchangeTokensResponse } from '../services/auth/types';\n\nexport function AnonymousTokenProvider({\n  children,\n}: {\n  children: React.ReactNode;\n}) {\n  const tokens = useTokenStore(state => state.tokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const { getAnonymousIdentityToken } = useAuthServices();\n\n  useEffect(() => {\n    if (!tokens.anonymous.idToken) {\n      getAnonymousIdentityToken().then((token: ExchangeTokensResponse) => {\n        updateAnonymousToken(token.access_token);\n      });\n    }\n  }, [\n    tokens.anonymous.idToken,\n    updateAnonymousToken,\n    getAnonymousIdentityToken,\n  ]);\n\n  return children;\n}\n","import { ExchangeTokensResponse } from './types';\nimport { request } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\n\nexport function useAuthServices() {\n  const { config } = useConfig();\n  const identityUrl = config.identityServiceUrl;\n\n  async function getAnonymousIdentityToken(): Promise<ExchangeTokensResponse> {\n    const url = `${identityUrl}/anonymous-token`;\n    return await request('POST', url);\n  }\n\n  return {\n    getAnonymousIdentityToken,\n  };\n}\n","import { AuthDialogProvider } from './auth-dialog-provider';\nimport { QueryClient, QueryClientProvider } from '@tanstack/react-query';\nimport { UserProvider } from './user-provider';\nimport { ConfigProvider } from './config-provider';\nimport AuthDialog from '../dialog';\nimport { AnonymousTokenProvider } from './anonymous-token-provider';\n\nexport function AuthProvider({\n  children,\n  queryClient,\n  environment,\n}: {\n  children: React.ReactNode;\n  queryClient?: QueryClient;\n  environment?: 'production' | 'development';\n}) {\n  queryClient = queryClient || new QueryClient();\n\n  return (\n    <QueryClientProvider client={queryClient}>\n      <ConfigProvider environment={environment}>\n        <UserProvider>\n          <AuthDialogProvider>\n            <AnonymousTokenProvider>\n              {children}\n              <AuthDialog />\n            </AnonymousTokenProvider>\n          </AuthDialogProvider>\n        </UserProvider>\n      </ConfigProvider>\n    </QueryClientProvider>\n  );\n}\n\nexport { useAuthDialog } from './auth-dialog-provider';\n","import Cookies from 'js-cookie';\nimport { AuthCookie } from '../types/token';\nimport { useUserStore } from '../stores';\nimport { getConfig } from '../config';\n\nfunction getRefreshTokenApiKey(): string {\n  const environment =\n    typeof process !== 'undefined' && process.env?.NODE_ENV === 'production'\n      ? 'production'\n      : 'development';\n  return getConfig(environment).refreshTokenApiKey;\n}\n\nconst defaultHeaders = {\n  'Content-Type': 'application/json',\n};\n\nlet refreshPromise: Promise<void> | null = null;\n\nasync function ensureRefreshToken(): Promise<void> {\n  if (refreshPromise) {\n    return refreshPromise;\n  }\n\n  const userStore = useUserStore.getState();\n  refreshPromise = userStore\n    .refreshPublicTokens({\n      refreshTokenApiKey: getRefreshTokenApiKey(),\n    })\n    .finally(() => {\n      refreshPromise = null;\n    });\n\n  return refreshPromise;\n}\n\nasync function authenticatedFetch(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n): Promise<Response> {\n  const token = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n\n  if (!token) {\n    throw new Error('No authentication token found');\n  }\n\n  const headers = {\n    ...defaultHeaders,\n    ...options.headers,\n    Authorization: `Bearer ${token}`,\n  };\n\n  const params = {\n    ...options,\n    method,\n    headers,\n  };\n\n  return fetch(url, params);\n}\n\nasync function parseResponse(response: Response): Promise<unknown> {\n  const contentType = response.headers.get('content-type');\n  if (!contentType || !contentType.includes('application/json')) {\n    return response;\n  }\n\n  const text = await response.text();\n  if (!text) {\n    return null;\n  }\n\n  try {\n    return JSON.parse(text);\n  } catch (error) {\n    console.error({ error });\n    throw new Error('Invalid JSON response from server');\n  }\n}\n\nfunction throwOnErrorResponse(response: Response, text: string): never {\n  let errorMessage: string;\n\n  try {\n    const parsed = JSON.parse(text);\n    errorMessage = parsed?.errors?.[0] || text || 'Internal server error';\n  } catch {\n    errorMessage = text || 'Internal server error';\n  }\n\n  throw new Error(errorMessage);\n}\n\nexport async function authenticatedRequest(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n): Promise<unknown> {\n  async function attempt(): Promise<unknown> {\n    const response = await authenticatedFetch(method, url, options);\n\n    if (response.ok) {\n      return parseResponse(response);\n    }\n\n    const text = await response.text();\n    if (!text) {\n      throw new Error(`Failed to process request - ${response.status}`);\n    }\n\n    if (response.status === 401) {\n      const err = new Error('Unauthorized') as Error & { status?: number };\n      err.status = 401;\n      throw err;\n    }\n\n    throwOnErrorResponse(response, text);\n  }\n\n  const hasToken = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n\n  if (!hasToken) {\n    const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n    if (refreshToken) {\n      await ensureRefreshToken();\n      return await attempt();\n    }\n    throw new Error('No authentication token found');\n  }\n\n  try {\n    return await attempt();\n  } catch (error) {\n    const is401 =\n      error instanceof Error &&\n      'status' in error &&\n      (error as Error & { status?: number }).status === 401;\n\n    if (!is401) {\n      throw error;\n    }\n\n    const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n    if (!refreshToken) {\n      throw new Error('Unauthorized');\n    }\n\n    await ensureRefreshToken();\n\n    try {\n      return await attempt();\n    } catch (retryError) {\n      const retryIs401 =\n        retryError instanceof Error &&\n        'status' in retryError &&\n        (retryError as Error & { status?: number }).status === 401;\n\n      if (retryIs401) {\n        throw new Error('Unauthorized');\n      }\n\n      throw retryError;\n    }\n  }\n}\n"],"names":["AuthDialogContext","createContext","undefined","AuthDialogProvider","children","isOpen","setIsOpen","useState","appName","setAppName","appDescription","setAppDescription","onAuthCompleted","setOnAuthCompleted","trackOptions","setTrackOptions","language","setLanguage","_jsx","Provider","value","openDialog","closeDialog","onOpenChange","open","useAuthDialog","context","useContext","Error","getConfig","environment","isDev","profileServiceUrl","identityServiceUrl","refreshTokenApiKey","authIframeUrl","debug","ConfigContext","ConfigProvider","config","useConfig","defaultHeaders","async","request","method","url","options","response","fetch","headers","ok","statusText","json","TokenType","AuthCookie","TOKEN_UPDATED_EVENT","dispatchTokenUpdatedEvent","type","params","document","dispatchEvent","CustomEvent","detail","defaultTokens","public","idToken","Cookies","get","PUBLIC_ID_TOKEN","refreshToken","PUBLIC_REFRESH_TOKEN","anonymous","ANONYMOUS_ID_TOKEN","guest","GUEST_ID_TOKEN","custom","CUSTOM_ID_TOKEN","useTokenStore","create","subscribeWithSelector","set","updatePublicTokensHelper","source","tokens","state","expires","PUBLIC","updateAnonymousTokenHelper","ANONYMOUS","updateGuestTokensHelper","GUEST","updateCustomTokenHelper","CUSTOM","clearPublicTokensHelper","remove","clearAnonymousTokensHelper","clearGuestTokensHelper","clearCustomTokensHelper","localStorage","removeItem","CUSTOM_USER","getToken","getMostPrivilegedToken","includes","getRefreshToken","updatePublicTokens","updateAnonymousToken","updateGuestTokens","updateCustomToken","clearTokens","clearPublicTokens","clearAnonymousTokens","clearGuestTokens","clearCustomTokens","silentUpdatePublicTokens","silentUpdateAnonymousToken","silentUpdateGuestTokens","silentUpdateCustomToken","silentClearPublicTokens","silentClearAnonymousTokens","silentClearGuestTokens","silentClearCustomTokens","useTokenEventListener","eventSourceRef","useRef","Math","random","toString","substr","useEffect","handleTokenUpdate","event","current","addEventListener","removeEventListener","eventSource","useTokens","useToken","useTokenValue","useRefreshToken","AnalyticsWidgetType","AnalyticsEvent","useProfileServices","token","refreshPublicTokens","useUserActions","profileUrl","getPublicProfile","userId","updatePublicProfile","Authorization","payload","text","status","errors","JSON","parse","contentType","error","console","securedRequest","body","stringify","useUserStore","user","publicProfile","refreshedTokenLoaded","setUser","setPublicProfile","setUserByTokenId","jwtDecode","userProps","uid","user_id","displayName","safeDisplayName","email","photoURL","safePhotoURL","handle","logout","tokenStore","getState","Event","URLSearchParams","refresh_token","grant_type","data","id_token","loadStoredUser","publicIdToken","publicRefreshToken","customIdToken","getItem","customUser","parsedUser","ssoV2Exchange","ssoSourceID","jwt","env","signedUserData","decodedUser","sub","useUser","usePublicProfile","useRefreshedTokenLoaded","useUpdateProfile","useUserWithProfile","UserProvider","getPublicProfileService","mutateAsync","useMutation","mutationFn","loadPublicProfile","useCallback","profile","ANONYMOUS_ID_KEY","LS_KEYS","getOrSetAnonymousId","existing","id","crypto","randomUUID","setItem","parseCampaign","u","out","forEach","k","v","searchParams","Object","keys","length","buildRudderContext","w","window","d","s","screen","URL","location","href","ref","referrer","domain","hostname","rememberInitialReferrer","initial_referrer","initial_referring_domain","channel","anonymousId","locale","navigator","userAgent","timezone","Intl","DateTimeFormat","resolvedOptions","timeZone","os","name","platform","version","page","path","pathname","referring_domain","search","title","density","devicePixelRatio","height","width","innerHeight","innerWidth","campaign","getIdentifier","identifier","currentAnonymousId","warn","newAnonymousId","replace","c","r","getCanonicalUrl","canonicalMeta","querySelector","urlObj","removeParamsFromUrl","getEventProperties","widgetType","properties","identity","widget_type","canonical_url","snippet_id","__ARENA__","snippetId","timestamp","Date","toISOString","integrations","All","getEventHeaders","writeKey","btoa","useTrack","analytics","rsWriteKey","dataPlaneUrl","rsDataPlaneUrl","track","trackProperties","site_id","siteId","widget_id","widgetId","trigger","AuthDialog","frameAppName","frameAppDescription","iframeUrl","handler","message","authType","AuthenticationStarted","isSignup","AuthenticationCompleted","is_signup","auth_type","AuthenticationViewed","src","style","position","top","left","zIndex","AnonymousTokenProvider","getAnonymousIdentityToken","identityUrl","useAuthServices","then","access_token","AuthProvider","queryClient","QueryClient","QueryClientProvider","client","_jsxs","getRefreshTokenApiKey","process","NODE_ENV","refreshPromise","ensureRefreshToken","userStore","finally","authenticatedRequest","attempt","authenticatedFetch","parseResponse","err","errorMessage","parsed","throwOnErrorResponse","retryError"],"mappings":"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"}
|
|
1
|
+
import{jsx as e,jsxs as t}from"react/jsx-runtime";import{createContext as n,useContext as o,useState as r,useEffect as i,useRef as s,useCallback as a}from"react";import{useMutation as u,QueryClient as c,QueryClientProvider as l}from"@tanstack/react-query";import{create as d}from"zustand";import{subscribeWithSelector as h}from"zustand/middleware";import p from"js-cookie";import{jwtDecode as k}from"jwt-decode";const f=n(void 0),m=({children:t})=>{const[n,o]=r(!1),[i,s]=r(void 0),[a,u]=r(void 0),[c,l]=r(void 0),[d,h]=r(void 0),[p,k]=r(void 0);return e(f.Provider,{value:{isOpen:n,appName:i,language:p,appDescription:a,trackOptions:d,onAuthCompleted:c,openDialog:({trackOptions:e,appName:t,language:n,appDescription:r,onAuthCompleted:i})=>{o(!0),h(e),s(t),k(n),u(r),l(i)},closeDialog:()=>o(!1),onOpenChange:e=>o(e)},children:t})},T=()=>{const e=o(f);if(!e)throw new Error("useAuthDialog must be used within an AuthDialogProvider");return e};let g="development";const y=e=>{const t="development"===e;return{profileServiceUrl:t?"https://profile-service-dev.arena.im":"https://profile-service-prd.arena.im",identityServiceUrl:t?"https://token-service-dev.arena.im":"https://token-service-prd.arena.im",refreshTokenApiKey:t?"AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk":"AIzaSyD_a4tNVdFVqgGbTfOGCaZ5pvUHErcE79c",authIframeUrl:t?"https://auth2.dev.arena.im":"https://auth2.arena.im",environment:e,debug:"development"===e}},w=n(void 0),U=({children:t,environment:n="development"})=>{const o=y(n);return i(()=>{!function(e){g=e}(n)},[n]),e(w.Provider,{value:{config:o,environment:n},children:t})},S=()=>{const e=o(w);if(!e)throw new Error("useConfig must be used within a ConfigProvider");return e},I={"Content-Type":"application/json"};async function E(e,t,n={}){const o=await fetch(t,{...n,method:e,headers:{"Content-Type":"application/json",...n.headers}});if(!o.ok)throw new Error(`Error: ${o.statusText}`);return o.json()}var v,_;!function(e){e.ANONYMOUS="anonymous",e.GUEST="guest",e.PUBLIC="public",e.CUSTOM="custom"}(v||(v={})),function(e){e.PUBLIC_ID_TOKEN="arena-auth-public-id-token",e.PUBLIC_REFRESH_TOKEN="arena-auth-public-refresh-token",e.ANONYMOUS_ID_TOKEN="arena-auth-anonymous-id-token",e.GUEST_ID_TOKEN="arena-auth-guest-id-token",e.CUSTOM_ID_TOKEN="arena-auth-custom-id-token",e.CUSTOM_USER="arena-auth-custom-user"}(_||(_={}));const O="arena-auth-token-updated";function P(e,t){document.dispatchEvent(new CustomEvent(O,{detail:{...t,type:e}}))}const C={public:{idToken:p.get(_.PUBLIC_ID_TOKEN)||null,refreshToken:p.get(_.PUBLIC_REFRESH_TOKEN)||null},anonymous:{idToken:p.get(_.ANONYMOUS_ID_TOKEN)||null},guest:{idToken:p.get(_.GUEST_ID_TOKEN)||null},custom:{idToken:p.get(_.CUSTOM_ID_TOKEN)||null}},N=d()(h((e,t)=>{const n=(n,o,r=!0,i)=>{n===t().tokens.public.idToken&&o===t().tokens.public.refreshToken||(e(e=>({tokens:{...e.tokens,public:{idToken:n,refreshToken:o}}})),p.set(_.PUBLIC_ID_TOKEN,n,{expires:1/24}),p.set(_.PUBLIC_REFRESH_TOKEN,o,{expires:30}),r&&P(v.PUBLIC,{idToken:n,refreshToken:o,source:i}))},o=(n,o=!0,r)=>{n!==t().tokens.anonymous.idToken&&(e(e=>({tokens:{...e.tokens,anonymous:{idToken:n}}})),p.set(_.ANONYMOUS_ID_TOKEN,n,{expires:1/24}),o&&P(v.ANONYMOUS,{idToken:n,source:r}))},r=(n,o=!0,r)=>{n!==t().tokens.guest.idToken&&(e(e=>({tokens:{...e.tokens,guest:{idToken:n}}})),p.set(_.GUEST_ID_TOKEN,n,{expires:1/24}),o&&P(v.GUEST,{idToken:n,source:r}))},i=(n,o=!0,r)=>{n!==t().tokens.custom.idToken&&(e(e=>({tokens:{...e.tokens,custom:{idToken:n}}})),p.set(_.CUSTOM_ID_TOKEN,n),o&&P(v.CUSTOM,{idToken:n,source:r}))},s=(t=!0,n)=>{p.remove(_.PUBLIC_ID_TOKEN),p.remove(_.PUBLIC_REFRESH_TOKEN),e(e=>({tokens:{...e.tokens,public:{idToken:null,refreshToken:null}}})),t&&P(v.PUBLIC,{idToken:null,source:n})},a=(t=!0,n)=>{p.remove(_.ANONYMOUS_ID_TOKEN),e(e=>({tokens:{...e.tokens,anonymous:{idToken:null}}})),t&&P(v.ANONYMOUS,{idToken:null,source:n})},u=(t=!0,n)=>{p.remove(_.GUEST_ID_TOKEN),e(e=>({tokens:{...e.tokens,guest:{idToken:null}}})),t&&P(v.GUEST,{idToken:null,source:n})},c=(t=!0,n)=>{p.remove(_.CUSTOM_ID_TOKEN),localStorage.removeItem(_.CUSTOM_ID_TOKEN),localStorage.removeItem(_.CUSTOM_USER),e(e=>({tokens:{...e.tokens,custom:{idToken:null}}})),t&&P(v.CUSTOM,{idToken:null,source:n})};return{tokens:C,getToken:e=>t().tokens[e]?.idToken||null,getMostPrivilegedToken:(e=[v.PUBLIC,v.GUEST,v.ANONYMOUS])=>t().tokens.custom.idToken&&e.includes(v.CUSTOM)?{type:v.CUSTOM,idToken:t().tokens.custom.idToken}:t().tokens.public.idToken&&e.includes(v.PUBLIC)?{type:v.PUBLIC,idToken:t().tokens.public.idToken}:t().tokens.guest.idToken&&e.includes(v.GUEST)?{type:v.GUEST,idToken:t().tokens.guest.idToken}:t().tokens.anonymous.idToken&&e.includes(v.ANONYMOUS)?{type:v.ANONYMOUS,idToken:t().tokens.anonymous.idToken}:null,getRefreshToken:e=>t().tokens[e]?.refreshToken||null,updatePublicTokens:(e,t,o)=>{n(e,t,!0,o)},updateAnonymousToken:(e,t)=>{o(e,!0,t)},updateGuestTokens:(e,t)=>{r(e,!0,t)},updateCustomToken:(e,t)=>{i(e,!0,t)},clearTokens:e=>{s(!0,e),a(!0,e),u(!0,e),c(!0,e)},clearPublicTokens:e=>{s(!0,e)},clearAnonymousTokens:e=>{a(!0,e)},clearGuestTokens:e=>{u(!0,e)},clearCustomTokens:e=>{c(!0,e)},silentUpdatePublicTokens:(e,t)=>{n(e,t,!1)},silentUpdateAnonymousToken:e=>{o(e,!1)},silentUpdateGuestTokens:e=>{r(e,!1)},silentUpdateCustomToken:e=>{i(e,!1)},silentClearPublicTokens:()=>{s(!1)},silentClearAnonymousTokens:()=>{a(!1)},silentClearGuestTokens:()=>{u(!1)},silentClearCustomTokens:()=>{c(!1)}}}));function b(){const e=N(e=>e.silentUpdatePublicTokens),t=N(e=>e.silentUpdateAnonymousToken),n=N(e=>e.silentUpdateGuestTokens),o=N(e=>e.silentUpdateCustomToken),r=N(e=>e.clearTokens),a=N(e=>e.silentClearPublicTokens),u=N(e=>e.silentClearAnonymousTokens),c=N(e=>e.silentClearGuestTokens),l=N(e=>e.silentClearCustomTokens),d=s(`widget-${Math.random().toString(36).substr(2,9)}`);return i(()=>{const r=r=>{const{idToken:i,refreshToken:s,type:h,source:p}=r.detail;if(p!==d.current)switch(h){case v.PUBLIC:if(i){if(!s)throw new Error("Refresh token is required for public tokens");e(i,s)}else a();break;case v.ANONYMOUS:i?t(i):u();break;case v.GUEST:i?n(i):c();break;case v.CUSTOM:i?o(i):l()}};return document.addEventListener(O,r),()=>{document.removeEventListener(O,r)}},[e,t,n,o,r,a,u,c,l]),{eventSource:d.current}}function A(){const e=N(e=>e.getToken),t=N(e=>e.getMostPrivilegedToken),n=N(e=>e.getRefreshToken),o=N(e=>e.updatePublicTokens),r=N(e=>e.updateAnonymousToken),i=N(e=>e.updateGuestTokens),s=N(e=>e.updateCustomToken),a=N(e=>e.clearTokens),u=N(e=>e.clearPublicTokens),c=N(e=>e.clearCustomTokens),{eventSource:l}=b();return{getToken:e,getMostPrivilegedToken:t,getRefreshToken:n,updatePublicTokens:(e,t)=>o(e,t,l),updateAnonymousToken:e=>r(e,l),updateGuestTokens:e=>i(e,l),updateCustomToken:e=>s(e,l),clearTokens:()=>a(l),clearPublicTokens:()=>u(l),clearCustomTokens:()=>c(l)}}function x(e){return N(t=>t.tokens[e])}function L(e){return N(t=>t.tokens[e]?.idToken)}function R(e){return N(t=>t.tokens[e]?.refreshToken)}var D,K;function B(){const e=x(v.PUBLIC),{refreshPublicTokens:t}=J(),{config:n}=S(),o=n.profileServiceUrl;return{getPublicProfile:async function(e){const t=`${o}/public/users/${e}/profile?fields=bio,photoURL,displayName,location,handle`;return await E("GET",t)},updatePublicProfile:async function(r){const i=`${o}/me/profile/personal`;await async function(e){const{method:t,url:n,options:o={},token:r}=e;if(!r)throw new Error("No authentication token found");const i={...I,...o.headers,Authorization:`Bearer ${r}`},s={...o,method:t,headers:i},a=await fetch(n,s);if(!a.ok){const e=await a.text();if(!e)throw new Error(`Error to process request - ${a.status}`);const{errors:t}=JSON.parse(e)||{};throw new Error(t?.[0]||"Internal server error")}const u=a.headers.get("content-type");if(!u||!u.includes("application/json"))return a;const c=await a.text();if(!c)return null;try{return JSON.parse(c)}catch(e){throw console.error(e),new Error("Invalid JSON response from server")}}({method:"PUT",url:i,options:{body:JSON.stringify(r)},token:e.idToken}),t({refreshTokenApiKey:n.refreshTokenApiKey})}}}!function(e){e.AvatarProfile="avatar-profile",e.AvatarChat="avatar-chat",e.Comments="comments",e.GlobalProfile="global-profile",e.GroupChat="group-chat",e.Polls="polls",e.UniversalSnippet="universal-snippet"}(D||(D={})),function(e){e.AuthenticationCompleted="Authentication Completed",e.AuthenticationStarted="Authentication Started",e.AuthenticationViewed="Authentication Viewed"}(K||(K={}));const M=d()(h((e,t)=>({user:null,publicProfile:null,refreshedTokenLoaded:!1,setUser:t=>{e({user:t})},setPublicProfile:t=>{e({publicProfile:t})},setUserByTokenId:t=>{try{const n=k(t),o={uid:n.user_id,displayName:n.safeDisplayName,email:n.email,photoURL:n.safePhotoURL,handle:n.handle};e({user:o})}catch(e){console.error(e)}},logout:()=>{try{const t=N.getState();t.clearPublicTokens(),t.clearCustomTokens(),e({user:null}),document.dispatchEvent(new Event("arena-comments-logout"))}catch(e){console.error(e)}},refreshPublicTokens:async e=>{try{const n=p.get(_.PUBLIC_REFRESH_TOKEN);if(!n)throw new Error("No refresh token found");const o=`${"https://securetoken.googleapis.com/v1/token?key="}${e.refreshTokenApiKey}`,r=await fetch(o,{method:"POST",body:new URLSearchParams({refresh_token:n,grant_type:"refresh_token"})}),i=await r.json(),{setUserByTokenId:s}=t();s(i.id_token);N.getState().updatePublicTokens(i.id_token,i.refresh_token)}catch(e){console.error(e);const{logout:n}=t();n()}},loadStoredUser:async n=>{const o=p.get(_.PUBLIC_ID_TOKEN),r=p.get(_.PUBLIC_REFRESH_TOKEN),i=localStorage.getItem(_.CUSTOM_ID_TOKEN),s=localStorage.getItem(_.CUSTOM_USER);if(i&&s){const t=JSON.parse(s);e({user:t});N.getState().updateCustomToken(i)}else if(o){const{setUserByTokenId:e}=t();e(o)}else if(r&&n){const{refreshPublicTokens:e}=t();await e(n)}e({refreshedTokenLoaded:!0})},ssoV2Exchange:async(e,n,o)=>{try{const r=y(o??"production"),i=`${r.profileServiceUrl}/sso/sources/${e}/user`,s=await E("POST",i,{body:JSON.stringify({signedUserData:n})});if(s){const e=k(s.token),{setUser:n,setPublicProfile:o}=t();n({uid:e?.sub,email:e?.email,displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle}),o({displayName:e?.displayName,photoURL:e?.photoURL,handle:e?.handle});N.getState().updateCustomToken(s.token)}return s}catch(e){throw console.error("SSO V2 Exchange failed:",e),e}}})));function $(){return M(e=>e.user)}function G(){return M(e=>e.publicProfile)}function F(){return M(e=>e.refreshedTokenLoaded)}function J(){return{setUser:M(e=>e.setUser),setPublicProfile:M(e=>e.setPublicProfile),logout:M(e=>e.logout),refreshPublicTokens:M(e=>e.refreshPublicTokens),setUserByTokenId:M(e=>e.setUserByTokenId),loadStoredUser:M(e=>e.loadStoredUser),ssoV2Exchange:M(e=>e.ssoV2Exchange)}}function j(){const{updatePublicProfile:e}=B();return{updatePublicProfile:e}}function z(){return{user:M(e=>e.user),publicProfile:M(e=>e.publicProfile),refreshedTokenLoaded:M(e=>e.refreshedTokenLoaded)}}function H({children:e}){const{config:t}=S(),n=$(),{setPublicProfile:o,loadStoredUser:r}=J(),{getPublicProfile:s}=B(),{mutateAsync:c}=u({mutationFn:s}),l=a(async()=>{if(n?.uid){const e=await c(n.uid);o(e)}},[n?.uid,c,o]);return i(()=>{l()},[l]),i(()=>{r(t)},[t,r]),e}const Y="arenaAnonymousId",V="rs_anonymous_id",q="rs_initial_referrer",W="rs_initial_referring_domain";function Z(){const e=localStorage.getItem(V);if(e)return e;const t=crypto.randomUUID();return localStorage.setItem(V,t),t}function Q(e){const t={};return["utm_source","utm_medium","utm_campaign","utm_term","utm_content"].forEach(n=>{const o=e.searchParams.get(n);o&&(t[n]=o)}),Object.keys(t).length?t:void 0}function X(){const e=window,t=document,n=window.screen,o=new URL(e.location.href);!function(){if(!localStorage.getItem(q)){const e=document.referrer||"$direct",t="$direct"!==e?new URL(e).hostname:"";localStorage.setItem(q,e),localStorage.setItem(W,t)}}();const r=localStorage.getItem(q)||"$direct",i=localStorage.getItem(W)||"";return{channel:"web",anonymousId:Z(),locale:navigator.language,userAgent:navigator.userAgent,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone,os:{name:navigator.platform,version:void 0},page:{path:o.pathname,referrer:t.referrer||"$direct",referring_domain:t.referrer?new URL(t.referrer).hostname:"",search:o.search,title:t.title,url:o.toString(),initial_referrer:r,initial_referring_domain:i},screen:{density:e.devicePixelRatio||1,height:n.height,width:n.width,innerHeight:e.innerHeight,innerWidth:e.innerWidth},campaign:Q(o)}}function ee(e={}){const t={};e.userId&&(t.userId=e.userId);let n=null;try{n=localStorage.getItem(Y)}catch(e){console.warn("Failed to access localStorage:",e)}if(e.anonymousId){t.anonymousId=e.anonymousId;try{localStorage.setItem(Y,e.anonymousId)}catch(e){console.warn("Failed to save anonymousId to localStorage:",e)}}else if(n)t.anonymousId=n;else{const e="undefined"!=typeof crypto&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)});t.anonymousId=e;try{localStorage.setItem(Y,e)}catch(e){console.warn("Failed to save new anonymousId to localStorage:",e)}}return t}function te(){const e=document.querySelector('link[rel="canonical"]');return function(e){try{const t=new URL(e);return t.search="",t.href}catch(t){return console.error("Error clearing search params from URL:",t),e}}(e?.href||window.location.href)}function ne(e,t,n){return{properties:{widget_type:e,url:window.location.href,domain:window.location.hostname,title:window.document.title,canonical_url:te(),snippet_id:window.__ARENA__?.snippetId||null,...t},context:X(),timestamp:(new Date).toISOString(),integrations:{All:!0},...ee(n)}}function oe(e){return{"Content-Type":"application/json",Authorization:"Basic "+btoa(`${e}:`)}}function re(e){return a((t,n,o)=>{if(!e)return;const r=(i=e.rsWriteKey,s=e.rsDataPlaneUrl,{page:async(e,t,n)=>{const o=await fetch(`${s}/v1/page`,{method:"POST",headers:oe(i),body:JSON.stringify({type:"page",...ne(e,t,n)})});if(o.ok)return await o.text();throw new Error("Failed to send page event to Rudderstack")},track:async(e,t,n,o)=>{const r=await fetch(`${s}/v1/track`,{method:"POST",headers:oe(i),body:JSON.stringify({event:t,type:"track",...ne(e,n,o)})});if(r.ok)return await r.text();throw new Error("Failed to send track event to Rudderstack")}});var i,s;const a={site_id:e.siteId,widget_id:e.widgetId,trigger:e.trigger,...o};r.track(e.widgetType,t,a,n?{userId:n}:void 0)},[e])}function ie(){const{appName:t,appDescription:n,language:o,trackOptions:r,isOpen:s,closeDialog:a,onAuthCompleted:u}=T(),c=t||"Arena AI Chat",l=n||"Arena AI Chat",{setUser:d}=J(),{updatePublicTokens:h}=A(),{config:p}=S(),k=re(r),f=`${p.authIframeUrl}/?app-name=${c}&app-description=${l}&language=${o??"en"}`;return i(()=>{const e=e=>{if("arena-authentication"===e.data?.source)if("canceled"!==e.data?.type)if("authentication-viewed"!==e.data?.type){if("authentication-started"===e.data?.type){const{authType:t}=e.data?.payload||{};return void k(K.AuthenticationStarted,void 0,{authType:t})}if("authentication-completed"===e.data?.type){const{idToken:t,refreshToken:n,user:o,authType:r,isSignup:i}=e.data?.payload||{};return o?(k(K.AuthenticationCompleted,o.uid,{is_signup:i,auth_type:r}),u?.(o),h(t,n),d(o),void a()):void console.error("Authentication completed but user data is missing")}}else k(K.AuthenticationViewed);else a()};return window.addEventListener("message",e),()=>window.removeEventListener("message",e)},[d,h,u,k,a]),s?e("iframe",{src:f,title:"Arena Authentication",style:{position:"fixed",top:0,left:0,width:"100vw",height:"100vh",zIndex:9999999999}}):null}function se(e){const t=e?.trim();return t&&"null"!==t&&"undefined"!==t?t:null}function ae(){if("undefined"==typeof window)return null;const e=window,t=se(e.rudderanalytics?.getAnonymousId?.()??e.rudderAnalytics?.getAnonymousId?.());if(t)return t;try{return se(window.localStorage.getItem("arena-analytics:rs-anonymous-id"))}catch{return null}}function ue({children:e}){const{config:t}=S(),n=N(e=>e.tokens),o=N(e=>e.updateAnonymousToken),{getAnonymousIdentityToken:r}=function(){const{config:e}=S(),t=e.identityServiceUrl;return{getAnonymousIdentityToken:async function(){const e=`${t}/anonymous-token`,n=ae();return n?await E("POST",e,{body:JSON.stringify({anonymousId:n})}):await E("POST",e)}}}(),a=s(!1);return i(()=>{const e=ae();(!n.anonymous.idToken||t.debug&&Boolean(e)&&!a.current)&&(n.anonymous.idToken&&(a.current=!0),r().then(e=>{o(e.access_token,n.anonymous.idToken?"force-refresh-debug":void 0)}).catch(e=>{n.anonymous.idToken&&(a.current=!1),console.error("[react-sdk-auth] getAnonymousIdentityToken failed",{error:e})}))},[t.debug,n.anonymous.idToken,o,r]),e}function ce({children:n,queryClient:o,environment:r}){return o=o||new c,e(l,{client:o,children:e(U,{environment:r,children:e(H,{children:e(m,{children:t(ue,{children:[n,e(ie,{})]})})})})})}function le(){return y(g).refreshTokenApiKey}const de={"Content-Type":"application/json"};let he=null;async function pe(){if(he)return he;const e=M.getState();return he=e.refreshPublicTokens({refreshTokenApiKey:le()}).finally(()=>{he=null}),he}async function ke(e,t,n={}){async function o(){const o=await async function(e,t,n={}){const o=p.get(_.PUBLIC_ID_TOKEN);if(!o)throw new Error("No authentication token found");const r={...de,...n.headers,Authorization:`Bearer ${o}`},i={...n,method:e,headers:r};return fetch(t,i)}(e,t,n);if(o.ok)return async function(e){const t=e.headers.get("content-type");if(!t||!t.includes("application/json"))return e;const n=await e.text();if(!n)return null;try{return JSON.parse(n)}catch(e){throw console.error({error:e}),new Error("Invalid JSON response from server")}}(o);const r=await o.text();if(!r)throw new Error(`Failed to process request - ${o.status}`);if(401===o.status){const e=new Error("Unauthorized");throw e.status=401,e}!function(e,t){let n;try{const e=JSON.parse(t);n=e?.errors?.[0]||t||"Internal server error"}catch{n=t||"Internal server error"}throw new Error(n)}(0,r)}if(!p.get(_.PUBLIC_ID_TOKEN)){if(p.get(_.PUBLIC_REFRESH_TOKEN))return await pe(),await o();throw new Error("No authentication token found")}try{return await o()}catch(e){if(!(e instanceof Error&&"status"in e&&401===e.status))throw e;if(!p.get(_.PUBLIC_REFRESH_TOKEN))throw new Error("Unauthorized");await pe();try{return await o()}catch(e){if(e instanceof Error&&"status"in e&&401===e.status)throw new Error("Unauthorized");throw e}}}export{K as AnalyticsEvent,D as AnalyticsWidgetType,_ as AuthCookie,ce as AuthProvider,v as TokenType,ke as authenticatedRequest,T as useAuthDialog,G as usePublicProfile,R as useRefreshToken,F as useRefreshedTokenLoaded,x as useToken,b as useTokenEventListener,N as useTokenStore,L as useTokenValue,A as useTokens,j as useUpdateProfile,$ as useUser,J as useUserActions,M as useUserStore,z as useUserWithProfile};
|
|
2
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.esm.js","sources":["../src/context/auth-dialog-provider.tsx","../src/config/runtime-environment.ts","../src/config/index.ts","../src/context/config-provider.tsx","../src/utils/request.ts","../src/types/token.ts","../src/utils/dom-events.ts","../src/stores/token-store.ts","../src/hooks/use-token-event-listener.ts","../src/hooks/use-tokens.ts","../src/types/analytics.ts","../src/services/profile/use-profile-services.ts","../src/stores/user-store.ts","../src/hooks/use-user.ts","../src/context/user-provider.tsx","../src/utils/analytics.ts","../src/utils/url.ts","../src/hooks/use-track.ts","../src/dialog/index.tsx","../src/services/auth/use-auth-services.ts","../src/context/anonymous-token-provider.tsx","../src/context/index.tsx","../src/utils/authenticated-request.ts"],"sourcesContent":["import { createContext, useContext, useState, ReactNode } from 'react';\nimport { UserProps } from '../services/auth/types';\nimport { TrackOptions } from '../types/analytics';\n\ninterface AuthDialogContextType {\n  isOpen: boolean;\n  appName: string | undefined;\n  appDescription: string | undefined;\n  language: string | undefined;\n  trackOptions: TrackOptions | undefined;\n  onAuthCompleted: ((user: UserProps) => void) | undefined;\n  openDialog: (options: OpenDialogOptions) => void;\n  closeDialog: () => void;\n  onOpenChange: (open: boolean) => void;\n}\n\nconst AuthDialogContext = createContext<AuthDialogContextType | undefined>(\n  undefined\n);\n\ntype OpenDialogOptions = {\n  trackOptions: TrackOptions;\n  appName?: string;\n  language?: string;\n  appDescription?: string;\n  onAuthCompleted?: () => (user: UserProps) => void;\n};\n\nexport const AuthDialogProvider = ({ children }: { children: ReactNode }) => {\n  const [isOpen, setIsOpen] = useState(false);\n  const [appName, setAppName] = useState<string | undefined>(undefined);\n  const [appDescription, setAppDescription] = useState<string | undefined>(\n    undefined\n  );\n  const [onAuthCompleted, setOnAuthCompleted] = useState<\n    ((user: UserProps) => void) | undefined\n  >(undefined);\n  const [trackOptions, setTrackOptions] = useState<TrackOptions | undefined>(\n    undefined\n  );\n  const [language, setLanguage] = useState<string | undefined>(\n    undefined\n  );\n  const openDialog = ({\n    trackOptions,\n    appName,\n    language,\n    appDescription,\n    onAuthCompleted,\n  }: OpenDialogOptions) => {\n    setIsOpen(true);\n    setTrackOptions(trackOptions);\n    setAppName(appName);\n    setLanguage(language);\n    setAppDescription(appDescription);\n    setOnAuthCompleted(onAuthCompleted);\n  };\n\n  const closeDialog = () => setIsOpen(false);\n  const onOpenChange = (open: boolean) => setIsOpen(open);\n\n  return (\n    <AuthDialogContext.Provider\n      value={{\n        isOpen,\n        appName,\n        language,\n        appDescription,\n        trackOptions,\n        onAuthCompleted,\n        openDialog,\n        closeDialog,\n        onOpenChange,\n      }}\n    >\n      {children}\n    </AuthDialogContext.Provider>\n  );\n};\n\nexport const useAuthDialog = () => {\n  const context = useContext(AuthDialogContext);\n  if (!context) {\n    throw new Error('useAuthDialog must be used within an AuthDialogProvider');\n  }\n  return context;\n};\n","import { Environment } from './index';\n\nlet runtimeEnvironment: Environment = 'development';\n\nexport function setRuntimeEnvironment(environment: Environment): void {\n  runtimeEnvironment = environment;\n}\n\nexport function getRuntimeEnvironment(): Environment {\n  return runtimeEnvironment;\n}\n","export interface Config {\n  profileServiceUrl: string;\n  identityServiceUrl: string;\n  refreshTokenApiKey: string;\n  authIframeUrl: string;\n  environment: 'development' | 'production';\n  debug: boolean;\n}\n\nexport type Environment = 'development' | 'production';\n\nexport const getConfig = (environment: Environment): Config => {\n  const isDev = environment === 'development';\n\n  return {\n    profileServiceUrl: isDev\n      ? process.env.PROFILE_SERVICE_URL_DEV ||\n        'https://profile-service-dev.arena.im'\n      : process.env.PROFILE_SERVICE_URL_PRD ||\n        'https://profile-service-prd.arena.im',\n    identityServiceUrl: isDev\n      ? process.env.IDENTITY_SERVICE_URL_DEV ||\n        'https://token-service-dev.arena.im'\n      : process.env.IDENTITY_SERVICE_URL_PRD ||\n        'https://token-service-prd.arena.im',\n    refreshTokenApiKey: isDev\n      ? process.env.FIREBASE_PUBLIC_API_KEY_DEV ||\n        'AIzaSyCJhWFCK3ics9kJ2eSgQD7kWHUsOsJyPdk'\n      : process.env.FIREBASE_PUBLIC_API_KEY_PRD ||\n        'AIzaSyD-9tSrQWn73S0qm6BqEH5-12Hq8L0eTsQ',\n    authIframeUrl: isDev\n      ? process.env.AUTH_IFRAME_URL_DEV || 'https://auth2.dev.arena.im'\n      : process.env.AUTH_IFRAME_URL_PRD || 'https://auth2.arena.im',\n    environment,\n    debug: environment === 'development',\n  };\n};\n\nexport {\n  setRuntimeEnvironment,\n  getRuntimeEnvironment,\n} from './runtime-environment';\n","import { createContext, useContext, ReactNode, useEffect } from 'react';\nimport { getConfig, Environment, Config } from '../config';\nimport { setRuntimeEnvironment } from '../config/runtime-environment';\n\ninterface ConfigContextType {\n  config: Config;\n  environment: Environment;\n}\n\nconst ConfigContext = createContext<ConfigContextType | undefined>(undefined);\n\ninterface ConfigProviderProps {\n  children: ReactNode;\n  environment?: Environment;\n}\n\nexport const ConfigProvider = ({\n  children,\n  environment = 'development',\n}: ConfigProviderProps) => {\n  const config = getConfig(environment);\n\n  useEffect(() => {\n    setRuntimeEnvironment(environment);\n  }, [environment]);\n\n  return (\n    <ConfigContext.Provider value={{ config, environment }}>\n      {children}\n    </ConfigContext.Provider>\n  );\n};\n\nexport const useConfig = () => {\n  const context = useContext(ConfigContext);\n  if (!context) {\n    throw new Error('useConfig must be used within a ConfigProvider');\n  }\n  return context;\n};\n","const defaultHeaders = {\n  'Content-Type': 'application/json',\n};\n\nexport async function request(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n) {\n  const response = await fetch(url, {\n    ...options,\n    method,\n    headers: {\n      'Content-Type': 'application/json',\n      ...options.headers,\n    },\n  });\n\n  if (!response.ok) {\n    throw new Error(`Error: ${response.statusText}`);\n  }\n\n  return response.json();\n}\n\nexport async function securedRequest(params: {\n  method: string;\n  url: string;\n  options: RequestInit;\n  token: string;\n}) {\n  const { method, url, options = {}, token } = params;\n  if (!token) {\n    throw new Error('No authentication token found');\n  }\n\n  const headers = {\n    ...defaultHeaders,\n    ...options.headers,\n    Authorization: `Bearer ${token}`,\n  };\n\n  const payload = {\n    ...options,\n    method,\n    headers,\n  };\n\n  const response = await fetch(url, payload);\n\n  if (!response.ok) {\n    const text = await response.text();\n    if (!text) {\n      throw new Error(`Error to process request - ${response.status}`);\n    }\n\n    const { errors } = JSON.parse(text) || {};\n    const errorMessage = errors?.[0] || 'Internal server error';\n    throw new Error(errorMessage);\n  }\n\n  const contentType = response.headers.get('content-type');\n  if (!contentType || !contentType.includes('application/json')) {\n    return response;\n  }\n\n  const text = await response.text();\n  if (!text) {\n    return null;\n  }\n\n  try {\n    return JSON.parse(text);\n  } catch (error) {\n    console.error(error);\n    throw new Error('Invalid JSON response from server');\n  }\n}\n","export enum TokenType {\n  ANONYMOUS = 'anonymous',\n  GUEST = 'guest',\n  PUBLIC = 'public',\n  CUSTOM = 'custom',\n}\n\nexport interface TokenPair {\n  idToken: string | null;\n  refreshToken?: string | null;\n}\n\nexport type TokensMap = Record<TokenType, TokenPair>;\n\nexport enum AuthCookie {\n  PUBLIC_ID_TOKEN = 'arena-auth-public-id-token',\n  PUBLIC_REFRESH_TOKEN = 'arena-auth-public-refresh-token',\n  ANONYMOUS_ID_TOKEN = 'arena-auth-anonymous-id-token',\n  GUEST_ID_TOKEN = 'arena-auth-guest-id-token',\n  CUSTOM_ID_TOKEN = 'arena-auth-custom-id-token',\n  CUSTOM_USER = 'arena-auth-custom-user',\n}\n","import { TokenType } from '../types/token';\n\nexport const TOKEN_UPDATED_EVENT = 'arena-auth-token-updated';\n\ninterface TokenEventParams {\n  idToken: string | null;\n  refreshToken?: string | null;\n  source?: string;\n}\n\nexport function dispatchTokenUpdatedEvent(\n  type: TokenType,\n  params: TokenEventParams\n) {\n  document.dispatchEvent(\n    new CustomEvent(TOKEN_UPDATED_EVENT, {\n      detail: { ...params, type },\n    })\n  );\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport { AuthCookie, TokensMap, TokenType } from '../types/token';\nimport { dispatchTokenUpdatedEvent } from '../utils/dom-events';\n\ninterface TokenStore {\n  tokens: TokensMap;\n  getToken: (type: TokenType) => string | null;\n  getMostPrivilegedToken: (\n    options?: Array<TokenType>\n  ) => { type: TokenType; idToken: string } | null;\n  getRefreshToken: (type: TokenType) => string | null;\n  updatePublicTokens: (\n    idToken: string,\n    refreshToken: string,\n    source?: string\n  ) => void;\n  updateAnonymousToken: (idToken: string, source?: string) => void;\n  updateGuestTokens: (idToken: string, source?: string) => void;\n  updateCustomToken: (idToken: string, source?: string) => void;\n  clearTokens: (source?: string) => void;\n  clearPublicTokens: (source?: string) => void;\n  clearAnonymousTokens: (source?: string) => void;\n  clearGuestTokens: (source?: string) => void;\n  clearCustomTokens: (source?: string) => void;\n  silentUpdatePublicTokens: (idToken: string, refreshToken: string) => void;\n  silentUpdateAnonymousToken: (idToken: string) => void;\n  silentUpdateGuestTokens: (idToken: string) => void;\n  silentUpdateCustomToken: (idToken: string) => void;\n  silentClearPublicTokens: () => void;\n  silentClearAnonymousTokens: () => void;\n  silentClearGuestTokens: () => void;\n  silentClearCustomTokens: () => void;\n}\n\nconst defaultTokens: TokensMap = {\n  public: {\n    idToken: Cookies.get(AuthCookie.PUBLIC_ID_TOKEN) || null,\n    refreshToken: Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN) || null,\n  },\n  anonymous: {\n    idToken: Cookies.get(AuthCookie.ANONYMOUS_ID_TOKEN) || null,\n  },\n  guest: {\n    idToken: Cookies.get(AuthCookie.GUEST_ID_TOKEN) || null,\n  },\n  custom: {\n    idToken: Cookies.get(AuthCookie.CUSTOM_ID_TOKEN) || null,\n  },\n};\n\nexport const useTokenStore = create<TokenStore>()(\n  subscribeWithSelector((set, get) => {\n    const updatePublicTokensHelper = (\n      idToken: string,\n      refreshToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (\n        idToken === get().tokens.public.idToken &&\n        refreshToken === get().tokens.public.refreshToken\n      ) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: {\n            idToken,\n            refreshToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.PUBLIC_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      Cookies.set(AuthCookie.PUBLIC_REFRESH_TOKEN, refreshToken, {\n        expires: 30,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, {\n          idToken,\n          refreshToken,\n          source,\n        });\n      }\n    };\n\n    const updateAnonymousTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.anonymous.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.ANONYMOUS_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, { idToken, source });\n      }\n    };\n\n    const updateGuestTokensHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.guest.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: {\n            idToken,\n          },\n        },\n      }));\n\n      Cookies.set(AuthCookie.GUEST_ID_TOKEN, idToken, {\n        expires: 1 / 24,\n      });\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken, source });\n      }\n    };\n\n    const updateCustomTokenHelper = (\n      idToken: string,\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      if (idToken === get().tokens.custom.idToken) {\n        return;\n      }\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken },\n        },\n      }));\n\n      Cookies.set(AuthCookie.CUSTOM_ID_TOKEN, idToken);\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken, source });\n      }\n    };\n\n    const clearPublicTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.PUBLIC_ID_TOKEN);\n      Cookies.remove(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          public: { idToken: null, refreshToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.PUBLIC, { idToken: null, source });\n      }\n    };\n\n    const clearAnonymousTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.ANONYMOUS_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          anonymous: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.ANONYMOUS, {\n          idToken: null,\n          source,\n        });\n      }\n    };\n\n    const clearGuestTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.GUEST_ID_TOKEN);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          guest: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.GUEST, { idToken: null, source });\n      }\n    };\n\n    const clearCustomTokensHelper = (\n      dispatchEvent: boolean = true,\n      source?: string\n    ) => {\n      Cookies.remove(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_ID_TOKEN);\n      localStorage.removeItem(AuthCookie.CUSTOM_USER);\n\n      set(state => ({\n        tokens: {\n          ...state.tokens,\n          custom: { idToken: null },\n        },\n      }));\n\n      if (dispatchEvent) {\n        dispatchTokenUpdatedEvent(TokenType.CUSTOM, { idToken: null, source });\n      }\n    };\n\n    return {\n      tokens: defaultTokens,\n\n      getToken: (type: TokenType) => {\n        return get().tokens[type]?.idToken || null;\n      },\n\n      getMostPrivilegedToken: (\n        options = [TokenType.PUBLIC, TokenType.GUEST, TokenType.ANONYMOUS]\n      ) => {\n        if (get().tokens.custom.idToken && options.includes(TokenType.CUSTOM)) {\n          return {\n            type: TokenType.CUSTOM,\n            idToken: get().tokens.custom.idToken!,\n          };\n        }\n        if (get().tokens.public.idToken && options.includes(TokenType.PUBLIC)) {\n          return {\n            type: TokenType.PUBLIC,\n            idToken: get().tokens.public.idToken!,\n          };\n        }\n        if (get().tokens.guest.idToken && options.includes(TokenType.GUEST)) {\n          return {\n            type: TokenType.GUEST,\n            idToken: get().tokens.guest.idToken!,\n          };\n        }\n        if (\n          get().tokens.anonymous.idToken &&\n          options.includes(TokenType.ANONYMOUS)\n        ) {\n          return {\n            type: TokenType.ANONYMOUS,\n            idToken: get().tokens.anonymous.idToken!,\n          };\n        }\n        return null;\n      },\n\n      getRefreshToken: (type: TokenType) => {\n        return get().tokens[type]?.refreshToken || null;\n      },\n\n      updatePublicTokens: (\n        idToken: string,\n        refreshToken: string,\n        source?: string\n      ) => {\n        updatePublicTokensHelper(idToken, refreshToken, true, source);\n      },\n\n      updateAnonymousToken: (idToken: string, source?: string) => {\n        updateAnonymousTokenHelper(idToken, true, source);\n      },\n\n      updateGuestTokens: (idToken: string, source?: string) => {\n        updateGuestTokensHelper(idToken, true, source);\n      },\n\n      updateCustomToken: (idToken: string, source?: string) => {\n        updateCustomTokenHelper(idToken, true, source);\n      },\n\n      clearTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n        clearAnonymousTokensHelper(true, source);\n        clearGuestTokensHelper(true, source);\n        clearCustomTokensHelper(true, source);\n      },\n\n      clearPublicTokens: (source?: string) => {\n        clearPublicTokensHelper(true, source);\n      },\n\n      clearAnonymousTokens: (source?: string) => {\n        clearAnonymousTokensHelper(true, source);\n      },\n\n      clearGuestTokens: (source?: string) => {\n        clearGuestTokensHelper(true, source);\n      },\n\n      clearCustomTokens: (source?: string) => {\n        clearCustomTokensHelper(true, source);\n      },\n\n      silentUpdatePublicTokens: (idToken: string, refreshToken: string) => {\n        updatePublicTokensHelper(idToken, refreshToken, false);\n      },\n\n      silentUpdateAnonymousToken: (idToken: string) => {\n        updateAnonymousTokenHelper(idToken, false);\n      },\n\n      silentUpdateGuestTokens: (idToken: string) => {\n        updateGuestTokensHelper(idToken, false);\n      },\n\n      silentUpdateCustomToken: (idToken: string) => {\n        updateCustomTokenHelper(idToken, false);\n      },\n\n      silentClearPublicTokens: () => {\n        clearPublicTokensHelper(false);\n      },\n\n      silentClearAnonymousTokens: () => {\n        clearAnonymousTokensHelper(false);\n      },\n\n      silentClearGuestTokens: () => {\n        clearGuestTokensHelper(false);\n      },\n\n      silentClearCustomTokens: () => {\n        clearCustomTokensHelper(false);\n      },\n    };\n  })\n);\n","import { useEffect, useRef } from 'react';\nimport { TokenType } from '../types/token';\nimport { useTokenStore } from '../stores/token-store';\nimport { TOKEN_UPDATED_EVENT } from '../utils/dom-events';\n\ninterface TokenUpdateEvent {\n  detail: {\n    idToken: string | null;\n    refreshToken?: string | null;\n    type: TokenType;\n    source?: string;\n  };\n}\n\nexport function useTokenEventListener() {\n  const updatePublicTokens = useTokenStore(\n    state => state.silentUpdatePublicTokens\n  );\n  const updateAnonymousToken = useTokenStore(\n    state => state.silentUpdateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(\n    state => state.silentUpdateGuestTokens\n  );\n  const updateCustomToken = useTokenStore(\n    state => state.silentUpdateCustomToken\n  );\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(\n    state => state.silentClearPublicTokens\n  );\n  const clearAnonymousTokens = useTokenStore(\n    state => state.silentClearAnonymousTokens\n  );\n  const clearGuestTokens = useTokenStore(state => state.silentClearGuestTokens);\n  const clearCustomTokens = useTokenStore(\n    state => state.silentClearCustomTokens\n  );\n\n  const eventSourceRef = useRef<string>(\n    `widget-${Math.random().toString(36).substr(2, 9)}`\n  );\n\n  useEffect(() => {\n    const handleTokenUpdate = (\n      event: CustomEvent<TokenUpdateEvent['detail']>\n    ) => {\n      const { idToken, refreshToken, type, source } = event.detail;\n\n      if (source === eventSourceRef.current) {\n        return;\n      }\n\n      switch (type) {\n        case TokenType.PUBLIC:\n          if (idToken) {\n            if (!refreshToken) {\n              throw new Error('Refresh token is required for public tokens');\n            }\n            updatePublicTokens(idToken, refreshToken);\n          } else {\n            clearPublicTokens();\n          }\n          break;\n\n        case TokenType.ANONYMOUS:\n          if (idToken) {\n            updateAnonymousToken(idToken);\n          } else {\n            clearAnonymousTokens();\n          }\n          break;\n\n        case TokenType.GUEST:\n          if (idToken) {\n            updateGuestTokens(idToken);\n          } else {\n            clearGuestTokens();\n          }\n          break;\n\n        case TokenType.CUSTOM:\n          if (idToken) {\n            updateCustomToken(idToken);\n          } else {\n            clearCustomTokens();\n          }\n          break;\n      }\n    };\n\n    document.addEventListener(\n      TOKEN_UPDATED_EVENT,\n      handleTokenUpdate as EventListener\n    );\n\n    return () => {\n      document.removeEventListener(\n        TOKEN_UPDATED_EVENT,\n        handleTokenUpdate as EventListener\n      );\n    };\n  }, [\n    updatePublicTokens,\n    updateAnonymousToken,\n    updateGuestTokens,\n    updateCustomToken,\n    clearTokens,\n    clearPublicTokens,\n    clearAnonymousTokens,\n    clearGuestTokens,\n    clearCustomTokens,\n  ]);\n\n  return {\n    eventSource: eventSourceRef.current,\n  };\n}\n","import { useTokenStore } from '../stores/token-store';\nimport { useTokenEventListener } from './use-token-event-listener';\n\nexport function useTokens() {\n  const getToken = useTokenStore(state => state.getToken);\n  const getMostPrivilegedToken = useTokenStore(\n    state => state.getMostPrivilegedToken\n  );\n  const getRefreshToken = useTokenStore(state => state.getRefreshToken);\n  const updatePublicTokens = useTokenStore(state => state.updatePublicTokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const updateGuestTokens = useTokenStore(state => state.updateGuestTokens);\n  const updateCustomToken = useTokenStore(state => state.updateCustomToken);\n  const clearTokens = useTokenStore(state => state.clearTokens);\n  const clearPublicTokens = useTokenStore(state => state.clearPublicTokens);\n  const clearCustomTokens = useTokenStore(state => state.clearCustomTokens);\n\n  const { eventSource } = useTokenEventListener();\n\n  return {\n    getToken,\n    getMostPrivilegedToken,\n    getRefreshToken,\n    updatePublicTokens: (idToken: string, refreshToken: string) =>\n      updatePublicTokens(idToken, refreshToken, eventSource),\n    updateAnonymousToken: (idToken: string) =>\n      updateAnonymousToken(idToken, eventSource),\n    updateGuestTokens: (idToken: string) =>\n      updateGuestTokens(idToken, eventSource),\n    updateCustomToken: (idToken: string) =>\n      updateCustomToken(idToken, eventSource),\n    clearTokens: () => clearTokens(eventSource),\n    clearPublicTokens: () => clearPublicTokens(eventSource),\n    clearCustomTokens: () => clearCustomTokens(eventSource),\n  };\n}\n\nexport function useToken(type: 'anonymous' | 'guest' | 'public' | 'custom') {\n  return useTokenStore(state => state.tokens[type]);\n}\n\nexport function useTokenValue(\n  type: 'anonymous' | 'guest' | 'public' | 'custom'\n) {\n  return useTokenStore(state => state.tokens[type]?.idToken);\n}\n\nexport function useRefreshToken(type: 'anonymous' | 'guest' | 'public') {\n  return useTokenStore(state => state.tokens[type]?.refreshToken);\n}\n","type Nullable<T> = T | null;\n\nexport enum AnalyticsWidgetType {\n  AvatarProfile = 'avatar-profile',\n  AvatarChat = 'avatar-chat',\n  Comments = 'comments',\n  GlobalProfile = 'global-profile',\n  GroupChat = 'group-chat',\n  Polls = 'polls',\n  UniversalSnippet = 'universal-snippet',\n}\n\nexport type TrackOptions = {\n  widgetId: string | null;\n  widgetType: AnalyticsWidgetType;\n  siteId: string;\n  rsWriteKey: string;\n  rsDataPlaneUrl: string;\n  trigger: string;\n};\n\nexport enum AnalyticsEvent {\n  AuthenticationCompleted = 'Authentication Completed',\n  AuthenticationStarted = 'Authentication Started',\n  AuthenticationViewed = 'Authentication Viewed',\n}\n\nexport type TrackProps = Nullable<Record<string, unknown>>;\n\nexport interface IdentityProps {\n  anonymousId?: string;\n  userId?: string;\n}\n\nexport interface RudderContext {\n  channel: 'web';\n  anonymousId?: string;\n  locale?: string;\n  userAgent?: string;\n  timezone?: string;\n  os?: { name: string; version?: string };\n  page?: {\n    path?: string;\n    referrer?: string;\n    referring_domain?: string;\n    search?: string;\n    title?: string;\n    url?: string;\n    initial_referrer?: string;\n    initial_referring_domain?: string;\n  };\n  screen?: {\n    density?: number;\n    height?: number;\n    width?: number;\n    innerHeight?: number;\n    innerWidth?: number;\n  };\n  campaign?: Record<string, string>;\n}\n","import { PublicProfile } from './types';\nimport { request, securedRequest } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\nimport { useToken } from '../../hooks/use-tokens';\nimport { TokenType } from '../../types';\nimport { useUserActions } from '../../hooks/use-user';\n\nexport function useProfileServices() {\n  const token = useToken(TokenType.PUBLIC);\n  const { refreshPublicTokens } = useUserActions();\n  const { config } = useConfig();\n  const profileUrl = config.profileServiceUrl;\n\n  async function getPublicProfile(userId?: string): Promise<PublicProfile> {\n    const fields = 'bio,photoURL,displayName,location,handle';\n    const url = `${profileUrl}/public/users/${userId}/profile?fields=${fields}`;\n    return await request('GET', url);\n  }\n\n  async function updatePublicProfile(\n    params: Omit<PublicProfile, 'metadata'>\n  ): Promise<void> {\n    const url = `${profileUrl}/me/profile/personal`;\n    await securedRequest({\n      method: 'PUT',\n      url,\n      options: {\n        body: JSON.stringify(params),\n      },\n      token: token.idToken!,\n    });\n    refreshPublicTokens({ refreshTokenApiKey: config.refreshTokenApiKey });\n  }\n  return {\n    getPublicProfile,\n    updatePublicProfile,\n  };\n}\n","import { create } from 'zustand';\nimport { subscribeWithSelector } from 'zustand/middleware';\nimport Cookies from 'js-cookie';\nimport {\n  UserProps,\n  FirebaseUser,\n  SsoUserProps,\n  SsoV2ExchangeResponse,\n} from '../services/auth/types';\nimport { jwtDecode } from 'jwt-decode';\nimport { type PublicProfile } from '../services/profile/types';\nimport { useTokenStore } from './token-store';\nimport { AuthCookie } from '../types/token';\nimport { request } from '../utils/request';\nimport { Environment, getConfig } from '../config';\n\ninterface UserStore {\n  user: UserProps | null;\n  publicProfile: PublicProfile | null;\n  refreshedTokenLoaded: boolean;\n  setUser: (user: UserProps | null) => void;\n  setPublicProfile: (publicProfile: PublicProfile | null) => void;\n  logout: () => void;\n  refreshPublicTokens: (config: {\n    refreshTokenApiKey: string;\n  }) => Promise<void>;\n  setUserByTokenId: (idToken: string) => void;\n  loadStoredUser: (config?: { refreshTokenApiKey: string }) => Promise<void>;\n  ssoV2Exchange: (\n    ssoSourceID: string,\n    jwt: string,\n    env?: Environment\n  ) => Promise<SsoV2ExchangeResponse>;\n}\n\nexport const useUserStore = create<UserStore>()(\n  subscribeWithSelector((set, get) => ({\n    user: null,\n    publicProfile: null,\n    refreshedTokenLoaded: false,\n\n    setUser: (user: UserProps | null) => {\n      set({ user });\n    },\n\n    setPublicProfile: (publicProfile: PublicProfile | null) => {\n      set({ publicProfile });\n    },\n\n    setUserByTokenId: (idToken: string) => {\n      try {\n        const user = jwtDecode<FirebaseUser>(idToken);\n        const userProps: UserProps = {\n          uid: user.user_id,\n          displayName: user.safeDisplayName,\n          email: user.email,\n          photoURL: user.safePhotoURL,\n          handle: user.handle,\n        };\n        set({ user: userProps });\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    logout: () => {\n      try {\n        const tokenStore = useTokenStore.getState();\n        tokenStore.clearPublicTokens();\n        tokenStore.clearCustomTokens();\n        set({ user: null });\n        document.dispatchEvent(new Event('arena-comments-logout'));\n      } catch (error) {\n        console.error(error);\n      }\n    },\n\n    refreshPublicTokens: async (config: { refreshTokenApiKey: string }) => {\n      try {\n        const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n\n        if (!refreshToken) {\n          throw new Error('No refresh token found');\n        }\n\n        const prefix = 'https://securetoken.googleapis.com/v1/token?key=';\n        const apiKey = config.refreshTokenApiKey;\n        const url = `${prefix}${apiKey}`;\n        const response = await fetch(url, {\n          method: 'POST',\n          body: new URLSearchParams({\n            refresh_token: refreshToken,\n            grant_type: 'refresh_token',\n          }),\n        });\n        const data = await response.json();\n\n        const { setUserByTokenId } = get();\n        setUserByTokenId(data.id_token);\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updatePublicTokens(data.id_token, data.refresh_token);\n      } catch (error) {\n        console.error(error);\n        const { logout } = get();\n        logout();\n      }\n    },\n\n    loadStoredUser: async (config?: { refreshTokenApiKey: string }) => {\n      const publicIdToken = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n      const publicRefreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n      const customIdToken = localStorage.getItem(AuthCookie.CUSTOM_ID_TOKEN);\n      const customUser = localStorage.getItem(AuthCookie.CUSTOM_USER);\n\n      if (!!customIdToken && !!customUser) {\n        const parsedUser = JSON.parse(customUser);\n\n        set({ user: parsedUser });\n\n        const tokenStore = useTokenStore.getState();\n        tokenStore.updateCustomToken(customIdToken);\n      } else {\n        if (publicIdToken) {\n          const { setUserByTokenId } = get();\n          setUserByTokenId(publicIdToken);\n        } else if (publicRefreshToken && config) {\n          const { refreshPublicTokens } = get();\n          await refreshPublicTokens(config);\n        }\n      }\n\n      set({ refreshedTokenLoaded: true });\n    },\n\n    ssoV2Exchange: async (\n      ssoSourceID: string,\n      jwt: string,\n      env?: Environment\n    ) => {\n      try {\n        const config = getConfig(env ?? 'production');\n        const profileUrl = config.profileServiceUrl;\n\n        const url = `${profileUrl}/sso/sources/${ssoSourceID}/user`;\n        const response: SsoV2ExchangeResponse = await request('POST', url, {\n          body: JSON.stringify({ signedUserData: jwt }),\n        });\n\n        if (response) {\n          const decodedUser = jwtDecode<SsoUserProps>(response.token);\n\n          const { setUser, setPublicProfile } = get();\n\n          setUser({\n            uid: decodedUser?.sub,\n            email: decodedUser?.email,\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          setPublicProfile({\n            displayName: decodedUser?.displayName,\n            photoURL: decodedUser?.photoURL,\n            handle: decodedUser?.handle,\n          });\n\n          const tokenStore = useTokenStore.getState();\n          tokenStore.updateCustomToken(response.token);\n        }\n\n        return response;\n      } catch (error) {\n        console.error('SSO V2 Exchange failed:', error);\n        throw error;\n      }\n    },\n  }))\n);\n","import { useProfileServices } from '../services/profile/use-profile-services';\nimport { useUserStore } from '../stores/user-store';\n\nexport function useUser() {\n  return useUserStore(state => state.user);\n}\n\nexport function usePublicProfile() {\n  return useUserStore(state => state.publicProfile);\n}\n\nexport function useRefreshedTokenLoaded() {\n  return useUserStore(state => state.refreshedTokenLoaded);\n}\n\nexport function useUserActions() {\n  const setUser = useUserStore(state => state.setUser);\n  const setPublicProfile = useUserStore(state => state.setPublicProfile);\n  const logout = useUserStore(state => state.logout);\n  const refreshPublicTokens = useUserStore(state => state.refreshPublicTokens);\n  const setUserByTokenId = useUserStore(state => state.setUserByTokenId);\n  const loadStoredUser = useUserStore(state => state.loadStoredUser);\n  const ssoV2Exchange = useUserStore(state => state.ssoV2Exchange);\n  \n\n  return {\n    setUser,\n    setPublicProfile,\n    logout,\n    refreshPublicTokens,\n    setUserByTokenId,\n    loadStoredUser,\n    ssoV2Exchange,\n  };\n}\n\nexport function useUpdateProfile() {\n  const { updatePublicProfile } = useProfileServices();\n  return {\n    updatePublicProfile,\n  };\n}\n\nexport function useUserWithProfile() {\n  const user = useUserStore(state => state.user);\n  const publicProfile = useUserStore(state => state.publicProfile);\n  const refreshedTokenLoaded = useUserStore(\n    state => state.refreshedTokenLoaded\n  );\n\n  return {\n    user,\n    publicProfile,\n    refreshedTokenLoaded,\n  };\n}\n\n","import React, { useCallback, useEffect } from 'react';\nimport { useConfig } from './config-provider';\nimport { useUser, useUserActions } from '../hooks/use-user';\nimport { useMutation } from '@tanstack/react-query';\nimport { useProfileServices } from '../services/profile/use-profile-services';\n\nexport function UserProvider({ children }: { children: React.ReactNode }) {\n  const { config } = useConfig();\n  const user = useUser();\n  const { setPublicProfile, loadStoredUser } = useUserActions();\n  const { getPublicProfile: getPublicProfileService } = useProfileServices();\n  const { mutateAsync: getPublicProfile } = useMutation({\n    mutationFn: getPublicProfileService,\n  });\n\n  const loadPublicProfile = useCallback(async () => {\n    if (user?.uid) {\n      const profile = await getPublicProfile(user.uid);\n      setPublicProfile(profile);\n    }\n  }, [user?.uid, getPublicProfile, setPublicProfile]);\n\n  useEffect(() => {\n    loadPublicProfile();\n  }, [loadPublicProfile]);\n\n  useEffect(() => {\n    loadStoredUser(config);\n  }, [config, loadStoredUser]);\n\n  return children;\n}\n","import type {\n  AnalyticsWidgetType,\n  AnalyticsEvent,\n  IdentityProps,\n  RudderContext,\n  TrackProps,\n} from '../types/analytics';\n\nimport { removeParamsFromUrl } from '../utils/url';\n\nconst ANONYMOUS_ID_KEY = 'arenaAnonymousId';\n\nconst LS_KEYS = {\n  anon: 'rs_anonymous_id',\n  initReferrer: 'rs_initial_referrer',\n  initDomain: 'rs_initial_referring_domain',\n} as const;\n\nfunction generateUUID(): string {\n  if (typeof crypto !== 'undefined' && crypto.randomUUID) {\n    return crypto.randomUUID();\n  }\n\n  return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) {\n    const r = (Math.random() * 16) | 0;\n    const v = c === 'x' ? r : (r & 0x3) | 0x8;\n    return v.toString(16);\n  });\n}\n\nfunction getOrSetAnonymousId(): string {\n  const existing = localStorage.getItem(LS_KEYS.anon);\n  if (existing) return existing;\n  const id = crypto.randomUUID();\n  localStorage.setItem(LS_KEYS.anon, id);\n  return id;\n}\n\nfunction rememberInitialReferrer(): void {\n  if (!localStorage.getItem(LS_KEYS.initReferrer)) {\n    const ref = document.referrer || '$direct';\n    const domain = ref && ref !== '$direct' ? new URL(ref).hostname : '';\n    localStorage.setItem(LS_KEYS.initReferrer, ref);\n    localStorage.setItem(LS_KEYS.initDomain, domain);\n  }\n}\n\nfunction parseCampaign(u: URL): Record<string, string> | undefined {\n  const keys = [\n    'utm_source',\n    'utm_medium',\n    'utm_campaign',\n    'utm_term',\n    'utm_content',\n  ];\n  const out: Record<string, string> = {};\n  keys.forEach(k => {\n    const v = u.searchParams.get(k);\n    if (v) out[k] = v;\n  });\n  return Object.keys(out).length ? out : undefined;\n}\n\nexport function buildRudderContext(): RudderContext {\n  const w = window;\n  const d = document;\n  const s = window.screen;\n  const url = new URL(w.location.href);\n\n  rememberInitialReferrer();\n\n  const initial_referrer =\n    localStorage.getItem(LS_KEYS.initReferrer) || '$direct';\n  const initial_referring_domain =\n    localStorage.getItem(LS_KEYS.initDomain) || '';\n\n  return {\n    channel: 'web',\n    anonymousId: getOrSetAnonymousId(),\n    locale: navigator.language,\n    userAgent: navigator.userAgent,\n    timezone: Intl.DateTimeFormat().resolvedOptions().timeZone,\n    os: { name: navigator.platform, version: undefined },\n    page: {\n      path: url.pathname,\n      referrer: d.referrer || '$direct',\n      referring_domain: d.referrer ? new URL(d.referrer).hostname : '',\n      search: url.search,\n      title: d.title,\n      url: url.toString(),\n      initial_referrer,\n      initial_referring_domain,\n    },\n    screen: {\n      density: (w.devicePixelRatio || 1) ?? 1,\n      height: s.height,\n      width: s.width,\n      innerHeight: w.innerHeight,\n      innerWidth: w.innerWidth,\n    },\n    campaign: parseCampaign(url),\n  };\n}\n\nfunction getIdentifier(options: IdentityProps = {}): IdentityProps {\n  const identifier: IdentityProps = {};\n\n  if (options.userId) {\n    identifier.userId = options.userId;\n  }\n\n  let currentAnonymousId: string | null = null;\n\n  try {\n    currentAnonymousId = localStorage.getItem(ANONYMOUS_ID_KEY);\n  } catch (error) {\n    console.warn('Failed to access localStorage:', error);\n  }\n\n  if (options.anonymousId) {\n    identifier.anonymousId = options.anonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, options.anonymousId);\n    } catch (error) {\n      console.warn('Failed to save anonymousId to localStorage:', error);\n    }\n  } else if (currentAnonymousId) {\n    identifier.anonymousId = currentAnonymousId;\n  } else {\n    const newAnonymousId = generateUUID();\n    identifier.anonymousId = newAnonymousId;\n    try {\n      localStorage.setItem(ANONYMOUS_ID_KEY, newAnonymousId);\n    } catch (error) {\n      console.warn('Failed to save new anonymousId to localStorage:', error);\n    }\n  }\n\n  return identifier;\n}\n\nfunction getCanonicalUrl(): string {\n  const canonicalMeta = document.querySelector(\n    'link[rel=\"canonical\"]'\n  ) as HTMLLinkElement;\n  const rawUrl = canonicalMeta?.href || window.location.href;\n  return removeParamsFromUrl(rawUrl);\n}\n\nfunction getEventProperties(\n  widgetType: string,\n  properties: TrackProps,\n  identity?: IdentityProps\n) {\n  return {\n    properties: {\n      widget_type: widgetType,\n      url: window.location.href,\n      domain: window.location.hostname,\n      title: window.document.title,\n      canonical_url: getCanonicalUrl(),\n      snippet_id: window.__ARENA__?.snippetId || null,\n      ...properties,\n    },\n    context: buildRudderContext(),\n    timestamp: new Date().toISOString(),\n    integrations: { All: true },\n    ...getIdentifier(identity),\n  };\n}\n\nfunction getEventHeaders(writeKey: string) {\n  return {\n    'Content-Type': 'application/json',\n    Authorization: 'Basic ' + btoa(`${writeKey}:`),\n  };\n}\n\nexport function getAnalytics(writeKey: string, dataPlaneUrl: string) {\n  return {\n    page: async (\n      widgetType: AnalyticsWidgetType,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/page`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          type: 'page',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send page event to Rudderstack');\n      }\n    },\n    track: async (\n      widgetType: AnalyticsWidgetType,\n      event: AnalyticsEvent,\n      properties: TrackProps,\n      identity?: IdentityProps\n    ) => {\n      const response = await fetch(`${dataPlaneUrl}/v1/track`, {\n        method: 'POST',\n        headers: getEventHeaders(writeKey),\n        body: JSON.stringify({\n          event,\n          type: 'track',\n          ...getEventProperties(widgetType, properties, identity),\n        }),\n      });\n\n      if (response.ok) {\n        const data = await response.text();\n        return data;\n      } else {\n        throw new Error('Failed to send track event to Rudderstack');\n      }\n    },\n  };\n}\n","export function removeParamsFromUrl(url: string): string {\n  try {\n    const urlObj = new URL(url);\n\n    urlObj.search = '';\n\n    return urlObj.href;\n  } catch (error) {\n    console.error('Error clearing search params from URL:', error);\n    return url;\n  }\n}\n","import { useCallback } from 'react';\nimport { getAnalytics } from '../utils/analytics';\nimport { AnalyticsEvent, TrackOptions } from '../types/analytics';\n\nexport function useTrack(trackOptions?: TrackOptions) {\n  const track = useCallback(\n    (\n      event: AnalyticsEvent,\n      userId?: string,\n      properties?: Record<string, string | null>\n    ) => {\n      if (!trackOptions) return;\n\n      const analytics = getAnalytics(\n        trackOptions.rsWriteKey,\n        trackOptions.rsDataPlaneUrl\n      );\n\n      const trackProperties: Record<string, string | null> = {\n        site_id: trackOptions.siteId,\n        widget_id: trackOptions.widgetId,\n        trigger: trackOptions.trigger,\n        ...properties,\n      };\n\n      analytics.track(\n        trackOptions.widgetType,\n        event,\n        trackProperties,\n        userId ? { userId } : undefined\n      );\n    },\n    [trackOptions]\n  );\n\n  return track;\n}\n","import { useAuthDialog } from '../context/auth-dialog-provider';\nimport { useEffect } from 'react';\nimport { useUserActions } from '../hooks/use-user';\nimport { useConfig } from '../context/config-provider';\nimport { useTokens } from '../hooks/use-tokens';\nimport { AnalyticsEvent } from '../types/analytics';\nimport { useTrack } from '../hooks/use-track';\n\nexport default function AuthDialog() {\n  const {\n    appName,\n    appDescription,\n    language,\n    trackOptions,\n    isOpen,\n    closeDialog,\n    onAuthCompleted,\n  } = useAuthDialog();\n  const frameAppName = appName || 'Arena AI Chat';\n  const frameAppDescription = appDescription || 'Arena AI Chat';\n  const { setUser } = useUserActions();\n  const { updatePublicTokens } = useTokens();\n  const { config } = useConfig();\n\n  const track = useTrack(trackOptions);\n\n  const iframeUrl = `${config.authIframeUrl}/?app-name=${frameAppName}&app-description=${frameAppDescription}&language=${language ?? 'en'}`;\n\n  useEffect(() => {\n    const handler = (message: MessageEvent) => {\n      if (message.data?.source !== 'arena-authentication') return;\n\n      if (message.data?.type === 'canceled') {\n        closeDialog();\n        return;\n      }\n\n      if (message.data?.type === 'authentication-viewed') {\n        track(AnalyticsEvent.AuthenticationViewed);\n        return;\n      }\n\n      if (message.data?.type === 'authentication-started') {\n        const { authType } = message.data?.payload || {};\n        track(AnalyticsEvent.AuthenticationStarted, undefined, {\n          authType: authType,\n        });\n        return;\n      }\n\n      if (message.data?.type === 'authentication-completed') {\n        const { idToken, refreshToken, user, authType, isSignup } =\n          message.data?.payload || {};\n\n        if (!user) {\n          console.error('Authentication completed but user data is missing');\n          return;\n        }\n\n        track(AnalyticsEvent.AuthenticationCompleted, user.uid, {\n          is_signup: isSignup,\n          auth_type: authType,\n        });\n        onAuthCompleted?.(user);\n        updatePublicTokens(idToken, refreshToken);\n        setUser(user);\n        closeDialog();\n        return;\n      }\n    };\n\n    window.addEventListener('message', handler);\n\n    return () => window.removeEventListener('message', handler);\n  }, [setUser, updatePublicTokens, onAuthCompleted, track, closeDialog]);\n\n  return isOpen ? (\n    <iframe\n      src={iframeUrl}\n      title=\"Arena Authentication\"\n      style={{\n        position: 'fixed',\n        top: 0,\n        left: 0,\n        width: '100vw',\n        height: '100vh',\n        zIndex: 9999999999,\n      }}\n    ></iframe>\n  ) : null;\n}\n","import { ExchangeTokensResponse } from './types';\nimport { request } from '../../utils/request';\nimport { useConfig } from '../../context/config-provider';\n\nconst RUDDER_ANONYMOUS_ID_STORAGE_KEY = 'arena-analytics:rs-anonymous-id';\n\ntype RudderWindow = Window & {\n  rudderanalytics?: { getAnonymousId?: () => string | null };\n  rudderAnalytics?: { getAnonymousId?: () => string | null };\n};\n\nfunction parseAnonymousId(value?: string | null): string | null {\n  const parsed = value?.trim();\n  if (!parsed || parsed === 'null' || parsed === 'undefined') return null;\n  return parsed;\n}\n\nexport function getRudderAnonymousId(): string | null {\n  if (typeof window === 'undefined') {\n    return null;\n  }\n\n  const rudderWindow = window as RudderWindow;\n  const fromRudderClient = parseAnonymousId(\n    rudderWindow.rudderanalytics?.getAnonymousId?.() ??\n      rudderWindow.rudderAnalytics?.getAnonymousId?.(),\n  );\n  if (fromRudderClient) return fromRudderClient;\n\n  try {\n    return parseAnonymousId(\n      window.localStorage.getItem(RUDDER_ANONYMOUS_ID_STORAGE_KEY),\n    );\n  } catch {\n    return null;\n  }\n}\n\nexport function useAuthServices() {\n  const { config } = useConfig();\n  const identityUrl = config.identityServiceUrl;\n\n  async function getAnonymousIdentityToken(): Promise<ExchangeTokensResponse> {\n    const url = `${identityUrl}/anonymous-token`;\n    const anonymousId = getRudderAnonymousId();\n\n    if (!anonymousId) {\n      return await request('POST', url);\n    }\n\n    return await request('POST', url, {\n      body: JSON.stringify({ anonymousId }),\n    });\n  }\n\n  return {\n    getAnonymousIdentityToken,\n  };\n}\n","import React, { useEffect, useRef } from 'react';\nimport { useConfig } from './config-provider';\nimport { useTokenStore } from '../stores/token-store';\nimport {\n  getRudderAnonymousId,\n  useAuthServices,\n} from '../services/auth/use-auth-services';\nimport { ExchangeTokensResponse } from '../services/auth/types';\n\nexport function AnonymousTokenProvider({\n  children,\n}: {\n  children: React.ReactNode;\n}) {\n  const { config } = useConfig();\n  const tokens = useTokenStore(state => state.tokens);\n  const updateAnonymousToken = useTokenStore(\n    state => state.updateAnonymousToken\n  );\n  const { getAnonymousIdentityToken } = useAuthServices();\n  const hasForcedRefreshInDebugRef = useRef(false);\n\n  useEffect(() => {\n    const rudderAnonymousId = getRudderAnonymousId();\n    const shouldRefreshAnonymousToken =\n      !tokens.anonymous.idToken ||\n      (config.debug &&\n        Boolean(rudderAnonymousId) &&\n        !hasForcedRefreshInDebugRef.current);\n\n    if (!shouldRefreshAnonymousToken) return;\n\n    if (tokens.anonymous.idToken) {\n      hasForcedRefreshInDebugRef.current = true;\n    }\n\n    getAnonymousIdentityToken()\n      .then((token: ExchangeTokensResponse) => {\n        updateAnonymousToken(\n          token.access_token,\n          tokens.anonymous.idToken ? 'force-refresh-debug' : undefined\n        );\n      })\n      .catch(error => {\n        if (tokens.anonymous.idToken) {\n          hasForcedRefreshInDebugRef.current = false;\n        }\n        console.error('[react-sdk-auth] getAnonymousIdentityToken failed', {\n          error,\n        });\n      });\n  }, [\n    config.debug,\n    tokens.anonymous.idToken,\n    updateAnonymousToken,\n    getAnonymousIdentityToken,\n  ]);\n\n  return children;\n}\n","import { AuthDialogProvider } from './auth-dialog-provider';\nimport { QueryClient, QueryClientProvider } from '@tanstack/react-query';\nimport { UserProvider } from './user-provider';\nimport { ConfigProvider } from './config-provider';\nimport AuthDialog from '../dialog';\nimport { AnonymousTokenProvider } from './anonymous-token-provider';\n\nexport function AuthProvider({\n  children,\n  queryClient,\n  environment,\n}: {\n  children: React.ReactNode;\n  queryClient?: QueryClient;\n  environment?: 'production' | 'development';\n}) {\n  queryClient = queryClient || new QueryClient();\n\n  return (\n    <QueryClientProvider client={queryClient}>\n      <ConfigProvider environment={environment}>\n        <UserProvider>\n          <AuthDialogProvider>\n            <AnonymousTokenProvider>\n              {children}\n              <AuthDialog />\n            </AnonymousTokenProvider>\n          </AuthDialogProvider>\n        </UserProvider>\n      </ConfigProvider>\n    </QueryClientProvider>\n  );\n}\n\nexport { useAuthDialog } from './auth-dialog-provider';\n","import Cookies from 'js-cookie';\nimport { AuthCookie } from '../types/token';\nimport { useUserStore } from '../stores';\nimport { getConfig } from '../config';\nimport { getRuntimeEnvironment } from '../config/runtime-environment';\n\nfunction getRefreshTokenApiKey(): string {\n  const environment = getRuntimeEnvironment();\n  return getConfig(environment).refreshTokenApiKey;\n}\n\nconst defaultHeaders = {\n  'Content-Type': 'application/json',\n};\n\nlet refreshPromise: Promise<void> | null = null;\n\nasync function ensureRefreshToken(): Promise<void> {\n  if (refreshPromise) {\n    return refreshPromise;\n  }\n\n  const userStore = useUserStore.getState();\n  refreshPromise = userStore\n    .refreshPublicTokens({\n      refreshTokenApiKey: getRefreshTokenApiKey(),\n    })\n    .finally(() => {\n      refreshPromise = null;\n    });\n\n  return refreshPromise;\n}\n\nasync function authenticatedFetch(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n): Promise<Response> {\n  const token = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n\n  if (!token) {\n    throw new Error('No authentication token found');\n  }\n\n  const headers = {\n    ...defaultHeaders,\n    ...options.headers,\n    Authorization: `Bearer ${token}`,\n  };\n\n  const params = {\n    ...options,\n    method,\n    headers,\n  };\n\n  return fetch(url, params);\n}\n\nasync function parseResponse(response: Response): Promise<unknown> {\n  const contentType = response.headers.get('content-type');\n  if (!contentType || !contentType.includes('application/json')) {\n    return response;\n  }\n\n  const text = await response.text();\n  if (!text) {\n    return null;\n  }\n\n  try {\n    return JSON.parse(text);\n  } catch (error) {\n    console.error({ error });\n    throw new Error('Invalid JSON response from server');\n  }\n}\n\nfunction throwOnErrorResponse(response: Response, text: string): never {\n  let errorMessage: string;\n\n  try {\n    const parsed = JSON.parse(text);\n    errorMessage = parsed?.errors?.[0] || text || 'Internal server error';\n  } catch {\n    errorMessage = text || 'Internal server error';\n  }\n\n  throw new Error(errorMessage);\n}\n\nexport async function authenticatedRequest(\n  method: string,\n  url: string,\n  options: RequestInit = {}\n): Promise<unknown> {\n  async function attempt(): Promise<unknown> {\n    const response = await authenticatedFetch(method, url, options);\n\n    if (response.ok) {\n      return parseResponse(response);\n    }\n\n    const text = await response.text();\n    if (!text) {\n      throw new Error(`Failed to process request - ${response.status}`);\n    }\n\n    if (response.status === 401) {\n      const err = new Error('Unauthorized') as Error & { status?: number };\n      err.status = 401;\n      throw err;\n    }\n\n    throwOnErrorResponse(response, text);\n  }\n\n  const hasToken = Cookies.get(AuthCookie.PUBLIC_ID_TOKEN);\n\n  if (!hasToken) {\n    const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n    if (refreshToken) {\n      await ensureRefreshToken();\n      return await attempt();\n    }\n    throw new Error('No authentication token found');\n  }\n\n  try {\n    return await attempt();\n  } catch (error) {\n    const is401 =\n      error instanceof Error &&\n      'status' in error &&\n      (error as Error & { status?: number }).status === 401;\n\n    if (!is401) {\n      throw error;\n    }\n\n    const refreshToken = Cookies.get(AuthCookie.PUBLIC_REFRESH_TOKEN);\n    if (!refreshToken) {\n      throw new Error('Unauthorized');\n    }\n\n    await ensureRefreshToken();\n\n    try {\n      return await attempt();\n    } catch (retryError) {\n      const retryIs401 =\n        retryError instanceof Error &&\n        'status' in retryError &&\n        (retryError as Error & { status?: number }).status === 401;\n\n      if (retryIs401) {\n        throw new Error('Unauthorized');\n      }\n\n      throw retryError;\n    }\n  }\n}\n"],"names":["AuthDialogContext","createContext","undefined","AuthDialogProvider","children","isOpen","setIsOpen","useState","appName","setAppName","appDescription","setAppDescription","onAuthCompleted","setOnAuthCompleted","trackOptions","setTrackOptions","language","setLanguage","_jsx","Provider","value","openDialog","closeDialog","onOpenChange","open","useAuthDialog","context","useContext","Error","runtimeEnvironment","getConfig","environment","isDev","profileServiceUrl","identityServiceUrl","refreshTokenApiKey","authIframeUrl","debug","ConfigContext","ConfigProvider","config","useEffect","setRuntimeEnvironment","useConfig","defaultHeaders","async","request","method","url","options","response","fetch","headers","ok","statusText","json","TokenType","AuthCookie","TOKEN_UPDATED_EVENT","dispatchTokenUpdatedEvent","type","params","document","dispatchEvent","CustomEvent","detail","defaultTokens","public","idToken","Cookies","get","PUBLIC_ID_TOKEN","refreshToken","PUBLIC_REFRESH_TOKEN","anonymous","ANONYMOUS_ID_TOKEN","guest","GUEST_ID_TOKEN","custom","CUSTOM_ID_TOKEN","useTokenStore","create","subscribeWithSelector","set","updatePublicTokensHelper","source","tokens","state","expires","PUBLIC","updateAnonymousTokenHelper","ANONYMOUS","updateGuestTokensHelper","GUEST","updateCustomTokenHelper","CUSTOM","clearPublicTokensHelper","remove","clearAnonymousTokensHelper","clearGuestTokensHelper","clearCustomTokensHelper","localStorage","removeItem","CUSTOM_USER","getToken","getMostPrivilegedToken","includes","getRefreshToken","updatePublicTokens","updateAnonymousToken","updateGuestTokens","updateCustomToken","clearTokens","clearPublicTokens","clearAnonymousTokens","clearGuestTokens","clearCustomTokens","silentUpdatePublicTokens","silentUpdateAnonymousToken","silentUpdateGuestTokens","silentUpdateCustomToken","silentClearPublicTokens","silentClearAnonymousTokens","silentClearGuestTokens","silentClearCustomTokens","useTokenEventListener","eventSourceRef","useRef","Math","random","toString","substr","handleTokenUpdate","event","current","addEventListener","removeEventListener","eventSource","useTokens","useToken","useTokenValue","useRefreshToken","AnalyticsWidgetType","AnalyticsEvent","useProfileServices","token","refreshPublicTokens","useUserActions","profileUrl","getPublicProfile","userId","updatePublicProfile","Authorization","payload","text","status","errors","JSON","parse","contentType","error","console","securedRequest","body","stringify","useUserStore","user","publicProfile","refreshedTokenLoaded","setUser","setPublicProfile","setUserByTokenId","jwtDecode","userProps","uid","user_id","displayName","safeDisplayName","email","photoURL","safePhotoURL","handle","logout","tokenStore","getState","Event","URLSearchParams","refresh_token","grant_type","data","id_token","loadStoredUser","publicIdToken","publicRefreshToken","customIdToken","getItem","customUser","parsedUser","ssoV2Exchange","ssoSourceID","jwt","env","signedUserData","decodedUser","sub","useUser","usePublicProfile","useRefreshedTokenLoaded","useUpdateProfile","useUserWithProfile","UserProvider","getPublicProfileService","mutateAsync","useMutation","mutationFn","loadPublicProfile","useCallback","profile","ANONYMOUS_ID_KEY","LS_KEYS","getOrSetAnonymousId","existing","id","crypto","randomUUID","setItem","parseCampaign","u","out","forEach","k","v","searchParams","Object","keys","length","buildRudderContext","w","window","d","s","screen","URL","location","href","ref","referrer","domain","hostname","rememberInitialReferrer","initial_referrer","initial_referring_domain","channel","anonymousId","locale","navigator","userAgent","timezone","Intl","DateTimeFormat","resolvedOptions","timeZone","os","name","platform","version","page","path","pathname","referring_domain","search","title","density","devicePixelRatio","height","width","innerHeight","innerWidth","campaign","getIdentifier","identifier","currentAnonymousId","warn","newAnonymousId","replace","c","r","getCanonicalUrl","canonicalMeta","querySelector","urlObj","removeParamsFromUrl","getEventProperties","widgetType","properties","identity","widget_type","canonical_url","snippet_id","__ARENA__","snippetId","timestamp","Date","toISOString","integrations","All","getEventHeaders","writeKey","btoa","useTrack","analytics","rsWriteKey","dataPlaneUrl","rsDataPlaneUrl","track","trackProperties","site_id","siteId","widget_id","widgetId","trigger","AuthDialog","frameAppName","frameAppDescription","iframeUrl","handler","message","authType","AuthenticationStarted","isSignup","AuthenticationCompleted","is_signup","auth_type","AuthenticationViewed","src","style","position","top","left","zIndex","parseAnonymousId","parsed","trim","getRudderAnonymousId","rudderWindow","fromRudderClient","rudderanalytics","getAnonymousId","rudderAnalytics","AnonymousTokenProvider","getAnonymousIdentityToken","identityUrl","useAuthServices","hasForcedRefreshInDebugRef","rudderAnonymousId","Boolean","then","access_token","catch","AuthProvider","queryClient","QueryClient","QueryClientProvider","client","_jsxs","getRefreshTokenApiKey","refreshPromise","ensureRefreshToken","userStore","finally","authenticatedRequest","attempt","authenticatedFetch","parseResponse","err","errorMessage","throwOnErrorResponse","retryError"],"mappings":"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"}
|