@arena-im/react-sdk-auth 1.9.0-wid-961.4

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.
Files changed (55) hide show
  1. package/config/index.d.ts +11 -0
  2. package/config/index.d.ts.map +1 -0
  3. package/context/anonymous-token-provider.d.ts +5 -0
  4. package/context/anonymous-token-provider.d.ts.map +1 -0
  5. package/context/auth-dialog-provider.d.ts +25 -0
  6. package/context/auth-dialog-provider.d.ts.map +1 -0
  7. package/context/config-provider.d.ts +14 -0
  8. package/context/config-provider.d.ts.map +1 -0
  9. package/context/index.d.ts +8 -0
  10. package/context/index.d.ts.map +1 -0
  11. package/context/user-provider.d.ts +5 -0
  12. package/context/user-provider.d.ts.map +1 -0
  13. package/dialog/index.d.ts +2 -0
  14. package/dialog/index.d.ts.map +1 -0
  15. package/hooks/use-token-event-listener.d.ts +4 -0
  16. package/hooks/use-token-event-listener.d.ts.map +1 -0
  17. package/hooks/use-tokens.d.ts +19 -0
  18. package/hooks/use-tokens.d.ts.map +1 -0
  19. package/hooks/use-track.d.ts +3 -0
  20. package/hooks/use-track.d.ts.map +1 -0
  21. package/hooks/use-user.d.ts +25 -0
  22. package/hooks/use-user.d.ts.map +1 -0
  23. package/index.d.ts +249 -0
  24. package/index.d.ts.map +1 -0
  25. package/index.esm.js +2 -0
  26. package/index.umd.js +2 -0
  27. package/package.json +75 -0
  28. package/services/auth/types.d.ts +51 -0
  29. package/services/auth/types.d.ts.map +1 -0
  30. package/services/auth/use-auth-services.d.ts +5 -0
  31. package/services/auth/use-auth-services.d.ts.map +1 -0
  32. package/services/profile/types.d.ts +17 -0
  33. package/services/profile/types.d.ts.map +1 -0
  34. package/services/profile/use-profile-services.d.ts +6 -0
  35. package/services/profile/use-profile-services.d.ts.map +1 -0
  36. package/stores/index.d.ts +3 -0
  37. package/stores/index.d.ts.map +1 -0
  38. package/stores/token-store.d.ts +38 -0
  39. package/stores/token-store.d.ts.map +1 -0
  40. package/stores/user-store.d.ts +30 -0
  41. package/stores/user-store.d.ts.map +1 -0
  42. package/types/analytics.d.ts +59 -0
  43. package/types/analytics.d.ts.map +1 -0
  44. package/types/index.d.ts +3 -0
  45. package/types/index.d.ts.map +1 -0
  46. package/types/token.d.ts +20 -0
  47. package/types/token.d.ts.map +1 -0
  48. package/utils/analytics.d.ts +7 -0
  49. package/utils/analytics.d.ts.map +1 -0
  50. package/utils/dom-events.d.ts +10 -0
  51. package/utils/dom-events.d.ts.map +1 -0
  52. package/utils/request.d.ts +8 -0
  53. package/utils/request.d.ts.map +1 -0
  54. package/utils/url.d.ts +2 -0
  55. package/utils/url.d.ts.map +1 -0
