@nxcode/sdk 1.0.0 → 1.0.5

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.
@@ -400,6 +400,313 @@ class NxcodePayment {
400
400
  }
401
401
  }
402
402
 
403
+ /**
404
+ * Nxcode SDK - AI Module
405
+ *
406
+ * Provides access to AI capabilities through the Nxcode AI Gateway.
407
+ * All AI calls require user authentication and are billed to the user's balance.
408
+ */
409
+ /**
410
+ * Convert simplified schema to JSON Schema (Gemini format)
411
+ */
412
+ function toJsonSchema(schema) {
413
+ // Primitive types
414
+ if (schema === 'string') {
415
+ return { type: 'STRING' };
416
+ }
417
+ if (schema === 'number') {
418
+ return { type: 'NUMBER' };
419
+ }
420
+ if (schema === 'boolean') {
421
+ return { type: 'BOOLEAN' };
422
+ }
423
+ // Array type
424
+ if (Array.isArray(schema)) {
425
+ if (schema.length !== 1) {
426
+ throw new Error('Array schema must have exactly one element type');
427
+ }
428
+ return {
429
+ type: 'ARRAY',
430
+ items: toJsonSchema(schema[0]),
431
+ };
432
+ }
433
+ // Object type
434
+ if (typeof schema === 'object' && schema !== null) {
435
+ const properties = {};
436
+ const required = [];
437
+ for (const [key, value] of Object.entries(schema)) {
438
+ properties[key] = toJsonSchema(value);
439
+ required.push(key); // All fields required by default
440
+ }
441
+ return {
442
+ type: 'OBJECT',
443
+ properties,
444
+ required,
445
+ };
446
+ }
447
+ throw new Error(`Invalid schema type: ${schema}`);
448
+ }
449
+ class NxcodeAI {
450
+ constructor(apiEndpoint, appId, getToken) {
451
+ this.apiEndpoint = apiEndpoint;
452
+ this.appId = appId;
453
+ this.getToken = getToken;
454
+ }
455
+ /**
456
+ * Send a chat message and get a response.
457
+ *
458
+ * @example
459
+ * const response = await Nxcode.ai.chat({
460
+ * messages: [
461
+ * { role: 'user', content: 'Hello!' }
462
+ * ]
463
+ * });
464
+ * console.log(response.content);
465
+ */
466
+ async chat(options) {
467
+ const token = this.getToken();
468
+ if (!token) {
469
+ throw new Error('Not authenticated. Please login first.');
470
+ }
471
+ const model = options.model || 'fast';
472
+ // Build Gemini API request
473
+ const geminiRequest = {
474
+ contents: this.convertMessagesToGemini(options.messages),
475
+ };
476
+ // Add structured output config if schema provided
477
+ if (options.responseSchema) {
478
+ geminiRequest.generationConfig = {
479
+ responseMimeType: 'application/json',
480
+ responseSchema: toJsonSchema(options.responseSchema),
481
+ };
482
+ }
483
+ const response = await fetch(`${this.apiEndpoint}/api/ai-gateway/v1beta/models/${model}:generateContent`, {
484
+ method: 'POST',
485
+ headers: this.getHeaders(token),
486
+ body: JSON.stringify(geminiRequest),
487
+ });
488
+ if (!response.ok) {
489
+ await this.handleError(response);
490
+ }
491
+ const data = await response.json();
492
+ return this.parseGeminiResponse(data);
493
+ }
494
+ /**
495
+ * Generate text from a prompt.
496
+ *
497
+ * @example
498
+ * const response = await Nxcode.ai.generate({
499
+ * prompt: 'Write a haiku about coding'
500
+ * });
501
+ * console.log(response.text);
502
+ */
503
+ async generate(options) {
504
+ const result = await this.chat({
505
+ messages: [{ role: 'user', content: options.prompt }],
506
+ model: options.model,
507
+ responseSchema: options.responseSchema,
508
+ });
509
+ return {
510
+ text: result.content,
511
+ usage: result.usage,
512
+ };
513
+ }
514
+ /**
515
+ * Stream a chat response in real-time.
516
+ *
517
+ * @example
518
+ * await Nxcode.ai.chatStream({
519
+ * messages: [{ role: 'user', content: 'Tell me a story' }],
520
+ * onChunk: (chunk) => {
521
+ * process.stdout.write(chunk.content);
522
+ * if (chunk.done) console.log('\n--- Done ---');
523
+ * }
524
+ * });
525
+ */
526
+ async chatStream(options) {
527
+ const token = this.getToken();
528
+ // Allow anonymous streaming if app permits
529
+ const headers = token ? this.getHeaders(token) : this.getAnonymousHeaders();
530
+ const model = options.model || 'fast';
531
+ const geminiRequest = {
532
+ contents: this.convertMessagesToGemini(options.messages),
533
+ };
534
+ const response = await fetch(`${this.apiEndpoint}/api/ai-gateway/v1beta/models/${model}:streamGenerateContent?alt=sse`, {
535
+ method: 'POST',
536
+ headers,
537
+ body: JSON.stringify(geminiRequest),
538
+ });
539
+ if (!response.ok) {
540
+ await this.handleError(response);
541
+ }
542
+ const reader = response.body?.getReader();
543
+ if (!reader) {
544
+ throw new Error('Streaming not supported');
545
+ }
546
+ const decoder = new TextDecoder();
547
+ let buffer = '';
548
+ try {
549
+ while (true) {
550
+ const { done, value } = await reader.read();
551
+ if (done)
552
+ break;
553
+ buffer += decoder.decode(value, { stream: true });
554
+ const lines = buffer.split('\n');
555
+ buffer = lines.pop() || '';
556
+ for (const line of lines) {
557
+ if (line.startsWith('data: ')) {
558
+ const jsonStr = line.slice(6).trim();
559
+ if (jsonStr === '[DONE]') {
560
+ options.onChunk({ content: '', done: true });
561
+ return;
562
+ }
563
+ try {
564
+ const data = JSON.parse(jsonStr);
565
+ const chunk = this.parseStreamChunk(data);
566
+ options.onChunk(chunk);
567
+ }
568
+ catch {
569
+ // Skip invalid JSON
570
+ }
571
+ }
572
+ }
573
+ }
574
+ // Process remaining buffer
575
+ if (buffer.startsWith('data: ')) {
576
+ const jsonStr = buffer.slice(6).trim();
577
+ if (jsonStr && jsonStr !== '[DONE]') {
578
+ try {
579
+ const data = JSON.parse(jsonStr);
580
+ const chunk = this.parseStreamChunk(data);
581
+ options.onChunk(chunk);
582
+ }
583
+ catch {
584
+ // Skip invalid JSON
585
+ }
586
+ }
587
+ }
588
+ options.onChunk({ content: '', done: true });
589
+ }
590
+ finally {
591
+ reader.releaseLock();
592
+ }
593
+ }
594
+ /**
595
+ * Stream text generation from a prompt.
596
+ *
597
+ * @example
598
+ * await Nxcode.ai.generateStream({
599
+ * prompt: 'Write a poem',
600
+ * onChunk: (chunk) => console.log(chunk.content)
601
+ * });
602
+ */
603
+ async generateStream(options) {
604
+ return this.chatStream({
605
+ messages: [{ role: 'user', content: options.prompt }],
606
+ model: options.model,
607
+ onChunk: options.onChunk,
608
+ });
609
+ }
610
+ // ==================== Private Methods ====================
611
+ getHeaders(token) {
612
+ return {
613
+ 'Content-Type': 'application/json',
614
+ 'X-App-Id': this.appId,
615
+ Authorization: `Bearer ${token}`,
616
+ };
617
+ }
618
+ getAnonymousHeaders() {
619
+ return {
620
+ 'Content-Type': 'application/json',
621
+ 'X-App-Id': this.appId,
622
+ };
623
+ }
624
+ convertMessagesToGemini(messages) {
625
+ return messages.map((msg) => ({
626
+ role: msg.role === 'assistant' ? 'model' : 'user',
627
+ parts: this.convertContentToParts(msg.content),
628
+ }));
629
+ }
630
+ convertContentToParts(content) {
631
+ // Simple text content
632
+ if (typeof content === 'string') {
633
+ return [{ text: content }];
634
+ }
635
+ // Multimodal content
636
+ return content.map((part) => {
637
+ switch (part.type) {
638
+ case 'text':
639
+ return { text: part.text };
640
+ case 'image':
641
+ // Gemini format: inlineData with base64
642
+ return {
643
+ inlineData: {
644
+ mimeType: part.mimeType,
645
+ data: part.data,
646
+ },
647
+ };
648
+ case 'image_url':
649
+ // Gemini format: fileData with URL
650
+ return {
651
+ fileData: {
652
+ fileUri: part.url,
653
+ },
654
+ };
655
+ default:
656
+ return { text: '' };
657
+ }
658
+ });
659
+ }
660
+ parseGeminiResponse(data) {
661
+ const candidates = data.candidates;
662
+ const content = candidates?.[0]?.content?.parts?.[0]?.text || '';
663
+ const usageMetadata = data.usageMetadata;
664
+ return {
665
+ content,
666
+ usage: usageMetadata
667
+ ? {
668
+ inputTokens: usageMetadata.promptTokenCount || 0,
669
+ outputTokens: usageMetadata.candidatesTokenCount || 0,
670
+ }
671
+ : undefined,
672
+ };
673
+ }
674
+ parseStreamChunk(data) {
675
+ const candidates = data.candidates;
676
+ const content = candidates?.[0]?.content?.parts?.[0]?.text || '';
677
+ const finishReason = candidates?.[0]?.finishReason;
678
+ const done = finishReason === 'STOP' || finishReason === 'END_TURN';
679
+ const usageMetadata = data.usageMetadata;
680
+ return {
681
+ content,
682
+ done,
683
+ usage: usageMetadata
684
+ ? {
685
+ inputTokens: usageMetadata.promptTokenCount || 0,
686
+ outputTokens: usageMetadata.candidatesTokenCount || 0,
687
+ }
688
+ : undefined,
689
+ };
690
+ }
691
+ async handleError(response) {
692
+ if (response.status === 401) {
693
+ throw new Error('Session expired. Please login again.');
694
+ }
695
+ if (response.status === 402) {
696
+ throw new Error('Insufficient balance. Please top up to continue.');
697
+ }
698
+ let message = 'AI request failed';
699
+ try {
700
+ const data = await response.json();
701
+ message = data.detail || data.message || message;
702
+ }
703
+ catch {
704
+ // Ignore parse errors
705
+ }
706
+ throw new Error(message);
707
+ }
708
+ }
709
+
403
710
  /**
404
711
  * Nxcode SDK
405
712
  *
@@ -421,6 +728,7 @@ class NxcodeSDK {
421
728
  this._auth = null;
422
729
  this._billing = null;
423
730
  this._payment = null;
731
+ this._ai = null;
424
732
  this.initPromise = null;
425
733
  this.apiEndpoint = this.detectApiEndpoint();
426
734
  this.autoInit();
@@ -454,9 +762,12 @@ class NxcodeSDK {
454
762
  }
455
763
  }
456
764
  /**
457
- * Manually configure SDK with app ID
765
+ * Manually configure SDK with app ID and optional endpoint
458
766
  */
