@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 +34 -0
- package/build.rs +10 -0
- package/computeruse.darwin-arm64.node +0 -0
- package/index.d.ts +0 -0
- package/index.js +327 -0
- package/package.json +74 -0
- package/scripts/sync-version.js +60 -0
- package/src/desktop.rs +2763 -0
- package/src/element.rs +1341 -0
- package/src/exceptions.rs +65 -0
- package/src/lib.rs +26 -0
- package/src/locator.rs +172 -0
- package/src/selector.rs +158 -0
- package/src/types.rs +963 -0
- package/src/window_manager.rs +342 -0
- package/tests/comprehensive-ui-elements.test.js +524 -0
- package/tests/cross-app-verification.test.js +243 -0
- package/tests/desktop-verify.test.js +169 -0
- package/tests/element-chaining.test.js +158 -0
- package/tests/element-range.test.js +207 -0
- package/tests/element-scroll-into-view.test.js +256 -0
- package/tests/element-value.test.js +264 -0
- package/tests/execute-browser-script-wrapper.test.js +135 -0
- package/tests/fixtures/sample-browser-script.js +7 -0
- package/tests/fixtures/script-with-env.js +16 -0
- package/tests/locator-validate.test.js +260 -0
- package/tests/locator-waitfor.test.js +286 -0
- package/wrapper.d.ts +84 -0
- package/wrapper.js +344 -0
- package/wrapper.ts +394 -0
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
|
+
}
|