@lastbrain/ai-ui-core 1.0.50 → 1.0.52
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 +13 -8
- package/dist/route-handlers/nextjs/lb-proxy.d.ts.map +1 -1
- package/dist/route-handlers/nextjs/lb-proxy.js +10 -1
- package/package.json +1 -1
- package/src/client/createClient.ts +14 -8
- package/src/route-handlers/nextjs/lb-proxy.ts +11 -1
|
@@ -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;AA4GlB,wBAAgB,cAAc,CAAC,MAAM,EAAE;IACrC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,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;AA4GlB,wBAAgB,cAAc,CAAC,MAAM,EAAE;IACrC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAyBzB;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,YAAY;qBAoBnB,OAAO,CAAC,QAAQ,EAAE,CAAC;iCA0KP,OAAO,CAAC,qBAAqB,CAAC;wBApIrC,aAAa,KAAG,OAAO,CAAC,cAAc,CAAC;yBAqCtC,cAAc,KAAG,OAAO,CAAC,eAAe,CAAC;iBAsDjD,cAAc,KAAG,OAAO,CAAC,eAAe,CAAC;qBAmBvC,OAAO,CAAC,QAAQ,CAAC;EAmD9C"}
|
|
@@ -80,18 +80,23 @@ export function getAuthHeaders(config) {
|
|
|
80
80
|
const token = config.apiKeyId?.trim();
|
|
81
81
|
const looksLikeApiKey = Boolean(token && token.startsWith("lb_"));
|
|
82
82
|
const looksLikeJwt = Boolean(token && token.split(".").length === 3);
|
|
83
|
+
const looksLikeSelectedKeyId = Boolean(token) && !looksLikeApiKey && !looksLikeJwt;
|
|
84
|
+
const headers = {};
|
|
85
|
+
if (looksLikeSelectedKeyId && token) {
|
|
86
|
+
headers["x-lb-api-key-selected"] = token;
|
|
87
|
+
}
|
|
83
88
|
if (token && (looksLikeApiKey || looksLikeJwt)) {
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
}
|
|
89
|
+
if (looksLikeApiKey) {
|
|
90
|
+
headers["x-lb-api-key"] = token;
|
|
91
|
+
}
|
|
92
|
+
headers.Authorization = `Bearer ${token}`;
|
|
93
|
+
return headers;
|
|
88
94
|
}
|
|
89
95
|
if (config.sessionToken) {
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
};
|
|
96
|
+
headers.Authorization = `Bearer ${config.sessionToken}`;
|
|
97
|
+
return headers;
|
|
93
98
|
}
|
|
94
|
-
return
|
|
99
|
+
return headers;
|
|
95
100
|
}
|
|
96
101
|
export function createClient(config) {
|
|
97
102
|
const timeout = config.timeout ?? DEFAULT_TIMEOUT;
|
|
@@ -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;mBA4BlD,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;mBA4BlD,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;EAuJzB;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"}
|
|
@@ -76,17 +76,26 @@ export function createLBProxyHandler(config = {}) {
|
|
|
76
76
|
}
|
|
77
77
|
const authorization = request.headers.get("authorization");
|
|
78
78
|
const explicitApiKeyHeader = request.headers.get("x-lb-api-key");
|
|
79
|
+
const selectedApiKeyHeader = request.headers.get("x-lb-api-key-selected");
|
|
79
80
|
const sessionToken = request.cookies.get(sessionCookieName)?.value;
|
|
81
|
+
const selectedApiKeyCookie = request.cookies.get("api_key_selected")?.value || null;
|
|
80
82
|
if (authorization) {
|
|
81
83
|
headers["Authorization"] = authorization;
|
|
82
84
|
}
|
|
83
85
|
if (explicitApiKeyHeader) {
|
|
84
86
|
headers["x-lb-api-key"] = explicitApiKeyHeader;
|
|
85
87
|
}
|
|
88
|
+
if (selectedApiKeyHeader) {
|
|
89
|
+
headers["x-lb-api-key-selected"] = selectedApiKeyHeader;
|
|
90
|
+
}
|
|
86
91
|
if (sessionToken) {
|
|
87
92
|
// Always forward lb_session cookie to allow backend fallback auth,
|
|
88
93
|
// even when an Authorization header is present.
|
|
89
|
-
|
|
94
|
+
const cookieParts = [`${sessionCookieName}=${sessionToken}`];
|
|
95
|
+
if (selectedApiKeyCookie) {
|
|
96
|
+
cookieParts.push(`api_key_selected=${selectedApiKeyCookie}`);
|
|
97
|
+
}
|
|
98
|
+
headers["Cookie"] = cookieParts.join("; ");
|
|
90
99
|
}
|
|
91
100
|
// Authentification : LB_API_KEY ou session cookie
|
|
92
101
|
if (!authorization && !explicitApiKeyHeader) {
|
package/package.json
CHANGED
|
@@ -124,21 +124,27 @@ export function getAuthHeaders(config: {
|
|
|
124
124
|
const token = config.apiKeyId?.trim();
|
|
125
125
|
const looksLikeApiKey = Boolean(token && token.startsWith("lb_"));
|
|
126
126
|
const looksLikeJwt = Boolean(token && token.split(".").length === 3);
|
|
127
|
+
const looksLikeSelectedKeyId =
|
|
128
|
+
Boolean(token) && !looksLikeApiKey && !looksLikeJwt;
|
|
129
|
+
const headers: Record<string, string> = {};
|
|
130
|
+
if (looksLikeSelectedKeyId && token) {
|
|
131
|
+
headers["x-lb-api-key-selected"] = token;
|
|
132
|
+
}
|
|
127
133
|
|
|
128
134
|
if (token && (looksLikeApiKey || looksLikeJwt)) {
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
}
|
|
135
|
+
if (looksLikeApiKey) {
|
|
136
|
+
headers["x-lb-api-key"] = token;
|
|
137
|
+
}
|
|
138
|
+
headers.Authorization = `Bearer ${token}`;
|
|
139
|
+
return headers;
|
|
133
140
|
}
|
|
134
141
|
|
|
135
142
|
if (config.sessionToken) {
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
};
|
|
143
|
+
headers.Authorization = `Bearer ${config.sessionToken}`;
|
|
144
|
+
return headers;
|
|
139
145
|
}
|
|
140
146
|
|
|
141
|
-
return
|
|
147
|
+
return headers;
|
|
142
148
|
}
|
|
143
149
|
|
|
144
150
|
export function createClient(config: ClientConfig) {
|
|
@@ -106,17 +106,27 @@ export function createLBProxyHandler(config: LBProxyConfig = {}) {
|
|
|
106
106
|
|
|
107
107
|
const authorization = request.headers.get("authorization");
|
|
108
108
|
const explicitApiKeyHeader = request.headers.get("x-lb-api-key");
|
|
109
|
+
const selectedApiKeyHeader = request.headers.get("x-lb-api-key-selected");
|
|
109
110
|
const sessionToken = request.cookies.get(sessionCookieName)?.value;
|
|
111
|
+
const selectedApiKeyCookie =
|
|
112
|
+
request.cookies.get("api_key_selected")?.value || null;
|
|
110
113
|
if (authorization) {
|
|
111
114
|
headers["Authorization"] = authorization;
|
|
112
115
|
}
|
|
113
116
|
if (explicitApiKeyHeader) {
|
|
114
117
|
headers["x-lb-api-key"] = explicitApiKeyHeader;
|
|
115
118
|
}
|
|
119
|
+
if (selectedApiKeyHeader) {
|
|
120
|
+
headers["x-lb-api-key-selected"] = selectedApiKeyHeader;
|
|
121
|
+
}
|
|
116
122
|
if (sessionToken) {
|
|
117
123
|
// Always forward lb_session cookie to allow backend fallback auth,
|
|
118
124
|
// even when an Authorization header is present.
|
|
119
|
-
|
|
125
|
+
const cookieParts = [`${sessionCookieName}=${sessionToken}`];
|
|
126
|
+
if (selectedApiKeyCookie) {
|
|
127
|
+
cookieParts.push(`api_key_selected=${selectedApiKeyCookie}`);
|
|
128
|
+
}
|
|
129
|
+
headers["Cookie"] = cookieParts.join("; ");
|
|
120
130
|
}
|
|
121
131
|
|
|
122
132
|
// Authentification : LB_API_KEY ou session cookie
|