459
- configure(appId) {
767
+ configure(appId, options) {
768
+ if (options?.apiEndpoint) {
769
+ this.apiEndpoint = options.apiEndpoint;
770
+ }
460
771
  this.config = {
461
772
  appId,
462
773
  name: '',
@@ -474,6 +785,7 @@ class NxcodeSDK {
474
785
  this._auth = new NxcodeAuth(this.config.apiEndpoint, this.config.appId);
475
786
  this._billing = new NxcodeBilling(this.config.apiEndpoint, this.config.appId, () => this._auth?.getToken() || null);
476
787
  this._payment = new NxcodePayment(this.config.apiEndpoint, this.config.appId, () => this._auth?.getToken() || null);
788
+ this._ai = new NxcodeAI(this.config.apiEndpoint, this.config.appId, () => this._auth?.getToken() || null);
477
789
  }
478
790
  /**
479
791
  * Detect API endpoint based on environment
@@ -604,6 +916,63 @@ class NxcodeSDK {
604
916
  },
605
917
  };
606
918
  }
919
+ // ==================== AI Module ====================
920
+ get ai() {
921
+ const self = this;
922
+ return {
923
+ /**
924
+ * Send a chat message and get a response
925
+ *
926
+ * @example
927
+ * const response = await Nxcode.ai.chat({
928
+ * messages: [{ role: 'user', content: 'Hello!' }]
929
+ * });
930
+ */
931
+ async chat(options) {
932
+ await self.ensureInitialized();
933
+ return self._ai.chat(options);
934
+ },
935
+ /**
936
+ * Generate text from a prompt
937
+ *
938
+ * @example
939
+ * const response = await Nxcode.ai.generate({ prompt: 'Write a haiku' });
940
+ */
941
+ async generate(options) {
942
+ await self.ensureInitialized();
943
+ return self._ai.generate(options);
944
+ },
945
+ /**
946
+ * Stream a chat response in real-time
947
+ *
948
+ * @example
949
+ * await Nxcode.ai.chatStream({
950
+ * messages: [{ role: 'user', content: 'Tell me a story' }],
951
+ * onChunk: (chunk) => {
952
+ * document.body.innerText += chunk.content;
953
+ * if (chunk.done) console.log('Done!');
954
+ * }
955
+ * });
956
+ */
957
+ async chatStream(options) {
958
+ await self.ensureInitialized();
959
+ return self._ai.chatStream(options);
960
+ },
961
+ /**
962
+ * Stream text generation from a prompt
963
+ *
964
+ * @example
965
+ * await Nxcode.ai.generateStream({
966
+ * prompt: 'Write a poem',
967
+ * onChunk: (chunk) => console.log(chunk.content)
968
+ * });
969
+ */
970
+ async generateStream(options) {
971
+ await self.ensureInitialized();
972
+ return self._ai.generateStream(options);
973
+ },
974
+ };
975
+ }
607
976
  // ==================== Utility Methods ====================
608
977
  /**
609
978
  * Get current configuration
@@ -1 +1 @@
1
- {"version":3,"file":"nxcode.esm.js","sources":["../src/auth.ts","../src/billing.ts","../src/payment.ts","../src/index.ts"],"sourcesContent":["/**\n * Nxcode SDK - Authentication Module\n */\n\nimport type { NxcodeUser, AuthResult, AuthStateCallback } from './types';\n\nconst STORAGE_KEY = 'nxcode_sdk_auth';\n\ninterface StoredAuth {\n token: string;\n refreshToken: string;\n expiresAt: string;\n user: NxcodeUser;\n}\n\nexport class NxcodeAuth {\n private apiEndpoint: string;\n private appId: string;\n private user: NxcodeUser | null = null;\n private token: string | null = null;\n private refreshToken: string | null = null;\n private expiresAt: Date | null = null;\n private authCallbacks: AuthStateCallback[] = [];\n private popupWindow: Window | null = null;\n private messageHandler: ((event: MessageEvent) => void) | null = null;\n\n constructor(apiEndpoint: string, appId: string) {\n this.apiEndpoint = apiEndpoint;\n this.appId = appId;\n this.loadFromStorage();\n this.setupMessageListener();\n }\n\n /**\n * Initiate login flow via OAuth popup\n */\n async login(provider: 'google' | 'github' = 'google'): Promise<NxcodeUser> {\n return new Promise((resolve, reject) => {\n // Open popup\n const width = 500;\n const height = 600;\n const left = window.screenX + (window.outerWidth - width) / 2;\n const top = window.screenY + (window.outerHeight - height) / 2;\n\n const loginUrl = `${this.apiEndpoint}/api/sdk/auth/login?app_id=${this.appId}&provider=${provider}`;\n\n this.popupWindow = window.open(\n loginUrl,\n 'nxcode_login',\n `width=${width},height=${height},left=${left},top=${top}`\n );\n\n if (!this.popupWindow) {\n reject(new Error('Failed to open login popup. Please allow popups for this site.'));\n return;\n }\n\n // Set up timeout\n const timeout = setTimeout(() => {\n this.popupWindow?.close();\n reject(new Error('Login timeout'));\n }, 120000); // 2 minute timeout\n\n // Wait for message from popup\n const handleMessage = (event: MessageEvent) => {\n if (event.data?.type !== 'NXCODE_SDK_AUTH') return;\n\n clearTimeout(timeout);\n window.removeEventListener('message', handleMessage);\n\n const result: AuthResult = event.data.payload;\n\n if (result.success && result.user && result.token) {\n this.setAuth(result);\n resolve(result.user);\n } else {\n reject(new Error(result.error || 'Login failed'));\n }\n };\n\n window.addEventListener('message', handleMessage);\n });\n }\n\n /**\n * Logout and clear session\n */\n async logout(): Promise<void> {\n try {\n if (this.token) {\n await fetch(`${this.apiEndpoint}/api/sdk/auth/logout`, {\n method: 'POST',\n headers: this.getHeaders(),\n });\n }\n } catch (error) {\n console.warn('Logout request failed:', error);\n }\n\n this.clearAuth();\n }\n\n /**\n * Get current user\n */\n getUser(): NxcodeUser | null {\n return this.user;\n }\n\n /**\n * Get current auth token\n */\n getToken(): string | null {\n // Check if token is expired\n if (this.expiresAt && new Date() > this.expiresAt) {\n // Token is expired, need to refresh\n // Start refresh in background but don't return the expired token\n this.refreshSession().catch(console.error);\n // Return null to force re-auth rather than using expired token\n return null;\n }\n return this.token;\n }\n\n /**\n * Get token, refreshing if needed (async version)\n */\n async getValidToken(): Promise<string | null> {\n if (this.expiresAt && new Date() > this.expiresAt) {\n await this.refreshSession();\n }\n return this.token;\n }\n\n /**\n * Register callback for auth state changes\n */\n onAuthStateChange(callback: AuthStateCallback): () => void {\n this.authCallbacks.push(callback);\n\n // Call immediately with current state\n callback(this.user);\n\n // Return unsubscribe function\n return () => {\n const index = this.authCallbacks.indexOf(callback);\n if (index > -1) {\n this.authCallbacks.splice(index, 1);\n }\n };\n }\n\n /**\n * Check if user is logged in\n */\n isLoggedIn(): boolean {\n return this.user !== null && this.token !== null;\n }\n\n /**\n * Refresh the current session\n */\n async refreshSession(): Promise<void> {\n if (!this.refreshToken) {\n this.clearAuth();\n return;\n }\n\n try {\n const response = await fetch(`${this.apiEndpoint}/api/sdk/auth/refresh`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n },\n body: JSON.stringify({ refreshToken: this.refreshToken }),\n });\n\n if (!response.ok) {\n throw new Error('Refresh failed');\n }\n\n const data = await response.json();\n this.setAuth({\n success: true,\n token: data.token,\n refreshToken: data.refreshToken,\n expiresAt: data.expiresAt,\n user: data.user,\n });\n } catch (error) {\n console.error('Session refresh failed:', error);\n this.clearAuth();\n }\n }\n\n /**\n * Fetch current user info from server\n */\n async fetchUser(): Promise<NxcodeUser | null> {\n if (!this.token) return null;\n\n try {\n const response = await fetch(`${this.apiEndpoint}/api/sdk/auth/me`, {\n headers: this.getHeaders(),\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n await this.refreshSession();\n return this.user;\n }\n throw new Error('Failed to fetch user');\n }\n\n const user = await response.json();\n this.user = user;\n this.notifyAuthChange();\n this.saveToStorage();\n\n return user;\n } catch (error) {\n console.error('Failed to fetch user:', error);\n return null;\n }\n }\n\n // ==================== Private Methods ====================\n\n private setAuth(result: AuthResult): void {\n if (result.success && result.user && result.token) {\n this.user = result.user;\n this.token = result.token;\n this.refreshToken = result.refreshToken || null;\n this.expiresAt = result.expiresAt ? new Date(result.expiresAt) : null;\n\n this.saveToStorage();\n this.notifyAuthChange();\n }\n }\n\n private clearAuth(): void {\n this.user = null;\n this.token = null;\n this.refreshToken = null;\n this.expiresAt = null;\n\n localStorage.removeItem(`${STORAGE_KEY}_${this.appId}`);\n this.notifyAuthChange();\n }\n\n private saveToStorage(): void {\n if (this.user && this.token) {\n const data: StoredAuth = {\n token: this.token,\n refreshToken: this.refreshToken || '',\n expiresAt: this.expiresAt?.toISOString() || '',\n user: this.user,\n };\n localStorage.setItem(`${STORAGE_KEY}_${this.appId}`, JSON.stringify(data));\n }\n }\n\n private loadFromStorage(): void {\n try {\n const stored = localStorage.getItem(`${STORAGE_KEY}_${this.appId}`);\n if (stored) {\n const data: StoredAuth = JSON.parse(stored);\n this.token = data.token;\n this.refreshToken = data.refreshToken;\n this.expiresAt = data.expiresAt ? new Date(data.expiresAt) : null;\n this.user = data.user;\n\n // Check if expired\n if (this.expiresAt && new Date() > this.expiresAt) {\n this.refreshSession().catch(() => this.clearAuth());\n }\n }\n } catch (error) {\n console.warn('Failed to load auth from storage:', error);\n }\n }\n\n private notifyAuthChange(): void {\n for (const callback of this.authCallbacks) {\n try {\n callback(this.user);\n } catch (error) {\n console.error('Auth callback error:', error);\n }\n }\n }\n\n private setupMessageListener(): void {\n // Already set up message handling in login()\n }\n\n private getHeaders(): HeadersInit {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n };\n\n if (this.token) {\n headers['Authorization'] = `Bearer ${this.token}`;\n }\n\n return headers;\n }\n}\n","/**\n * Nxcode SDK - Billing Module\n */\n\nexport class NxcodeBilling {\n private apiEndpoint: string;\n private appId: string;\n private getToken: () => string | null;\n\n constructor(\n apiEndpoint: string,\n appId: string,\n getToken: () => string | null\n ) {\n this.apiEndpoint = apiEndpoint;\n this.appId = appId;\n this.getToken = getToken;\n }\n\n /**\n * Get user's current balance\n */\n async getBalance(): Promise<number> {\n const token = this.getToken();\n if (!token) {\n throw new Error('Not authenticated. Please login first.');\n }\n\n const response = await fetch(`${this.apiEndpoint}/api/sdk/billing/balance`, {\n headers: this.getHeaders(token),\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n throw new Error('Session expired. Please login again.');\n }\n throw new Error('Failed to fetch balance');\n }\n\n const data = await response.json();\n return data.balance;\n }\n\n /**\n * Open top-up page in new tab\n */\n topUp(): void {\n const topUpUrl = `${this.apiEndpoint}/api/sdk/billing/topup?app_id=${this.appId}`;\n window.open(topUpUrl, '_blank');\n }\n\n // ==================== Private Methods ====================\n\n private getHeaders(token: string): HeadersInit {\n return {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n 'Authorization': `Bearer ${token}`,\n };\n }\n}\n","/**\n * Nxcode SDK - Payment Module\n */\n\nimport type { ChargeOptions, ChargeResult, Transaction } from './types';\n\nexport class NxcodePayment {\n private apiEndpoint: string;\n private appId: string;\n private getToken: () => string | null;\n\n constructor(\n apiEndpoint: string,\n appId: string,\n getToken: () => string | null\n ) {\n this.apiEndpoint = apiEndpoint;\n this.appId = appId;\n this.getToken = getToken;\n }\n\n /**\n * Process an in-app purchase\n *\n * @param options - Charge options\n * @returns Charge result with transaction details\n */\n async charge(options: ChargeOptions): Promise<ChargeResult> {\n const token = this.getToken();\n if (!token) {\n return {\n success: false,\n error: 'Not authenticated. Please login first.',\n };\n }\n\n try {\n const response = await fetch(`${this.apiEndpoint}/api/sdk/payment/charge`, {\n method: 'POST',\n headers: this.getHeaders(token),\n body: JSON.stringify({\n amount: options.amount,\n description: options.description,\n metadata: options.metadata,\n }),\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n return {\n success: false,\n error: 'Session expired. Please login again.',\n };\n }\n if (response.status === 402) {\n return {\n success: false,\n error: 'Insufficient balance. Please top up.',\n };\n }\n\n const errorData = await response.json().catch(() => ({}));\n return {\n success: false,\n error: errorData.detail || 'Payment failed',\n };\n }\n\n const result = await response.json();\n return result;\n } catch (error) {\n return {\n success: false,\n error: error instanceof Error ? error.message : 'Payment failed',\n };\n }\n }\n\n /**\n * Get user's transaction history\n *\n * @param limit - Maximum number of transactions to return\n * @param offset - Pagination offset\n * @returns Array of transactions\n */\n async getTransactions(limit = 50, offset = 0): Promise<Transaction[]> {\n const token = this.getToken();\n if (!token) {\n throw new Error('Not authenticated. Please login first.');\n }\n\n const response = await fetch(\n `${this.apiEndpoint}/api/sdk/payment/transactions?limit=${limit}&offset=${offset}`,\n {\n headers: this.getHeaders(token),\n }\n );\n\n if (!response.ok) {\n if (response.status === 401) {\n throw new Error('Session expired. Please login again.');\n }\n throw new Error('Failed to fetch transactions');\n }\n\n const data = await response.json();\n return data.transactions;\n }\n\n // ==================== Private Methods ====================\n\n private getHeaders(token: string): HeadersInit {\n return {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n 'Authorization': `Bearer ${token}`,\n };\n }\n}\n","/**\n * Nxcode SDK\n *\n * A lightweight SDK for integrating Nxcode authentication, billing,\n * and payment features into web applications.\n *\n * Usage:\n * <script src=\"https://sdk.nxcode.io/v1/nxcode.js\"></script>\n * <script>\n * const user = await Nxcode.auth.login();\n * console.log('Logged in:', user.email);\n * </script>\n */\n\nimport { NxcodeAuth } from './auth';\nimport { NxcodeBilling } from './billing';\nimport { NxcodePayment } from './payment';\nimport type {\n NxcodeUser,\n NxcodeConfig,\n ChargeOptions,\n ChargeResult,\n Transaction,\n AuthStateCallback,\n} from './types';\n\n// API endpoint - auto-detect or use default\nconst DEFAULT_API_ENDPOINT = 'https://studio-api.nxcode.io';\n\nclass NxcodeSDK {\n private config: NxcodeConfig | null = null;\n private _auth: NxcodeAuth | null = null;\n private _billing: NxcodeBilling | null = null;\n private _payment: NxcodePayment | null = null;\n private initPromise: Promise<void> | null = null;\n private apiEndpoint: string;\n\n constructor() {\n this.apiEndpoint = this.detectApiEndpoint();\n this.autoInit();\n }\n\n /**\n * Auto-initialize SDK based on environment\n */\n private async autoInit(): Promise<void> {\n if (this.initPromise) return this.initPromise;\n\n this.initPromise = this.init();\n return this.initPromise;\n }\n\n /**\n * Initialize SDK by fetching configuration\n */\n private async init(): Promise<void> {\n try {\n // Try to get config from server\n const response = await fetch(`${this.apiEndpoint}/api/sdk/config`, {\n credentials: 'include',\n });\n\n if (response.ok) {\n this.config = await response.json();\n this.config!.apiEndpoint = this.apiEndpoint;\n this.setupModules();\n }\n } catch (error) {\n console.warn('Nxcode SDK: Could not auto-detect app config. Call Nxcode.configure() manually.');\n }\n }\n\n /**\n * Manually configure SDK with app ID\n */\n configure(appId: string): void {\n this.config = {\n appId,\n name: '',\n billingMode: 'creator_pays',\n apiEndpoint: this.apiEndpoint,\n };\n this.setupModules();\n }\n\n /**\n * Set up SDK modules after configuration\n */\n private setupModules(): void {\n if (!this.config) return;\n\n this._auth = new NxcodeAuth(this.config.apiEndpoint, this.config.appId);\n this._billing = new NxcodeBilling(\n this.config.apiEndpoint,\n this.config.appId,\n () => this._auth?.getToken() || null\n );\n this._payment = new NxcodePayment(\n this.config.apiEndpoint,\n this.config.appId,\n () => this._auth?.getToken() || null\n );\n }\n\n /**\n * Detect API endpoint based on environment\n */\n private detectApiEndpoint(): string {\n if (typeof window !== 'undefined') {\n const hostname = window.location.hostname;\n\n // Development environment\n if (hostname === 'localhost' || hostname === '127.0.0.1') {\n return 'http://localhost:8001';\n }\n\n // Check for dev environment\n if (hostname.includes('.nxcode.dev') || hostname.includes('.nxcode.app')) {\n return 'https://studio-api.nxcode.io';\n }\n }\n\n return DEFAULT_API_ENDPOINT;\n }\n\n /**\n * Ensure SDK is initialized before operations\n */\n private async ensureInitialized(): Promise<void> {\n if (this.initPromise) {\n await this.initPromise;\n }\n\n if (!this.config) {\n throw new Error(\n 'Nxcode SDK not configured. Add X-App-Id header or call Nxcode.configure(appId).'\n );\n }\n }\n\n // ==================== Auth Module ====================\n\n get auth() {\n const self = this;\n\n return {\n /**\n * Login via OAuth popup\n */\n async login(provider: 'google' | 'github' = 'google'): Promise<NxcodeUser> {\n await self.ensureInitialized();\n return self._auth!.login(provider);\n },\n\n /**\n * Logout current user\n */\n async logout(): Promise<void> {\n await self.ensureInitialized();\n return self._auth!.logout();\n },\n\n /**\n * Get current user\n */\n getUser(): NxcodeUser | null {\n return self._auth?.getUser() || null;\n },\n\n /**\n * Get auth token for API calls\n */\n getToken(): string | null {\n return self._auth?.getToken() || null;\n },\n\n /**\n * Register auth state change callback\n */\n onAuthStateChange(callback: AuthStateCallback): () => void {\n if (!self._auth) {\n // Store the actual unsubscribe function when SDK initializes\n let actualUnsubscribe: (() => void) | null = null;\n let cancelled = false;\n\n // Queue callback until initialized\n self.ensureInitialized().then(() => {\n if (!cancelled && self._auth) {\n actualUnsubscribe = self._auth.onAuthStateChange(callback);\n }\n });\n\n // Return unsubscribe that handles both immediate and deferred cases\n return () => {\n cancelled = true;\n if (actualUnsubscribe) {\n actualUnsubscribe();\n }\n };\n }\n return self._auth.onAuthStateChange(callback);\n },\n\n /**\n * Check if user is logged in\n */\n isLoggedIn(): boolean {\n return self._auth?.isLoggedIn() || false;\n },\n };\n }\n\n // ==================== Billing Module ====================\n\n get billing() {\n const self = this;\n\n return {\n /**\n * Get user's current balance\n */\n async getBalance(): Promise<number> {\n await self.ensureInitialized();\n return self._billing!.getBalance();\n },\n\n /**\n * Open top-up page\n */\n topUp(): void {\n self._billing?.topUp();\n },\n };\n }\n\n // ==================== Payment Module ====================\n\n get payment() {\n const self = this;\n\n return {\n /**\n * Process in-app purchase\n */\n async charge(options: ChargeOptions): Promise<ChargeResult> {\n await self.ensureInitialized();\n return self._payment!.charge(options);\n },\n\n /**\n * Get transaction history\n */\n async getTransactions(limit?: number, offset?: number): Promise<Transaction[]> {\n await self.ensureInitialized();\n return self._payment!.getTransactions(limit, offset);\n },\n };\n }\n\n // ==================== Utility Methods ====================\n\n /**\n * Get current configuration\n */\n getConfig(): NxcodeConfig | null {\n return this.config;\n }\n\n /**\n * Check if SDK is ready\n */\n isReady(): boolean {\n return this.config !== null && this._auth !== null;\n }\n\n /**\n * Wait for SDK to be ready\n */\n async ready(): Promise<void> {\n await this.ensureInitialized();\n }\n}\n\n// Create singleton instance\nconst Nxcode = new NxcodeSDK();\n\n// Export for UMD (browser global)\nif (typeof window !== 'undefined') {\n (window as unknown as { Nxcode: typeof Nxcode }).Nxcode = Nxcode;\n}\n\n// Export for ESM\nexport default Nxcode;\nexport { Nxcode };\nexport type {\n NxcodeUser,\n NxcodeConfig,\n ChargeOptions,\n ChargeResult,\n Transaction,\n AuthStateCallback,\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"nxcode.esm.js","sources":["../src/auth.ts","../src/billing.ts","../src/payment.ts","../src/ai.ts","../src/index.ts"],"sourcesContent":["/**\n * Nxcode SDK - Authentication Module\n */\n\nimport type { NxcodeUser, AuthResult, AuthStateCallback } from './types';\n\nconst STORAGE_KEY = 'nxcode_sdk_auth';\n\ninterface StoredAuth {\n token: string;\n refreshToken: string;\n expiresAt: string;\n user: NxcodeUser;\n}\n\nexport class NxcodeAuth {\n private apiEndpoint: string;\n private appId: string;\n private user: NxcodeUser | null = null;\n private token: string | null = null;\n private refreshToken: string | null = null;\n private expiresAt: Date | null = null;\n private authCallbacks: AuthStateCallback[] = [];\n private popupWindow: Window | null = null;\n private messageHandler: ((event: MessageEvent) => void) | null = null;\n\n constructor(apiEndpoint: string, appId: string) {\n this.apiEndpoint = apiEndpoint;\n this.appId = appId;\n this.loadFromStorage();\n this.setupMessageListener();\n }\n\n /**\n * Initiate login flow via OAuth popup\n */\n async login(provider: 'google' | 'github' = 'google'): Promise<NxcodeUser> {\n return new Promise((resolve, reject) => {\n // Open popup\n const width = 500;\n const height = 600;\n const left = window.screenX + (window.outerWidth - width) / 2;\n const top = window.screenY + (window.outerHeight - height) / 2;\n\n const loginUrl = `${this.apiEndpoint}/api/sdk/auth/login?app_id=${this.appId}&provider=${provider}`;\n\n this.popupWindow = window.open(\n loginUrl,\n 'nxcode_login',\n `width=${width},height=${height},left=${left},top=${top}`\n );\n\n if (!this.popupWindow) {\n reject(new Error('Failed to open login popup. Please allow popups for this site.'));\n return;\n }\n\n // Set up timeout\n const timeout = setTimeout(() => {\n this.popupWindow?.close();\n reject(new Error('Login timeout'));\n }, 120000); // 2 minute timeout\n\n // Wait for message from popup\n const handleMessage = (event: MessageEvent) => {\n if (event.data?.type !== 'NXCODE_SDK_AUTH') return;\n\n clearTimeout(timeout);\n window.removeEventListener('message', handleMessage);\n\n const result: AuthResult = event.data.payload;\n\n if (result.success && result.user && result.token) {\n this.setAuth(result);\n resolve(result.user);\n } else {\n reject(new Error(result.error || 'Login failed'));\n }\n };\n\n window.addEventListener('message', handleMessage);\n });\n }\n\n /**\n * Logout and clear session\n */\n async logout(): Promise<void> {\n try {\n if (this.token) {\n await fetch(`${this.apiEndpoint}/api/sdk/auth/logout`, {\n method: 'POST',\n headers: this.getHeaders(),\n });\n }\n } catch (error) {\n console.warn('Logout request failed:', error);\n }\n\n this.clearAuth();\n }\n\n /**\n * Get current user\n */\n getUser(): NxcodeUser | null {\n return this.user;\n }\n\n /**\n * Get current auth token\n */\n getToken(): string | null {\n // Check if token is expired\n if (this.expiresAt && new Date() > this.expiresAt) {\n // Token is expired, need to refresh\n // Start refresh in background but don't return the expired token\n this.refreshSession().catch(console.error);\n // Return null to force re-auth rather than using expired token\n return null;\n }\n return this.token;\n }\n\n /**\n * Get token, refreshing if needed (async version)\n */\n async getValidToken(): Promise<string | null> {\n if (this.expiresAt && new Date() > this.expiresAt) {\n await this.refreshSession();\n }\n return this.token;\n }\n\n /**\n * Register callback for auth state changes\n */\n onAuthStateChange(callback: AuthStateCallback): () => void {\n this.authCallbacks.push(callback);\n\n // Call immediately with current state\n callback(this.user);\n\n // Return unsubscribe function\n return () => {\n const index = this.authCallbacks.indexOf(callback);\n if (index > -1) {\n this.authCallbacks.splice(index, 1);\n }\n };\n }\n\n /**\n * Check if user is logged in\n */\n isLoggedIn(): boolean {\n return this.user !== null && this.token !== null;\n }\n\n /**\n * Refresh the current session\n */\n async refreshSession(): Promise<void> {\n if (!this.refreshToken) {\n this.clearAuth();\n return;\n }\n\n try {\n const response = await fetch(`${this.apiEndpoint}/api/sdk/auth/refresh`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n },\n body: JSON.stringify({ refreshToken: this.refreshToken }),\n });\n\n if (!response.ok) {\n throw new Error('Refresh failed');\n }\n\n const data = await response.json();\n this.setAuth({\n success: true,\n token: data.token,\n refreshToken: data.refreshToken,\n expiresAt: data.expiresAt,\n user: data.user,\n });\n } catch (error) {\n console.error('Session refresh failed:', error);\n this.clearAuth();\n }\n }\n\n /**\n * Fetch current user info from server\n */\n async fetchUser(): Promise<NxcodeUser | null> {\n if (!this.token) return null;\n\n try {\n const response = await fetch(`${this.apiEndpoint}/api/sdk/auth/me`, {\n headers: this.getHeaders(),\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n await this.refreshSession();\n return this.user;\n }\n throw new Error('Failed to fetch user');\n }\n\n const user = await response.json();\n this.user = user;\n this.notifyAuthChange();\n this.saveToStorage();\n\n return user;\n } catch (error) {\n console.error('Failed to fetch user:', error);\n return null;\n }\n }\n\n // ==================== Private Methods ====================\n\n private setAuth(result: AuthResult): void {\n if (result.success && result.user && result.token) {\n this.user = result.user;\n this.token = result.token;\n this.refreshToken = result.refreshToken || null;\n this.expiresAt = result.expiresAt ? new Date(result.expiresAt) : null;\n\n this.saveToStorage();\n this.notifyAuthChange();\n }\n }\n\n private clearAuth(): void {\n this.user = null;\n this.token = null;\n this.refreshToken = null;\n this.expiresAt = null;\n\n localStorage.removeItem(`${STORAGE_KEY}_${this.appId}`);\n this.notifyAuthChange();\n }\n\n private saveToStorage(): void {\n if (this.user && this.token) {\n const data: StoredAuth = {\n token: this.token,\n refreshToken: this.refreshToken || '',\n expiresAt: this.expiresAt?.toISOString() || '',\n user: this.user,\n };\n localStorage.setItem(`${STORAGE_KEY}_${this.appId}`, JSON.stringify(data));\n }\n }\n\n private loadFromStorage(): void {\n try {\n const stored = localStorage.getItem(`${STORAGE_KEY}_${this.appId}`);\n if (stored) {\n const data: StoredAuth = JSON.parse(stored);\n this.token = data.token;\n this.refreshToken = data.refreshToken;\n this.expiresAt = data.expiresAt ? new Date(data.expiresAt) : null;\n this.user = data.user;\n\n // Check if expired\n if (this.expiresAt && new Date() > this.expiresAt) {\n this.refreshSession().catch(() => this.clearAuth());\n }\n }\n } catch (error) {\n console.warn('Failed to load auth from storage:', error);\n }\n }\n\n private notifyAuthChange(): void {\n for (const callback of this.authCallbacks) {\n try {\n callback(this.user);\n } catch (error) {\n console.error('Auth callback error:', error);\n }\n }\n }\n\n private setupMessageListener(): void {\n // Already set up message handling in login()\n }\n\n private getHeaders(): HeadersInit {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n };\n\n if (this.token) {\n headers['Authorization'] = `Bearer ${this.token}`;\n }\n\n return headers;\n }\n}\n","/**\n * Nxcode SDK - Billing Module\n */\n\nexport class NxcodeBilling {\n private apiEndpoint: string;\n private appId: string;\n private getToken: () => string | null;\n\n constructor(\n apiEndpoint: string,\n appId: string,\n getToken: () => string | null\n ) {\n this.apiEndpoint = apiEndpoint;\n this.appId = appId;\n this.getToken = getToken;\n }\n\n /**\n * Get user's current balance\n */\n async getBalance(): Promise<number> {\n const token = this.getToken();\n if (!token) {\n throw new Error('Not authenticated. Please login first.');\n }\n\n const response = await fetch(`${this.apiEndpoint}/api/sdk/billing/balance`, {\n headers: this.getHeaders(token),\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n throw new Error('Session expired. Please login again.');\n }\n throw new Error('Failed to fetch balance');\n }\n\n const data = await response.json();\n return data.balance;\n }\n\n /**\n * Open top-up page in new tab\n */\n topUp(): void {\n const topUpUrl = `${this.apiEndpoint}/api/sdk/billing/topup?app_id=${this.appId}`;\n window.open(topUpUrl, '_blank');\n }\n\n // ==================== Private Methods ====================\n\n private getHeaders(token: string): HeadersInit {\n return {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n 'Authorization': `Bearer ${token}`,\n };\n }\n}\n","/**\n * Nxcode SDK - Payment Module\n */\n\nimport type { ChargeOptions, ChargeResult, Transaction } from './types';\n\nexport class NxcodePayment {\n private apiEndpoint: string;\n private appId: string;\n private getToken: () => string | null;\n\n constructor(\n apiEndpoint: string,\n appId: string,\n getToken: () => string | null\n ) {\n this.apiEndpoint = apiEndpoint;\n this.appId = appId;\n this.getToken = getToken;\n }\n\n /**\n * Process an in-app purchase\n *\n * @param options - Charge options\n * @returns Charge result with transaction details\n */\n async charge(options: ChargeOptions): Promise<ChargeResult> {\n const token = this.getToken();\n if (!token) {\n return {\n success: false,\n error: 'Not authenticated. Please login first.',\n };\n }\n\n try {\n const response = await fetch(`${this.apiEndpoint}/api/sdk/payment/charge`, {\n method: 'POST',\n headers: this.getHeaders(token),\n body: JSON.stringify({\n amount: options.amount,\n description: options.description,\n metadata: options.metadata,\n }),\n });\n\n if (!response.ok) {\n if (response.status === 401) {\n return {\n success: false,\n error: 'Session expired. Please login again.',\n };\n }\n if (response.status === 402) {\n return {\n success: false,\n error: 'Insufficient balance. Please top up.',\n };\n }\n\n const errorData = await response.json().catch(() => ({}));\n return {\n success: false,\n error: errorData.detail || 'Payment failed',\n };\n }\n\n const result = await response.json();\n return result;\n } catch (error) {\n return {\n success: false,\n error: error instanceof Error ? error.message : 'Payment failed',\n };\n }\n }\n\n /**\n * Get user's transaction history\n *\n * @param limit - Maximum number of transactions to return\n * @param offset - Pagination offset\n * @returns Array of transactions\n */\n async getTransactions(limit = 50, offset = 0): Promise<Transaction[]> {\n const token = this.getToken();\n if (!token) {\n throw new Error('Not authenticated. Please login first.');\n }\n\n const response = await fetch(\n `${this.apiEndpoint}/api/sdk/payment/transactions?limit=${limit}&offset=${offset}`,\n {\n headers: this.getHeaders(token),\n }\n );\n\n if (!response.ok) {\n if (response.status === 401) {\n throw new Error('Session expired. Please login again.');\n }\n throw new Error('Failed to fetch transactions');\n }\n\n const data = await response.json();\n return data.transactions;\n }\n\n // ==================== Private Methods ====================\n\n private getHeaders(token: string): HeadersInit {\n return {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n 'Authorization': `Bearer ${token}`,\n };\n }\n}\n","/**\n * Nxcode SDK - AI Module\n *\n * Provides access to AI capabilities through the Nxcode AI Gateway.\n * All AI calls require user authentication and are billed to the user's balance.\n */\n\n// ==================== Simplified Schema Types ====================\n\n/**\n * Simplified schema type for structured output.\n *\n * Use simple TypeScript-style notation:\n * - Primitives: 'string', 'number', 'boolean'\n * - Arrays: ['string'], ['number'], [{ nested: 'object' }]\n * - Objects: { key: 'type', nested: { ... } }\n *\n * @example\n * // Simple object\n * { name: 'string', age: 'number', active: 'boolean' }\n *\n * // With arrays\n * { tags: ['string'], scores: ['number'] }\n *\n * // Nested objects\n * { user: { name: 'string', profile: { bio: 'string' } } }\n */\nexport type SimpleSchema =\n | 'string'\n | 'number'\n | 'boolean'\n | SimpleSchema[]\n | { [key: string]: SimpleSchema };\n\n/**\n * JSON Schema type (Gemini API format)\n */\ninterface JsonSchema {\n type: 'STRING' | 'NUMBER' | 'INTEGER' | 'BOOLEAN' | 'ARRAY' | 'OBJECT';\n items?: JsonSchema;\n properties?: { [key: string]: JsonSchema };\n required?: string[];\n}\n\n/**\n * Convert simplified schema to JSON Schema (Gemini format)\n */\nfunction toJsonSchema(schema: SimpleSchema): JsonSchema {\n // Primitive types\n if (schema === 'string') {\n return { type: 'STRING' };\n }\n if (schema === 'number') {\n return { type: 'NUMBER' };\n }\n if (schema === 'boolean') {\n return { type: 'BOOLEAN' };\n }\n\n // Array type\n if (Array.isArray(schema)) {\n if (schema.length !== 1) {\n throw new Error('Array schema must have exactly one element type');\n }\n return {\n type: 'ARRAY',\n items: toJsonSchema(schema[0]),\n };\n }\n\n // Object type\n if (typeof schema === 'object' && schema !== null) {\n const properties: { [key: string]: JsonSchema } = {};\n const required: string[] = [];\n\n for (const [key, value] of Object.entries(schema)) {\n properties[key] = toJsonSchema(value);\n required.push(key); // All fields required by default\n }\n\n return {\n type: 'OBJECT',\n properties,\n required,\n };\n }\n\n throw new Error(`Invalid schema type: ${schema}`);\n}\n\n// ==================== Content Part Types ====================\n\n/**\n * Content part for multimodal messages\n */\nexport interface TextPart {\n type: 'text';\n text: string;\n}\n\nexport interface ImagePart {\n type: 'image';\n /** Base64 encoded image data */\n data: string;\n /** MIME type (e.g., 'image/png', 'image/jpeg') */\n mimeType: string;\n}\n\nexport interface ImageUrlPart {\n type: 'image_url';\n /** URL of the image */\n url: string;\n}\n\nexport type ContentPart = TextPart | ImagePart | ImageUrlPart;\n\nexport interface ChatMessage {\n role: 'user' | 'assistant' | 'system';\n /** Text content or array of content parts for multimodal */\n content: string | ContentPart[];\n}\n\nexport interface ChatOptions {\n messages: ChatMessage[];\n model?: string;\n /** Schema for structured output. AI will return JSON matching this schema. */\n responseSchema?: SimpleSchema;\n}\n\nexport interface ChatResponse {\n content: string;\n usage?: {\n inputTokens: number;\n outputTokens: number;\n };\n}\n\nexport interface GenerateOptions {\n prompt: string;\n model?: string;\n /** Schema for structured output. AI will return JSON matching this schema. */\n responseSchema?: SimpleSchema;\n}\n\nexport interface GenerateResponse {\n text: string;\n usage?: {\n inputTokens: number;\n outputTokens: number;\n };\n}\n\nexport interface StreamChunk {\n content: string;\n done: boolean;\n usage?: {\n inputTokens: number;\n outputTokens: number;\n };\n}\n\nexport type StreamCallback = (chunk: StreamChunk) => void;\n\nexport class NxcodeAI {\n private apiEndpoint: string;\n private appId: string;\n private getToken: () => string | null;\n\n constructor(\n apiEndpoint: string,\n appId: string,\n getToken: () => string | null\n ) {\n this.apiEndpoint = apiEndpoint;\n this.appId = appId;\n this.getToken = getToken;\n }\n\n /**\n * Send a chat message and get a response.\n *\n * @example\n * const response = await Nxcode.ai.chat({\n * messages: [\n * { role: 'user', content: 'Hello!' }\n * ]\n * });\n * console.log(response.content);\n */\n async chat(options: ChatOptions): Promise<ChatResponse> {\n const token = this.getToken();\n if (!token) {\n throw new Error('Not authenticated. Please login first.');\n }\n\n const model = options.model || 'fast';\n\n // Build Gemini API request\n const geminiRequest: Record<string, unknown> = {\n contents: this.convertMessagesToGemini(options.messages),\n };\n\n // Add structured output config if schema provided\n if (options.responseSchema) {\n geminiRequest.generationConfig = {\n responseMimeType: 'application/json',\n responseSchema: toJsonSchema(options.responseSchema),\n };\n }\n\n const response = await fetch(\n `${this.apiEndpoint}/api/ai-gateway/v1beta/models/${model}:generateContent`,\n {\n method: 'POST',\n headers: this.getHeaders(token),\n body: JSON.stringify(geminiRequest),\n }\n );\n\n if (!response.ok) {\n await this.handleError(response);\n }\n\n const data = await response.json();\n return this.parseGeminiResponse(data);\n }\n\n /**\n * Generate text from a prompt.\n *\n * @example\n * const response = await Nxcode.ai.generate({\n * prompt: 'Write a haiku about coding'\n * });\n * console.log(response.text);\n */\n async generate(options: GenerateOptions): Promise<GenerateResponse> {\n const result = await this.chat({\n messages: [{ role: 'user', content: options.prompt }],\n model: options.model,\n responseSchema: options.responseSchema,\n });\n\n return {\n text: result.content,\n usage: result.usage,\n };\n }\n\n /**\n * Stream a chat response in real-time.\n *\n * @example\n * await Nxcode.ai.chatStream({\n * messages: [{ role: 'user', content: 'Tell me a story' }],\n * onChunk: (chunk) => {\n * process.stdout.write(chunk.content);\n * if (chunk.done) console.log('\\n--- Done ---');\n * }\n * });\n */\n async chatStream(\n options: ChatOptions & { onChunk: StreamCallback }\n ): Promise<void> {\n const token = this.getToken();\n // Allow anonymous streaming if app permits\n const headers = token ? this.getHeaders(token) : this.getAnonymousHeaders();\n\n const model = options.model || 'fast';\n\n const geminiRequest = {\n contents: this.convertMessagesToGemini(options.messages),\n };\n\n const response = await fetch(\n `${this.apiEndpoint}/api/ai-gateway/v1beta/models/${model}:streamGenerateContent?alt=sse`,\n {\n method: 'POST',\n headers,\n body: JSON.stringify(geminiRequest),\n }\n );\n\n if (!response.ok) {\n await this.handleError(response);\n }\n\n const reader = response.body?.getReader();\n if (!reader) {\n throw new Error('Streaming not supported');\n }\n\n const decoder = new TextDecoder();\n let buffer = '';\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() || '';\n\n for (const line of lines) {\n if (line.startsWith('data: ')) {\n const jsonStr = line.slice(6).trim();\n if (jsonStr === '[DONE]') {\n options.onChunk({ content: '', done: true });\n return;\n }\n\n try {\n const data = JSON.parse(jsonStr);\n const chunk = this.parseStreamChunk(data);\n options.onChunk(chunk);\n } catch {\n // Skip invalid JSON\n }\n }\n }\n }\n\n // Process remaining buffer\n if (buffer.startsWith('data: ')) {\n const jsonStr = buffer.slice(6).trim();\n if (jsonStr && jsonStr !== '[DONE]') {\n try {\n const data = JSON.parse(jsonStr);\n const chunk = this.parseStreamChunk(data);\n options.onChunk(chunk);\n } catch {\n // Skip invalid JSON\n }\n }\n }\n\n options.onChunk({ content: '', done: true });\n } finally {\n reader.releaseLock();\n }\n }\n\n /**\n * Stream text generation from a prompt.\n *\n * @example\n * await Nxcode.ai.generateStream({\n * prompt: 'Write a poem',\n * onChunk: (chunk) => console.log(chunk.content)\n * });\n */\n async generateStream(\n options: GenerateOptions & { onChunk: StreamCallback }\n ): Promise<void> {\n return this.chatStream({\n messages: [{ role: 'user', content: options.prompt }],\n model: options.model,\n onChunk: options.onChunk,\n });\n }\n\n // ==================== Private Methods ====================\n\n private getHeaders(token: string): HeadersInit {\n return {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n Authorization: `Bearer ${token}`,\n };\n }\n\n private getAnonymousHeaders(): HeadersInit {\n return {\n 'Content-Type': 'application/json',\n 'X-App-Id': this.appId,\n };\n }\n\n private convertMessagesToGemini(\n messages: ChatMessage[]\n ): Array<{ role: string; parts: Array<Record<string, unknown>> }> {\n return messages.map((msg) => ({\n role: msg.role === 'assistant' ? 'model' : 'user',\n parts: this.convertContentToParts(msg.content),\n }));\n }\n\n private convertContentToParts(\n content: string | ContentPart[]\n ): Array<Record<string, unknown>> {\n // Simple text content\n if (typeof content === 'string') {\n return [{ text: content }];\n }\n\n // Multimodal content\n return content.map((part) => {\n switch (part.type) {\n case 'text':\n return { text: part.text };\n\n case 'image':\n // Gemini format: inlineData with base64\n return {\n inlineData: {\n mimeType: part.mimeType,\n data: part.data,\n },\n };\n\n case 'image_url':\n // Gemini format: fileData with URL\n return {\n fileData: {\n fileUri: part.url,\n },\n };\n\n default:\n return { text: '' };\n }\n });\n }\n\n private parseGeminiResponse(data: Record<string, unknown>): ChatResponse {\n const candidates = data.candidates as Array<{\n content?: { parts?: Array<{ text?: string }> };\n }>;\n const content =\n candidates?.[0]?.content?.parts?.[0]?.text || '';\n\n const usageMetadata = data.usageMetadata as {\n promptTokenCount?: number;\n candidatesTokenCount?: number;\n };\n\n return {\n content,\n usage: usageMetadata\n ? {\n inputTokens: usageMetadata.promptTokenCount || 0,\n outputTokens: usageMetadata.candidatesTokenCount || 0,\n }\n : undefined,\n };\n }\n\n private parseStreamChunk(data: Record<string, unknown>): StreamChunk {\n const candidates = data.candidates as Array<{\n content?: { parts?: Array<{ text?: string }> };\n finishReason?: string;\n }>;\n\n const content = candidates?.[0]?.content?.parts?.[0]?.text || '';\n const finishReason = candidates?.[0]?.finishReason;\n const done = finishReason === 'STOP' || finishReason === 'END_TURN';\n\n const usageMetadata = data.usageMetadata as {\n promptTokenCount?: number;\n candidatesTokenCount?: number;\n };\n\n return {\n content,\n done,\n usage: usageMetadata\n ? {\n inputTokens: usageMetadata.promptTokenCount || 0,\n outputTokens: usageMetadata.candidatesTokenCount || 0,\n }\n : undefined,\n };\n }\n\n private async handleError(response: Response): Promise<never> {\n if (response.status === 401) {\n throw new Error('Session expired. Please login again.');\n }\n if (response.status === 402) {\n throw new Error('Insufficient balance. Please top up to continue.');\n }\n\n let message = 'AI request failed';\n try {\n const data = await response.json();\n message = data.detail || data.message || message;\n } catch {\n // Ignore parse errors\n }\n throw new Error(message);\n }\n}\n","/**\n * Nxcode SDK\n *\n * A lightweight SDK for integrating Nxcode authentication, billing,\n * and payment features into web applications.\n *\n * Usage:\n * <script src=\"https://sdk.nxcode.io/v1/nxcode.js\"></script>\n * <script>\n * const user = await Nxcode.auth.login();\n * console.log('Logged in:', user.email);\n * </script>\n */\n\nimport { NxcodeAuth } from './auth';\nimport { NxcodeBilling } from './billing';\nimport { NxcodePayment } from './payment';\nimport { NxcodeAI, type ChatOptions, type ChatResponse, type GenerateOptions, type GenerateResponse, type StreamChunk, type StreamCallback, type ChatMessage, type ContentPart, type TextPart, type ImagePart, type ImageUrlPart } from './ai';\nimport type {\n NxcodeUser,\n NxcodeConfig,\n ChargeOptions,\n ChargeResult,\n Transaction,\n AuthStateCallback,\n} from './types';\n\n// API endpoint - auto-detect or use default\nconst DEFAULT_API_ENDPOINT = 'https://studio-api.nxcode.io';\n\nclass NxcodeSDK {\n private config: NxcodeConfig | null = null;\n private _auth: NxcodeAuth | null = null;\n private _billing: NxcodeBilling | null = null;\n private _payment: NxcodePayment | null = null;\n private _ai: NxcodeAI | null = null;\n private initPromise: Promise<void> | null = null;\n private apiEndpoint: string;\n\n constructor() {\n this.apiEndpoint = this.detectApiEndpoint();\n this.autoInit();\n }\n\n /**\n * Auto-initialize SDK based on environment\n */\n private async autoInit(): Promise<void> {\n if (this.initPromise) return this.initPromise;\n\n this.initPromise = this.init();\n return this.initPromise;\n }\n\n /**\n * Initialize SDK by fetching configuration\n */\n private async init(): Promise<void> {\n try {\n // Try to get config from server\n const response = await fetch(`${this.apiEndpoint}/api/sdk/config`, {\n credentials: 'include',\n });\n\n if (response.ok) {\n this.config = await response.json();\n this.config!.apiEndpoint = this.apiEndpoint;\n this.setupModules();\n }\n } catch (error) {\n console.warn('Nxcode SDK: Could not auto-detect app config. Call Nxcode.configure() manually.');\n }\n }\n\n /**\n * Manually configure SDK with app ID and optional endpoint\n */\n configure(appId: string, options?: { apiEndpoint?: string }): void {\n if (options?.apiEndpoint) {\n this.apiEndpoint = options.apiEndpoint;\n }\n this.config = {\n appId,\n name: '',\n billingMode: 'creator_pays',\n apiEndpoint: this.apiEndpoint,\n };\n this.setupModules();\n }\n\n /**\n * Set up SDK modules after configuration\n */\n private setupModules(): void {\n if (!this.config) return;\n\n this._auth = new NxcodeAuth(this.config.apiEndpoint, this.config.appId);\n this._billing = new NxcodeBilling(\n this.config.apiEndpoint,\n this.config.appId,\n () => this._auth?.getToken() || null\n );\n this._payment = new NxcodePayment(\n this.config.apiEndpoint,\n this.config.appId,\n () => this._auth?.getToken() || null\n );\n this._ai = new NxcodeAI(\n this.config.apiEndpoint,\n this.config.appId,\n () => this._auth?.getToken() || null\n );\n }\n\n /**\n * Detect API endpoint based on environment\n */\n private detectApiEndpoint(): string {\n if (typeof window !== 'undefined') {\n const hostname = window.location.hostname;\n\n // Development environment\n if (hostname === 'localhost' || hostname === '127.0.0.1') {\n return 'http://localhost:8001';\n }\n\n // Check for dev environment\n if (hostname.includes('.nxcode.dev') || hostname.includes('.nxcode.app')) {\n return 'https://studio-api.nxcode.io';\n }\n }\n\n return DEFAULT_API_ENDPOINT;\n }\n\n /**\n * Ensure SDK is initialized before operations\n */\n private async ensureInitialized(): Promise<void> {\n if (this.initPromise) {\n await this.initPromise;\n }\n\n if (!this.config) {\n throw new Error(\n 'Nxcode SDK not configured. Add X-App-Id header or call Nxcode.configure(appId).'\n );\n }\n }\n\n // ==================== Auth Module ====================\n\n get auth() {\n const self = this;\n\n return {\n /**\n * Login via OAuth popup\n */\n async login(provider: 'google' | 'github' = 'google'): Promise<NxcodeUser> {\n await self.ensureInitialized();\n return self._auth!.login(provider);\n },\n\n /**\n * Logout current user\n */\n async logout(): Promise<void> {\n await self.ensureInitialized();\n return self._auth!.logout();\n },\n\n /**\n * Get current user\n */\n getUser(): NxcodeUser | null {\n return self._auth?.getUser() || null;\n },\n\n /**\n * Get auth token for API calls\n */\n getToken(): string | null {\n return self._auth?.getToken() || null;\n },\n\n /**\n * Register auth state change callback\n */\n onAuthStateChange(callback: AuthStateCallback): () => void {\n if (!self._auth) {\n // Store the actual unsubscribe function when SDK initializes\n let actualUnsubscribe: (() => void) | null = null;\n let cancelled = false;\n\n // Queue callback until initialized\n self.ensureInitialized().then(() => {\n if (!cancelled && self._auth) {\n actualUnsubscribe = self._auth.onAuthStateChange(callback);\n }\n });\n\n // Return unsubscribe that handles both immediate and deferred cases\n return () => {\n cancelled = true;\n if (actualUnsubscribe) {\n actualUnsubscribe();\n }\n };\n }\n return self._auth.onAuthStateChange(callback);\n },\n\n /**\n * Check if user is logged in\n */\n isLoggedIn(): boolean {\n return self._auth?.isLoggedIn() || false;\n },\n };\n }\n\n // ==================== Billing Module ====================\n\n get billing() {\n const self = this;\n\n return {\n /**\n * Get user's current balance\n */\n async getBalance(): Promise<number> {\n await self.ensureInitialized();\n return self._billing!.getBalance();\n },\n\n /**\n * Open top-up page\n */\n topUp(): void {\n self._billing?.topUp();\n },\n };\n }\n\n // ==================== Payment Module ====================\n\n get payment() {\n const self = this;\n\n return {\n /**\n * Process in-app purchase\n */\n async charge(options: ChargeOptions): Promise<ChargeResult> {\n await self.ensureInitialized();\n return self._payment!.charge(options);\n },\n\n /**\n * Get transaction history\n */\n async getTransactions(limit?: number, offset?: number): Promise<Transaction[]> {\n await self.ensureInitialized();\n return self._payment!.getTransactions(limit, offset);\n },\n };\n }\n\n // ==================== AI Module ====================\n\n get ai() {\n const self = this;\n\n return {\n /**\n * Send a chat message and get a response\n *\n * @example\n * const response = await Nxcode.ai.chat({\n * messages: [{ role: 'user', content: 'Hello!' }]\n * });\n */\n async chat(options: ChatOptions): Promise<ChatResponse> {\n await self.ensureInitialized();\n return self._ai!.chat(options);\n },\n\n /**\n * Generate text from a prompt\n *\n * @example\n * const response = await Nxcode.ai.generate({ prompt: 'Write a haiku' });\n */\n async generate(options: GenerateOptions): Promise<GenerateResponse> {\n await self.ensureInitialized();\n return self._ai!.generate(options);\n },\n\n /**\n * Stream a chat response in real-time\n *\n * @example\n * await Nxcode.ai.chatStream({\n * messages: [{ role: 'user', content: 'Tell me a story' }],\n * onChunk: (chunk) => {\n * document.body.innerText += chunk.content;\n * if (chunk.done) console.log('Done!');\n * }\n * });\n */\n async chatStream(options: ChatOptions & { onChunk: StreamCallback }): Promise<void> {\n await self.ensureInitialized();\n return self._ai!.chatStream(options);\n },\n\n /**\n * Stream text generation from a prompt\n *\n * @example\n * await Nxcode.ai.generateStream({\n * prompt: 'Write a poem',\n * onChunk: (chunk) => console.log(chunk.content)\n * });\n */\n async generateStream(options: GenerateOptions & { onChunk: StreamCallback }): Promise<void> {\n await self.ensureInitialized();\n return self._ai!.generateStream(options);\n },\n };\n }\n\n // ==================== Utility Methods ====================\n\n /**\n * Get current configuration\n */\n getConfig(): NxcodeConfig | null {\n return this.config;\n }\n\n /**\n * Check if SDK is ready\n */\n isReady(): boolean {\n return this.config !== null && this._auth !== null;\n }\n\n /**\n * Wait for SDK to be ready\n */\n async ready(): Promise<void> {\n await this.ensureInitialized();\n }\n}\n\n// Create singleton instance\nconst Nxcode = new NxcodeSDK();\n\n// Export for UMD (browser global)\nif (typeof window !== 'undefined') {\n (window as unknown as { Nxcode: typeof Nxcode }).Nxcode = Nxcode;\n}\n\n// Export for ESM\nexport default Nxcode;\nexport { Nxcode };\nexport type {\n NxcodeUser,\n NxcodeConfig,\n ChargeOptions,\n ChargeResult,\n Transaction,\n AuthStateCallback,\n ChatOptions,\n ChatResponse,\n ChatMessage,\n ContentPart,\n TextPart,\n ImagePart,\n ImageUrlPart,\n GenerateOptions,\n GenerateResponse,\n StreamChunk,\n StreamCallback,\n};\n"],"names":[],"mappings":"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"}