@skylabs-digital/react-identity-access 2.32.0 → 3.1.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/README.md +439 -352
- package/dist/components/LoginForm.d.ts +2 -19
- package/dist/components/LoginForm.d.ts.map +1 -1
- package/dist/components/MagicLinkForm.d.ts +2 -23
- package/dist/components/MagicLinkForm.d.ts.map +1 -1
- package/dist/components/PasswordRecoveryForm.d.ts +2 -19
- package/dist/components/PasswordRecoveryForm.d.ts.map +1 -1
- package/dist/components/SignupForm.d.ts +2 -21
- package/dist/components/SignupForm.d.ts.map +1 -1
- package/dist/components/authFormShared.d.ts +39 -0
- package/dist/components/authFormShared.d.ts.map +1 -0
- package/dist/errors/SessionErrors.d.ts +10 -0
- package/dist/errors/SessionErrors.d.ts.map +1 -1
- package/dist/hooks/useAuthForm.d.ts +24 -0
- package/dist/hooks/useAuthForm.d.ts.map +1 -0
- package/dist/index.d.ts +3 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.es.js +2101 -2673
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/providers/AppProvider.d.ts +0 -3
- package/dist/providers/AppProvider.d.ts.map +1 -1
- package/dist/providers/AuthProvider.d.ts +33 -19
- package/dist/providers/AuthProvider.d.ts.map +1 -1
- package/dist/providers/RoutingProvider.d.ts.map +1 -1
- package/dist/providers/TenantProvider.d.ts +0 -2
- package/dist/providers/TenantProvider.d.ts.map +1 -1
- package/dist/services/AppApiService.d.ts +1 -3
- package/dist/services/AppApiService.d.ts.map +1 -1
- package/dist/services/AuthApiService.d.ts +4 -2
- package/dist/services/AuthApiService.d.ts.map +1 -1
- package/dist/services/FeatureFlagApiService.d.ts +1 -3
- package/dist/services/FeatureFlagApiService.d.ts.map +1 -1
- package/dist/services/PermissionApiService.d.ts +1 -3
- package/dist/services/PermissionApiService.d.ts.map +1 -1
- package/dist/services/RoleApiService.d.ts +1 -3
- package/dist/services/RoleApiService.d.ts.map +1 -1
- package/dist/services/SessionManager.d.ts +10 -14
- package/dist/services/SessionManager.d.ts.map +1 -1
- package/dist/services/SubscriptionApiService.d.ts +1 -3
- package/dist/services/SubscriptionApiService.d.ts.map +1 -1
- package/dist/services/SubscriptionPlanApiService.d.ts +1 -3
- package/dist/services/SubscriptionPlanApiService.d.ts.map +1 -1
- package/dist/services/TenantApiService.d.ts +1 -3
- package/dist/services/TenantApiService.d.ts.map +1 -1
- package/dist/services/UserApiService.d.ts +1 -3
- package/dist/services/UserApiService.d.ts.map +1 -1
- package/dist/utils/configValidation.d.ts +39 -0
- package/dist/utils/configValidation.d.ts.map +1 -0
- package/dist/utils/jwt.d.ts +25 -0
- package/dist/utils/jwt.d.ts.map +1 -0
- package/dist/utils/query.d.ts +6 -0
- package/dist/utils/query.d.ts.map +1 -0
- package/package.json +15 -16
- package/dist/utils/crossDomainAuth.d.ts +0 -37
- package/dist/utils/crossDomainAuth.d.ts.map +0 -1
- package/dist/utils/mappers.d.ts +0 -29
- package/dist/utils/mappers.d.ts.map +0 -1
|
@@ -24,9 +24,6 @@ interface AppProviderProps {
|
|
|
24
24
|
}
|
|
25
25
|
export declare function AppProvider({ config, children }: AppProviderProps): import("react/jsx-runtime").JSX.Element;
|
|
26
26
|
export declare function useApp(): AppContextValue;
|
|
27
|
-
/**
|
|
28
|
-
* Optional hook that returns AppContext if available, null otherwise.
|
|
29
|
-
*/
|
|
30
27
|
export declare function useAppOptional(): AppContextValue | null;
|
|
31
28
|
export declare const useApi: typeof useApp;
|
|
32
29
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AppProvider.d.ts","sourceRoot":"","sources":["../../src/providers/AppProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAIL,SAAS,
|
|
1
|
+
{"version":3,"file":"AppProvider.d.ts","sourceRoot":"","sources":["../../src/providers/AppProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAIL,SAAS,EAKV,MAAM,OAAO,CAAC;AAGf,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAQlD,MAAM,WAAW,SAAS;IACxB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE;QACN,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;CACH;AAED,UAAU,eAAe;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,aAAa,GAAG,IAAI,CAAC;IAC9B,YAAY,EAAE,OAAO,CAAC;IACtB,QAAQ,EAAE,KAAK,GAAG,IAAI,CAAC;IACvB,QAAQ,EAAE,MAAM,IAAI,CAAC;CACtB;AAID,UAAU,gBAAgB;IACxB,MAAM,EAAE,SAAS,CAAC;IAClB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAID,wBAAgB,WAAW,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,gBAAgB,2CAqHjE;AAED,wBAAgB,MAAM,IAAI,eAAe,CAMxC;AAED,wBAAgB,cAAc,IAAI,eAAe,GAAG,IAAI,CAEvD;AAED,eAAO,MAAM,MAAM,eAAS,CAAC"}
|
|
@@ -18,10 +18,29 @@ export interface AuthConfig {
|
|
|
18
18
|
baseUrl?: string;
|
|
19
19
|
appId?: string;
|
|
20
20
|
}
|
|
21
|
-
|
|
21
|
+
/** Reactive auth state + permission helpers. Subscribe via useAuthState(). */
|
|
22
|
+
export interface AuthStateValue {
|
|
22
23
|
isAuthenticated: boolean;
|
|
24
|
+
isAuthInitializing: boolean;
|
|
25
|
+
isAuthReady: boolean;
|
|
26
|
+
currentUser: User | null;
|
|
27
|
+
isUserLoading: boolean;
|
|
28
|
+
userError: Error | null;
|
|
29
|
+
userRole: Role | null;
|
|
30
|
+
userPermissions: string[];
|
|
31
|
+
availableRoles: Role[];
|
|
32
|
+
rolesLoading: boolean;
|
|
33
|
+
userTenants: UserTenantMembership[];
|
|
34
|
+
hasTenantContext: boolean;
|
|
23
35
|
sessionManager: SessionManager;
|
|
24
36
|
authenticatedHttpService: HttpService;
|
|
37
|
+
hasPermission: (permission: string | Permission) => boolean;
|
|
38
|
+
hasAnyPermission: (permissions: (string | Permission)[]) => boolean;
|
|
39
|
+
hasAllPermissions: (permissions: (string | Permission)[]) => boolean;
|
|
40
|
+
getUserPermissionStrings: () => string[];
|
|
41
|
+
}
|
|
42
|
+
/** Stable auth action methods. Subscribe via useAuthActions() — never re-renders. */
|
|
43
|
+
export interface AuthActionsValue {
|
|
25
44
|
login: (params: LoginParams) => Promise<LoginResponse>;
|
|
26
45
|
signup: (params: SignupParams) => Promise<User>;
|
|
27
46
|
signupTenantAdmin: (params: SignupTenantAdminParams) => Promise<{
|
|
@@ -42,39 +61,34 @@ export interface AuthContextValue {
|
|
|
42
61
|
}) => void;
|
|
43
62
|
hasValidSession: () => boolean;
|
|
44
63
|
clearSession: () => void;
|
|
45
|
-
currentUser: User | null;
|
|
46
|
-
isUserLoading: boolean;
|
|
47
|
-
userError: Error | null;
|
|
48
64
|
loadUserData: (forceRefresh?: boolean) => Promise<void>;
|
|
49
65
|
refreshUser: () => Promise<void>;
|
|
50
|
-
isAuthInitializing: boolean;
|
|
51
|
-
isAuthReady: boolean;
|
|
52
|
-
userRole: Role | null;
|
|
53
|
-
userPermissions: string[];
|
|
54
|
-
availableRoles: Role[];
|
|
55
|
-
rolesLoading: boolean;
|
|
56
|
-
hasPermission: (permission: string | Permission) => boolean;
|
|
57
|
-
hasAnyPermission: (permissions: (string | Permission)[]) => boolean;
|
|
58
|
-
hasAllPermissions: (permissions: (string | Permission)[]) => boolean;
|
|
59
|
-
getUserPermissionStrings: () => string[];
|
|
60
66
|
refreshRoles: () => Promise<void>;
|
|
61
|
-
userTenants: UserTenantMembership[];
|
|
62
|
-
hasTenantContext: boolean;
|
|
63
67
|
switchToTenant: (tenantId: string, options?: {
|
|
64
68
|
redirectPath?: string;
|
|
65
69
|
}) => Promise<void>;
|
|
66
70
|
refreshUserTenants: () => Promise<UserTenantMembership[]>;
|
|
67
71
|
}
|
|
72
|
+
export type AuthContextValue = AuthStateValue & AuthActionsValue;
|
|
68
73
|
interface AuthProviderProps {
|
|
69
74
|
config?: AuthConfig;
|
|
70
75
|
children: ReactNode;
|
|
71
76
|
}
|
|
72
77
|
export declare function AuthProvider({ config, children }: AuthProviderProps): import("react/jsx-runtime").JSX.Element;
|
|
73
|
-
|
|
78
|
+
/** Fine-grained subscription to reactive auth state. */
|
|
79
|
+
export declare function useAuthState(): AuthStateValue;
|
|
80
|
+
/**
|
|
81
|
+
* Fine-grained subscription to stable auth actions.
|
|
82
|
+
* The returned object has a stable reference — subscribers never re-render
|
|
83
|
+
* when auth state changes.
|
|
84
|
+
*/
|
|
85
|
+
export declare function useAuthActions(): AuthActionsValue;
|
|
74
86
|
/**
|
|
75
|
-
*
|
|
76
|
-
*
|
|
87
|
+
* Backward-compatible hook that exposes state + actions together.
|
|
88
|
+
* Prefer useAuthState() or useAuthActions() for fine-grained re-render control.
|
|
77
89
|
*/
|
|
90
|
+
export declare function useAuth(): AuthContextValue;
|
|
91
|
+
/** Optional variant of useAuth — returns null when not inside a provider. */
|
|
78
92
|
export declare function useAuthOptional(): AuthContextValue | null;
|
|
79
93
|
export {};
|
|
80
94
|
//# sourceMappingURL=AuthProvider.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AuthProvider.d.ts","sourceRoot":"","sources":["../../src/providers/AuthProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6B,SAAS,EAAwC,MAAM,OAAO,CAAC;AACnG,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAK5D,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"AuthProvider.d.ts","sourceRoot":"","sources":["../../src/providers/AuthProvider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RoutingProvider.d.ts","sourceRoot":"","sources":["../../src/providers/RoutingProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6B,SAAS,EAAW,MAAM,OAAO,CAAC;AACtE,OAAO,EACL,aAAa,EACb,SAAS,EACT,WAAW,EACX,gBAAgB,EAChB,kBAAkB,EAClB,eAAe,EAGhB,MAAM,sBAAsB,CAAC;AAE9B;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC/B,OAAO,EAAE,WAAW,CAAC;IACrB,eAAe,EAAE,SAAS,CAAC;IAC3B,oBAAoB,EAAE,SAAS,CAAC;IAChC,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IACtD,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,eAAe,CAAC;CAClC;
|
|
1
|
+
{"version":3,"file":"RoutingProvider.d.ts","sourceRoot":"","sources":["../../src/providers/RoutingProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6B,SAAS,EAAW,MAAM,OAAO,CAAC;AACtE,OAAO,EACL,aAAa,EACb,SAAS,EACT,WAAW,EACX,gBAAgB,EAChB,kBAAkB,EAClB,eAAe,EAGhB,MAAM,sBAAsB,CAAC;AAE9B;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC/B,OAAO,EAAE,WAAW,CAAC;IACrB,eAAe,EAAE,SAAS,CAAC;IAC3B,oBAAoB,EAAE,SAAS,CAAC;IAChC,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IACtD,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,eAAe,CAAC;CAClC;AAcD,MAAM,WAAW,oBAAoB;IACnC,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,eAAe,CAAC,EAAE,MAAW,EAAE,QAAQ,EAAE,EAAE,oBAAoB,2CAyB9E;AAED;;;GAGG;AACH,wBAAgB,UAAU,IAAI,mBAAmB,CAMhD;AAED;;;GAGG;AACH,wBAAgB,kBAAkB,IAAI,mBAAmB,CAExD;AAED;;GAEG;AACH,wBAAgB,aAAa,CAC3B,UAAU,EAAE,MAAM,WAAW,GAAG,MAAM,GACrC,gBAAgB,GAAG,SAAS,CAG9B"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { ReactNode } from 'react';
|
|
2
|
-
import { AuthTokens } from '../utils/crossDomainAuth';
|
|
3
2
|
import { TenantSettings, JSONSchema, PublicTenantInfo } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export interface TenantConfig {
|
|
@@ -27,7 +26,6 @@ interface TenantContextValue {
|
|
|
27
26
|
refreshSettings: () => void;
|
|
28
27
|
switchTenant: (tenantSlug: string, options?: {
|
|
29
28
|
mode?: 'navigate' | 'reload';
|
|
30
|
-
tokens?: AuthTokens;
|
|
31
29
|
redirectPath?: string;
|
|
32
30
|
}) => void;
|
|
33
31
|
validateSettings: (settings: TenantSettings) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TenantProvider.d.ts","sourceRoot":"","sources":["../../src/providers/TenantProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAIL,SAAS,EAIV,MAAM,OAAO,CAAC;AAKf,OAAO,
|
|
1
|
+
{"version":3,"file":"TenantProvider.d.ts","sourceRoot":"","sources":["../../src/providers/TenantProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAIL,SAAS,EAIV,MAAM,OAAO,CAAC;AAKf,OAAO,KAAK,EAAE,cAAc,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AASjF,MAAM,WAAW,YAAY;IAE3B,UAAU,CAAC,EAAE,WAAW,GAAG,UAAU,GAAG,OAAO,CAAC;IAChD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB,KAAK,CAAC,EAAE;QACN,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;IAEF,aAAa,CAAC,EAAE,gBAAgB,CAAC;CAClC;AAED,UAAU,kBAAkB;IAE1B,MAAM,EAAE,gBAAgB,GAAG,IAAI,CAAC;IAChC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,KAAK,GAAG,IAAI,CAAC;IAC1B,WAAW,EAAE,MAAM,IAAI,CAAC;IAExB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;IAChC,cAAc,EAAE,UAAU,GAAG,IAAI,CAAC;IAClC,iBAAiB,EAAE,OAAO,CAAC;IAC3B,aAAa,EAAE,KAAK,GAAG,IAAI,CAAC;IAE5B,eAAe,EAAE,MAAM,IAAI,CAAC;IAC5B,YAAY,EAAE,CACZ,UAAU,EAAE,MAAM,EAClB,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,UAAU,GAAG,QAAQ,CAAC;QAAC,YAAY,CAAC,EAAE,MAAM,CAAA;KAAE,KAC9D,IAAI,CAAC;IAEV,gBAAgB,EAAE,CAAC,QAAQ,EAAE,cAAc,KAAK;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,EAAE,CAAA;KAAE,CAAC;CACxF;AAID,UAAU,mBAAmB;IAC3B,MAAM,EAAE,YAAY,CAAC;IACrB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,wBAAgB,cAAc,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,mBAAmB,2CAgbvE;AAED,wBAAgB,SAAS,IAAI,kBAAkB,CAM9C;AAGD,wBAAgB,iBAAiB,IAAI,kBAAkB,GAAG,IAAI,CAE7D;AAGD,eAAO,MAAM,iBAAiB,kBAAY,CAAC;AAG3C,wBAAgB,WAAW;;;;;iCA7cI,cAAc,KAAK;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,EAAE,CAAA;KAAE;EAudvF;AAGD,wBAAgB,aAAa;;;;;iBAveR,IAAI;EAgfxB"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { App, CreateAppRequest, PublicAppInfo, PaginationParams } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class AppApiService {
|
|
6
5
|
private httpService;
|
|
7
|
-
|
|
8
|
-
constructor(httpService: HttpService, sessionManager: SessionManager);
|
|
6
|
+
constructor(httpService: HttpService);
|
|
9
7
|
createApp(request: CreateAppRequest): Promise<App>;
|
|
10
8
|
getApps(params?: PaginationParams): Promise<{
|
|
11
9
|
apps: App[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AppApiService.d.ts","sourceRoot":"","sources":["../../src/services/AppApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"AppApiService.d.ts","sourceRoot":"","sources":["../../src/services/AppApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EAEV,GAAG,EACH,gBAAgB,EAChB,aAAa,EACb,gBAAgB,EACjB,MAAM,cAAc,CAAC;AAGtB,qBAAa,aAAa;IACZ,OAAO,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAEtC,SAAS,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,GAAG,CAAC;IAKlD,OAAO,CAAC,MAAM,CAAC,EAAE,gBAAgB,GAAG,OAAO,CAAC;QAAE,IAAI,EAAE,GAAG,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;IAOvE,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAKpC,SAAS,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,gBAAgB,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC;IAKvE,gBAAgB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC;IAOpD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAQvE,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,eAAe,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;IAQpF,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;CAIhD"}
|
|
@@ -3,6 +3,8 @@ import { LoginRequest, LoginResponse, SignupRequest, ChangePasswordRequest, Refr
|
|
|
3
3
|
|
|
4
4
|
export declare class AuthApiService {
|
|
5
5
|
private httpService;
|
|
6
|
+
private pendingVerifications;
|
|
7
|
+
private pendingMagicLinks;
|
|
6
8
|
constructor(httpService: HttpService);
|
|
7
9
|
login(request: LoginRequest): Promise<LoginResponse>;
|
|
8
10
|
signup(request: SignupRequest): Promise<User>;
|
|
@@ -20,7 +22,7 @@ export declare class AuthApiService {
|
|
|
20
22
|
}>;
|
|
21
23
|
refreshToken(request: RefreshTokenRequest): Promise<RefreshTokenResponse>;
|
|
22
24
|
switchTenant(request: SwitchTenantRequest): Promise<SwitchTenantResponse>;
|
|
23
|
-
getUserTenants(
|
|
25
|
+
getUserTenants(): Promise<UserTenantMembership[]>;
|
|
24
26
|
requestPasswordReset(request: {
|
|
25
27
|
email: string;
|
|
26
28
|
tenantId: string;
|
|
@@ -31,6 +33,6 @@ export declare class AuthApiService {
|
|
|
31
33
|
token: string;
|
|
32
34
|
newPassword: string;
|
|
33
35
|
}): Promise<void>;
|
|
34
|
-
changePassword(request: ChangePasswordRequest
|
|
36
|
+
changePassword(request: ChangePasswordRequest): Promise<void>;
|
|
35
37
|
}
|
|
36
38
|
//# sourceMappingURL=AuthApiService.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AuthApiService.d.ts","sourceRoot":"","sources":["../../src/services/AuthApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EACV,YAAY,EACZ,aAAa,EACb,aAAa,EACb,qBAAqB,EACrB,mBAAmB,EACnB,oBAAoB,EACpB,gBAAgB,EAChB,iBAAiB,EACjB,sBAAsB,EACtB,uBAAuB,EAEvB,IAAI,EACJ,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACrB,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"AuthApiService.d.ts","sourceRoot":"","sources":["../../src/services/AuthApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EACV,YAAY,EACZ,aAAa,EACb,aAAa,EACb,qBAAqB,EACrB,mBAAmB,EACnB,oBAAoB,EACpB,gBAAgB,EAChB,iBAAiB,EACjB,sBAAsB,EACtB,uBAAuB,EAEvB,IAAI,EACJ,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACrB,MAAM,cAAc,CAAC;AAEtB,qBAAa,cAAc;IAMb,OAAO,CAAC,WAAW;IAJ/B,OAAO,CAAC,oBAAoB,CAAuD;IAEnF,OAAO,CAAC,iBAAiB,CAAiD;gBAEtD,WAAW,EAAE,WAAW;IAGtC,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,aAAa,CAAC;IAKpD,MAAM,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAK7C,iBAAiB,CAAC,OAAO,EAAE;QAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;QACnB,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,GAAG,OAAO,CAAC;QAAE,IAAI,EAAE,IAAI,CAAC;QAAC,MAAM,EAAE,GAAG,CAAA;KAAE,CAAC;IAQlC,YAAY,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAKzE,YAAY,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAQzE,cAAc,IAAI,OAAO,CAAC,oBAAoB,EAAE,CAAC;IAIjD,oBAAoB,CAAC,OAAO,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAIjF,aAAa,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAoBpE,eAAe,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,uBAAuB,CAAC;IAelF,oBAAoB,CAAC,OAAO,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAIpF,cAAc,CAAC,OAAO,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;CAGpE"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { FeatureFlagItem, FeatureFlagValueResponse, FeatureFlag, CreateFeatureFlagRequest, PaginationParams } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class FeatureFlagApiService {
|
|
6
5
|
private httpService;
|
|
7
|
-
|
|
8
|
-
constructor(httpService: HttpService, sessionManager?: SessionManager | undefined);
|
|
6
|
+
constructor(httpService: HttpService);
|
|
9
7
|
createFeatureFlag(request: CreateFeatureFlagRequest): Promise<FeatureFlag>;
|
|
10
8
|
getFeatureFlags(params?: PaginationParams): Promise<{
|
|
11
9
|
featureFlags: FeatureFlag[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FeatureFlagApiService.d.ts","sourceRoot":"","sources":["../../src/services/FeatureFlagApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"FeatureFlagApiService.d.ts","sourceRoot":"","sources":["../../src/services/FeatureFlagApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EAEV,eAAe,EACf,wBAAwB,EACxB,WAAW,EACX,wBAAwB,EACxB,gBAAgB,EACjB,MAAM,cAAc,CAAC;AAGtB,qBAAa,qBAAqB;IACpB,OAAO,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAEtC,iBAAiB,CAAC,OAAO,EAAE,wBAAwB,GAAG,OAAO,CAAC,WAAW,CAAC;IAQ1E,eAAe,CACnB,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC;QAAE,YAAY,EAAE,WAAW,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;IAOhD,kBAAkB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAKpD,iBAAiB,CACrB,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,OAAO,CAAC,wBAAwB,CAAC,GACzC,OAAO,CAAC,WAAW,CAAC;IAQjB,iBAAiB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI5C,qBAAqB,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;IAalF,oBAAoB,CACxB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,wBAAwB,CAAC;CAYrC"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { Permission, CreatePermissionRequest, PaginationParams } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class PermissionApiService {
|
|
6
5
|
private httpService;
|
|
7
|
-
|
|
8
|
-
constructor(httpService: HttpService, sessionManager?: SessionManager | undefined);
|
|
6
|
+
constructor(httpService: HttpService);
|
|
9
7
|
createPermission(request: CreatePermissionRequest): Promise<Permission>;
|
|
10
8
|
getPermissions(params?: PaginationParams): Promise<{
|
|
11
9
|
permissions: Permission[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PermissionApiService.d.ts","sourceRoot":"","sources":["../../src/services/PermissionApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"PermissionApiService.d.ts","sourceRoot":"","sources":["../../src/services/PermissionApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EACV,UAAU,EACV,uBAAuB,EAEvB,gBAAgB,EACjB,MAAM,cAAc,CAAC;AAGtB,qBAAa,oBAAoB;IACnB,OAAO,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAEtC,gBAAgB,CAAC,OAAO,EAAE,uBAAuB,GAAG,OAAO,CAAC,UAAU,CAAC;IAKvE,cAAc,CAClB,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC;QAAE,WAAW,EAAE,UAAU,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;IAO9C,iBAAiB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAKlD,gBAAgB,CACpB,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,OAAO,CAAC,uBAAuB,CAAC,GACxC,OAAO,CAAC,UAAU,CAAC;IAQhB,gBAAgB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI3C,iBAAiB,CACrB,KAAK,EAAE,MAAM,EACb,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC;QAAE,WAAW,EAAE,UAAU,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;CAOrD"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { Role, CreateRoleRequest, AssignRoleRequest, PaginationParams } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class RoleApiService {
|
|
6
5
|
private httpService;
|
|
7
|
-
|
|
8
|
-
constructor(httpService: HttpService, sessionManager?: SessionManager | undefined);
|
|
6
|
+
constructor(httpService: HttpService);
|
|
9
7
|
createRole(request: CreateRoleRequest): Promise<Role>;
|
|
10
8
|
getRoleById(id: string): Promise<Role>;
|
|
11
9
|
updateRole(id: string, request: Partial<CreateRoleRequest>): Promise<Role>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RoleApiService.d.ts","sourceRoot":"","sources":["../../src/services/RoleApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"RoleApiService.d.ts","sourceRoot":"","sources":["../../src/services/RoleApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EACV,IAAI,EACJ,iBAAiB,EACjB,iBAAiB,EAEjB,gBAAgB,EACjB,MAAM,cAAc,CAAC;AAGtB,qBAAa,cAAc;IACb,OAAO,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAEtC,UAAU,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAKrD,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKtC,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,iBAAiB,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAK1E,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIrC,aAAa,CACjB,KAAK,EAAE,MAAM,EACb,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC;QAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;IAQlC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAIrE,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAIrE,YAAY,CAChB,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC;QAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;CAMzC"}
|
|
@@ -70,19 +70,16 @@ export declare class SessionManager {
|
|
|
70
70
|
private consecutiveBackgroundFailures;
|
|
71
71
|
private static readonly MAX_BACKGROUND_FAILURES;
|
|
72
72
|
constructor(config?: SessionConfig);
|
|
73
|
+
private static validateConfig;
|
|
73
74
|
/** Update mutable config (callbacks, baseUrl) on an existing instance. */
|
|
74
75
|
private updateConfig;
|
|
76
|
+
private memoryStore;
|
|
75
77
|
private createTokenStorage;
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
private
|
|
81
|
-
/**
|
|
82
|
-
* Extract an arbitrary claim from a JWT token.
|
|
83
|
-
* Returns undefined if the token cannot be decoded or the claim is missing.
|
|
84
|
-
*/
|
|
85
|
-
private static extractJwtClaim;
|
|
78
|
+
private static probeLocalStorage;
|
|
79
|
+
private activateMemoryFallback;
|
|
80
|
+
private storageGet;
|
|
81
|
+
private storageSet;
|
|
82
|
+
private storageRemove;
|
|
86
83
|
setTokens(tokens: TokenData): void;
|
|
87
84
|
getTokens(): TokenData | null;
|
|
88
85
|
clearTokens(): void;
|
|
@@ -91,6 +88,9 @@ export declare class SessionManager {
|
|
|
91
88
|
getAccessToken(): string | null;
|
|
92
89
|
private scheduleProactiveRefresh;
|
|
93
90
|
private cancelProactiveTimer;
|
|
91
|
+
private visibilityListener;
|
|
92
|
+
private attachVisibilityListener;
|
|
93
|
+
private detachVisibilityListener;
|
|
94
94
|
private backgroundRefresh;
|
|
95
95
|
/**
|
|
96
96
|
* Wait for any in-progress token refresh to settle.
|
|
@@ -141,10 +141,6 @@ export declare class SessionManager {
|
|
|
141
141
|
* Cancels all timers and rejects pending queue entries.
|
|
142
142
|
*/
|
|
143
143
|
destroy(): void;
|
|
144
|
-
/**
|
|
145
|
-
* Decode JWT token and extract payload
|
|
146
|
-
* Returns null if token is invalid or cannot be decoded
|
|
147
|
-
*/
|
|
148
144
|
getTokenPayload(): JwtPayload | null;
|
|
149
145
|
/**
|
|
150
146
|
* Get userId from token (source of truth) or fallback to stored user
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SessionManager.d.ts","sourceRoot":"","sources":["../../src/services/SessionManager.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,
|
|
1
|
+
{"version":3,"file":"SessionManager.d.ts","sourceRoot":"","sources":["../../src/services/SessionManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { Subscription, CreateSubscriptionRequest, TenantSubscriptionFeatures } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class SubscriptionApiService {
|
|
6
5
|
private httpService;
|
|
7
|
-
|
|
8
|
-
constructor(httpService: HttpService, sessionManager?: SessionManager | undefined);
|
|
6
|
+
constructor(httpService: HttpService);
|
|
9
7
|
createSubscription(request: CreateSubscriptionRequest): Promise<Subscription>;
|
|
10
8
|
getSubscriptionById(id: string): Promise<Subscription>;
|
|
11
9
|
updateSubscription(id: string, request: Partial<CreateSubscriptionRequest>): Promise<Subscription>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SubscriptionApiService.d.ts","sourceRoot":"","sources":["../../src/services/SubscriptionApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"SubscriptionApiService.d.ts","sourceRoot":"","sources":["../../src/services/SubscriptionApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EACV,YAAY,EACZ,yBAAyB,EAEzB,0BAA0B,EAC3B,MAAM,cAAc,CAAC;AAEtB,qBAAa,sBAAsB;IACrB,OAAO,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAEtC,kBAAkB,CAAC,OAAO,EAAE,yBAAyB,GAAG,OAAO,CAAC,YAAY,CAAC;IAQ7E,mBAAmB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAOtD,kBAAkB,CACtB,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,OAAO,CAAC,yBAAyB,CAAC,GAC1C,OAAO,CAAC,YAAY,CAAC;IAQlB,sBAAsB,CAAC,cAAc,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAQrF,6BAA6B,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,0BAA0B,CAAC;IAQpF,cAAc,CAAC,cAAc,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;CAO7E"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { SubscriptionPlan, CreateSubscriptionPlanRequest, PaginationParams } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class SubscriptionPlanApiService {
|
|
6
5
|
private httpService;
|
|
7
|
-
|
|
8
|
-
constructor(httpService: HttpService, sessionManager: SessionManager);
|
|
6
|
+
constructor(httpService: HttpService);
|
|
9
7
|
createSubscriptionPlan(request: CreateSubscriptionPlanRequest): Promise<SubscriptionPlan>;
|
|
10
8
|
getSubscriptionPlans(params?: PaginationParams & {
|
|
11
9
|
appId?: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SubscriptionPlanApiService.d.ts","sourceRoot":"","sources":["../../src/services/SubscriptionPlanApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"SubscriptionPlanApiService.d.ts","sourceRoot":"","sources":["../../src/services/SubscriptionPlanApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EACV,gBAAgB,EAChB,6BAA6B,EAE7B,gBAAgB,EACjB,MAAM,cAAc,CAAC;AAGtB,qBAAa,0BAA0B;IACzB,OAAO,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAEtC,sBAAsB,CAAC,OAAO,EAAE,6BAA6B,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAQzF,oBAAoB,CACxB,MAAM,CAAC,EAAE,gBAAgB,GAAG;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAC7C,OAAO,CAAC;QAAE,KAAK,EAAE,gBAAgB,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;IAO9C,uBAAuB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAO9D,sBAAsB,CAC1B,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,OAAO,CAAC,6BAA6B,CAAC,GAC9C,OAAO,CAAC,gBAAgB,CAAC;IAQtB,sBAAsB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGxD"}
|
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { Tenant, CreateTenantRequest, PublicTenantInfo, TenantSettings, UpdateTenantSettingsRequest, PaginationParams } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class TenantApiService {
|
|
6
5
|
private httpService;
|
|
7
6
|
private appId?;
|
|
8
|
-
|
|
9
|
-
constructor(httpService: HttpService, appId?: string | undefined, sessionManager?: SessionManager | undefined);
|
|
7
|
+
constructor(httpService: HttpService, appId?: string | undefined);
|
|
10
8
|
createTenant(request: CreateTenantRequest): Promise<Tenant>;
|
|
11
9
|
getTenants(params?: PaginationParams): Promise<{
|
|
12
10
|
tenants: Tenant[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TenantApiService.d.ts","sourceRoot":"","sources":["../../src/services/TenantApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"TenantApiService.d.ts","sourceRoot":"","sources":["../../src/services/TenantApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EACV,MAAM,EACN,mBAAmB,EACnB,gBAAgB,EAChB,cAAc,EACd,2BAA2B,EAE3B,gBAAgB,EACjB,MAAM,cAAc,CAAC;AAGtB,qBAAa,gBAAgB;IAEzB,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,KAAK,CAAC;gBADN,WAAW,EAAE,WAAW,EACxB,KAAK,CAAC,EAAE,MAAM,YAAA;IAGlB,YAAY,CAAC,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC;IAK3D,UAAU,CAAC,MAAM,CAAC,EAAE,gBAAgB,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;IAOhF,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAK1C,YAAY,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,mBAAmB,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAKhF,iBAAiB,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,mBAAmB,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAQrF,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAQ5D,iBAAiB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC;IAQtD,oBAAoB,CACxB,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,2BAA2B,GACnC,OAAO,CAAC,cAAc,CAAC;CAO3B"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { HttpService } from './HttpService';
|
|
2
|
-
import { SessionManager } from './SessionManager';
|
|
3
2
|
import { User, CreateUserRequest, PaginationParams } from '../types/api';
|
|
4
3
|
|
|
5
4
|
export declare class UserApiService {
|
|
6
5
|
private httpService;
|
|
7
|
-
|
|
8
|
-
constructor(httpService: HttpService, sessionManager: SessionManager);
|
|
6
|
+
constructor(httpService: HttpService);
|
|
9
7
|
createUser(request: CreateUserRequest): Promise<User>;
|
|
10
8
|
getUsers(params?: PaginationParams): Promise<{
|
|
11
9
|
users: User[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserApiService.d.ts","sourceRoot":"","sources":["../../src/services/UserApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"UserApiService.d.ts","sourceRoot":"","sources":["../../src/services/UserApiService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EAAE,IAAI,EAAE,iBAAiB,EAAe,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAG3F,qBAAa,cAAc;IACb,OAAO,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAEtC,UAAU,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAKrD,QAAQ,CAAC,MAAM,CAAC,EAAE,gBAAgB,GAAG,OAAO,CAAC;QAAE,KAAK,EAAE,IAAI,EAAE,CAAC;QAAC,IAAI,EAAE,GAAG,CAAA;KAAE,CAAC;IAO1E,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKtC,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,iBAAiB,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAK1E,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAG5C"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Validate a baseUrl string. Empty/undefined is allowed (standalone mode and
|
|
3
|
+
* inheritance from AppProvider both rely on this), but any non-empty value
|
|
4
|
+
* must start with http:// or https://. Dangerous schemes (javascript:, data:,
|
|
5
|
+
* vbscript:, file:) are rejected with a typed error.
|
|
6
|
+
*/
|
|
7
|
+
export declare function validateBaseUrl(baseUrl: unknown, field?: string): void;
|
|
8
|
+
/**
|
|
9
|
+
* Validate a numeric config option. Rejects NaN, Infinity, non-numbers, and
|
|
10
|
+
* values outside [min, max]. `min` defaults to 0 (non-negative); pass a
|
|
11
|
+
* positive `min` to require strictly positive.
|
|
12
|
+
*/
|
|
13
|
+
export declare function validateNumber(field: string, value: unknown, options?: {
|
|
14
|
+
min?: number;
|
|
15
|
+
max?: number;
|
|
16
|
+
}): void;
|
|
17
|
+
/**
|
|
18
|
+
* Validate a boolean config option. Rejects strings like "true"/"false" that
|
|
19
|
+
* callers sometimes pass by accident.
|
|
20
|
+
*/
|
|
21
|
+
export declare function validateBoolean(field: string, value: unknown): void;
|
|
22
|
+
/**
|
|
23
|
+
* Validate an access token's structural shape. Tokens with dots are treated
|
|
24
|
+
* as JWTs and must decode cleanly; tokens without dots are treated as opaque
|
|
25
|
+
* and accepted as-is.
|
|
26
|
+
*/
|
|
27
|
+
export declare function validateTokenShape(token: unknown, field?: string): void;
|
|
28
|
+
/**
|
|
29
|
+
* Validate an expiresIn value (seconds until access token expires).
|
|
30
|
+
* Must be a finite positive number if provided. Rejects 0, NaN, Infinity,
|
|
31
|
+
* negative, and non-number inputs.
|
|
32
|
+
*/
|
|
33
|
+
export declare function validateExpiresIn(value: unknown): void;
|
|
34
|
+
/**
|
|
35
|
+
* Validate an absolute expiresAt timestamp (ms since epoch). Same rules as
|
|
36
|
+
* expiresIn: finite, positive.
|
|
37
|
+
*/
|
|
38
|
+
export declare function validateExpiresAt(value: unknown): void;
|
|
39
|
+
//# sourceMappingURL=configValidation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configValidation.d.ts","sourceRoot":"","sources":["../../src/utils/configValidation.ts"],"names":[],"mappings":"AAMA;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,SAAY,GAAG,IAAI,CAWzE;AAED;;;;GAIG;AACH,wBAAgB,cAAc,CAC5B,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,OAAO,EACd,OAAO,GAAE;IAAE,GAAG,CAAC,EAAE,MAAM,CAAC;IAAC,GAAG,CAAC,EAAE,MAAM,CAAA;CAAO,GAC3C,IAAI,CAYN;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,IAAI,CAKnE;AAED;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,SAAgB,GAAG,IAAI,CAuB9E;AAED;;;;GAIG;AACH,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,CAKtD;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,CAStD"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared JWT helpers. Both SessionManager and configValidation use these to
|
|
3
|
+
* avoid duplicating base64url decoding logic.
|
|
4
|
+
*/
|
|
5
|
+
export interface DecodedJwt {
|
|
6
|
+
header: Record<string, unknown>;
|
|
7
|
+
payload: Record<string, unknown>;
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Decode a JWT into its header and payload objects. Returns null for anything
|
|
11
|
+
* that is not a structurally valid 3-segment JWT with parseable base64url
|
|
12
|
+
* JSON header and payload. Does NOT verify the signature.
|
|
13
|
+
*/
|
|
14
|
+
export declare function decodeJwt(token: string): DecodedJwt | null;
|
|
15
|
+
/**
|
|
16
|
+
* Extract the `exp` claim (as ms since epoch) from a JWT access token, or
|
|
17
|
+
* undefined if the token isn't a JWT or has no exp claim.
|
|
18
|
+
*/
|
|
19
|
+
export declare function extractJwtExpiry(token: string): number | undefined;
|
|
20
|
+
/**
|
|
21
|
+
* Extract a string claim from a JWT payload, or undefined if the token isn't
|
|
22
|
+
* a JWT, the claim is missing, or the claim value isn't a string.
|
|
23
|
+
*/
|
|
24
|
+
export declare function extractJwtClaim(token: string, claim: string): string | undefined;
|
|
25
|
+
//# sourceMappingURL=jwt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwt.d.ts","sourceRoot":"","sources":["../../src/utils/jwt.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAClC;AAMD;;;;GAIG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,CAQ1D;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAIlE;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAGhF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../src/utils/query.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAU5D"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@skylabs-digital/react-identity-access",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "3.1.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"publishConfig": {
|
|
6
6
|
"access": "public"
|
|
@@ -21,32 +21,32 @@
|
|
|
21
21
|
"README.md"
|
|
22
22
|
],
|
|
23
23
|
"scripts": {
|
|
24
|
-
"build": "
|
|
24
|
+
"build": "tsc && vite build",
|
|
25
25
|
"dev": "tsc --watch & vite build --watch",
|
|
26
26
|
"dev:types": "tsc --watch",
|
|
27
|
-
"dev:
|
|
28
|
-
"dev:example": "yarn dev",
|
|
27
|
+
"dev:example": "yarn dev:types & cd example && yarn dev",
|
|
29
28
|
"link:example": "yarn link && cd example && yarn link @skylabs-digital/react-identity-access",
|
|
30
29
|
"unlink:example": "cd example && yarn unlink @skylabs-digital/react-identity-access && yarn install --force",
|
|
31
30
|
"lint": "eslint \"src/**/*.{ts,tsx}\" --report-unused-disable-directives --max-warnings 0",
|
|
32
31
|
"lint:fix": "eslint \"src/**/*.{ts,tsx}\" --fix",
|
|
33
32
|
"format": "prettier --write \"src/**/*.{ts,tsx,json,md}\"",
|
|
34
33
|
"format:check": "prettier --check \"src/**/*.{ts,tsx,json,md}\"",
|
|
35
|
-
"type-check": "
|
|
36
|
-
"test": "
|
|
37
|
-
"test:watch": "
|
|
38
|
-
"test:ui": "
|
|
39
|
-
"test:coverage": "
|
|
40
|
-
"sim": "
|
|
41
|
-
"sim:watch": "
|
|
42
|
-
"sim:verbose": "
|
|
43
|
-
"
|
|
34
|
+
"type-check": "tsc --noEmit",
|
|
35
|
+
"test": "vitest run",
|
|
36
|
+
"test:watch": "vitest",
|
|
37
|
+
"test:ui": "vitest --ui",
|
|
38
|
+
"test:coverage": "vitest run --coverage",
|
|
39
|
+
"sim": "vitest run --config qa/vitest.config.ts",
|
|
40
|
+
"sim:watch": "vitest --config qa/vitest.config.ts",
|
|
41
|
+
"sim:verbose": "vitest run --config qa/vitest.config.ts --reporter=verbose",
|
|
42
|
+
"qa:agentic": "vitest run --config qa/vitest.config.ts --reporter=verbose",
|
|
43
|
+
"ci": "yarn type-check && yarn test && yarn build",
|
|
44
44
|
"prepublishOnly": "yarn build",
|
|
45
45
|
"prepare": "husky install",
|
|
46
46
|
"commit": "git-cz",
|
|
47
47
|
"release": "semantic-release",
|
|
48
48
|
"preview": "vite preview",
|
|
49
|
-
"demo": "cd
|
|
49
|
+
"demo": "cd example && yarn dev"
|
|
50
50
|
},
|
|
51
51
|
"keywords": [
|
|
52
52
|
"react",
|
|
@@ -129,7 +129,6 @@
|
|
|
129
129
|
"vite-plugin-dts": "^3.9.1",
|
|
130
130
|
"vitest": "^1.6.0"
|
|
131
131
|
},
|
|
132
|
-
"dependencies": {},
|
|
133
132
|
"lint-staged": {
|
|
134
133
|
"src/**/*.{ts,tsx}": [
|
|
135
134
|
"eslint --fix",
|
|
@@ -141,5 +140,5 @@
|
|
|
141
140
|
"path": "./node_modules/cz-conventional-changelog"
|
|
142
141
|
}
|
|
143
142
|
},
|
|
144
|
-
"packageManager": "yarn@
|
|
143
|
+
"packageManager": "yarn@4.5.3"
|
|
145
144
|
}
|