@@ -0,0 +1,11 @@
1
+ export interface Config {
2
+ profileServiceUrl: string;
3
+ identityServiceUrl: string;
4
+ refreshTokenApiKey: string;
5
+ authIframeUrl: string;
6
+ environment: 'development' | 'production';
7
+ debug: boolean;
8
+ }
9
+ export type Environment = 'development' | 'production';
10
+ export declare const getConfig: (environment: Environment) => Config;
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,MAAM;IACrB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,aAAa,GAAG,YAAY,CAAC;IAC1C,KAAK,EAAE,OAAO,CAAC;CAChB;AAED,MAAM,MAAM,WAAW,GAAG,aAAa,GAAG,YAAY,CAAC;AAEvD,eAAO,MAAM,SAAS,GAAI,aAAa,WAAW,KAAG,MAyBpD,CAAC"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ export declare function AnonymousTokenProvider({ children, }: {
3
+ children: React.ReactNode;
4
+ }): React.ReactNode;
5
+ //# sourceMappingURL=anonymous-token-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anonymous-token-provider.d.ts","sourceRoot":"","sources":["../../src/context/anonymous-token-provider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AAKzC,wBAAgB,sBAAsB,CAAC,EACrC,QAAQ,GACT,EAAE;IACD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,mBAoBA"}
@@ -0,0 +1,25 @@
1
+ import { ReactNode } from 'react';
2
+ import { UserProps } from '../services/auth/types';
3
+ import { TrackOptions } from '../types/analytics';
4
+ interface AuthDialogContextType {
5
+ isOpen: boolean;
6
+ appName: string | undefined;
7
+ appDescription: string | undefined;
8
+ trackOptions: TrackOptions | undefined;
9
+ onAuthCompleted: ((user: UserProps) => void) | undefined;
10
+ openDialog: (options: OpenDialogOptions) => void;
11
+ closeDialog: () => void;
12
+ onOpenChange: (open: boolean) => void;
13
+ }
14
+ type OpenDialogOptions = {
15
+ trackOptions: TrackOptions;
16
+ appName?: string;
17
+ appDescription?: string;
18
+ onAuthCompleted?: () => (user: UserProps) => void;
19
+ };
20
+ export declare const AuthDialogProvider: ({ children }: {
21
+ children: ReactNode;
22
+ }) => import("react/jsx-runtime").JSX.Element;
23
+ export declare const useAuthDialog: () => AuthDialogContextType;
24
+ export {};
25
+ //# sourceMappingURL=auth-dialog-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-dialog-provider.d.ts","sourceRoot":"","sources":["../../src/context/auth-dialog-provider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAuC,SAAS,EAAE,MAAM,OAAO,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,UAAU,qBAAqB;IAC7B,MAAM,EAAE,OAAO,CAAC;IAChB,OAAO,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,cAAc,EAAE,MAAM,GAAG,SAAS,CAAC;IACnC,YAAY,EAAE,YAAY,GAAG,SAAS,CAAC;IACvC,eAAe,EAAE,CAAC,CAAC,IAAI,EAAE,SAAS,KAAK,IAAI,CAAC,GAAG,SAAS,CAAC;IACzD,UAAU,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,IAAI,CAAC;IACjD,WAAW,EAAE,MAAM,IAAI,CAAC;IACxB,YAAY,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;CACvC;AAMD,KAAK,iBAAiB,GAAG;IACvB,YAAY,EAAE,YAAY,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC,IAAI,EAAE,SAAS,KAAK,IAAI,CAAC;CACnD,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,cAAc;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,4CA4CvE,CAAC;AAEF,eAAO,MAAM,aAAa,6BAMzB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { ReactNode } from 'react';
2
+ import { Environment, Config } from '../config';
3
+ interface ConfigContextType {
4
+ config: Config;
5
+ environment: Environment;
6
+ }
7
+ interface ConfigProviderProps {
8
+ children: ReactNode;
9
+ environment?: Environment;
10
+ }
11
+ export declare const ConfigProvider: ({ children, environment, }: ConfigProviderProps) => import("react/jsx-runtime").JSX.Element;
12
+ export declare const useConfig: () => ConfigContextType;
13
+ export {};
14
+ //# sourceMappingURL=config-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config-provider.d.ts","sourceRoot":"","sources":["../../src/context/config-provider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6B,SAAS,EAAE,MAAM,OAAO,CAAC;AAC7D,OAAO,EAAa,WAAW,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAE3D,UAAU,iBAAiB;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,WAAW,CAAC;CAC1B;AAID,UAAU,mBAAmB;IAC3B,QAAQ,EAAE,SAAS,CAAC;IACpB,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B;AAED,eAAO,MAAM,cAAc,GAAI,4BAG5B,mBAAmB,4CAQrB,CAAC;AAEF,eAAO,MAAM,SAAS,yBAMrB,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { QueryClient } from '@tanstack/react-query';
2
+ export declare function AuthProvider({ children, queryClient, environment, }: {
3
+ children: React.ReactNode;
4
+ queryClient?: QueryClient;
5
+ environment?: 'production' | 'development';
6
+ }): import("react/jsx-runtime").JSX.Element;
7
+ export { useAuthDialog } from './auth-dialog-provider';
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/context/index.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAuB,MAAM,uBAAuB,CAAC;AAMzE,wBAAgB,YAAY,CAAC,EAC3B,QAAQ,EACR,WAAW,EACX,WAAW,GACZ,EAAE;IACD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,WAAW,CAAC,EAAE,YAAY,GAAG,aAAa,CAAC;CAC5C,2CAiBA;AAED,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ export declare function UserProvider({ children }: {
3
+ children: React.ReactNode;
4
+ }): React.ReactNode;
5
+ //# sourceMappingURL=user-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-provider.d.ts","sourceRoot":"","sources":["../../src/context/user-provider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAiC,MAAM,OAAO,CAAC;AAMtD,wBAAgB,YAAY,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CAAE,mBAyBvE"}
@@ -0,0 +1,2 @@
1
+ export default function AuthDialog(): import("react/jsx-runtime").JSX.Element | null;
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/dialog/index.tsx"],"names":[],"mappings":"AAQA,MAAM,CAAC,OAAO,UAAU,UAAU,mDAoFjC"}
@@ -0,0 +1,4 @@
1
+ export declare function useTokenEventListener(): {
2
+ eventSource: string;
3
+ };
4
+ //# sourceMappingURL=use-token-event-listener.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-token-event-listener.d.ts","sourceRoot":"","sources":["../../src/hooks/use-token-event-listener.ts"],"names":[],"mappings":"AAcA,wBAAgB,qBAAqB;;EAuGpC"}
@@ -0,0 +1,19 @@
1
+ export declare function useTokens(): {
2
+ getToken: (type: import("..").TokenType) => string | null;
3
+ getMostPrivilegedToken: (options?: Array<import("..").TokenType>) => {
4
+ type: import("..").TokenType;
5
+ idToken: string;
6
+ } | null;
7
+ getRefreshToken: (type: import("..").TokenType) => string | null;
8
+ updatePublicTokens: (idToken: string, refreshToken: string) => void;
9
+ updateAnonymousToken: (idToken: string) => void;
10
+ updateGuestTokens: (idToken: string) => void;
11
+ updateCustomToken: (idToken: string) => void;
12
+ clearTokens: () => void;
13
+ clearPublicTokens: () => void;
14
+ clearCustomTokens: () => void;
15
+ };
16
+ export declare function useToken(type: 'anonymous' | 'guest' | 'public' | 'custom'): import("..").TokenPair;
17
+ export declare function useTokenValue(type: 'anonymous' | 'guest' | 'public' | 'custom'): string | null;
18
+ export declare function useRefreshToken(type: 'anonymous' | 'guest' | 'public'): string | null | undefined;
19
+ //# sourceMappingURL=use-tokens.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-tokens.d.ts","sourceRoot":"","sources":["../../src/hooks/use-tokens.ts"],"names":[],"mappings":"AAGA,wBAAgB,SAAS;;;;;;;kCAsBS,MAAM,gBAAgB,MAAM;oCAE1B,MAAM;iCAET,MAAM;iCAEN,MAAM;;;;EAMtC;AAED,wBAAgB,QAAQ,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,GAAG,QAAQ,GAAG,QAAQ,0BAEzE;AAED,wBAAgB,aAAa,CAC3B,IAAI,EAAE,WAAW,GAAG,OAAO,GAAG,QAAQ,GAAG,QAAQ,iBAGlD;AAED,wBAAgB,eAAe,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,GAAG,QAAQ,6BAErE"}
@@ -0,0 +1,3 @@
1
+ import { AnalyticsEvent, TrackOptions } from '../types/analytics';
2
+ export declare function useTrack(trackOptions?: TrackOptions): (event: AnalyticsEvent, userId?: string, properties?: Record<string, string | null>) => void;
3
+ //# sourceMappingURL=use-track.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-track.d.ts","sourceRoot":"","sources":["../../src/hooks/use-track.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElE,wBAAgB,QAAQ,CAAC,YAAY,CAAC,EAAE,YAAY,WAGvC,cAAc,WACZ,MAAM,eACF,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,UA2B/C"}
@@ -0,0 +1,25 @@
1
+ export declare function useUser(): import("../services/auth/types").UserProps | null;
2
+ export declare function usePublicProfile(): import("../services/profile/types").PublicProfile | null;
3
+ export declare function useRefreshedTokenLoaded(): boolean;
4
+ export declare function useUserActions(): {
5
+ setUser: (user: import("../services/auth/types").UserProps | null) => void;
6
+ setPublicProfile: (publicProfile: import("../services/profile/types").PublicProfile | null) => void;
7
+ logout: () => void;
8
+ refreshPublicTokens: (config: {
9
+ refreshTokenApiKey: string;
10
+ }) => Promise<void>;
11
+ setUserByTokenId: (idToken: string) => void;
12
+ loadStoredUser: (config?: {
13
+ refreshTokenApiKey: string;
14
+ }) => Promise<void>;
15
+ ssoV2Exchange: (ssoSourceID: string, jwt: string, env?: import("../config").Environment) => Promise<import("../services/auth/types").SsoV2ExchangeResponse>;
16
+ };
17
+ export declare function useUpdateProfile(): {
18
+ updatePublicProfile: (params: Omit<import("../services/profile/types").PublicProfile, "metadata">) => Promise<void>;
19
+ };
20
+ export declare function useUserWithProfile(): {
21
+ user: import("../services/auth/types").UserProps | null;
22
+ publicProfile: import("../services/profile/types").PublicProfile | null;
23
+ refreshedTokenLoaded: boolean;
24
+ };
25
+ //# sourceMappingURL=use-user.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-user.d.ts","sourceRoot":"","sources":["../../src/hooks/use-user.ts"],"names":[],"mappings":"AAGA,wBAAgB,OAAO,sDAEtB;AAED,wBAAgB,gBAAgB,6DAE/B;AAED,wBAAgB,uBAAuB,YAEtC;AAED,wBAAgB,cAAc;;;;;;;;;;;;EAmB7B;AAED,wBAAgB,gBAAgB;;EAK/B;AAED,wBAAgB,kBAAkB;;;;EAYjC"}
package/index.d.ts ADDED
@@ -0,0 +1,249 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { QueryClient } from '@tanstack/react-query';
3
+ import * as zustand from 'zustand';
4
+
5
+ interface UserProps {
6
+ uid: string;
7
+ email: string;
8
+ displayName: string;
9
+ photoURL?: string;
10
+ handle?: string;
11
+ }
12
+ interface SsoV2ExchangeResponse {
13
+ token: string;
14
+ }
15
+
16
+ type Nullable<T> = T | null;
17
+ declare enum AnalyticsWidgetType {
18
+ AvatarProfile = "avatar-profile",
19
+ AvatarChat = "avatar-chat",
20
+ Comments = "comments",
21
+ GlobalProfile = "global-profile",
22
+ GroupChat = "group-chat",
23
+ Polls = "polls",
24
+ UniversalSnippet = "universal-snippet"
25
+ }
26
+ type TrackOptions = {
27
+ widgetId: string | null;
28
+ widgetType: AnalyticsWidgetType;
29
+ siteId: string;
30
+ rsWriteKey: string;
31
+ rsDataPlaneUrl: string;
32
+ trigger: string;
33
+ };
34
+ declare enum AnalyticsEvent {
35
+ AuthenticationCompleted = "Authentication Completed",
36
+ AuthenticationStarted = "Authentication Started",
37
+ AuthenticationViewed = "Authentication Viewed"
38
+ }
39
+ type TrackProps = Nullable<Record<string, unknown>>;
40
+ interface IdentityProps {
41
+ anonymousId?: string;
42
+ userId?: string;
43
+ }
44
+ interface RudderContext {
45
+ channel: 'web';
46
+ anonymousId?: string;
47
+ locale?: string;
48
+ userAgent?: string;
49
+ timezone?: string;
50
+ os?: {
51
+ name: string;
52
+ version?: string;
53
+ };
54
+ page?: {
55
+ path?: string;
56
+ referrer?: string;
57
+ referring_domain?: string;
58
+ search?: string;
59
+ title?: string;
60
+ url?: string;
61
+ initial_referrer?: string;
62
+ initial_referring_domain?: string;
63
+ };
64
+ screen?: {
65
+ density?: number;
66
+ height?: number;
67
+ width?: number;
68
+ innerHeight?: number;
69
+ innerWidth?: number;
70
+ };
71
+ campaign?: Record<string, string>;
72
+ }
73
+
74
+ interface AuthDialogContextType {
75
+ isOpen: boolean;
76
+ appName: string | undefined;
77
+ appDescription: string | undefined;
78
+ trackOptions: TrackOptions | undefined;
79
+ onAuthCompleted: ((user: UserProps) => void) | undefined;
80
+ openDialog: (options: OpenDialogOptions) => void;
81
+ closeDialog: () => void;
82
+ onOpenChange: (open: boolean) => void;
83
+ }
84
+ type OpenDialogOptions = {
85
+ trackOptions: TrackOptions;
86
+ appName?: string;
87
+ appDescription?: string;
88
+ onAuthCompleted?: () => (user: UserProps) => void;
89
+ };
90
+ declare const useAuthDialog: () => AuthDialogContextType;
91
+
92
+ declare function AuthProvider({ children, queryClient, environment, }: {
93
+ children: React.ReactNode;
94
+ queryClient?: QueryClient;
95
+ environment?: 'production' | 'development';
96
+ }): react_jsx_runtime.JSX.Element;
97
+
98
+ declare enum TokenType {
99
+ ANONYMOUS = "anonymous",
100
+ GUEST = "guest",
101
+ PUBLIC = "public",
102
+ CUSTOM = "custom"
103
+ }
104
+ interface TokenPair {
105
+ idToken: string | null;
106
+ refreshToken?: string | null;
107
+ }
108
+ type TokensMap = Record<TokenType, TokenPair>;
109
+ declare enum AuthCookie {
110
+ PUBLIC_ID_TOKEN = "arena-auth-public-id-token",
111
+ PUBLIC_REFRESH_TOKEN = "arena-auth-public-refresh-token",
112
+ ANONYMOUS_ID_TOKEN = "arena-auth-anonymous-id-token",
113
+ GUEST_ID_TOKEN = "arena-auth-guest-id-token",
114
+ CUSTOM_ID_TOKEN = "arena-auth-custom-id-token",
115
+ CUSTOM_USER = "arena-auth-custom-user"
116
+ }
117
+
118
+ interface TokenStore {
119
+ tokens: TokensMap;
120
+ getToken: (type: TokenType) => string | null;
121
+ getMostPrivilegedToken: (options?: Array<TokenType>) => {
122
+ type: TokenType;
123
+ idToken: string;
124
+ } | null;
125
+ getRefreshToken: (type: TokenType) => string | null;
126
+ updatePublicTokens: (idToken: string, refreshToken: string, source?: string) => void;
127
+ updateAnonymousToken: (idToken: string, source?: string) => void;
128
+ updateGuestTokens: (idToken: string, source?: string) => void;
129
+ updateCustomToken: (idToken: string, source?: string) => void;
130
+ clearTokens: (source?: string) => void;
131
+ clearPublicTokens: (source?: string) => void;
132
+ clearAnonymousTokens: (source?: string) => void;
133
+ clearGuestTokens: (source?: string) => void;
134
+ clearCustomTokens: (source?: string) => void;
135
+ silentUpdatePublicTokens: (idToken: string, refreshToken: string) => void;
136
+ silentUpdateAnonymousToken: (idToken: string) => void;
137
+ silentUpdateGuestTokens: (idToken: string) => void;
138
+ silentUpdateCustomToken: (idToken: string) => void;
139
+ silentClearPublicTokens: () => void;
140
+ silentClearAnonymousTokens: () => void;
141
+ silentClearGuestTokens: () => void;
142
+ silentClearCustomTokens: () => void;
143
+ }
144
+ declare const useTokenStore: zustand.UseBoundStore<Omit<zustand.StoreApi<TokenStore>, "subscribe"> & {
145
+ subscribe: {
146
+ (listener: (selectedState: TokenStore, previousSelectedState: TokenStore) => void): () => void;
147
+ <U>(selector: (state: TokenStore) => U, listener: (selectedState: U, previousSelectedState: U) => void, options?: {
148
+ equalityFn?: ((a: U, b: U) => boolean) | undefined;
149
+ fireImmediately?: boolean;
150
+ } | undefined): () => void;
151
+ };
152
+ }>;
153
+
154
+ interface PublicProfile {
155
+ displayName?: string;
156
+ handle?: string;
157
+ bio?: string;
158
+ metadata?: {
159
+ commentCountBySite?: {
160
+ [siteId: string]: number;
161
+ };
162
+ commentReactionCountBySite?: {
163
+ [siteId: string]: number;
164
+ };
165
+ overallCommentCount?: number;
166
+ overallCommentReactionCount?: number;
167
+ };
168
+ photoURL?: string;
169
+ }
170
+
171
+ type Environment = 'development' | 'production';
172
+
173
+ interface UserStore {
174
+ user: UserProps | null;
175
+ publicProfile: PublicProfile | null;
176
+ refreshedTokenLoaded: boolean;
177
+ setUser: (user: UserProps | null) => void;
178
+ setPublicProfile: (publicProfile: PublicProfile | null) => void;
179
+ logout: () => void;
180
+ refreshPublicTokens: (config: {
181
+ refreshTokenApiKey: string;
182
+ }) => Promise<void>;
183
+ setUserByTokenId: (idToken: string) => void;
184
+ loadStoredUser: (config?: {
185
+ refreshTokenApiKey: string;
186
+ }) => Promise<void>;
187
+ ssoV2Exchange: (ssoSourceID: string, jwt: string, env?: Environment) => Promise<SsoV2ExchangeResponse>;
188
+ }
189
+ declare const useUserStore: zustand.UseBoundStore<Omit<zustand.StoreApi<UserStore>, "subscribe"> & {
190
+ subscribe: {
191
+ (listener: (selectedState: UserStore, previousSelectedState: UserStore) => void): () => void;
192
+ <U>(selector: (state: UserStore) => U, listener: (selectedState: U, previousSelectedState: U) => void, options?: {
193
+ equalityFn?: ((a: U, b: U) => boolean) | undefined;
194
+ fireImmediately?: boolean;
195
+ } | undefined): () => void;
196
+ };
197
+ }>;
198
+
199
+ declare function useTokens(): {
200
+ getToken: (type: TokenType) => string | null;
201
+ getMostPrivilegedToken: (options?: Array<TokenType>) => {
202
+ type: TokenType;
203
+ idToken: string;
204
+ } | null;
205
+ getRefreshToken: (type: TokenType) => string | null;
206
+ updatePublicTokens: (idToken: string, refreshToken: string) => void;
207
+ updateAnonymousToken: (idToken: string) => void;
208
+ updateGuestTokens: (idToken: string) => void;
209
+ updateCustomToken: (idToken: string) => void;
210
+ clearTokens: () => void;
211
+ clearPublicTokens: () => void;
212
+ clearCustomTokens: () => void;
213
+ };
214
+ declare function useToken(type: 'anonymous' | 'guest' | 'public' | 'custom'): TokenPair;
215
+ declare function useTokenValue(type: 'anonymous' | 'guest' | 'public' | 'custom'): string | null;
216
+ declare function useRefreshToken(type: 'anonymous' | 'guest' | 'public'): string | null | undefined;
217
+
218
+ declare function useUser(): UserProps | null;
219
+ declare function usePublicProfile(): PublicProfile | null;
220
+ declare function useRefreshedTokenLoaded(): boolean;
221
+ declare function useUserActions(): {
222
+ setUser: (user: UserProps | null) => void;
223
+ setPublicProfile: (publicProfile: PublicProfile | null) => void;
224
+ logout: () => void;
225
+ refreshPublicTokens: (config: {
226
+ refreshTokenApiKey: string;
227
+ }) => Promise<void>;
228
+ setUserByTokenId: (idToken: string) => void;
229
+ loadStoredUser: (config?: {
230
+ refreshTokenApiKey: string;
231
+ }) => Promise<void>;
232
+ ssoV2Exchange: (ssoSourceID: string, jwt: string, env?: Environment) => Promise<SsoV2ExchangeResponse>;
233
+ };
234
+ declare function useUpdateProfile(): {
235
+ updatePublicProfile: (params: Omit<PublicProfile, "metadata">) => Promise<void>;
236
+ };
237
+ declare function useUserWithProfile(): {
238
+ user: UserProps | null;
239
+ publicProfile: PublicProfile | null;
240
+ refreshedTokenLoaded: boolean;
241
+ };
242
+
243
+ declare function useTokenEventListener(): {
244
+ eventSource: string;
245
+ };
246
+
247
+ export { AnalyticsEvent, AnalyticsWidgetType, AuthCookie, AuthProvider, TokenType, useAuthDialog, usePublicProfile, useRefreshToken, useRefreshedTokenLoaded, useToken, useTokenEventListener, useTokenStore, useTokenValue, useTokens, useUpdateProfile, useUser, useUserActions, useUserStore, useUserWithProfile };
248
+ export type { IdentityProps, RudderContext, TokenPair, TokensMap, TrackOptions, TrackProps };
249
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.d.ts","sources":["../src/services/auth/types.ts","../src/types/analytics.ts","../src/context/auth-dialog-provider.tsx","../src/context/index.tsx","../src/types/token.ts","../src/stores/token-store.ts","../src/services/profile/types.ts","../src/config/index.ts","../src/stores/user-store.ts","../src/hooks/use-tokens.ts","../src/hooks/use-user.ts","../src/hooks/use-token-event-listener.ts"],"sourcesContent":["export interface ExchangeTokensResponse {\n  access_token: string;\n  expiresIn: number;\n}\n\nexport interface UserProps {\n  uid: string;\n  email: string;\n  displayName: string;\n  photoURL?: string;\n  handle?: string;\n}\nexport interface SsoUserProps {\n  sub: string;\n  email: string;\n  displayName: string;\n  photoURL?: string;\n  handle?: string;\n}\n\nexport interface SsoV2ExchangeResponse {\n  token: string;\n}\n\nexport interface SignInResponse {\n  data: {\n    user: UserProps;\n    token: string;\n  };\n}\n\nexport interface FirebaseUser {\n  name: string;\n  picture: string;\n  originalEmail: string;\n  safeDisplayName: string;\n  safePhotoURL: string;\n  initialized: boolean;\n  legacyID: string;\n  handle: string;\n  iss: string;\n  aud: string;\n  auth_time: number;\n  user_id: string;\n  sub: string;\n  iat: number;\n  exp: number;\n  email: string;\n  email_verified: boolean;\n  firebase: {\n    identities: Record<string, string[]>;\n    sign_in_provider: string;\n  };\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 { 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  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  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 openDialog = ({\n    trackOptions,\n    appName,\n    appDescription,\n    onAuthCompleted,\n  }: OpenDialogOptions) => {\n    setIsOpen(true);\n    setTrackOptions(trackOptions);\n    setAppName(appName);\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        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 { 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","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 { 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","export interface PublicProfile {\n  displayName?: string;\n  handle?: string;\n  bio?: string;\n  metadata?: {\n    commentCountBySite?: {\n      [siteId: string]: number;\n    };\n    commentReactionCountBySite?: {\n      [siteId: string]: number;\n    };\n    overallCommentCount?: number;\n    overallCommentReactionCount?: number;\n  };\n  photoURL?: string;\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 { 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 { 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","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 { 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"],"names":[],"mappings":";;;;AAIO;AACP;AACA;AACA;AACA;AACA;AACA;AAQO;AACP;AACA;;ACpBA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACO;AACA;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIO;;ACrBA;AACP;AACA;AACA;AACA;;ACLO;AACP;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACO;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPO;;ACLP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;;ACvBO;AACP;AACA;;;"}
package/index.d.ts.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACvD,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,kCAAkC,CAAC;AACjD,cAAc,SAAS,CAAC"}