@nxcode/sdk 1.0.0 → 1.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/README.md +535 -0
- package/dist/nxcode.esm.js +323 -2
- package/dist/nxcode.esm.js.map +1 -1
- package/dist/nxcode.js +323 -2
- package/dist/nxcode.js.map +1 -1
- package/dist/nxcode.min.js +1 -1
- package/dist/types/ai.d.ts +124 -0
- package/dist/types/auth.test.d.ts +6 -0
- package/dist/types/index.d.ts +52 -3
- package/package.json +1 -1
package/dist/nxcode.esm.js
CHANGED
|
@@ -400,6 +400,265 @@ 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
|
+
class NxcodeAI {
|
|
410
|
+
constructor(apiEndpoint, appId, getToken) {
|
|
411
|
+
this.apiEndpoint = apiEndpoint;
|
|
412
|
+
this.appId = appId;
|
|
413
|
+
this.getToken = getToken;
|
|
414
|
+
}
|
|
415
|
+
/**
|
|
416
|
+
* Send a chat message and get a response.
|
|
417
|
+
*
|
|
418
|
+
* @example
|
|
419
|
+
* const response = await Nxcode.ai.chat({
|
|
420
|
+
* messages: [
|
|
421
|
+
* { role: 'user', content: 'Hello!' }
|
|
422
|
+
* ]
|
|
423
|
+
* });
|
|
424
|
+
* console.log(response.content);
|
|
425
|
+
*/
|
|
426
|
+
async chat(options) {
|
|
427
|
+
const token = this.getToken();
|
|
428
|
+
if (!token) {
|
|
429
|
+
throw new Error('Not authenticated. Please login first.');
|
|
430
|
+
}
|
|
431
|
+
const model = options.model || 'fast';
|
|
432
|
+
// Build Gemini API request
|
|
433
|
+
const geminiRequest = {
|
|
434
|
+
contents: this.convertMessagesToGemini(options.messages),
|
|
435
|
+
};
|
|
436
|
+
const response = await fetch(`${this.apiEndpoint}/api/ai-gateway/v1beta/models/${model}:generateContent`, {
|
|
437
|
+
method: 'POST',
|
|
438
|
+
headers: this.getHeaders(token),
|
|
439
|
+
body: JSON.stringify(geminiRequest),
|
|
440
|
+
});
|
|
441
|
+
if (!response.ok) {
|
|
442
|
+
await this.handleError(response);
|
|
443
|
+
}
|
|
444
|
+
const data = await response.json();
|
|
445
|
+
return this.parseGeminiResponse(data);
|
|
446
|
+
}
|
|
447
|
+
/**
|
|
448
|
+
* Generate text from a prompt.
|
|
449
|
+
*
|
|
450
|
+
* @example
|
|
451
|
+
* const response = await Nxcode.ai.generate({
|
|
452
|
+
* prompt: 'Write a haiku about coding'
|
|
453
|
+
* });
|
|
454
|
+
* console.log(response.text);
|
|
455
|
+
*/
|
|
456
|
+
async generate(options) {
|
|
457
|
+
const result = await this.chat({
|
|
458
|
+
messages: [{ role: 'user', content: options.prompt }],
|
|
459
|
+
model: options.model,
|
|
460
|
+
});
|
|
461
|
+
return {
|
|
462
|
+
text: result.content,
|
|
463
|
+
usage: result.usage,
|
|
464
|
+
};
|
|
465
|
+
}
|
|
466
|
+
/**
|
|
467
|
+
* Stream a chat response in real-time.
|
|
468
|
+
*
|
|
469
|
+
* @example
|
|
470
|
+
* await Nxcode.ai.chatStream({
|
|
471
|
+
* messages: [{ role: 'user', content: 'Tell me a story' }],
|
|
472
|
+
* onChunk: (chunk) => {
|
|
473
|
+
* process.stdout.write(chunk.content);
|
|
474
|
+
* if (chunk.done) console.log('\n--- Done ---');
|
|
475
|
+
* }
|
|
476
|
+
* });
|
|
477
|
+
*/
|
|
478
|
+
async chatStream(options) {
|
|
479
|
+
const token = this.getToken();
|
|
480
|
+
// Allow anonymous streaming if app permits
|
|
481
|
+
const headers = token ? this.getHeaders(token) : this.getAnonymousHeaders();
|
|
482
|
+
const model = options.model || 'fast';
|
|
483
|
+
const geminiRequest = {
|
|
484
|
+
contents: this.convertMessagesToGemini(options.messages),
|
|
485
|
+
};
|
|
486
|
+
const response = await fetch(`${this.apiEndpoint}/api/ai-gateway/v1beta/models/${model}:streamGenerateContent?alt=sse`, {
|
|
487
|
+
method: 'POST',
|
|
488
|
+
headers,
|
|
489
|
+
body: JSON.stringify(geminiRequest),
|
|
490
|
+
});
|
|
491
|
+
if (!response.ok) {
|
|
492
|
+
await this.handleError(response);
|
|
493
|
+
}
|
|
494
|
+
const reader = response.body?.getReader();
|
|
495
|
+
if (!reader) {
|
|
496
|
+
throw new Error('Streaming not supported');
|
|
497
|
+
}
|
|
498
|
+
const decoder = new TextDecoder();
|
|
499
|
+
let buffer = '';
|
|
500
|
+
try {
|
|
501
|
+
while (true) {
|
|
502
|
+
const { done, value } = await reader.read();
|
|
503
|
+
if (done)
|
|
504
|
+
break;
|
|
505
|
+
buffer += decoder.decode(value, { stream: true });
|
|
506
|
+
const lines = buffer.split('\n');
|
|
507
|
+
buffer = lines.pop() || '';
|
|
508
|
+
for (const line of lines) {
|
|
509
|
+
if (line.startsWith('data: ')) {
|
|
510
|
+
const jsonStr = line.slice(6).trim();
|
|
511
|
+
if (jsonStr === '[DONE]') {
|
|
512
|
+
options.onChunk({ content: '', done: true });
|
|
513
|
+
return;
|
|
514
|
+
}
|
|
515
|
+
try {
|
|
516
|
+
const data = JSON.parse(jsonStr);
|
|
517
|
+
const chunk = this.parseStreamChunk(data);
|
|
518
|
+
options.onChunk(chunk);
|
|
519
|
+
}
|
|
520
|
+
catch {
|
|
521
|
+
// Skip invalid JSON
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
// Process remaining buffer
|
|
527
|
+
if (buffer.startsWith('data: ')) {
|
|
528
|
+
const jsonStr = buffer.slice(6).trim();
|
|
529
|
+
if (jsonStr && jsonStr !== '[DONE]') {
|
|
530
|
+
try {
|
|
531
|
+
const data = JSON.parse(jsonStr);
|
|
532
|
+
const chunk = this.parseStreamChunk(data);
|
|
533
|
+
options.onChunk(chunk);
|
|
534
|
+
}
|
|
535
|
+
catch {
|
|
536
|
+
// Skip invalid JSON
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
options.onChunk({ content: '', done: true });
|
|
541
|
+
}
|
|
542
|
+
finally {
|
|
543
|
+
reader.releaseLock();
|
|
544
|
+
}
|
|
545
|
+
}
|
|
546
|
+
/**
|
|
547
|
+
* Stream text generation from a prompt.
|
|
548
|
+
*
|
|
549
|
+
* @example
|
|
550
|
+
* await Nxcode.ai.generateStream({
|
|
551
|
+
* prompt: 'Write a poem',
|
|
552
|
+
* onChunk: (chunk) => console.log(chunk.content)
|
|
553
|
+
* });
|
|
554
|
+
*/
|
|
555
|
+
async generateStream(options) {
|
|
556
|
+
return this.chatStream({
|
|
557
|
+
messages: [{ role: 'user', content: options.prompt }],
|
|
558
|
+
model: options.model,
|
|
559
|
+
onChunk: options.onChunk,
|
|
560
|
+
});
|
|
561
|
+
}
|
|
562
|
+
// ==================== Private Methods ====================
|
|
563
|
+
getHeaders(token) {
|
|
564
|
+
return {
|
|
565
|
+
'Content-Type': 'application/json',
|
|
566
|
+
'X-App-Id': this.appId,
|
|
567
|
+
Authorization: `Bearer ${token}`,
|
|
568
|
+
};
|
|
569
|
+
}
|
|
570
|
+
getAnonymousHeaders() {
|
|
571
|
+
return {
|
|
572
|
+
'Content-Type': 'application/json',
|
|
573
|
+
'X-App-Id': this.appId,
|
|
574
|
+
};
|
|
575
|
+
}
|
|
576
|
+
convertMessagesToGemini(messages) {
|
|
577
|
+
return messages.map((msg) => ({
|
|
578
|
+
role: msg.role === 'assistant' ? 'model' : 'user',
|
|
579
|
+
parts: this.convertContentToParts(msg.content),
|
|
580
|
+
}));
|
|
581
|
+
}
|
|
582
|
+
convertContentToParts(content) {
|
|
583
|
+
// Simple text content
|
|
584
|
+
if (typeof content === 'string') {
|
|
585
|
+
return [{ text: content }];
|
|
586
|
+
}
|
|
587
|
+
// Multimodal content
|
|
588
|
+
return content.map((part) => {
|
|
589
|
+
switch (part.type) {
|
|
590
|
+
case 'text':
|
|
591
|
+
return { text: part.text };
|
|
592
|
+
case 'image':
|
|
593
|
+
// Gemini format: inlineData with base64
|
|
594
|
+
return {
|
|
595
|
+
inlineData: {
|
|
596
|
+
mimeType: part.mimeType,
|
|
597
|
+
data: part.data,
|
|
598
|
+
},
|
|
599
|
+
};
|
|
600
|
+
case 'image_url':
|
|
601
|
+
// Gemini format: fileData with URL
|
|
602
|
+
return {
|
|
603
|
+
fileData: {
|
|
604
|
+
fileUri: part.url,
|
|
605
|
+
},
|
|
606
|
+
};
|
|
607
|
+
default:
|
|
608
|
+
return { text: '' };
|
|
609
|
+
}
|
|
610
|
+
});
|
|
611
|
+
}
|
|
612
|
+
parseGeminiResponse(data) {
|
|
613
|
+
const candidates = data.candidates;
|
|
614
|
+
const content = candidates?.[0]?.content?.parts?.[0]?.text || '';
|
|
615
|
+
const usageMetadata = data.usageMetadata;
|
|
616
|
+
return {
|
|
617
|
+
content,
|
|
618
|
+
usage: usageMetadata
|
|
619
|
+
? {
|
|
620
|
+
inputTokens: usageMetadata.promptTokenCount || 0,
|
|
621
|
+
outputTokens: usageMetadata.candidatesTokenCount || 0,
|
|
622
|
+
}
|
|
623
|
+
: undefined,
|
|
624
|
+
};
|
|
625
|
+
}
|
|
626
|
+
parseStreamChunk(data) {
|
|
627
|
+
const candidates = data.candidates;
|
|
628
|
+
const content = candidates?.[0]?.content?.parts?.[0]?.text || '';
|
|
629
|
+
const finishReason = candidates?.[0]?.finishReason;
|
|
630
|
+
const done = finishReason === 'STOP' || finishReason === 'END_TURN';
|
|
631
|
+
const usageMetadata = data.usageMetadata;
|
|
632
|
+
return {
|
|
633
|
+
content,
|
|
634
|
+
done,
|
|
635
|
+
usage: usageMetadata
|
|
636
|
+
? {
|
|
637
|
+
inputTokens: usageMetadata.promptTokenCount || 0,
|
|
638
|
+
outputTokens: usageMetadata.candidatesTokenCount || 0,
|
|
639
|
+
}
|
|
640
|
+
: undefined,
|
|
641
|
+
};
|
|
642
|
+
}
|
|
643
|
+
async handleError(response) {
|
|
644
|
+
if (response.status === 401) {
|
|
645
|
+
throw new Error('Session expired. Please login again.');
|
|
646
|
+
}
|
|
647
|
+
if (response.status === 402) {
|
|
648
|
+
throw new Error('Insufficient balance. Please top up to continue.');
|
|
649
|
+
}
|
|
650
|
+
let message = 'AI request failed';
|
|
651
|
+
try {
|
|
652
|
+
const data = await response.json();
|
|
653
|
+
message = data.detail || data.message || message;
|
|
654
|
+
}
|
|
655
|
+
catch {
|
|
656
|
+
// Ignore parse errors
|
|
657
|
+
}
|
|
658
|
+
throw new Error(message);
|
|
659
|
+
}
|
|
660
|
+
}
|
|
661
|
+
|
|
403
662
|
/**
|
|
404
663
|
* Nxcode SDK
|
|
405
664
|
*
|
|
@@ -421,6 +680,7 @@ class NxcodeSDK {
|
|
|
421
680
|
this._auth = null;
|
|
422
681
|
this._billing = null;
|
|
423
682
|
this._payment = null;
|
|
683
|
+
this._ai = null;
|
|
424
684
|
this.initPromise = null;
|
|
425
685
|
this.apiEndpoint = this.detectApiEndpoint();
|
|
426
686
|
this.autoInit();
|
|
@@ -454,9 +714,12 @@ class NxcodeSDK {
|
|
|
454
714
|
}
|
|
455
715
|
}
|
|
456
716
|
/**
|
|
457
|
-
* Manually configure SDK with app ID
|
|
717
|
+
* Manually configure SDK with app ID and optional endpoint
|
|
458
718
|
*/
|
|
459
|
-
configure(appId) {
|
|
719
|
+
configure(appId, options) {
|
|
720
|
+
if (options?.apiEndpoint) {
|
|
721
|
+
this.apiEndpoint = options.apiEndpoint;
|
|
722
|
+
}
|
|
460
723
|
this.config = {
|
|
461
724
|
appId,
|
|
462
725
|
name: '',
|
|
@@ -474,6 +737,7 @@ class NxcodeSDK {
|
|
|
474
737
|
this._auth = new NxcodeAuth(this.config.apiEndpoint, this.config.appId);
|
|
475
738
|
this._billing = new NxcodeBilling(this.config.apiEndpoint, this.config.appId, () => this._auth?.getToken() || null);
|
|
476
739
|
this._payment = new NxcodePayment(this.config.apiEndpoint, this.config.appId, () => this._auth?.getToken() || null);
|
|
740
|
+
this._ai = new NxcodeAI(this.config.apiEndpoint, this.config.appId, () => this._auth?.getToken() || null);
|
|
477
741
|
}
|
|
478
742
|
/**
|
|
479
743
|
* Detect API endpoint based on environment
|
|
@@ -604,6 +868,63 @@ class NxcodeSDK {
|
|
|
604
868
|
},
|
|
605
869
|
};
|
|
606
870
|
}
|
|
871
|
+
// ==================== AI Module ====================
|
|
872
|
+
get ai() {
|
|
873
|
+
const self = this;
|
|
874
|
+
return {
|
|
875
|
+
/**
|
|
876
|
+
* Send a chat message and get a response
|
|
877
|
+
*
|
|
878
|
+
* @example
|
|
879
|
+
* const response = await Nxcode.ai.chat({
|
|
880
|
+
* messages: [{ role: 'user', content: 'Hello!' }]
|
|
881
|
+
* });
|
|
882
|
+
*/
|
|
883
|
+
async chat(options) {
|
|
884
|
+
await self.ensureInitialized();
|
|
885
|
+
return self._ai.chat(options);
|
|
886
|
+
},
|
|
887
|
+
/**
|
|
888
|
+
* Generate text from a prompt
|
|
889
|
+
*
|
|
890
|
+
* @example
|
|
891
|
+
* const response = await Nxcode.ai.generate({ prompt: 'Write a haiku' });
|
|
892
|
+
*/
|
|
893
|
+
async generate(options) {
|
|
894
|
+
await self.ensureInitialized();
|
|
895
|
+
return self._ai.generate(options);
|
|
896
|
+
},
|
|
897
|
+
/**
|
|
898
|
+
* Stream a chat response in real-time
|
|
899
|
+
*
|
|
900
|
+
* @example
|
|
901
|
+
* await Nxcode.ai.chatStream({
|
|
902
|
+
* messages: [{ role: 'user', content: 'Tell me a story' }],
|
|
903
|
+
* onChunk: (chunk) => {
|
|
904
|
+
* document.body.innerText += chunk.content;
|
|
905
|
+
* if (chunk.done) console.log('Done!');
|
|
906
|
+
* }
|
|
907
|
+
* });
|
|
908
|
+
*/
|
|
909
|
+
async chatStream(options) {
|
|
910
|
+
await self.ensureInitialized();
|
|
911
|
+
return self._ai.chatStream(options);
|
|
912
|
+
},
|
|
913
|
+
/**
|
|
914
|
+
* Stream text generation from a prompt
|
|
915
|
+
*
|
|
916
|
+
* @example
|
|
917
|
+
* await Nxcode.ai.generateStream({
|
|
918
|
+
* prompt: 'Write a poem',
|
|
919
|
+
* onChunk: (chunk) => console.log(chunk.content)
|
|
920
|
+
* });
|
|
921
|
+
*/
|
|
922
|
+
async generateStream(options) {
|
|
923
|
+
await self.ensureInitialized();
|
|
924
|
+
return self._ai.generateStream(options);
|
|
925
|
+
},
|
|
926
|
+
};
|
|
927
|
+
}
|
|
607
928
|
// ==================== Utility Methods ====================
|
|
608
929
|
/**
|
|
609
930
|
* Get current configuration
|
package/dist/nxcode.esm.js.map
CHANGED
|
@@ -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/**\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}\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}\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 = {\n contents: this.convertMessagesToGemini(options.messages),\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 });\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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"}
|