@exulu/backend 1.19.0 → 1.19.2
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/.claude/settings.json +7 -0
- package/.github/workflows/release.yml +1 -0
- package/dist/index.cjs +7 -5
- package/dist/index.js +7 -5
- package/package.json +1 -1
- package/release.config.cjs +5 -1
- package/CHANGELOG.md +0 -6
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"env": {
|
|
3
|
+
"ANTHROPIC_BASE_URL": "https://backend.exulu.com/gateway/anthropic/12b88f47-5a8c-41cc-aea8-c4842352b46a",
|
|
4
|
+
"DISABLE_AUTOUPDATER": 0
|
|
5
|
+
},
|
|
6
|
+
"apiKeyHelper": "echo eyJhbGciOiJIUzI1NiJ9.eyJpZCI6IjEiLCJlbWFpbCI6ImFkbWluQGV4dWx1LmNvbSIsImlhdCI6MTc2MDA4ODI5NiwiZXhwIjoxNzkxNjI0Mjk2fQ.gTXGxccE0hXoIjsrpIIp6b0lCWqrQKm-xEwXc8kZqyw"
|
|
7
|
+
}
|
package/dist/index.cjs
CHANGED
|
@@ -1421,7 +1421,7 @@ var ExuluContext = class {
|
|
|
1421
1421
|
COALESCE(1.0 / (? + ft.rank_ix), 0.0) * ?
|
|
1422
1422
|
+
|
|
1423
1423
|
COALESCE(1.0 / (? + se.rank_ix), 0.0) * ?
|
|
1424
|
-
) AS hybrid_score
|
|
1424
|
+
)::float AS hybrid_score
|
|
1425
1425
|
|
|
1426
1426
|
FROM full_text ft
|
|
1427
1427
|
FULL OUTER JOIN semantic se
|
|
@@ -1457,7 +1457,7 @@ var ExuluContext = class {
|
|
|
1457
1457
|
];
|
|
1458
1458
|
items = await db3.raw(hybridSQL, bindings).then((r) => r.rows ?? r);
|
|
1459
1459
|
}
|
|
1460
|
-
console.log("items", items
|
|
1460
|
+
console.log("items", items);
|
|
1461
1461
|
const seenSources = /* @__PURE__ */ new Map();
|
|
1462
1462
|
items = items.reduce((acc, item) => {
|
|
1463
1463
|
if (!seenSources.has(item.source)) {
|
|
@@ -1490,6 +1490,7 @@ var ExuluContext = class {
|
|
|
1490
1490
|
}
|
|
1491
1491
|
return acc;
|
|
1492
1492
|
}, []);
|
|
1493
|
+
console.log("items", items);
|
|
1493
1494
|
items.forEach((item) => {
|
|
1494
1495
|
if (!item.chunks?.length) {
|
|
1495
1496
|
return;
|
|
@@ -1511,7 +1512,8 @@ var ExuluContext = class {
|
|
|
1511
1512
|
item.averageRelevance = average;
|
|
1512
1513
|
item.totalRelevance = total;
|
|
1513
1514
|
} else if (method === "hybridSearch") {
|
|
1514
|
-
|
|
1515
|
+
console.log("item.chunks", item.chunks);
|
|
1516
|
+
const scores = item.chunks.map((c) => typeof c.hybrid_score === "number" ? c.hybrid_score * 10 + 1 : 0);
|
|
1515
1517
|
const total = scores.reduce((a, b) => a + b, 0);
|
|
1516
1518
|
const average = scores.length ? total / scores.length : 0;
|
|
1517
1519
|
item.averageRelevance = average;
|
|
@@ -1588,8 +1590,8 @@ var ExuluContext = class {
|
|
|
1588
1590
|
CREATE INDEX IF NOT EXISTS ${tableName}_embedding_hnsw_cosine
|
|
1589
1591
|
ON ${tableName}
|
|
1590
1592
|
USING hnsw (embedding vector_cosine_ops)
|
|
1591
|
-
WHERE embedding IS NOT NULL
|
|
1592
1593
|
WITH (m = 16, ef_construction = 64)
|
|
1594
|
+
WHERE embedding IS NOT NULL
|
|
1593
1595
|
`);
|
|
1594
1596
|
return;
|
|
1595
1597
|
};
|
|
@@ -5058,7 +5060,7 @@ var createWorkers = async (queues2, logger, contexts, _logsDir, tracer) => {
|
|
|
5058
5060
|
const result = await context.createAndUpsertEmbeddings(data.inputs, data.user, {
|
|
5059
5061
|
label: embedder.name,
|
|
5060
5062
|
trigger: data.trigger
|
|
5061
|
-
});
|
|
5063
|
+
}, data.role, bullmqJob.id);
|
|
5062
5064
|
return result;
|
|
5063
5065
|
}
|
|
5064
5066
|
if (bullmqJob.data.type === "workflow") {
|
package/dist/index.js
CHANGED
|
@@ -1380,7 +1380,7 @@ var ExuluContext = class {
|
|
|
1380
1380
|
COALESCE(1.0 / (? + ft.rank_ix), 0.0) * ?
|
|
1381
1381
|
+
|
|
1382
1382
|
COALESCE(1.0 / (? + se.rank_ix), 0.0) * ?
|
|
1383
|
-
) AS hybrid_score
|
|
1383
|
+
)::float AS hybrid_score
|
|
1384
1384
|
|
|
1385
1385
|
FROM full_text ft
|
|
1386
1386
|
FULL OUTER JOIN semantic se
|
|
@@ -1416,7 +1416,7 @@ var ExuluContext = class {
|
|
|
1416
1416
|
];
|
|
1417
1417
|
items = await db3.raw(hybridSQL, bindings).then((r) => r.rows ?? r);
|
|
1418
1418
|
}
|
|
1419
|
-
console.log("items", items
|
|
1419
|
+
console.log("items", items);
|
|
1420
1420
|
const seenSources = /* @__PURE__ */ new Map();
|
|
1421
1421
|
items = items.reduce((acc, item) => {
|
|
1422
1422
|
if (!seenSources.has(item.source)) {
|
|
@@ -1449,6 +1449,7 @@ var ExuluContext = class {
|
|
|
1449
1449
|
}
|
|
1450
1450
|
return acc;
|
|
1451
1451
|
}, []);
|
|
1452
|
+
console.log("items", items);
|
|
1452
1453
|
items.forEach((item) => {
|
|
1453
1454
|
if (!item.chunks?.length) {
|
|
1454
1455
|
return;
|
|
@@ -1470,7 +1471,8 @@ var ExuluContext = class {
|
|
|
1470
1471
|
item.averageRelevance = average;
|
|
1471
1472
|
item.totalRelevance = total;
|
|
1472
1473
|
} else if (method === "hybridSearch") {
|
|
1473
|
-
|
|
1474
|
+
console.log("item.chunks", item.chunks);
|
|
1475
|
+
const scores = item.chunks.map((c) => typeof c.hybrid_score === "number" ? c.hybrid_score * 10 + 1 : 0);
|
|
1474
1476
|
const total = scores.reduce((a, b) => a + b, 0);
|
|
1475
1477
|
const average = scores.length ? total / scores.length : 0;
|
|
1476
1478
|
item.averageRelevance = average;
|
|
@@ -1547,8 +1549,8 @@ var ExuluContext = class {
|
|
|
1547
1549
|
CREATE INDEX IF NOT EXISTS ${tableName}_embedding_hnsw_cosine
|
|
1548
1550
|
ON ${tableName}
|
|
1549
1551
|
USING hnsw (embedding vector_cosine_ops)
|
|
1550
|
-
WHERE embedding IS NOT NULL
|
|
1551
1552
|
WITH (m = 16, ef_construction = 64)
|
|
1553
|
+
WHERE embedding IS NOT NULL
|
|
1552
1554
|
`);
|
|
1553
1555
|
return;
|
|
1554
1556
|
};
|
|
@@ -5017,7 +5019,7 @@ var createWorkers = async (queues2, logger, contexts, _logsDir, tracer) => {
|
|
|
5017
5019
|
const result = await context.createAndUpsertEmbeddings(data.inputs, data.user, {
|
|
5018
5020
|
label: embedder.name,
|
|
5019
5021
|
trigger: data.trigger
|
|
5020
|
-
});
|
|
5022
|
+
}, data.role, bullmqJob.id);
|
|
5021
5023
|
return result;
|
|
5022
5024
|
}
|
|
5023
5025
|
if (bullmqJob.data.type === "workflow") {
|
package/package.json
CHANGED
package/release.config.cjs
CHANGED
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
module.exports = {
|
|
2
|
-
branches: [
|
|
2
|
+
branches: [
|
|
3
|
+
'main',
|
|
4
|
+
{ name: 'next', prerelease: true },
|
|
5
|
+
{ name: 'hotfix/*', rangeStrategy: 'always'} // any branch like hotfix/1.19.1 will trigger a release
|
|
6
|
+
],
|
|
3
7
|
plugins: [
|
|
4
8
|
'@semantic-release/commit-analyzer',
|
|
5
9
|
'@semantic-release/release-notes-generator',
|
package/CHANGELOG.md
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
# [1.19.0](https://github.com/Qventu/exulu-backend/compare/v1.18.0...v1.19.0) (2025-08-29)
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
### Features
|
|
5
|
-
|
|
6
|
-
* change context retrieval from name to ids, add hybrid search method ([80503e3](https://github.com/Qventu/exulu-backend/commit/80503e3b283d8a962b0491f8bde33102f5ee26de))
|