@elizaos/computeruse 0.24.20

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/Cargo.toml ADDED
@@ -0,0 +1,34 @@
1
+ [package]
2
+ name = "computeruse-node-bindings"
3
+ version.workspace = true
4
+ edition.workspace = true
5
+
6
+ [lib]
7
+ name = "computeruse_node_bindings"
8
+ crate-type = ["cdylib"]
9
+
10
+ [dependencies]
11
+ # NAPI for Node.js bindings
12
+ # Default enable napi4 feature, see https://nodejs.org/api/n-api.html#node-api-version-matrix
13
+ napi = { version = "2.12.2", default-features = false, features = [
14
+ "napi4",
15
+ "tokio_rt",
16
+ ] }
17
+ napi-derive = "2.12.2"
18
+ computeruse = { workspace = true }
19
+ tracing = { workspace = true }
20
+ tracing-subscriber = { workspace = true }
21
+ serde = { version = "1.0", features = ["derive"] }
22
+ serde_json = "1.0"
23
+ # For Gemini Vision image processing and HTTP requests
24
+ base64 = "0.22"
25
+ image = { version = "0.25", default-features = false, features = ["png"] }
26
+ reqwest = { version = "0.12", default-features = false, features = ["json", "rustls-tls"] }
27
+ # For blocking on async in sync context
28
+ futures = "0.3"
29
+
30
+ [build-dependencies]
31
+ napi-build = "2.0.1"
32
+
33
+ [target.'cfg(target_os = "windows")'.build-dependencies]
34
+ static_vcruntime = "2.0"
package/build.rs ADDED
@@ -0,0 +1,10 @@
1
+ extern crate napi_build;
2
+
3
+ fn main() {
4
+ // Statically link VC runtime to avoid VCRUNTIME140.dll dependency
5
+ // This ensures the native module works on fresh Windows installs and Windows Sandbox
6
+ #[cfg(target_os = "windows")]
7
+ static_vcruntime::metabuild();
8
+
9
+ napi_build::setup();
10
+ }
Binary file
package/index.d.ts ADDED
File without changes
package/index.js ADDED
@@ -0,0 +1,327 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+ /* prettier-ignore */
4
+
5
+ /* auto-generated by NAPI-RS */
6
+
7
+ const { existsSync, readFileSync } = require('fs')
8
+ const { join } = require('path')
9
+
10
+ const { platform, arch } = process
11
+
12
+ let nativeBinding = null
13
+ let localFileExisted = false
14
+ let loadError = null
15
+
16
+ function isMusl() {
17
+ // For Node 10
18
+ if (!process.report || typeof process.report.getReport !== 'function') {
19
+ try {
20
+ const lddPath = require('child_process').execSync('which ldd').toString().trim()
21
+ return readFileSync(lddPath, 'utf8').includes('musl')
22
+ } catch (e) {
23
+ return true
24
+ }
25
+ } else {
26
+ const { glibcVersionRuntime } = process.report.getReport().header
27
+ return !glibcVersionRuntime
28
+ }
29
+ }
30
+
31
+ switch (platform) {
32
+ case 'android':
33
+ switch (arch) {
34
+ case 'arm64':
35
+ localFileExisted = existsSync(join(__dirname, 'computeruse.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./computeruse.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('@elizaos/computeruse-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'computeruse.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./computeruse.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('@elizaos/computeruse-android-arm-eabi')
53
+ }
54
+ } catch (e) {
55
+ loadError = e
56
+ }
57
+ break
58
+ default:
59
+ throw new Error(`Unsupported architecture on Android ${arch}`)
60
+ }
61
+ break
62
+ case 'win32':
63
+ switch (arch) {
64
+ case 'x64':
65
+ localFileExisted = existsSync(
66
+ join(__dirname, 'computeruse.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./computeruse.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('@elizaos/computeruse-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'computeruse.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./computeruse.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('@elizaos/computeruse-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'computeruse.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./computeruse.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('@elizaos/computeruse-win32-arm64-msvc')
101
+ }
102
+ } catch (e) {
103
+ loadError = e
104
+ }
105
+ break
106
+ default:
107
+ throw new Error(`Unsupported architecture on Windows: ${arch}`)
108
+ }
109
+ break
110
+ case 'darwin':
111
+ localFileExisted = existsSync(join(__dirname, 'computeruse.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./computeruse.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('@elizaos/computeruse-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'computeruse.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./computeruse.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('@elizaos/computeruse-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'computeruse.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./computeruse.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('@elizaos/computeruse-darwin-arm64')
142
+ }
143
+ } catch (e) {
144
+ loadError = e
145
+ }
146
+ break
147
+ default:
148
+ throw new Error(`Unsupported architecture on macOS: ${arch}`)
149
+ }
150
+ break
151
+ case 'freebsd':
152
+ if (arch !== 'x64') {
153
+ throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
154
+ }
155
+ localFileExisted = existsSync(join(__dirname, 'computeruse.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./computeruse.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('@elizaos/computeruse-freebsd-x64')
161
+ }
162
+ } catch (e) {
163
+ loadError = e
164
+ }
165
+ break
166
+ case 'linux':
167
+ switch (arch) {
168
+ case 'x64':
169
+ if (isMusl()) {
170
+ localFileExisted = existsSync(
171
+ join(__dirname, 'computeruse.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./computeruse.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('@elizaos/computeruse-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'computeruse.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./computeruse.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('@elizaos/computeruse-linux-x64-gnu')
191
+ }
192
+ } catch (e) {
193
+ loadError = e
194
+ }
195
+ }
196
+ break
197
+ case 'arm64':
198
+ if (isMusl()) {
199
+ localFileExisted = existsSync(
200
+ join(__dirname, 'computeruse.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./computeruse.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('@elizaos/computeruse-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'computeruse.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./computeruse.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('@elizaos/computeruse-linux-arm64-gnu')
220
+ }
221
+ } catch (e) {
222
+ loadError = e
223
+ }
224
+ }
225
+ break
226
+ case 'arm':
227
+ if (isMusl()) {
228
+ localFileExisted = existsSync(
229
+ join(__dirname, 'computeruse.linux-arm-musleabihf.node')
230
+ )
231
+ try {
232
+ if (localFileExisted) {
233
+ nativeBinding = require('./computeruse.linux-arm-musleabihf.node')
234
+ } else {
235
+ nativeBinding = require('@elizaos/computeruse-linux-arm-musleabihf')
236
+ }
237
+ } catch (e) {
238
+ loadError = e
239
+ }
240
+ } else {
241
+ localFileExisted = existsSync(
242
+ join(__dirname, 'computeruse.linux-arm-gnueabihf.node')
243
+ )
244
+ try {
245
+ if (localFileExisted) {
246
+ nativeBinding = require('./computeruse.linux-arm-gnueabihf.node')
247
+ } else {
248
+ nativeBinding = require('@elizaos/computeruse-linux-arm-gnueabihf')
249
+ }
250
+ } catch (e) {
251
+ loadError = e
252
+ }
253
+ }
254
+ break
255
+ case 'riscv64':
256
+ if (isMusl()) {
257
+ localFileExisted = existsSync(
258
+ join(__dirname, 'computeruse.linux-riscv64-musl.node')
259
+ )
260
+ try {
261
+ if (localFileExisted) {
262
+ nativeBinding = require('./computeruse.linux-riscv64-musl.node')
263
+ } else {
264
+ nativeBinding = require('@elizaos/computeruse-linux-riscv64-musl')
265
+ }
266
+ } catch (e) {
267
+ loadError = e
268
+ }
269
+ } else {
270
+ localFileExisted = existsSync(
271
+ join(__dirname, 'computeruse.linux-riscv64-gnu.node')
272
+ )
273
+ try {
274
+ if (localFileExisted) {
275
+ nativeBinding = require('./computeruse.linux-riscv64-gnu.node')
276
+ } else {
277
+ nativeBinding = require('@elizaos/computeruse-linux-riscv64-gnu')
278
+ }
279
+ } catch (e) {
280
+ loadError = e
281
+ }
282
+ }
283
+ break
284
+ case 's390x':
285
+ localFileExisted = existsSync(
286
+ join(__dirname, 'computeruse.linux-s390x-gnu.node')
287
+ )
288
+ try {
289
+ if (localFileExisted) {
290
+ nativeBinding = require('./computeruse.linux-s390x-gnu.node')
291
+ } else {
292
+ nativeBinding = require('@elizaos/computeruse-linux-s390x-gnu')
293
+ }
294
+ } catch (e) {
295
+ loadError = e
296
+ }
297
+ break
298
+ default:
299
+ throw new Error(`Unsupported architecture on Linux: ${arch}`)
300
+ }
301
+ break
302
+ default:
303
+ throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
304
+ }
305
+
306
+ if (!nativeBinding) {
307
+ if (loadError) {
308
+ throw loadError
309
+ }
310
+ throw new Error(`Failed to load native binding`)
311
+ }
312
+
313
+ const { Desktop, Element, Locator, Selector, ClickType, VisionType, PropertyLoadingMode, TreeOutputFormat, ElementSource, OverlayDisplayMode, TextPosition, HighlightHandle, WindowManager } = nativeBinding
314
+
315
+ module.exports.Desktop = Desktop
316
+ module.exports.Element = Element
317
+ module.exports.Locator = Locator
318
+ module.exports.Selector = Selector
319
+ module.exports.ClickType = ClickType
320
+ module.exports.VisionType = VisionType
321
+ module.exports.PropertyLoadingMode = PropertyLoadingMode
322
+ module.exports.TreeOutputFormat = TreeOutputFormat
323
+ module.exports.ElementSource = ElementSource
324
+ module.exports.OverlayDisplayMode = OverlayDisplayMode
325
+ module.exports.TextPosition = TextPosition
326
+ module.exports.HighlightHandle = HighlightHandle
327
+ module.exports.WindowManager = WindowManager
package/package.json ADDED
@@ -0,0 +1,74 @@
1
+ {
2
+ "name": "@elizaos/computeruse",
3
+ "author": "elizaos",
4
+ "bugs": {
5
+ "url": "https://github.com/elizaos/eliza/issues"
6
+ },
7
+ "dependencies": {
8
+ "@mediar-ai/kv": "^0.23.30"
9
+ },
10
+ "description": "Node.js/TypeScript bindings for the ComputerUse Rust library (via napi-rs)",
11
+ "devDependencies": {
12
+ "@napi-rs/cli": "^2.18.4",
13
+ "esbuild": "^0.25.11"
14
+ },
15
+ "engines": {
16
+ "node": ">= 10"
17
+ },
18
+ "homepage": "https://github.com/elizaos/eliza",
19
+ "keywords": [
20
+ "napi",
21
+ "rust",
22
+ "native",
23
+ "computeruse",
24
+ "automation",
25
+ "desktop",
26
+ "gui",
27
+ "ui",
28
+ "testing",
29
+ "windows",
30
+ "macos",
31
+ "linux"
32
+ ],
33
+ "main": "wrapper.js",
34
+ "publishConfig": {
35
+ "access": "public"
36
+ },
37
+ "napi": {
38
+ "name": "computeruse",
39
+ "triples": {
40
+ "additional": [
41
+ "aarch64-pc-windows-msvc",
42
+ "aarch64-apple-darwin",
43
+ "x86_64-apple-darwin",
44
+ "x86_64-unknown-linux-gnu",
45
+ "aarch64-unknown-linux-gnu"
46
+ ]
47
+ }
48
+ },
49
+ "optionalDependencies": {
50
+ "@elizaos/computeruse-win32-arm64-msvc": "0.24.20",
51
+ "@elizaos/computeruse-win32-x64-msvc": "0.24.20",
52
+ "@elizaos/computeruse-darwin-arm64": "0.24.20",
53
+ "@elizaos/computeruse-darwin-x64": "0.24.20",
54
+ "@elizaos/computeruse-linux-x64-gnu": "0.24.20",
55
+ "@elizaos/computeruse-linux-arm64-gnu": "0.24.20"
56
+ },
57
+ "repository": {
58
+ "type": "git",
59
+ "url": "https://github.com/elizaos/eliza"
60
+ },
61
+ "scripts": {
62
+ "artifacts": "npx napi artifacts",
63
+ "build": "npm run sync-version && npm run build:wrapper && npx napi build --platform --release --strip",
64
+ "build:debug": "npm run sync-version && npm run build:wrapper && npx napi build --platform",
65
+ "build:wrapper": "npx esbuild wrapper.ts --outfile=wrapper.js --platform=node --format=cjs --target=es2020",
66
+ "prepublish:ci": "npm run sync-version && npm run build:wrapper",
67
+ "prepublishOnly": "npm run sync-version && npm run build:wrapper && npx napi prepublish -t npm",
68
+ "sync-version": "node scripts/sync-version.js",
69
+ "test": "node tests/element-chaining.test.js",
70
+ "test-hook": "powershell.exe -ExecutionPolicy Bypass -File \"../../.git/hooks/pre-push.ps1\""
71
+ },
72
+ "types": "wrapper.d.ts",
73
+ "version": "0.24.20"
74
+ }
@@ -0,0 +1,60 @@
1
+ #!/usr/bin/env node
2
+
3
+ const fs = require('fs');
4
+ const path = require('path');
5
+
6
+ // Read the workspace Cargo.toml
7
+ const workspaceCargoPath = path.join(__dirname, '../../../Cargo.toml');
8
+ const cargoContent = fs.readFileSync(workspaceCargoPath, 'utf8');
9
+
10
+ // Extract version from Cargo.toml
11
+ const versionMatch = cargoContent.match(/^version\s*=\s*"([^"]+)"/m);
12
+ if (!versionMatch) {
13
+ console.error('Could not find version in workspace Cargo.toml');
14
+ process.exit(1);
15
+ }
16
+
17
+ const version = versionMatch[1];
18
+ console.log(`Found version: ${version}`);
19
+
20
+ // Read package.json
21
+ const packagePath = path.join(__dirname, '../package.json');
22
+ const packageContent = JSON.parse(fs.readFileSync(packagePath, 'utf8'));
23
+
24
+ // Update version and optionalDependencies
25
+ packageContent.version = version;
26
+
27
+ // Update optionalDependencies to use the same version
28
+ if (packageContent.optionalDependencies) {
29
+ for (const dep in packageContent.optionalDependencies) {
30
+ if (dep.startsWith('@elizaos/computeruse-')) {
31
+ packageContent.optionalDependencies[dep] = version;
32
+ }
33
+ }
34
+ }
35
+
36
+ // Write back to package.json
37
+ fs.writeFileSync(packagePath, JSON.stringify(packageContent, null, 2) + '\n');
38
+
39
+ console.log(`Updated package.json version to: ${version}`);
40
+
41
+ // Also update platform packages
42
+ const npmDir = path.join(__dirname, '../npm');
43
+ if (fs.existsSync(npmDir)) {
44
+ const platforms = fs.readdirSync(npmDir);
45
+ for (const platform of platforms) {
46
+ const platformPath = path.join(npmDir, platform);
47
+ const platformPackagePath = path.join(platformPath, 'package.json');
48
+
49
+ if (fs.existsSync(platformPackagePath) && fs.statSync(platformPath).isDirectory()) {
50
+ try {
51
+ const platformPackage = JSON.parse(fs.readFileSync(platformPackagePath, 'utf8'));
52
+ platformPackage.version = version;
53
+ fs.writeFileSync(platformPackagePath, JSON.stringify(platformPackage, null, 2) + '\n');
54
+ console.log(`Updated ${platform} package version to: ${version}`);
55
+ } catch (error) {
56
+ console.warn(`Failed to update ${platform} package:`, error.message);
57
+ }
58
+ }
59
+ }
60
+ }