@bridgerust/embex 0.1.14 → 0.1.16
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 +2 -2
- package/bun.lockb +0 -0
- package/dist/native.d.ts +138 -0
- package/dist/native.js +579 -0
- package/package.json +13 -7
package/README.md
CHANGED
|
@@ -40,7 +40,7 @@ async function main() {
|
|
|
40
40
|
};
|
|
41
41
|
|
|
42
42
|
// 2. Initialize Client (uses LanceDB embedded)
|
|
43
|
-
const client = await EmbexClient.newAsync("lancedb
|
|
43
|
+
const client = await EmbexClient.newAsync("lancedb", "./data");
|
|
44
44
|
|
|
45
45
|
// 3. Create Collection (384 dimensions for MiniLM)
|
|
46
46
|
await client.createCollection("products", 384);
|
|
@@ -93,7 +93,7 @@ Ready for production? Just change the initialization line.
|
|
|
93
93
|
**From LanceDB (Dev):**
|
|
94
94
|
|
|
95
95
|
```typescript
|
|
96
|
-
const client = await EmbexClient.newAsync("lancedb
|
|
96
|
+
const client = await EmbexClient.newAsync("lancedb", "./data");
|
|
97
97
|
```
|
|
98
98
|
|
|
99
99
|
**To Qdrant Cloud (Prod):**
|
package/bun.lockb
CHANGED
|
Binary file
|
package/dist/native.d.ts
ADDED
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
/* auto-generated by NAPI-RS */
|
|
2
|
+
/* eslint-disable */
|
|
3
|
+
export declare class Collection {
|
|
4
|
+
/** Insert points into the collection. */
|
|
5
|
+
insert(points: Array<Point>): Promise<void>
|
|
6
|
+
/** Search for similar vectors. */
|
|
7
|
+
query(vector: Array<number>, options?: SearchOptions | undefined | null): Promise<SearchResponse>
|
|
8
|
+
/**
|
|
9
|
+
* Search for similar vectors with direct parameters.
|
|
10
|
+
*
|
|
11
|
+
* @param vector - Query vector
|
|
12
|
+
* @param topK - Number of results to return (default: 10)
|
|
13
|
+
* @param filter - Optional metadata filter
|
|
14
|
+
* @param includeMetadata - Whether to include metadata (default: true)
|
|
15
|
+
* @param includeVector - Whether to include vectors (default: false)
|
|
16
|
+
*/
|
|
17
|
+
search(vector: Array<number>, topK?: number | undefined | null, filter?: any | undefined | null, includeMetadata?: boolean | undefined | null, includeVector?: boolean | undefined | null): Promise<SearchResponse>
|
|
18
|
+
/** Search using a builder pattern. */
|
|
19
|
+
buildSearch(vector: Array<number>): SearchBuilder
|
|
20
|
+
/** Query using a builder pattern (filter-only, no vector search). */
|
|
21
|
+
buildQuery(): QueryBuilder
|
|
22
|
+
/** Update metadata for points in the collection. */
|
|
23
|
+
updateMetadata(updates: Array<MetadataUpdate>): Promise<void>
|
|
24
|
+
delete(ids: Array<string>): Promise<void>
|
|
25
|
+
deleteCollection(): Promise<void>
|
|
26
|
+
create(dimension: number, distance: string): Promise<void>
|
|
27
|
+
/**
|
|
28
|
+
* Create the collection with optional dimension.
|
|
29
|
+
*
|
|
30
|
+
* For providers like Chroma that infer dimension from the first insert,
|
|
31
|
+
* you can pass `undefined` for dimension. For other providers, dimension is required.
|
|
32
|
+
*
|
|
33
|
+
* @param dimension - Optional dimension. Use `undefined` for Chroma (infers from first insert).
|
|
34
|
+
* @param distance - Distance metric ("cosine", "euclidean", or "dot").
|
|
35
|
+
*/
|
|
36
|
+
createAuto(dimension?: number | undefined | null, distance?: string | undefined | null): Promise<void>
|
|
37
|
+
insertBatch(points: Array<Point>, batchSize?: number | undefined | null, parallel?: number | undefined | null): Promise<void>
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/** Main client for the Embex vector database. */
|
|
41
|
+
export declare class EmbexClient {
|
|
42
|
+
/**
|
|
43
|
+
* Create a new Embex client.
|
|
44
|
+
*
|
|
45
|
+
* @param provider - The database provider (e.g., 'qdrant', 'pinecone').
|
|
46
|
+
* @param url - The connection URL.
|
|
47
|
+
* @param apiKey - Optional API key.
|
|
48
|
+
*/
|
|
49
|
+
constructor(provider: string, url: string, apiKey?: string | undefined | null)
|
|
50
|
+
/**
|
|
51
|
+
* Create a new Embex client with async initialization.
|
|
52
|
+
* Required for providers like 'milvus', 'pgvector', and 'lancedb'.
|
|
53
|
+
*
|
|
54
|
+
* @param provider - The database provider.
|
|
55
|
+
* @param url - The connection URL.
|
|
56
|
+
* @param apiKey - Optional API key.
|
|
57
|
+
*/
|
|
58
|
+
static newAsync(provider: string, url: string, apiKey?: string | undefined | null): Promise<EmbexClient>
|
|
59
|
+
collection(name: string): Collection
|
|
60
|
+
/**
|
|
61
|
+
* Run database migrations.
|
|
62
|
+
*
|
|
63
|
+
* @param migrations - Array of migration objects
|
|
64
|
+
* {
|
|
65
|
+
* version: string,
|
|
66
|
+
* operations: [{ type: 'create_collection', schema: ... }, { type: 'delete_collection', name: ... }],
|
|
67
|
+
* down_operations: [...]
|
|
68
|
+
* }
|
|
69
|
+
*/
|
|
70
|
+
runMigrations(migrations: Array<MigrationInput>): Promise<void>
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export declare class QueryBuilder {
|
|
74
|
+
limit(limit: number): QueryBuilder
|
|
75
|
+
offset(offset: number): QueryBuilder
|
|
76
|
+
includeVector(include: boolean): QueryBuilder
|
|
77
|
+
includeMetadata(include: boolean): QueryBuilder
|
|
78
|
+
filter(filter: any): QueryBuilder
|
|
79
|
+
aggregation(aggType: string): QueryBuilder
|
|
80
|
+
execute(): Promise<SearchResponse>
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
export declare class SearchBuilder {
|
|
84
|
+
limit(limit: number): SearchBuilder
|
|
85
|
+
offset(offset: number): SearchBuilder
|
|
86
|
+
includeVector(include: boolean): SearchBuilder
|
|
87
|
+
includeMetadata(include: boolean): SearchBuilder
|
|
88
|
+
filter(filter: any): SearchBuilder
|
|
89
|
+
aggregation(aggType: string): SearchBuilder
|
|
90
|
+
execute(): Promise<SearchResponse>
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
export declare function cli(args: Array<string>): Promise<void>
|
|
94
|
+
|
|
95
|
+
export interface MetadataUpdate {
|
|
96
|
+
/** Point ID to update. */
|
|
97
|
+
id: string
|
|
98
|
+
/** Metadata updates to apply. */
|
|
99
|
+
updates: Record<string, any>
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
export interface MigrationInput {
|
|
103
|
+
version: string
|
|
104
|
+
operations?: any
|
|
105
|
+
downOperations?: any
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
/** A point in the vector database. */
|
|
109
|
+
export interface Point {
|
|
110
|
+
id: string
|
|
111
|
+
vector: Array<number>
|
|
112
|
+
metadata?: Record<string, any>
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
export interface SearchOptions {
|
|
116
|
+
/** Number of results to return. */
|
|
117
|
+
limit?: number
|
|
118
|
+
/** Metadata filter. */
|
|
119
|
+
filter?: any
|
|
120
|
+
/** Whether to include metadata in results. */
|
|
121
|
+
includeMetadata?: boolean
|
|
122
|
+
/** Whether to include vector in results. */
|
|
123
|
+
includeVector?: boolean
|
|
124
|
+
/** Pagination offset. */
|
|
125
|
+
offset?: number
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
export interface SearchResponse {
|
|
129
|
+
results: Array<SearchResult>
|
|
130
|
+
aggregations: Record<string, any>
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
export interface SearchResult {
|
|
134
|
+
id: string
|
|
135
|
+
score: number
|
|
136
|
+
vector?: Array<number>
|
|
137
|
+
metadata?: Record<string, any>
|
|
138
|
+
}
|
package/dist/native.js
ADDED
|
@@ -0,0 +1,579 @@
|
|
|
1
|
+
// prettier-ignore
|
|
2
|
+
/* eslint-disable */
|
|
3
|
+
// @ts-nocheck
|
|
4
|
+
/* auto-generated by NAPI-RS */
|
|
5
|
+
|
|
6
|
+
const { readFileSync } = require('node:fs')
|
|
7
|
+
let nativeBinding = null
|
|
8
|
+
const loadErrors = []
|
|
9
|
+
|
|
10
|
+
const isMusl = () => {
|
|
11
|
+
let musl = false
|
|
12
|
+
if (process.platform === 'linux') {
|
|
13
|
+
musl = isMuslFromFilesystem()
|
|
14
|
+
if (musl === null) {
|
|
15
|
+
musl = isMuslFromReport()
|
|
16
|
+
}
|
|
17
|
+
if (musl === null) {
|
|
18
|
+
musl = isMuslFromChildProcess()
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return musl
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const isFileMusl = (f) => f.includes('libc.musl-') || f.includes('ld-musl-')
|
|
25
|
+
|
|
26
|
+
const isMuslFromFilesystem = () => {
|
|
27
|
+
try {
|
|
28
|
+
return readFileSync('/usr/bin/ldd', 'utf-8').includes('musl')
|
|
29
|
+
} catch {
|
|
30
|
+
return null
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
const isMuslFromReport = () => {
|
|
35
|
+
let report = null
|
|
36
|
+
if (typeof process.report?.getReport === 'function') {
|
|
37
|
+
process.report.excludeNetwork = true
|
|
38
|
+
report = process.report.getReport()
|
|
39
|
+
}
|
|
40
|
+
if (!report) {
|
|
41
|
+
return null
|
|
42
|
+
}
|
|
43
|
+
if (report.header && report.header.glibcVersionRuntime) {
|
|
44
|
+
return false
|
|
45
|
+
}
|
|
46
|
+
if (Array.isArray(report.sharedObjects)) {
|
|
47
|
+
if (report.sharedObjects.some(isFileMusl)) {
|
|
48
|
+
return true
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return false
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const isMuslFromChildProcess = () => {
|
|
55
|
+
try {
|
|
56
|
+
return require('child_process').execSync('ldd --version', { encoding: 'utf8' }).includes('musl')
|
|
57
|
+
} catch (e) {
|
|
58
|
+
// If we reach this case, we don't know if the system is musl or not, so is better to just fallback to false
|
|
59
|
+
return false
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function requireNative() {
|
|
64
|
+
if (process.env.NAPI_RS_NATIVE_LIBRARY_PATH) {
|
|
65
|
+
try {
|
|
66
|
+
return require(process.env.NAPI_RS_NATIVE_LIBRARY_PATH);
|
|
67
|
+
} catch (err) {
|
|
68
|
+
loadErrors.push(err)
|
|
69
|
+
}
|
|
70
|
+
} else if (process.platform === 'android') {
|
|
71
|
+
if (process.arch === 'arm64') {
|
|
72
|
+
try {
|
|
73
|
+
return require('./embex.android-arm64.node')
|
|
74
|
+
} catch (e) {
|
|
75
|
+
loadErrors.push(e)
|
|
76
|
+
}
|
|
77
|
+
try {
|
|
78
|
+
const binding = require('@bridgerust/embex-android-arm64')
|
|
79
|
+
const bindingPackageVersion = require('@bridgerust/embex-android-arm64/package.json').version
|
|
80
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
81
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
82
|
+
}
|
|
83
|
+
return binding
|
|
84
|
+
} catch (e) {
|
|
85
|
+
loadErrors.push(e)
|
|
86
|
+
}
|
|
87
|
+
} else if (process.arch === 'arm') {
|
|
88
|
+
try {
|
|
89
|
+
return require('./embex.android-arm-eabi.node')
|
|
90
|
+
} catch (e) {
|
|
91
|
+
loadErrors.push(e)
|
|
92
|
+
}
|
|
93
|
+
try {
|
|
94
|
+
const binding = require('@bridgerust/embex-android-arm-eabi')
|
|
95
|
+
const bindingPackageVersion = require('@bridgerust/embex-android-arm-eabi/package.json').version
|
|
96
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
97
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
98
|
+
}
|
|
99
|
+
return binding
|
|
100
|
+
} catch (e) {
|
|
101
|
+
loadErrors.push(e)
|
|
102
|
+
}
|
|
103
|
+
} else {
|
|
104
|
+
loadErrors.push(new Error(`Unsupported architecture on Android ${process.arch}`))
|
|
105
|
+
}
|
|
106
|
+
} else if (process.platform === 'win32') {
|
|
107
|
+
if (process.arch === 'x64') {
|
|
108
|
+
if (process.config?.variables?.shlib_suffix === 'dll.a' || process.config?.variables?.node_target_type === 'shared_library') {
|
|
109
|
+
try {
|
|
110
|
+
return require('./embex.win32-x64-gnu.node')
|
|
111
|
+
} catch (e) {
|
|
112
|
+
loadErrors.push(e)
|
|
113
|
+
}
|
|
114
|
+
try {
|
|
115
|
+
const binding = require('@bridgerust/embex-win32-x64-gnu')
|
|
116
|
+
const bindingPackageVersion = require('@bridgerust/embex-win32-x64-gnu/package.json').version
|
|
117
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
118
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
119
|
+
}
|
|
120
|
+
return binding
|
|
121
|
+
} catch (e) {
|
|
122
|
+
loadErrors.push(e)
|
|
123
|
+
}
|
|
124
|
+
} else {
|
|
125
|
+
try {
|
|
126
|
+
return require('./embex.win32-x64-msvc.node')
|
|
127
|
+
} catch (e) {
|
|
128
|
+
loadErrors.push(e)
|
|
129
|
+
}
|
|
130
|
+
try {
|
|
131
|
+
const binding = require('@bridgerust/embex-win32-x64-msvc')
|
|
132
|
+
const bindingPackageVersion = require('@bridgerust/embex-win32-x64-msvc/package.json').version
|
|
133
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
134
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
135
|
+
}
|
|
136
|
+
return binding
|
|
137
|
+
} catch (e) {
|
|
138
|
+
loadErrors.push(e)
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
} else if (process.arch === 'ia32') {
|
|
142
|
+
try {
|
|
143
|
+
return require('./embex.win32-ia32-msvc.node')
|
|
144
|
+
} catch (e) {
|
|
145
|
+
loadErrors.push(e)
|
|
146
|
+
}
|
|
147
|
+
try {
|
|
148
|
+
const binding = require('@bridgerust/embex-win32-ia32-msvc')
|
|
149
|
+
const bindingPackageVersion = require('@bridgerust/embex-win32-ia32-msvc/package.json').version
|
|
150
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
151
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
152
|
+
}
|
|
153
|
+
return binding
|
|
154
|
+
} catch (e) {
|
|
155
|
+
loadErrors.push(e)
|
|
156
|
+
}
|
|
157
|
+
} else if (process.arch === 'arm64') {
|
|
158
|
+
try {
|
|
159
|
+
return require('./embex.win32-arm64-msvc.node')
|
|
160
|
+
} catch (e) {
|
|
161
|
+
loadErrors.push(e)
|
|
162
|
+
}
|
|
163
|
+
try {
|
|
164
|
+
const binding = require('@bridgerust/embex-win32-arm64-msvc')
|
|
165
|
+
const bindingPackageVersion = require('@bridgerust/embex-win32-arm64-msvc/package.json').version
|
|
166
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
167
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
168
|
+
}
|
|
169
|
+
return binding
|
|
170
|
+
} catch (e) {
|
|
171
|
+
loadErrors.push(e)
|
|
172
|
+
}
|
|
173
|
+
} else {
|
|
174
|
+
loadErrors.push(new Error(`Unsupported architecture on Windows: ${process.arch}`))
|
|
175
|
+
}
|
|
176
|
+
} else if (process.platform === 'darwin') {
|
|
177
|
+
try {
|
|
178
|
+
return require('./embex.darwin-universal.node')
|
|
179
|
+
} catch (e) {
|
|
180
|
+
loadErrors.push(e)
|
|
181
|
+
}
|
|
182
|
+
try {
|
|
183
|
+
const binding = require('@bridgerust/embex-darwin-universal')
|
|
184
|
+
const bindingPackageVersion = require('@bridgerust/embex-darwin-universal/package.json').version
|
|
185
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
186
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
187
|
+
}
|
|
188
|
+
return binding
|
|
189
|
+
} catch (e) {
|
|
190
|
+
loadErrors.push(e)
|
|
191
|
+
}
|
|
192
|
+
if (process.arch === 'x64') {
|
|
193
|
+
try {
|
|
194
|
+
return require('./embex.darwin-x64.node')
|
|
195
|
+
} catch (e) {
|
|
196
|
+
loadErrors.push(e)
|
|
197
|
+
}
|
|
198
|
+
try {
|
|
199
|
+
const binding = require('@bridgerust/embex-darwin-x64')
|
|
200
|
+
const bindingPackageVersion = require('@bridgerust/embex-darwin-x64/package.json').version
|
|
201
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
202
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
203
|
+
}
|
|
204
|
+
return binding
|
|
205
|
+
} catch (e) {
|
|
206
|
+
loadErrors.push(e)
|
|
207
|
+
}
|
|
208
|
+
} else if (process.arch === 'arm64') {
|
|
209
|
+
try {
|
|
210
|
+
return require('./embex.darwin-arm64.node')
|
|
211
|
+
} catch (e) {
|
|
212
|
+
loadErrors.push(e)
|
|
213
|
+
}
|
|
214
|
+
try {
|
|
215
|
+
const binding = require('@bridgerust/embex-darwin-arm64')
|
|
216
|
+
const bindingPackageVersion = require('@bridgerust/embex-darwin-arm64/package.json').version
|
|
217
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
218
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
219
|
+
}
|
|
220
|
+
return binding
|
|
221
|
+
} catch (e) {
|
|
222
|
+
loadErrors.push(e)
|
|
223
|
+
}
|
|
224
|
+
} else {
|
|
225
|
+
loadErrors.push(new Error(`Unsupported architecture on macOS: ${process.arch}`))
|
|
226
|
+
}
|
|
227
|
+
} else if (process.platform === 'freebsd') {
|
|
228
|
+
if (process.arch === 'x64') {
|
|
229
|
+
try {
|
|
230
|
+
return require('./embex.freebsd-x64.node')
|
|
231
|
+
} catch (e) {
|
|
232
|
+
loadErrors.push(e)
|
|
233
|
+
}
|
|
234
|
+
try {
|
|
235
|
+
const binding = require('@bridgerust/embex-freebsd-x64')
|
|
236
|
+
const bindingPackageVersion = require('@bridgerust/embex-freebsd-x64/package.json').version
|
|
237
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
238
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
239
|
+
}
|
|
240
|
+
return binding
|
|
241
|
+
} catch (e) {
|
|
242
|
+
loadErrors.push(e)
|
|
243
|
+
}
|
|
244
|
+
} else if (process.arch === 'arm64') {
|
|
245
|
+
try {
|
|
246
|
+
return require('./embex.freebsd-arm64.node')
|
|
247
|
+
} catch (e) {
|
|
248
|
+
loadErrors.push(e)
|
|
249
|
+
}
|
|
250
|
+
try {
|
|
251
|
+
const binding = require('@bridgerust/embex-freebsd-arm64')
|
|
252
|
+
const bindingPackageVersion = require('@bridgerust/embex-freebsd-arm64/package.json').version
|
|
253
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
254
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
255
|
+
}
|
|
256
|
+
return binding
|
|
257
|
+
} catch (e) {
|
|
258
|
+
loadErrors.push(e)
|
|
259
|
+
}
|
|
260
|
+
} else {
|
|
261
|
+
loadErrors.push(new Error(`Unsupported architecture on FreeBSD: ${process.arch}`))
|
|
262
|
+
}
|
|
263
|
+
} else if (process.platform === 'linux') {
|
|
264
|
+
if (process.arch === 'x64') {
|
|
265
|
+
if (isMusl()) {
|
|
266
|
+
try {
|
|
267
|
+
return require('./embex.linux-x64-musl.node')
|
|
268
|
+
} catch (e) {
|
|
269
|
+
loadErrors.push(e)
|
|
270
|
+
}
|
|
271
|
+
try {
|
|
272
|
+
const binding = require('@bridgerust/embex-linux-x64-musl')
|
|
273
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-x64-musl/package.json').version
|
|
274
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
275
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
276
|
+
}
|
|
277
|
+
return binding
|
|
278
|
+
} catch (e) {
|
|
279
|
+
loadErrors.push(e)
|
|
280
|
+
}
|
|
281
|
+
} else {
|
|
282
|
+
try {
|
|
283
|
+
return require('./embex.linux-x64-gnu.node')
|
|
284
|
+
} catch (e) {
|
|
285
|
+
loadErrors.push(e)
|
|
286
|
+
}
|
|
287
|
+
try {
|
|
288
|
+
const binding = require('@bridgerust/embex-linux-x64-gnu')
|
|
289
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-x64-gnu/package.json').version
|
|
290
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
291
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
292
|
+
}
|
|
293
|
+
return binding
|
|
294
|
+
} catch (e) {
|
|
295
|
+
loadErrors.push(e)
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
} else if (process.arch === 'arm64') {
|
|
299
|
+
if (isMusl()) {
|
|
300
|
+
try {
|
|
301
|
+
return require('./embex.linux-arm64-musl.node')
|
|
302
|
+
} catch (e) {
|
|
303
|
+
loadErrors.push(e)
|
|
304
|
+
}
|
|
305
|
+
try {
|
|
306
|
+
const binding = require('@bridgerust/embex-linux-arm64-musl')
|
|
307
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-arm64-musl/package.json').version
|
|
308
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
309
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
310
|
+
}
|
|
311
|
+
return binding
|
|
312
|
+
} catch (e) {
|
|
313
|
+
loadErrors.push(e)
|
|
314
|
+
}
|
|
315
|
+
} else {
|
|
316
|
+
try {
|
|
317
|
+
return require('./embex.linux-arm64-gnu.node')
|
|
318
|
+
} catch (e) {
|
|
319
|
+
loadErrors.push(e)
|
|
320
|
+
}
|
|
321
|
+
try {
|
|
322
|
+
const binding = require('@bridgerust/embex-linux-arm64-gnu')
|
|
323
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-arm64-gnu/package.json').version
|
|
324
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
325
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
326
|
+
}
|
|
327
|
+
return binding
|
|
328
|
+
} catch (e) {
|
|
329
|
+
loadErrors.push(e)
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
} else if (process.arch === 'arm') {
|
|
333
|
+
if (isMusl()) {
|
|
334
|
+
try {
|
|
335
|
+
return require('./embex.linux-arm-musleabihf.node')
|
|
336
|
+
} catch (e) {
|
|
337
|
+
loadErrors.push(e)
|
|
338
|
+
}
|
|
339
|
+
try {
|
|
340
|
+
const binding = require('@bridgerust/embex-linux-arm-musleabihf')
|
|
341
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-arm-musleabihf/package.json').version
|
|
342
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
343
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
344
|
+
}
|
|
345
|
+
return binding
|
|
346
|
+
} catch (e) {
|
|
347
|
+
loadErrors.push(e)
|
|
348
|
+
}
|
|
349
|
+
} else {
|
|
350
|
+
try {
|
|
351
|
+
return require('./embex.linux-arm-gnueabihf.node')
|
|
352
|
+
} catch (e) {
|
|
353
|
+
loadErrors.push(e)
|
|
354
|
+
}
|
|
355
|
+
try {
|
|
356
|
+
const binding = require('@bridgerust/embex-linux-arm-gnueabihf')
|
|
357
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-arm-gnueabihf/package.json').version
|
|
358
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
359
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
360
|
+
}
|
|
361
|
+
return binding
|
|
362
|
+
} catch (e) {
|
|
363
|
+
loadErrors.push(e)
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
} else if (process.arch === 'loong64') {
|
|
367
|
+
if (isMusl()) {
|
|
368
|
+
try {
|
|
369
|
+
return require('./embex.linux-loong64-musl.node')
|
|
370
|
+
} catch (e) {
|
|
371
|
+
loadErrors.push(e)
|
|
372
|
+
}
|
|
373
|
+
try {
|
|
374
|
+
const binding = require('@bridgerust/embex-linux-loong64-musl')
|
|
375
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-loong64-musl/package.json').version
|
|
376
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
377
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
378
|
+
}
|
|
379
|
+
return binding
|
|
380
|
+
} catch (e) {
|
|
381
|
+
loadErrors.push(e)
|
|
382
|
+
}
|
|
383
|
+
} else {
|
|
384
|
+
try {
|
|
385
|
+
return require('./embex.linux-loong64-gnu.node')
|
|
386
|
+
} catch (e) {
|
|
387
|
+
loadErrors.push(e)
|
|
388
|
+
}
|
|
389
|
+
try {
|
|
390
|
+
const binding = require('@bridgerust/embex-linux-loong64-gnu')
|
|
391
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-loong64-gnu/package.json').version
|
|
392
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
393
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
394
|
+
}
|
|
395
|
+
return binding
|
|
396
|
+
} catch (e) {
|
|
397
|
+
loadErrors.push(e)
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
} else if (process.arch === 'riscv64') {
|
|
401
|
+
if (isMusl()) {
|
|
402
|
+
try {
|
|
403
|
+
return require('./embex.linux-riscv64-musl.node')
|
|
404
|
+
} catch (e) {
|
|
405
|
+
loadErrors.push(e)
|
|
406
|
+
}
|
|
407
|
+
try {
|
|
408
|
+
const binding = require('@bridgerust/embex-linux-riscv64-musl')
|
|
409
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-riscv64-musl/package.json').version
|
|
410
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
411
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
412
|
+
}
|
|
413
|
+
return binding
|
|
414
|
+
} catch (e) {
|
|
415
|
+
loadErrors.push(e)
|
|
416
|
+
}
|
|
417
|
+
} else {
|
|
418
|
+
try {
|
|
419
|
+
return require('./embex.linux-riscv64-gnu.node')
|
|
420
|
+
} catch (e) {
|
|
421
|
+
loadErrors.push(e)
|
|
422
|
+
}
|
|
423
|
+
try {
|
|
424
|
+
const binding = require('@bridgerust/embex-linux-riscv64-gnu')
|
|
425
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-riscv64-gnu/package.json').version
|
|
426
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
427
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
428
|
+
}
|
|
429
|
+
return binding
|
|
430
|
+
} catch (e) {
|
|
431
|
+
loadErrors.push(e)
|
|
432
|
+
}
|
|
433
|
+
}
|
|
434
|
+
} else if (process.arch === 'ppc64') {
|
|
435
|
+
try {
|
|
436
|
+
return require('./embex.linux-ppc64-gnu.node')
|
|
437
|
+
} catch (e) {
|
|
438
|
+
loadErrors.push(e)
|
|
439
|
+
}
|
|
440
|
+
try {
|
|
441
|
+
const binding = require('@bridgerust/embex-linux-ppc64-gnu')
|
|
442
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-ppc64-gnu/package.json').version
|
|
443
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
444
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
445
|
+
}
|
|
446
|
+
return binding
|
|
447
|
+
} catch (e) {
|
|
448
|
+
loadErrors.push(e)
|
|
449
|
+
}
|
|
450
|
+
} else if (process.arch === 's390x') {
|
|
451
|
+
try {
|
|
452
|
+
return require('./embex.linux-s390x-gnu.node')
|
|
453
|
+
} catch (e) {
|
|
454
|
+
loadErrors.push(e)
|
|
455
|
+
}
|
|
456
|
+
try {
|
|
457
|
+
const binding = require('@bridgerust/embex-linux-s390x-gnu')
|
|
458
|
+
const bindingPackageVersion = require('@bridgerust/embex-linux-s390x-gnu/package.json').version
|
|
459
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
460
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
461
|
+
}
|
|
462
|
+
return binding
|
|
463
|
+
} catch (e) {
|
|
464
|
+
loadErrors.push(e)
|
|
465
|
+
}
|
|
466
|
+
} else {
|
|
467
|
+
loadErrors.push(new Error(`Unsupported architecture on Linux: ${process.arch}`))
|
|
468
|
+
}
|
|
469
|
+
} else if (process.platform === 'openharmony') {
|
|
470
|
+
if (process.arch === 'arm64') {
|
|
471
|
+
try {
|
|
472
|
+
return require('./embex.openharmony-arm64.node')
|
|
473
|
+
} catch (e) {
|
|
474
|
+
loadErrors.push(e)
|
|
475
|
+
}
|
|
476
|
+
try {
|
|
477
|
+
const binding = require('@bridgerust/embex-openharmony-arm64')
|
|
478
|
+
const bindingPackageVersion = require('@bridgerust/embex-openharmony-arm64/package.json').version
|
|
479
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
480
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
481
|
+
}
|
|
482
|
+
return binding
|
|
483
|
+
} catch (e) {
|
|
484
|
+
loadErrors.push(e)
|
|
485
|
+
}
|
|
486
|
+
} else if (process.arch === 'x64') {
|
|
487
|
+
try {
|
|
488
|
+
return require('./embex.openharmony-x64.node')
|
|
489
|
+
} catch (e) {
|
|
490
|
+
loadErrors.push(e)
|
|
491
|
+
}
|
|
492
|
+
try {
|
|
493
|
+
const binding = require('@bridgerust/embex-openharmony-x64')
|
|
494
|
+
const bindingPackageVersion = require('@bridgerust/embex-openharmony-x64/package.json').version
|
|
495
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
496
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
497
|
+
}
|
|
498
|
+
return binding
|
|
499
|
+
} catch (e) {
|
|
500
|
+
loadErrors.push(e)
|
|
501
|
+
}
|
|
502
|
+
} else if (process.arch === 'arm') {
|
|
503
|
+
try {
|
|
504
|
+
return require('./embex.openharmony-arm.node')
|
|
505
|
+
} catch (e) {
|
|
506
|
+
loadErrors.push(e)
|
|
507
|
+
}
|
|
508
|
+
try {
|
|
509
|
+
const binding = require('@bridgerust/embex-openharmony-arm')
|
|
510
|
+
const bindingPackageVersion = require('@bridgerust/embex-openharmony-arm/package.json').version
|
|
511
|
+
if (bindingPackageVersion !== '0.1.8' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
|
|
512
|
+
throw new Error(`Native binding package version mismatch, expected 0.1.8 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
|
|
513
|
+
}
|
|
514
|
+
return binding
|
|
515
|
+
} catch (e) {
|
|
516
|
+
loadErrors.push(e)
|
|
517
|
+
}
|
|
518
|
+
} else {
|
|
519
|
+
loadErrors.push(new Error(`Unsupported architecture on OpenHarmony: ${process.arch}`))
|
|
520
|
+
}
|
|
521
|
+
} else {
|
|
522
|
+
loadErrors.push(new Error(`Unsupported OS: ${process.platform}, architecture: ${process.arch}`))
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
|
|
526
|
+
nativeBinding = requireNative()
|
|
527
|
+
|
|
528
|
+
if (!nativeBinding || process.env.NAPI_RS_FORCE_WASI) {
|
|
529
|
+
let wasiBinding = null
|
|
530
|
+
let wasiBindingError = null
|
|
531
|
+
try {
|
|
532
|
+
wasiBinding = require('./embex.wasi.cjs')
|
|
533
|
+
nativeBinding = wasiBinding
|
|
534
|
+
} catch (err) {
|
|
535
|
+
if (process.env.NAPI_RS_FORCE_WASI) {
|
|
536
|
+
wasiBindingError = err
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
if (!nativeBinding) {
|
|
540
|
+
try {
|
|
541
|
+
wasiBinding = require('@bridgerust/embex-wasm32-wasi')
|
|
542
|
+
nativeBinding = wasiBinding
|
|
543
|
+
} catch (err) {
|
|
544
|
+
if (process.env.NAPI_RS_FORCE_WASI) {
|
|
545
|
+
wasiBindingError.cause = err
|
|
546
|
+
loadErrors.push(err)
|
|
547
|
+
}
|
|
548
|
+
}
|
|
549
|
+
}
|
|
550
|
+
if (process.env.NAPI_RS_FORCE_WASI === 'error' && !wasiBinding) {
|
|
551
|
+
const error = new Error('WASI binding not found and NAPI_RS_FORCE_WASI is set to error')
|
|
552
|
+
error.cause = wasiBindingError
|
|
553
|
+
throw error
|
|
554
|
+
}
|
|
555
|
+
}
|
|
556
|
+
|
|
557
|
+
if (!nativeBinding) {
|
|
558
|
+
if (loadErrors.length > 0) {
|
|
559
|
+
throw new Error(
|
|
560
|
+
`Cannot find native binding. ` +
|
|
561
|
+
`npm has a bug related to optional dependencies (https://github.com/npm/cli/issues/4828). ` +
|
|
562
|
+
'Please try `npm i` again after removing both package-lock.json and node_modules directory.',
|
|
563
|
+
{
|
|
564
|
+
cause: loadErrors.reduce((err, cur) => {
|
|
565
|
+
cur.cause = err
|
|
566
|
+
return cur
|
|
567
|
+
}),
|
|
568
|
+
},
|
|
569
|
+
)
|
|
570
|
+
}
|
|
571
|
+
throw new Error(`Failed to load native binding`)
|
|
572
|
+
}
|
|
573
|
+
|
|
574
|
+
module.exports = nativeBinding
|
|
575
|
+
module.exports.Collection = nativeBinding.Collection
|
|
576
|
+
module.exports.EmbexClient = nativeBinding.EmbexClient
|
|
577
|
+
module.exports.QueryBuilder = nativeBinding.QueryBuilder
|
|
578
|
+
module.exports.SearchBuilder = nativeBinding.SearchBuilder
|
|
579
|
+
module.exports.cli = nativeBinding.cli
|
package/package.json
CHANGED
|
@@ -1,8 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bridgerust/embex",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.16",
|
|
4
4
|
"description": "Embex Vector Database ORM Node.js Bindings",
|
|
5
5
|
"homepage": "https://github.com/bridgerust/bridgerust/tree/main/crates/embex",
|
|
6
|
+
"authors": [
|
|
7
|
+
{
|
|
8
|
+
"name": "BridgeRust",
|
|
9
|
+
"email": "hello@kologojosias.com"
|
|
10
|
+
}
|
|
11
|
+
],
|
|
6
12
|
"repository": {
|
|
7
13
|
"type": "git",
|
|
8
14
|
"url": "https://github.com/bridgerust/bridgerust/tree/main/crates/embex"
|
|
@@ -49,7 +55,7 @@
|
|
|
49
55
|
"build": "napi build --platform --release --js native.js --dts native.d.ts && tsc",
|
|
50
56
|
"build:debug": "napi build --platform --js native.js --dts native.d.ts && tsc",
|
|
51
57
|
"artifacts": "napi artifacts",
|
|
52
|
-
"prepublishOnly": "tsc",
|
|
58
|
+
"prepublishOnly": "tsc && cp native.js dist/native.js && cp native.d.ts dist/native.d.ts || true",
|
|
53
59
|
"test": "vitest run",
|
|
54
60
|
"test:unit": "vitest run tests/unit",
|
|
55
61
|
"test:integration": "vitest run tests/integration",
|
|
@@ -62,10 +68,10 @@
|
|
|
62
68
|
"@types/node": "^25.0.3"
|
|
63
69
|
},
|
|
64
70
|
"optionalDependencies": {
|
|
65
|
-
"@bridgerust/embex-darwin-arm64": "0.1.
|
|
66
|
-
"@bridgerust/embex-darwin-x64": "0.1.
|
|
67
|
-
"@bridgerust/embex-linux-x64-gnu": "0.1.
|
|
68
|
-
"@bridgerust/embex-linux-x64-musl": "0.1.
|
|
69
|
-
"@bridgerust/embex-win32-x64-msvc": "0.1.
|
|
71
|
+
"@bridgerust/embex-darwin-arm64": "0.1.16",
|
|
72
|
+
"@bridgerust/embex-darwin-x64": "0.1.16",
|
|
73
|
+
"@bridgerust/embex-linux-x64-gnu": "0.1.16",
|
|
74
|
+
"@bridgerust/embex-linux-x64-musl": "0.1.16",
|
|
75
|
+
"@bridgerust/embex-win32-x64-msvc": "0.1.16"
|
|
70
76
|
}
|
|
71
77
|
}
|