@lastbrain/ai-ui-core 1.0.35 → 1.0.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/client/createClient.d.ts.map +1 -1
- package/dist/client/createClient.js +4 -3
- package/dist/route-handlers/nextjs/lb-proxy.d.ts.map +1 -1
- package/dist/route-handlers/nextjs/lb-proxy.js +10 -0
- package/package.json +1 -1
- package/src/client/createClient.ts +4 -3
- package/src/route-handlers/nextjs/lb-proxy.ts +10 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createClient.d.ts","sourceRoot":"","sources":["../../src/client/createClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,YAAY,EACZ,QAAQ,EACR,aAAa,EACb,cAAc,EACd,cAAc,EACd,eAAe,EACf,cAAc,EACd,eAAe,EACf,QAAQ,EACR,qBAAqB,EACtB,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"createClient.d.ts","sourceRoot":"","sources":["../../src/client/createClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,YAAY,EACZ,QAAQ,EACR,aAAa,EACb,cAAc,EACd,cAAc,EACd,eAAe,EACf,cAAc,EACd,eAAe,EACf,QAAQ,EACR,qBAAqB,EACtB,MAAM,UAAU,CAAC;AAyGlB,wBAAgB,YAAY,CAAC,MAAM,EAAE,YAAY;qBAsBnB,OAAO,CAAC,QAAQ,EAAE,CAAC;iCAqKP,OAAO,CAAC,qBAAqB,CAAC;wBAhIrC,aAAa,KAAG,OAAO,CAAC,cAAc,CAAC;yBAoCtC,cAAc,KAAG,OAAO,CAAC,eAAe,CAAC;iBAqDjD,cAAc,KAAG,OAAO,CAAC,eAAe,CAAC;qBAkBvC,OAAO,CAAC,QAAQ,CAAC;EAiD9C"}
|
|
@@ -47,11 +47,12 @@ function buildUrl(baseUrl, endpoint) {
|
|
|
47
47
|
const isPublicApi = baseUrl.includes("/api/public/v1");
|
|
48
48
|
const isExternalProxy = baseUrl.includes("/api/lastbrain");
|
|
49
49
|
// Map endpoints for internal vs external context
|
|
50
|
+
// Pour external: le proxy ajoute /api/ai/ automatiquement, donc on envoie juste auth/*, public/*, etc.
|
|
50
51
|
const endpointMap = {
|
|
51
52
|
// Text and image generation
|
|
52
|
-
"text-ai": { internal: "/generate-text", external: "/
|
|
53
|
-
"image-ai": { internal: "/generate-image", external: "/
|
|
54
|
-
// Auth endpoints -
|
|
53
|
+
"text-ai": { internal: "/generate-text", external: "/auth/text-ai" },
|
|
54
|
+
"image-ai": { internal: "/generate-image", external: "/auth/image-ai" },
|
|
55
|
+
// Auth endpoints - le proxy ajoutera /api/ai/ devant
|
|
55
56
|
status: { internal: "/auth/status", external: "/auth/status" },
|
|
56
57
|
provider: { internal: "/auth/provider", external: "/auth/provider" },
|
|
57
58
|
"gateway-models": {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lb-proxy.d.ts","sourceRoot":"","sources":["../../../src/route-handlers/nextjs/lb-proxy.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAExD;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,qCAAqC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,+BAA+B;IAC/B,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED;;;;;;;;;;;;GAYG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,GAAE,aAAkB;mBA6BlD,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;oBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;mBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;sBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;qBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"lb-proxy.d.ts","sourceRoot":"","sources":["../../../src/route-handlers/nextjs/lb-proxy.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAExD;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,qCAAqC;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,uDAAuD;IACvD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,+BAA+B;IAC/B,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED;;;;;;;;;;;;GAYG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,GAAE,aAAkB;mBA6BlD,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;oBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;mBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;sBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;qBAFb,WAAW,YACV;QAAE,MAAM,EAAE,OAAO,CAAC;YAAE,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAA;KAAE,KACjD,OAAO,CAAC,YAAY,CAAC;EAoIzB;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAChC,QAAQ,EAAE,YAAY,EACtB,YAAY,EAAE,MAAM,EACpB,SAAS,GAAE,MAAe,GACzB,YAAY,CAYd;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,YAAY,GAAG,YAAY,CAGzE"}
|
|
@@ -88,10 +88,20 @@ export function createLBProxyHandler(config = {}) {
|
|
|
88
88
|
// Lire le cookie de session
|
|
89
89
|
const sessionToken = request.cookies.get(sessionCookieName)?.value;
|
|
90
90
|
if (sessionToken) {
|
|
91
|
+
// Envoyer le cookie à la fois comme Authorization ET comme Cookie
|
|
91
92
|
headers["Authorization"] = `Bearer ${sessionToken}`;
|
|
93
|
+
headers["Cookie"] = `${sessionCookieName}=${sessionToken}`;
|
|
94
|
+
console.log("[LB Proxy] Forwarding session cookie:", {
|
|
95
|
+
name: sessionCookieName,
|
|
96
|
+
hasValue: !!sessionToken,
|
|
97
|
+
});
|
|
92
98
|
}
|
|
93
99
|
else if (!isPublicPath) {
|
|
94
100
|
// Pas d'auth disponible et route protégée
|
|
101
|
+
console.log("[LB Proxy] No auth available for protected route:", {
|
|
102
|
+
path,
|
|
103
|
+
isPublicPath,
|
|
104
|
+
});
|
|
95
105
|
return NextResponse.json({
|
|
96
106
|
error: "No authentication provided",
|
|
97
107
|
hint: "Set LB_API_KEY env variable or login via /api/lastbrain/auth/login",
|
package/package.json
CHANGED
|
@@ -82,11 +82,12 @@ function buildUrl(baseUrl: string, endpoint: string): string {
|
|
|
82
82
|
const isExternalProxy = baseUrl.includes("/api/lastbrain");
|
|
83
83
|
|
|
84
84
|
// Map endpoints for internal vs external context
|
|
85
|
+
// Pour external: le proxy ajoute /api/ai/ automatiquement, donc on envoie juste auth/*, public/*, etc.
|
|
85
86
|
const endpointMap: Record<string, { internal: string; external: string }> = {
|
|
86
87
|
// Text and image generation
|
|
87
|
-
"text-ai": { internal: "/generate-text", external: "/
|
|
88
|
-
"image-ai": { internal: "/generate-image", external: "/
|
|
89
|
-
// Auth endpoints -
|
|
88
|
+
"text-ai": { internal: "/generate-text", external: "/auth/text-ai" },
|
|
89
|
+
"image-ai": { internal: "/generate-image", external: "/auth/image-ai" },
|
|
90
|
+
// Auth endpoints - le proxy ajoutera /api/ai/ devant
|
|
90
91
|
status: { internal: "/auth/status", external: "/auth/status" },
|
|
91
92
|
provider: { internal: "/auth/provider", external: "/auth/provider" },
|
|
92
93
|
"gateway-models": {
|
|
@@ -118,9 +118,19 @@ export function createLBProxyHandler(config: LBProxyConfig = {}) {
|
|
|
118
118
|
// Lire le cookie de session
|
|
119
119
|
const sessionToken = request.cookies.get(sessionCookieName)?.value;
|
|
120
120
|
if (sessionToken) {
|
|
121
|
+
// Envoyer le cookie à la fois comme Authorization ET comme Cookie
|
|
121
122
|
headers["Authorization"] = `Bearer ${sessionToken}`;
|
|
123
|
+
headers["Cookie"] = `${sessionCookieName}=${sessionToken}`;
|
|
124
|
+
console.log("[LB Proxy] Forwarding session cookie:", {
|
|
125
|
+
name: sessionCookieName,
|
|
126
|
+
hasValue: !!sessionToken,
|
|
127
|
+
});
|
|
122
128
|
} else if (!isPublicPath) {
|
|
123
129
|
// Pas d'auth disponible et route protégée
|
|
130
|
+
console.log("[LB Proxy] No auth available for protected route:", {
|
|
131
|
+
path,
|
|
132
|
+
isPublicPath,
|
|
133
|
+
});
|
|
124
134
|
return NextResponse.json(
|
|
125
135
|
{
|
|
126
136
|
error: "No authentication provided",
|