@insforge/sdk 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js ADDED
@@ -0,0 +1,417 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ Auth: () => Auth,
24
+ HttpClient: () => HttpClient,
25
+ InsForgeClient: () => InsForgeClient,
26
+ InsForgeError: () => InsForgeError,
27
+ TokenManager: () => TokenManager,
28
+ createClient: () => createClient,
29
+ default: () => index_default
30
+ });
31
+ module.exports = __toCommonJS(index_exports);
32
+
33
+ // src/types.ts
34
+ var InsForgeError = class _InsForgeError extends Error {
35
+ constructor(message, statusCode, error, nextActions) {
36
+ super(message);
37
+ this.name = "InsForgeError";
38
+ this.statusCode = statusCode;
39
+ this.error = error;
40
+ this.nextActions = nextActions;
41
+ }
42
+ static fromApiError(apiError) {
43
+ return new _InsForgeError(
44
+ apiError.message,
45
+ apiError.statusCode,
46
+ apiError.error,
47
+ apiError.nextActions
48
+ );
49
+ }
50
+ };
51
+
52
+ // src/lib/http-client.ts
53
+ var HttpClient = class {
54
+ constructor(config) {
55
+ this.baseUrl = config.url || "http://localhost:7130";
56
+ this.fetch = config.fetch || globalThis.fetch;
57
+ this.defaultHeaders = {
58
+ "Content-Type": "application/json",
59
+ ...config.headers
60
+ };
61
+ if (config.apiKey) {
62
+ this.defaultHeaders["Authorization"] = `Bearer ${config.apiKey}`;
63
+ }
64
+ if (!this.fetch) {
65
+ throw new Error(
66
+ "Fetch is not available. Please provide a fetch implementation in the config."
67
+ );
68
+ }
69
+ }
70
+ buildUrl(path, params) {
71
+ const url = new URL(path, this.baseUrl);
72
+ if (params) {
73
+ Object.entries(params).forEach(([key, value]) => {
74
+ url.searchParams.append(key, value);
75
+ });
76
+ }
77
+ return url.toString();
78
+ }
79
+ async request(method, path, options = {}) {
80
+ const { params, headers = {}, body, ...fetchOptions } = options;
81
+ const url = this.buildUrl(path, params);
82
+ const response = await this.fetch(url, {
83
+ method,
84
+ headers: {
85
+ ...this.defaultHeaders,
86
+ ...headers
87
+ },
88
+ body: body ? JSON.stringify(body) : void 0,
89
+ ...fetchOptions
90
+ });
91
+ if (response.status === 204) {
92
+ return void 0;
93
+ }
94
+ let data;
95
+ const contentType = response.headers.get("content-type");
96
+ if (contentType?.includes("application/json")) {
97
+ data = await response.json();
98
+ } else {
99
+ data = await response.text();
100
+ }
101
+ if (!response.ok) {
102
+ if (data && typeof data === "object" && "error" in data) {
103
+ throw InsForgeError.fromApiError(data);
104
+ }
105
+ throw new InsForgeError(
106
+ `Request failed: ${response.statusText}`,
107
+ response.status,
108
+ "REQUEST_FAILED"
109
+ );
110
+ }
111
+ return data;
112
+ }
113
+ get(path, options) {
114
+ return this.request("GET", path, options);
115
+ }
116
+ post(path, body, options) {
117
+ return this.request("POST", path, { ...options, body });
118
+ }
119
+ put(path, body, options) {
120
+ return this.request("PUT", path, { ...options, body });
121
+ }
122
+ patch(path, body, options) {
123
+ return this.request("PATCH", path, { ...options, body });
124
+ }
125
+ delete(path, options) {
126
+ return this.request("DELETE", path, options);
127
+ }
128
+ setAuthToken(token) {
129
+ if (token) {
130
+ this.defaultHeaders["Authorization"] = `Bearer ${token}`;
131
+ } else {
132
+ delete this.defaultHeaders["Authorization"];
133
+ }
134
+ }
135
+ };
136
+
137
+ // src/lib/token-manager.ts
138
+ var TOKEN_KEY = "insforge-auth-token";
139
+ var USER_KEY = "insforge-auth-user";
140
+ var TokenManager = class {
141
+ constructor(storage) {
142
+ if (storage) {
143
+ this.storage = storage;
144
+ } else if (typeof window !== "undefined" && window.localStorage) {
145
+ this.storage = window.localStorage;
146
+ } else {
147
+ const store = /* @__PURE__ */ new Map();
148
+ this.storage = {
149
+ getItem: (key) => store.get(key) || null,
150
+ setItem: (key, value) => {
151
+ store.set(key, value);
152
+ },
153
+ removeItem: (key) => {
154
+ store.delete(key);
155
+ }
156
+ };
157
+ }
158
+ }
159
+ saveSession(session) {
160
+ this.storage.setItem(TOKEN_KEY, session.accessToken);
161
+ this.storage.setItem(USER_KEY, JSON.stringify(session.user));
162
+ }
163
+ getSession() {
164
+ const token = this.storage.getItem(TOKEN_KEY);
165
+ const userStr = this.storage.getItem(USER_KEY);
166
+ if (!token || !userStr) {
167
+ return null;
168
+ }
169
+ try {
170
+ const user = JSON.parse(userStr);
171
+ return { accessToken: token, user };
172
+ } catch {
173
+ this.clearSession();
174
+ return null;
175
+ }
176
+ }
177
+ getAccessToken() {
178
+ const token = this.storage.getItem(TOKEN_KEY);
179
+ return typeof token === "string" ? token : null;
180
+ }
181
+ clearSession() {
182
+ this.storage.removeItem(TOKEN_KEY);
183
+ this.storage.removeItem(USER_KEY);
184
+ }
185
+ };
186
+
187
+ // src/modules/auth.ts
188
+ var Auth = class {
189
+ constructor(http, tokenManager) {
190
+ this.http = http;
191
+ this.tokenManager = tokenManager;
192
+ }
193
+ /**
194
+ * Sign up a new user
195
+ */
196
+ async signUp(request) {
197
+ try {
198
+ const response = await this.http.post("/api/auth/users", request);
199
+ const session = {
200
+ accessToken: response.accessToken,
201
+ user: response.user
202
+ };
203
+ this.tokenManager.saveSession(session);
204
+ this.http.setAuthToken(response.accessToken);
205
+ return {
206
+ data: {
207
+ user: response.user,
208
+ session
209
+ },
210
+ error: null
211
+ };
212
+ } catch (error) {
213
+ return {
214
+ data: { user: null, session: null },
215
+ error: error instanceof InsForgeError ? error : new InsForgeError(
216
+ "Failed to sign up",
217
+ 500,
218
+ "SIGNUP_ERROR"
219
+ )
220
+ };
221
+ }
222
+ }
223
+ /**
224
+ * Sign in with email and password
225
+ */
226
+ async signInWithPassword(request) {
227
+ try {
228
+ const response = await this.http.post("/api/auth/sessions", request);
229
+ const session = {
230
+ accessToken: response.accessToken,
231
+ user: response.user
232
+ };
233
+ this.tokenManager.saveSession(session);
234
+ this.http.setAuthToken(response.accessToken);
235
+ return {
236
+ data: {
237
+ user: response.user,
238
+ session
239
+ },
240
+ error: null
241
+ };
242
+ } catch (error) {
243
+ return {
244
+ data: { user: null, session: null },
245
+ error: error instanceof InsForgeError ? error : new InsForgeError(
246
+ "Invalid login credentials",
247
+ 401,
248
+ "INVALID_CREDENTIALS"
249
+ )
250
+ };
251
+ }
252
+ }
253
+ /**
254
+ * Sign in with OAuth provider
255
+ */
256
+ async signInWithOAuth(options) {
257
+ try {
258
+ const { provider, redirectTo, skipBrowserRedirect } = options;
259
+ const params = redirectTo ? { redirect_uri: redirectTo } : void 0;
260
+ const endpoint = `/api/auth/oauth/${provider}`;
261
+ const response = await this.http.get(endpoint, { params });
262
+ if (typeof window !== "undefined" && !skipBrowserRedirect) {
263
+ window.location.href = response.authUrl;
264
+ return { data: {}, error: null };
265
+ }
266
+ return {
267
+ data: {
268
+ url: response.authUrl,
269
+ provider
270
+ },
271
+ error: null
272
+ };
273
+ } catch (error) {
274
+ return {
275
+ data: {},
276
+ error: error instanceof InsForgeError ? error : new InsForgeError(
277
+ `Failed to initialize OAuth`,
278
+ 500,
279
+ "OAUTH_ERROR"
280
+ )
281
+ };
282
+ }
283
+ }
284
+ /**
285
+ * Sign out the current user
286
+ */
287
+ async signOut() {
288
+ try {
289
+ this.tokenManager.clearSession();
290
+ this.http.setAuthToken(null);
291
+ return { error: null };
292
+ } catch (error) {
293
+ return {
294
+ error: new InsForgeError(
295
+ "Failed to sign out",
296
+ 500,
297
+ "SIGNOUT_ERROR"
298
+ )
299
+ };
300
+ }
301
+ }
302
+ /**
303
+ * Get the current user from the API
304
+ * Returns exactly what the backend returns: {id, email, role}
305
+ */
306
+ async getCurrentUser() {
307
+ try {
308
+ const session = this.tokenManager.getSession();
309
+ if (!session?.accessToken) {
310
+ return { data: null, error: null };
311
+ }
312
+ this.http.setAuthToken(session.accessToken);
313
+ const response = await this.http.get("/api/auth/sessions/current");
314
+ return {
315
+ data: response,
316
+ error: null
317
+ };
318
+ } catch (error) {
319
+ if (error instanceof InsForgeError && error.statusCode === 401) {
320
+ await this.signOut();
321
+ return { data: null, error: null };
322
+ }
323
+ return {
324
+ data: null,
325
+ error: error instanceof InsForgeError ? error : new InsForgeError(
326
+ "Failed to get current user",
327
+ 500,
328
+ "GET_USER_ERROR"
329
+ )
330
+ };
331
+ }
332
+ }
333
+ /**
334
+ * Get the stored session (no API call)
335
+ */
336
+ async getSession() {
337
+ try {
338
+ const session = this.tokenManager.getSession();
339
+ if (session?.accessToken) {
340
+ this.http.setAuthToken(session.accessToken);
341
+ return { data: { session }, error: null };
342
+ }
343
+ return { data: { session: null }, error: null };
344
+ } catch (error) {
345
+ return {
346
+ data: { session: null },
347
+ error: error instanceof InsForgeError ? error : new InsForgeError(
348
+ "Failed to get session",
349
+ 500,
350
+ "GET_SESSION_ERROR"
351
+ )
352
+ };
353
+ }
354
+ }
355
+ };
356
+
357
+ // src/client.ts
358
+ var InsForgeClient = class {
359
+ constructor(config = {}) {
360
+ this.http = new HttpClient(config);
361
+ this.tokenManager = new TokenManager(config.storage);
362
+ this.auth = new Auth(
363
+ this.http,
364
+ this.tokenManager
365
+ );
366
+ }
367
+ /**
368
+ * Set a custom API key for authentication
369
+ * This is useful for server-to-server communication
370
+ *
371
+ * @param apiKey - The API key (should start with 'ik_')
372
+ *
373
+ * @example
374
+ * ```typescript
375
+ * client.setApiKey('ik_your_api_key_here');
376
+ * ```
377
+ */
378
+ setApiKey(apiKey) {
379
+ this.http.setAuthToken(apiKey);
380
+ }
381
+ /**
382
+ * Get the underlying HTTP client for custom requests
383
+ *
384
+ * @example
385
+ * ```typescript
386
+ * const httpClient = client.getHttpClient();
387
+ * const customData = await httpClient.get('/api/custom-endpoint');
388
+ * ```
389
+ */
390
+ getHttpClient() {
391
+ return this.http;
392
+ }
393
+ /**
394
+ * Future modules will be added here:
395
+ * - database: Database operations
396
+ * - storage: File storage operations
397
+ * - functions: Serverless functions
398
+ * - tables: Table management
399
+ * - metadata: Backend metadata
400
+ */
401
+ };
402
+
403
+ // src/index.ts
404
+ function createClient(config) {
405
+ return new InsForgeClient(config);
406
+ }
407
+ var index_default = InsForgeClient;
408
+ // Annotate the CommonJS export names for ESM import in node:
409
+ 0 && (module.exports = {
410
+ Auth,
411
+ HttpClient,
412
+ InsForgeClient,
413
+ InsForgeError,
414
+ TokenManager,
415
+ createClient
416
+ });
417
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/types.ts","../src/lib/http-client.ts","../src/lib/token-manager.ts","../src/modules/auth.ts","../src/client.ts"],"sourcesContent":["/**\n * @insforge/sdk - TypeScript SDK for InsForge Backend-as-a-Service\n * \n * @packageDocumentation\n */\n\n// Main client\nexport { InsForgeClient } from './client';\n\n// Types\nexport type {\n InsForgeConfig,\n InsForgeConfig as ClientOptions, // Alias for compatibility\n TokenStorage,\n AuthSession,\n ApiError,\n} from './types';\n\nexport { InsForgeError } from './types';\n\n// Re-export shared schemas that SDK users will need\nexport type {\n UserSchema,\n CreateUserRequest,\n CreateSessionRequest,\n AuthErrorResponse,\n} from '@insforge/shared-schemas';\n\n// Re-export auth module for advanced usage\nexport { Auth } from './modules/auth';\n\n// Re-export utilities for advanced usage\nexport { HttpClient } from './lib/http-client';\nexport { TokenManager } from './lib/token-manager';\n\n// Factory function for creating clients (Supabase-style)\nimport { InsForgeClient } from './client';\nimport { InsForgeConfig } from './types';\n\nexport function createClient(config: InsForgeConfig): InsForgeClient {\n return new InsForgeClient(config);\n}\n\n// Default export for convenience\nexport default InsForgeClient;","/**\n * InsForge SDK Types - only SDK-specific types here\n * Use @insforge/shared-schemas directly for API types\n */\n\nimport type { UserSchema } from '@insforge/shared-schemas';\n\nexport interface InsForgeConfig {\n /**\n * The URL of the InsForge backend API\n * @default \"http://localhost:7130\"\n */\n url?: string;\n\n /**\n * API key (optional)\n * Can be used for server-side operations or specific use cases\n */\n apiKey?: string;\n\n /**\n * Custom fetch implementation (useful for Node.js environments)\n */\n fetch?: typeof fetch;\n\n /**\n * Storage adapter for persisting tokens\n */\n storage?: TokenStorage;\n\n /**\n * Whether to automatically refresh tokens before they expire\n * @default true\n */\n autoRefreshToken?: boolean;\n\n /**\n * Whether to persist session in storage\n * @default true\n */\n persistSession?: boolean;\n\n /**\n * Custom headers to include with every request\n */\n headers?: Record<string, string>;\n}\n\nexport interface TokenStorage {\n getItem(key: string): string | null | Promise<string | null>;\n setItem(key: string, value: string): void | Promise<void>;\n removeItem(key: string): void | Promise<void>;\n}\n\nexport interface AuthSession {\n user: UserSchema;\n accessToken: string;\n expiresAt?: Date;\n}\n\nexport interface ApiError {\n error: string;\n message: string;\n statusCode: number;\n nextActions?: string;\n}\n\nexport class InsForgeError extends Error {\n public statusCode: number;\n public error: string;\n public nextActions?: string;\n\n constructor(message: string, statusCode: number, error: string, nextActions?: string) {\n super(message);\n this.name = 'InsForgeError';\n this.statusCode = statusCode;\n this.error = error;\n this.nextActions = nextActions;\n }\n\n static fromApiError(apiError: ApiError): InsForgeError {\n return new InsForgeError(\n apiError.message,\n apiError.statusCode,\n apiError.error,\n apiError.nextActions\n );\n }\n}","import { InsForgeConfig, ApiError, InsForgeError } from '../types';\n\nexport interface RequestOptions extends RequestInit {\n params?: Record<string, string>;\n}\n\nexport class HttpClient {\n private baseUrl: string;\n private fetch: typeof fetch;\n private defaultHeaders: Record<string, string>;\n\n constructor(config: InsForgeConfig) {\n this.baseUrl = config.url || 'http://localhost:7130';\n this.fetch = config.fetch || globalThis.fetch;\n this.defaultHeaders = {\n 'Content-Type': 'application/json',\n ...config.headers,\n };\n \n // Add API key if provided\n if (config.apiKey) {\n this.defaultHeaders['Authorization'] = `Bearer ${config.apiKey}`;\n }\n\n if (!this.fetch) {\n throw new Error(\n 'Fetch is not available. Please provide a fetch implementation in the config.'\n );\n }\n }\n\n private buildUrl(path: string, params?: Record<string, string>): string {\n const url = new URL(path, this.baseUrl);\n if (params) {\n Object.entries(params).forEach(([key, value]) => {\n url.searchParams.append(key, value);\n });\n }\n return url.toString();\n }\n\n async request<T>(\n method: string,\n path: string,\n options: RequestOptions = {}\n ): Promise<T> {\n const { params, headers = {}, body, ...fetchOptions } = options;\n \n const url = this.buildUrl(path, params);\n \n const response = await this.fetch(url, {\n method,\n headers: {\n ...this.defaultHeaders,\n ...headers,\n },\n body: body ? JSON.stringify(body) : undefined,\n ...fetchOptions,\n });\n\n // Handle 204 No Content\n if (response.status === 204) {\n return undefined as T;\n }\n\n // Try to parse JSON response\n let data: any;\n const contentType = response.headers.get('content-type');\n if (contentType?.includes('application/json')) {\n data = await response.json();\n } else {\n // For non-JSON responses, return text\n data = await response.text();\n }\n\n // Handle errors\n if (!response.ok) {\n if (data && typeof data === 'object' && 'error' in data) {\n throw InsForgeError.fromApiError(data as ApiError);\n }\n throw new InsForgeError(\n `Request failed: ${response.statusText}`,\n response.status,\n 'REQUEST_FAILED'\n );\n }\n\n return data as T;\n }\n\n get<T>(path: string, options?: RequestOptions): Promise<T> {\n return this.request<T>('GET', path, options);\n }\n\n post<T>(path: string, body?: any, options?: RequestOptions): Promise<T> {\n return this.request<T>('POST', path, { ...options, body });\n }\n\n put<T>(path: string, body?: any, options?: RequestOptions): Promise<T> {\n return this.request<T>('PUT', path, { ...options, body });\n }\n\n patch<T>(path: string, body?: any, options?: RequestOptions): Promise<T> {\n return this.request<T>('PATCH', path, { ...options, body });\n }\n\n delete<T>(path: string, options?: RequestOptions): Promise<T> {\n return this.request<T>('DELETE', path, options);\n }\n\n setAuthToken(token: string | null) {\n if (token) {\n this.defaultHeaders['Authorization'] = `Bearer ${token}`;\n } else {\n delete this.defaultHeaders['Authorization'];\n }\n }\n}","import { TokenStorage, AuthSession } from '../types';\n\nconst TOKEN_KEY = 'insforge-auth-token';\nconst USER_KEY = 'insforge-auth-user';\n\nexport class TokenManager {\n private storage: TokenStorage;\n\n constructor(storage?: TokenStorage) {\n if (storage) {\n // Use provided storage\n this.storage = storage;\n } else if (typeof window !== 'undefined' && window.localStorage) {\n // Browser: use localStorage\n this.storage = window.localStorage;\n } else {\n // Node.js: use in-memory storage\n const store = new Map<string, string>();\n this.storage = {\n getItem: (key: string) => store.get(key) || null,\n setItem: (key: string, value: string) => { store.set(key, value); },\n removeItem: (key: string) => { store.delete(key); }\n };\n }\n }\n\n saveSession(session: AuthSession): void {\n this.storage.setItem(TOKEN_KEY, session.accessToken);\n this.storage.setItem(USER_KEY, JSON.stringify(session.user));\n }\n\n getSession(): AuthSession | null {\n const token = this.storage.getItem(TOKEN_KEY);\n const userStr = this.storage.getItem(USER_KEY);\n\n if (!token || !userStr) {\n return null;\n }\n\n try {\n const user = JSON.parse(userStr as string);\n return { accessToken: token as string, user };\n } catch {\n this.clearSession();\n return null;\n }\n }\n\n getAccessToken(): string | null {\n const token = this.storage.getItem(TOKEN_KEY);\n return typeof token === 'string' ? token : null;\n }\n\n clearSession(): void {\n this.storage.removeItem(TOKEN_KEY);\n this.storage.removeItem(USER_KEY);\n }\n}","/**\n * Auth module for InsForge SDK\n * Uses shared schemas for type safety\n */\n\nimport { HttpClient } from '../lib/http-client';\nimport { TokenManager } from '../lib/token-manager';\nimport { AuthSession, InsForgeError } from '../types';\n\nimport type {\n UserSchema,\n CreateUserRequest,\n CreateUserResponse,\n CreateSessionRequest,\n CreateSessionResponse,\n GetCurrentSessionResponse,\n GetOauthUrlResponse,\n} from '@insforge/shared-schemas';\n\nexport class Auth {\n constructor(\n private http: HttpClient,\n private tokenManager: TokenManager\n ) {}\n\n /**\n * Sign up a new user\n */\n async signUp(request: CreateUserRequest): Promise<{\n data: { user: UserSchema | null; session: AuthSession | null };\n error: InsForgeError | null;\n }> {\n try {\n const response = await this.http.post<CreateUserResponse>('/api/auth/users', request);\n \n const session: AuthSession = {\n accessToken: response.accessToken,\n user: response.user,\n };\n\n this.tokenManager.saveSession(session);\n this.http.setAuthToken(response.accessToken);\n\n return { \n data: { \n user: response.user, \n session \n }, \n error: null \n };\n } catch (error) {\n return { \n data: { user: null, session: null }, \n error: error instanceof InsForgeError ? error : new InsForgeError(\n 'Failed to sign up',\n 500,\n 'SIGNUP_ERROR'\n )\n };\n }\n }\n\n /**\n * Sign in with email and password\n */\n async signInWithPassword(request: CreateSessionRequest): Promise<{\n data: { user: UserSchema | null; session: AuthSession | null };\n error: InsForgeError | null;\n }> {\n try {\n const response = await this.http.post<CreateSessionResponse>('/api/auth/sessions', request);\n \n const session: AuthSession = {\n accessToken: response.accessToken,\n user: response.user,\n };\n\n this.tokenManager.saveSession(session);\n this.http.setAuthToken(response.accessToken);\n\n return { \n data: { \n user: response.user, \n session \n }, \n error: null \n };\n } catch (error) {\n return { \n data: { user: null, session: null }, \n error: error instanceof InsForgeError ? error : new InsForgeError(\n 'Invalid login credentials',\n 401,\n 'INVALID_CREDENTIALS'\n )\n };\n }\n }\n\n /**\n * Sign in with OAuth provider\n */\n async signInWithOAuth(options: {\n provider: 'google' | 'github';\n redirectTo?: string;\n skipBrowserRedirect?: boolean;\n }): Promise<{\n data: { url?: string; provider?: string };\n error: InsForgeError | null;\n }> {\n try {\n const { provider, redirectTo, skipBrowserRedirect } = options;\n \n const params = redirectTo \n ? { redirect_uri: redirectTo } \n : undefined;\n \n const endpoint = `/api/auth/oauth/${provider}`;\n const response = await this.http.get<GetOauthUrlResponse>(endpoint, { params });\n \n // Automatically redirect in browser unless told not to\n if (typeof window !== 'undefined' && !skipBrowserRedirect) {\n window.location.href = response.authUrl;\n return { data: {}, error: null };\n }\n\n return { \n data: { \n url: response.authUrl,\n provider \n }, \n error: null \n };\n } catch (error) {\n return { \n data: {}, \n error: error instanceof InsForgeError ? error : new InsForgeError(\n `Failed to initialize OAuth`,\n 500,\n 'OAUTH_ERROR'\n )\n };\n }\n }\n\n /**\n * Sign out the current user\n */\n async signOut(): Promise<{ error: InsForgeError | null }> {\n try {\n this.tokenManager.clearSession();\n this.http.setAuthToken(null);\n return { error: null };\n } catch (error) {\n return { \n error: new InsForgeError(\n 'Failed to sign out',\n 500,\n 'SIGNOUT_ERROR'\n )\n };\n }\n }\n\n /**\n * Get the current user from the API\n * Returns exactly what the backend returns: {id, email, role}\n */\n async getCurrentUser(): Promise<{\n data: GetCurrentSessionResponse | null;\n error: InsForgeError | null;\n }> {\n try {\n // Check if we have a token\n const session = this.tokenManager.getSession();\n if (!session?.accessToken) {\n return { data: null, error: null };\n }\n\n // Call the API\n this.http.setAuthToken(session.accessToken);\n const response = await this.http.get<GetCurrentSessionResponse>('/api/auth/sessions/current');\n \n return {\n data: response,\n error: null\n };\n } catch (error) {\n // If unauthorized, clear session\n if (error instanceof InsForgeError && error.statusCode === 401) {\n await this.signOut();\n return { data: null, error: null };\n }\n \n return { \n data: null, \n error: error instanceof InsForgeError ? error : new InsForgeError(\n 'Failed to get current user',\n 500,\n 'GET_USER_ERROR'\n )\n };\n }\n }\n\n /**\n * Get the stored session (no API call)\n */\n async getSession(): Promise<{\n data: { session: AuthSession | null };\n error: InsForgeError | null;\n }> {\n try {\n const session = this.tokenManager.getSession();\n \n if (session?.accessToken) {\n this.http.setAuthToken(session.accessToken);\n return { data: { session }, error: null };\n }\n\n return { data: { session: null }, error: null };\n } catch (error) {\n return { \n data: { session: null }, \n error: error instanceof InsForgeError ? error : new InsForgeError(\n 'Failed to get session',\n 500,\n 'GET_SESSION_ERROR'\n )\n };\n }\n }\n\n}","import { InsForgeConfig } from './types';\nimport { HttpClient } from './lib/http-client';\nimport { TokenManager } from './lib/token-manager';\nimport { Auth } from './modules/auth';\n\n/**\n * Main InsForge SDK Client\n * \n * @example\n * ```typescript\n * import { InsForgeClient } from '@insforge/sdk';\n * \n * const client = new InsForgeClient({\n * baseUrl: 'http://localhost:7130'\n * });\n * \n * // Register a new user\n * const session = await client.auth.register({\n * email: 'user@example.com',\n * password: 'password123',\n * name: 'John Doe'\n * });\n * \n * // Or login\n * const session = await client.auth.login({\n * email: 'user@example.com',\n * password: 'password123'\n * });\n * \n * // Get current user\n * const user = await client.auth.getCurrentUser();\n * ```\n */\nexport class InsForgeClient {\n private http: HttpClient;\n private tokenManager: TokenManager;\n \n /**\n * Authentication module\n */\n public readonly auth: Auth;\n\n constructor(config: InsForgeConfig = {}) {\n // Initialize HTTP client\n this.http = new HttpClient(config);\n \n // Initialize token manager with storage\n this.tokenManager = new TokenManager(config.storage);\n \n // Initialize auth module\n this.auth = new Auth(\n this.http,\n this.tokenManager\n );\n }\n\n\n /**\n * Set a custom API key for authentication\n * This is useful for server-to-server communication\n * \n * @param apiKey - The API key (should start with 'ik_')\n * \n * @example\n * ```typescript\n * client.setApiKey('ik_your_api_key_here');\n * ```\n */\n setApiKey(apiKey: string): void {\n // API keys can be used as Bearer tokens\n this.http.setAuthToken(apiKey);\n }\n\n /**\n * Get the underlying HTTP client for custom requests\n * \n * @example\n * ```typescript\n * const httpClient = client.getHttpClient();\n * const customData = await httpClient.get('/api/custom-endpoint');\n * ```\n */\n getHttpClient(): HttpClient {\n return this.http;\n }\n\n /**\n * Future modules will be added here:\n * - database: Database operations\n * - storage: File storage operations\n * - functions: Serverless functions\n * - tables: Table management\n * - metadata: Backend metadata\n */\n}"],"mappings":"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","names":[]}