@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 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://./data");
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://./data");
96
+ const client = await EmbexClient.newAsync("lancedb", "./data");
97
97
  ```
98
98
 
99
99
  **To Qdrant Cloud (Prod):**
package/bun.lockb CHANGED
Binary file
@@ -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.14",
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.14",
66
- "@bridgerust/embex-darwin-x64": "0.1.14",
67
- "@bridgerust/embex-linux-x64-gnu": "0.1.14",
68
- "@bridgerust/embex-linux-x64-musl": "0.1.14",
69
- "@bridgerust/embex-win32-x64-msvc": "0.1.14"
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
  }