woozlit 2.2.1 → 2.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/LICENSE +21 -0
  2. package/bin/woozlit +179 -0
  3. package/package.json +24 -78
  4. package/postinstall.mjs +102 -0
  5. package/README.md +0 -108
  6. package/dist/auth/login.d.ts +0 -4
  7. package/dist/auth/login.js +0 -1
  8. package/dist/browser/index.d.ts +0 -78
  9. package/dist/browser/index.js +0 -1
  10. package/dist/browser/server.d.ts +0 -13
  11. package/dist/browser/server.js +0 -1
  12. package/dist/browser/tools.d.ts +0 -13
  13. package/dist/browser/tools.js +0 -1
  14. package/dist/chat/agent.d.ts +0 -1
  15. package/dist/chat/agent.js +0 -1
  16. package/dist/config/mcp.d.ts +0 -21
  17. package/dist/config/mcp.js +0 -1
  18. package/dist/config/settings.d.ts +0 -10
  19. package/dist/config/settings.js +0 -1
  20. package/dist/discord/client.d.ts +0 -3
  21. package/dist/discord/client.js +0 -1
  22. package/dist/discord/config.d.ts +0 -5
  23. package/dist/discord/config.js +0 -1
  24. package/dist/discord/index.d.ts +0 -3
  25. package/dist/discord/index.js +0 -1
  26. package/dist/discord/setup.d.ts +0 -1
  27. package/dist/discord/setup.js +0 -1
  28. package/dist/email/config.d.ts +0 -31
  29. package/dist/email/config.js +0 -1
  30. package/dist/email/index.d.ts +0 -3
  31. package/dist/email/index.js +0 -1
  32. package/dist/email/service.d.ts +0 -4
  33. package/dist/email/service.js +0 -1
  34. package/dist/email/setup.d.ts +0 -1
  35. package/dist/email/setup.js +0 -1
  36. package/dist/github/api.d.ts +0 -25
  37. package/dist/github/api.js +0 -1
  38. package/dist/github/auth.d.ts +0 -4
  39. package/dist/github/auth.js +0 -1
  40. package/dist/github/auto-setup.d.ts +0 -1
  41. package/dist/github/auto-setup.js +0 -1
  42. package/dist/github/index.d.ts +0 -1
  43. package/dist/github/index.js +0 -1
  44. package/dist/github/manual-setup.d.ts +0 -1
  45. package/dist/github/manual-setup.js +0 -1
  46. package/dist/index.d.ts +0 -2
  47. package/dist/index.js +0 -2
  48. package/dist/mcp-servers/computer-use.d.ts +0 -1
  49. package/dist/mcp-servers/computer-use.js +0 -1
  50. package/dist/services/bot-manager.d.ts +0 -13
  51. package/dist/services/bot-manager.js +0 -1
  52. package/dist/services/notifications.d.ts +0 -4
  53. package/dist/services/notifications.js +0 -1
  54. package/dist/services/voice-agent.d.ts +0 -6
  55. package/dist/services/voice-agent.js +0 -1
  56. package/dist/telegram/bot.d.ts +0 -3
  57. package/dist/telegram/bot.js +0 -1
  58. package/dist/telegram/config.d.ts +0 -12
  59. package/dist/telegram/config.js +0 -1
  60. package/dist/telegram/index.d.ts +0 -3
  61. package/dist/telegram/index.js +0 -1
  62. package/dist/telegram/reminders.d.ts +0 -11
  63. package/dist/telegram/reminders.js +0 -1
  64. package/dist/telegram/setup.d.ts +0 -1
  65. package/dist/telegram/setup.js +0 -1
  66. package/dist/tools/command.d.ts +0 -23
  67. package/dist/tools/command.js +0 -1
  68. package/dist/tools/file.d.ts +0 -79
  69. package/dist/tools/file.js +0 -1
  70. package/dist/tools/git.d.ts +0 -30
  71. package/dist/tools/git.js +0 -1
  72. package/dist/tools/index.d.ts +0 -10
  73. package/dist/tools/index.js +0 -1
  74. package/dist/tools/knowledge.d.ts +0 -4
  75. package/dist/tools/knowledge.js +0 -1
  76. package/dist/tools/mcp.d.ts +0 -10
  77. package/dist/tools/mcp.js +0 -1
  78. package/dist/tools/network.d.ts +0 -10
  79. package/dist/tools/network.js +0 -1
  80. package/dist/tools/project.d.ts +0 -54
  81. package/dist/tools/project.js +0 -1
  82. package/dist/tools/rollback.d.ts +0 -21
  83. package/dist/tools/rollback.js +0 -1
  84. package/dist/tools/rules.d.ts +0 -4
  85. package/dist/tools/rules.js +0 -1
  86. package/dist/tools/system.d.ts +0 -33
  87. package/dist/tools/system.js +0 -1
  88. package/dist/twilio/config.d.ts +0 -11
  89. package/dist/twilio/config.js +0 -1
  90. package/dist/twilio/index.d.ts +0 -3
  91. package/dist/twilio/index.js +0 -1
  92. package/dist/twilio/server.d.ts +0 -5
  93. package/dist/twilio/server.js +0 -1
  94. package/dist/twilio/setup.d.ts +0 -1
  95. package/dist/twilio/setup.js +0 -1
  96. package/dist/ui/output.d.ts +0 -28
  97. package/dist/ui/output.js +0 -1
  98. package/dist/ui/select.d.ts +0 -3
  99. package/dist/ui/select.js +0 -1
  100. package/dist/ui/themes.d.ts +0 -25
  101. package/dist/ui/themes.js +0 -1
  102. package/dist/utils/api.d.ts +0 -22
  103. package/dist/utils/api.js +0 -1
  104. package/dist/utils/chat-history.d.ts +0 -15
  105. package/dist/utils/chat-history.js +0 -1
  106. package/dist/utils/history.d.ts +0 -3
  107. package/dist/utils/history.js +0 -1
  108. package/dist/utils/mcp-installer.d.ts +0 -1
  109. package/dist/utils/mcp-installer.js +0 -1
  110. package/dist/utils/platform.d.ts +0 -7
  111. package/dist/utils/platform.js +0 -1
  112. package/dist/utils/storage.d.ts +0 -23
  113. package/dist/utils/storage.js +0 -1
  114. package/dist/utils/update-check.d.ts +0 -5
  115. package/dist/utils/update-check.js +0 -1
  116. package/dist/utils/updater.d.ts +0 -2
  117. package/dist/utils/updater.js +0 -1
  118. package/dist/verify_repro.d.ts +0 -4
  119. package/dist/verify_repro.js +0 -1
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 Woozlit
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/bin/woozlit ADDED
@@ -0,0 +1,179 @@
1
+ #!/usr/bin/env node
2
+
3
+ const childProcess = require("child_process")
4
+ const fs = require("fs")
5
+ const path = require("path")
6
+ const os = require("os")
7
+
8
+ function run(target) {
9
+ const result = childProcess.spawnSync(target, process.argv.slice(2), {
10
+ stdio: "inherit",
11
+ })
12
+ if (result.error) {
13
+ console.error(result.error.message)
14
+ process.exit(1)
15
+ }
16
+ const code = typeof result.status === "number" ? result.status : 0
17
+ process.exit(code)
18
+ }
19
+
20
+ const envPath = process.env.WOOZLIT_BIN_PATH || process.env.MIMOCODE_BIN_PATH
21
+ if (envPath) {
22
+ run(envPath)
23
+ }
24
+
25
+ const scriptPath = fs.realpathSync(__filename)
26
+ const scriptDir = path.dirname(scriptPath)
27
+
28
+ //
29
+ const cached = path.join(scriptDir, ".woozlitcode")
30
+ if (fs.existsSync(cached)) {
31
+ run(cached)
32
+ }
33
+
34
+ const platformMap = {
35
+ darwin: "darwin",
36
+ linux: "linux",
37
+ win32: "windows",
38
+ }
39
+ const archMap = {
40
+ x64: "x64",
41
+ arm64: "arm64",
42
+ arm: "arm",
43
+ }
44
+
45
+ let platform = platformMap[os.platform()]
46
+ if (!platform) {
47
+ platform = os.platform()
48
+ }
49
+ let arch = archMap[os.arch()]
50
+ if (!arch) {
51
+ arch = os.arch()
52
+ }
53
+ const base = "woozlit-" + platform + "-" + arch
54
+ const binary = platform === "windows" ? "woozlit.exe" : "woozlit"
55
+
56
+ function supportsAvx2() {
57
+ if (arch !== "x64") return false
58
+
59
+ if (platform === "linux") {
60
+ try {
61
+ return /(^|\s)avx2(\s|$)/i.test(fs.readFileSync("/proc/cpuinfo", "utf8"))
62
+ } catch {
63
+ return false
64
+ }
65
+ }
66
+
67
+ if (platform === "darwin") {
68
+ try {
69
+ const result = childProcess.spawnSync("sysctl", ["-n", "hw.optional.avx2_0"], {
70
+ encoding: "utf8",
71
+ timeout: 1500,
72
+ })
73
+ if (result.status !== 0) return false
74
+ return (result.stdout || "").trim() === "1"
75
+ } catch {
76
+ return false
77
+ }
78
+ }
79
+
80
+ if (platform === "windows") {
81
+ const cmd =
82
+ '(Add-Type -MemberDefinition "[DllImport(""kernel32.dll"")] public static extern bool IsProcessorFeaturePresent(int ProcessorFeature);" -Name Kernel32 -Namespace Win32 -PassThru)::IsProcessorFeaturePresent(40)'
83
+
84
+ for (const exe of ["powershell.exe", "pwsh.exe", "pwsh", "powershell"]) {
85
+ try {
86
+ const result = childProcess.spawnSync(exe, ["-NoProfile", "-NonInteractive", "-Command", cmd], {
87
+ encoding: "utf8",
88
+ timeout: 3000,
89
+ windowsHide: true,
90
+ })
91
+ if (result.status !== 0) continue
92
+ const out = (result.stdout || "").trim().toLowerCase()
93
+ if (out === "true" || out === "1") return true
94
+ if (out === "false" || out === "0") return false
95
+ } catch {
96
+ continue
97
+ }
98
+ }
99
+
100
+ return false
101
+ }
102
+
103
+ return false
104
+ }
105
+
106
+ const names = (() => {
107
+ const avx2 = supportsAvx2()
108
+ const baseline = arch === "x64" && !avx2
109
+
110
+ if (platform === "linux") {
111
+ const musl = (() => {
112
+ try {
113
+ if (fs.existsSync("/etc/alpine-release")) return true
114
+ } catch {
115
+ // ignore
116
+ }
117
+
118
+ try {
119
+ const result = childProcess.spawnSync("ldd", ["--version"], { encoding: "utf8" })
120
+ const text = ((result.stdout || "") + (result.stderr || "")).toLowerCase()
121
+ if (text.includes("musl")) return true
122
+ } catch {
123
+ // ignore
124
+ }
125
+
126
+ return false
127
+ })()
128
+
129
+ if (musl) {
130
+ if (arch === "x64") {
131
+ if (baseline) return [`${base}-baseline-musl`, `${base}-musl`, `${base}-baseline`, base]
132
+ return [`${base}-musl`, `${base}-baseline-musl`, base, `${base}-baseline`]
133
+ }
134
+ return [`${base}-musl`, base]
135
+ }
136
+
137
+ if (arch === "x64") {
138
+ if (baseline) return [`${base}-baseline`, base, `${base}-baseline-musl`, `${base}-musl`]
139
+ return [base, `${base}-baseline`, `${base}-musl`, `${base}-baseline-musl`]
140
+ }
141
+ return [base, `${base}-musl`]
142
+ }
143
+
144
+ if (arch === "x64") {
145
+ if (baseline) return [`${base}-baseline`, base]
146
+ return [base, `${base}-baseline`]
147
+ }
148
+ return [base]
149
+ })()
150
+
151
+ function findBinary(startDir) {
152
+ let current = startDir
153
+ for (;;) {
154
+ const modules = path.join(current, "node_modules")
155
+ if (fs.existsSync(modules)) {
156
+ for (const name of names) {
157
+ const candidate = path.join(modules, name, "bin", binary)
158
+ if (fs.existsSync(candidate)) return candidate
159
+ }
160
+ }
161
+ const parent = path.dirname(current)
162
+ if (parent === current) {
163
+ return
164
+ }
165
+ current = parent
166
+ }
167
+ }
168
+
169
+ const resolved = findBinary(scriptDir)
170
+ if (!resolved) {
171
+ console.error(
172
+ "It seems that your package manager failed to install the right version of the woozlitcode CLI for your platform. You can try manually installing " +
173
+ names.map((n) => `\"${n}\"`).join(" or ") +
174
+ " package",
175
+ )
176
+ process.exit(1)
177
+ }
178
+
179
+ run(resolved)
package/package.json CHANGED
@@ -1,80 +1,26 @@
1
1
  {
2
- "name": "woozlit",
3
- "version": "2.2.1",
4
- "description": "Woozlit AI - Agentic Coding Assistant",
5
- "type": "module",
6
- "files": [
7
- "dist"
8
- ],
9
- "bin": {
10
- "woozlit": "./dist/index.js"
11
- },
12
- "scripts": {
13
- "build": "tsc && javascript-obfuscator ./dist --output ./dist --target node",
14
- "build:bin": "tsc && pkg . --out-path binaries",
15
- "dev": "tsx src/index.ts",
16
- "start": "node dist/index.js"
17
- },
18
- "pkg": {
19
- "scripts": "dist/**/*.js",
20
- "assets": [
21
- "node_modules/**/*"
22
- ],
23
- "targets": [
24
- "node18-linux-x64",
25
- "node18-macos-x64",
26
- "node18-win-x64"
27
- ]
28
- },
29
- "dependencies": {
30
- "@google/generative-ai": "^0.24.1",
31
- "@hurdlegroup/robotjs": "^0.12.3",
32
- "@inquirer/prompts": "^8.2.0",
33
- "@modelcontextprotocol/sdk": "^1.25.2",
34
- "@ngrok/ngrok": "^1.7.0",
35
- "@octokit/auth-app": "^8.1.2",
36
- "chalk": "^5.4.1",
37
- "commander": "^13.1.0",
38
- "conf": "^13.1.0",
39
- "discord.js": "^14.25.1",
40
- "fluent-ffmpeg": "npm:fluent-ffmpeg-7@^2.1.5",
41
- "grammy": "^1.40.0",
42
- "imap-simple": "^5.1.0",
43
- "inquirer": "^12.3.2",
44
- "jimp": "^1.6.0",
45
- "marked": "^15.0.12",
46
- "marked-terminal": "^7.3.0",
47
- "ngrok": "4.3.3",
48
- "nodemailer": "^7.0.13",
49
- "open": "^10.1.0",
50
- "ora": "^8.1.1",
51
- "ws": "^8.18.0"
52
- },
53
- "devDependencies": {
54
- "@aws-sdk/client-s3": "^3.997.0",
55
- "@types/node": "^22.10.5",
56
- "@types/nodemailer": "^7.0.9",
57
- "@types/ws": "^8.5.13",
58
- "javascript-obfuscator": "^5.1.0",
59
- "pkg": "^5.8.1",
60
- "tsx": "^4.19.2",
61
- "typescript": "^5.7.3"
62
- },
63
- "engines": {
64
- "node": ">=18"
65
- },
66
- "keywords": [
67
- "ai",
68
- "cli",
69
- "coding",
70
- "assistant",
71
- "woozlit"
72
- ],
73
- "author": "Woozlit",
74
- "license": "MIT",
75
- "overrides": {
76
- "glob": "^11.0.0",
77
- "scmp": "npm:timing-safe-equal@^1.0.0",
78
- "node-domexception": "npm:domexception@^4.0.0"
79
- }
2
+ "name": "woozlit",
3
+ "bin": {
4
+ "woozlit": "./bin/woozlit"
5
+ },
6
+ "scripts": {
7
+ "postinstall": "bun ./postinstall.mjs || node ./postinstall.mjs"
8
+ },
9
+ "version": "2.2.2",
10
+ "license": "MIT",
11
+ "optionalDependencies": {
12
+ "woozlit-windows-x64-baseline": "2.2.2",
13
+ "woozlit-windows-x64": "2.2.2",
14
+ "woozlit-windows-arm64": "2.2.2",
15
+ "woozlit-linux-x64-musl": "2.2.2",
16
+ "woozlit-linux-x64-baseline-musl": "2.2.2",
17
+ "woozlit-linux-x64-baseline": "2.2.2",
18
+ "woozlit-linux-x64": "2.2.2",
19
+ "woozlit-linux-arm64-musl": "2.2.2",
20
+ "woozlit-linux-arm64": "2.2.2",
21
+ "woozlit-darwin-x64-baseline": "2.2.2",
22
+ "woozlit-darwin-x64": "2.2.2",
23
+ "woozlit-darwin-arm64": "2.2.2",
24
+ "woozlit": "2.2.2"
25
+ }
80
26
  }
@@ -0,0 +1,102 @@
1
+ #!/usr/bin/env node
2
+
3
+ import fs from "fs"
4
+ import path from "path"
5
+ import os from "os"
6
+ import { fileURLToPath } from "url"
7
+ import { createRequire } from "module"
8
+
9
+ const __dirname = path.dirname(fileURLToPath(import.meta.url))
10
+ const require = createRequire(import.meta.url)
11
+
12
+ function detectPlatformAndArch() {
13
+ // Map platform names
14
+ let platform
15
+ switch (os.platform()) {
16
+ case "darwin":
17
+ platform = "darwin"
18
+ break
19
+ case "linux":
20
+ platform = "linux"
21
+ break
22
+ case "win32":
23
+ platform = "windows"
24
+ break
25
+ default:
26
+ platform = os.platform()
27
+ break
28
+ }
29
+
30
+ // Map architecture names
31
+ let arch
32
+ switch (os.arch()) {
33
+ case "x64":
34
+ arch = "x64"
35
+ break
36
+ case "arm64":
37
+ arch = "arm64"
38
+ break
39
+ case "arm":
40
+ arch = "arm"
41
+ break
42
+ default:
43
+ arch = os.arch()
44
+ break
45
+ }
46
+
47
+ return { platform, arch }
48
+ }
49
+
50
+ function findBinary() {
51
+ const { platform, arch } = detectPlatformAndArch()
52
+ const packageName = `woozlit-${platform}-${arch}`
53
+ const binaryName = platform === "windows" ? "woozlit.exe" : "woozlit"
54
+
55
+ try {
56
+ // Use require.resolve to find the package
57
+ const packageJsonPath = require.resolve(`${packageName}/package.json`)
58
+ const packageDir = path.dirname(packageJsonPath)
59
+ const binaryPath = path.join(packageDir, "bin", binaryName)
60
+
61
+ if (!fs.existsSync(binaryPath)) {
62
+ throw new Error(`Binary not found at ${binaryPath}`)
63
+ }
64
+
65
+ return { binaryPath, binaryName }
66
+ } catch (error) {
67
+ throw new Error(`Could not find package ${packageName}: ${error.message}`, { cause: error })
68
+ }
69
+ }
70
+
71
+ async function main() {
72
+ try {
73
+ if (os.platform() === "win32") {
74
+ // On Windows, the .exe is already included in the package and bin field points to it
75
+ // No postinstall setup needed
76
+ console.log("Windows detected: binary setup not needed (using packaged .exe)")
77
+ return
78
+ }
79
+
80
+ // On non-Windows platforms, just verify the binary package exists
81
+ // Don't replace the wrapper script - it handles binary execution
82
+ const { binaryPath } = findBinary()
83
+ const target = path.join(__dirname, "bin", ".woozlitcode")
84
+ if (fs.existsSync(target)) fs.unlinkSync(target)
85
+ try {
86
+ fs.linkSync(binaryPath, target)
87
+ } catch {
88
+ fs.copyFileSync(binaryPath, target)
89
+ }
90
+ fs.chmodSync(target, 0o755)
91
+ } catch (error) {
92
+ console.error("Failed to setup woozlit binary:", error.message)
93
+ process.exit(1)
94
+ }
95
+ }
96
+
97
+ try {
98
+ void main()
99
+ } catch (error) {
100
+ console.error("Postinstall script error:", error.message)
101
+ process.exit(0)
102
+ }
package/README.md DELETED
@@ -1,108 +0,0 @@
1
- # Woozlit CLI v2.0.1
2
-
3
- The elite command-line interface for **Woozlit AI** - an autonomous, agentic coding assistant featuring a beautiful, modern terminal UI (Claude-Code style), global theming, browser automation natively, and remote Telegram control.
4
-
5
- ## Installation
6
-
7
- ```bash
8
- # Standalone binaries are available, or install via npm
9
- npm install -g woozlit
10
- ```
11
-
12
- ## Core Features
13
-
14
- - **Agentic AI**: Executes complex tasks (coding, testing, deployment) autonomously without stopping to ask permission.
15
- - **Modern Minimalist UI**: Sleek, Claude-Code inspired terminal aesthetics with spinner branches and concise one-line action summaries (`└ Read 58 lines`).
16
- - **Global Theming**: Switch the entire CLI's color palette on the fly (`/theme`). Supports: Woozlit Blue, Classic Purple, Hacker Green, Sunset Orange, Dracula Pink, and Monochrome Silver.
17
- - **Knowledge Presets**: Easily define custom instructions or framework stacks (e.g., Next.js conventions) that the AI automatically injects into its system prompt.
18
- - **Vision & Image Pasting**: Direct support for analyzing local images. Just paste an absolute file path into the chat prompt.
19
- - **Browser Automation**: The CLI can automatically spin up a headless/headed browser session to read documentation, debug web apps, and take screenshots using `browser_*` tools.
20
- - **Context & Process Safety**: Includes an automatic contextual summarizer for extremely long conversations to prevent token overflow, and an anti-spam monitor to stop duplicate dev servers.
21
- - **Telegram Remote**: Start the CLI on your desktop, leave it running, and text it complex coding tasks from your phone via Telegram.
22
- - **MCP Protocol**: Deep integration with Model Context Protocol to hook into external servers.
23
- - **Auto-Correction**: Automatically detects, reads `stderr`, and attempts to fix errors during execution loops.
24
-
25
- ## Usage
26
-
27
- ### Start Chat
28
- ```bash
29
- woozlit
30
- # or
31
- woozlit chat
32
- ```
33
-
34
- ### Global Themes
35
- ```bash
36
- woozlit theme
37
- ```
38
- Brings up an interactive prompt to switch color themes.
39
-
40
- ### Knowledge Presets
41
- Inject project-specific rules or context into the agent's system prompt (e.g. enforce architectural styles or point to specific docs).
42
-
43
- ```bash
44
- # List current knowledge presets
45
- woozlit knowledge list
46
-
47
- # Add a new piece of knowledge (Here is the built-in default Next.js preset)
48
- woozlit knowledge add "You are an expert Next.js 15, React 19, and Tailwind CSS developer."
49
- woozlit knowledge add "Use the App Router (app/ directory) exclusively. Avoid the pages/ directory."
50
- woozlit knowledge add "Default to Server Components. Only add 'use client' when hooks (useState, useEffect) or DOM event listeners are strictly necessary."
51
- woozlit knowledge add "Use Server Actions for data mutations and fetching. Avoid traditional API routes unless building external standard REST endpoints."
52
- woozlit knowledge add "Follow mobile-first responsive design patterns. Build clean, minimal UI components using Tailwind CSS."
53
-
54
- # Clear all presets
55
- woozlit knowledge clear
56
- ```
57
-
58
- ### Vision & Images
59
- You can ask the AI about local images directly in the chat interface by simply pasting their absolute paths alongside your prompt:
60
-
61
- ```text
62
- > C:\Users\docs\mockup.png Make this exact UI using React and Tailwind.
63
- ```
64
-
65
- ### Chat Commands
66
-
67
- Inside a chat session, you can use:
68
-
69
- | Command | Description |
70
- |---------|-------------|
71
- | `/exit` | Exit chat |
72
- | `/clear` | Clear conversation |
73
- | `/model` | Switch AI model (default is Woozie/Gemini-2.5-Flash) |
74
- | `/theme` | Switch UI color theme dynamically |
75
- | `/mcp` | List connected external tools |
76
- | `/telegram` | Control the remote Telegram bot |
77
- | `/usage` | Check token usage |
78
- | `/rollback` | Undo last AI file change |
79
- | `/help` | Show help |
80
-
81
- ## Available Models
82
-
83
- - **Woozie (Gemini 2.5 Flash)** - Default & Recommended for speed/autonomy
84
- - Llama 3.3 70B / 4 Maverick
85
- - Qwen3 235B / Coder
86
- - Mistral Small 3.2
87
- - DeepSeek V3 / R1
88
- - Kimi K2
89
- - *and more via OpenRouter...*
90
-
91
- ## MCP Support (Model Context Protocol)
92
-
93
- **Manage MCP Servers:**
94
-
95
- ```bash
96
- # Install specific tools (e.g. Browser Control)
97
- woozlit mcp install browsermcp
98
-
99
- # Install Chrome Bridge specifically
100
- woozlit mcp install mcp-chrome-bridge
101
-
102
- # Add standard MCP server (stdio)
103
- woozlit mcp add sqlite uvx mcp-server-sqlite --db test.db
104
- ```
105
-
106
- Once added, the AI can automatically discover and use tools provided by these servers natively in its autonomous loop.
107
-
108
-
@@ -1,4 +0,0 @@
1
- import { isLoggedIn } from "../utils/storage.js";
2
- export declare function login(): Promise<boolean>;
3
- export declare function logout(): void;
4
- export { isLoggedIn };
@@ -1 +0,0 @@
1
- function a0_0x1589(){const _0x564389=['writeHead','/callback','\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<!DOCTYPE\x20html>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<html>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<head><title>Woozlit\x20CLI</title></head>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<body\x20style=\x22font-family:\x20sans-serif;\x20text-align:\x20center;\x20padding:\x202rem;\x20background:\x20#0a0a0a;\x20color:\x20#fff;\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h1\x20style=\x22color:\x20#ef4444;\x22>Login\x20Failed</h1>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<p>Missing\x20authentication\x20data.\x20Please\x20try\x20again.</p>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</body>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</html>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20','displayName','6569000oFQUxP','8695435DDZAdN','url','searchParams','userId','text/html','3605340MPUgXv','end','http://localhost:','token','972845Vludfp','get','6ofBfIr','\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<!DOCTYPE\x20html>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<html>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<head>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<title>Woozlit\x20CLI</title>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<style>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20body\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20font-family:\x20system-ui,\x20-apple-system,\x20sans-serif;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20display:\x20flex;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20align-items:\x20center;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20justify-content:\x20center;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20height:\x20100vh;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20margin:\x200;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20background:\x20#0a0a0a;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20color:\x20#fff;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20}\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20.container\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20text-align:\x20center;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20padding:\x202rem;\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20}\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20h1\x20{\x20color:\x20#10b981;\x20}\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20p\x20{\x20color:\x20#9ca3af;\x20}\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</style>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</head>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<body>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<div\x20class=\x22container\x22>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<h1>Login\x20Successful</h1>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20<p>You\x20can\x20close\x20this\x20window\x20and\x20return\x20to\x20the\x20terminal.</p>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</div>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</body>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20</html>\x0a\x20\x20\x20\x20\x20\x20\x20\x20\x20\x20','/auth/cli?callback=http://localhost:','close','email','2QBLpKu','32516559VoDmlL','listen','4546929YVKWSM','8061624cjqpje'];a0_0x1589=function(){return _0x564389;};return a0_0x1589();}function a0_0x33a7(_0x52303b,_0x873c83){_0x52303b=_0x52303b-0x111;const _0x1589e1=a0_0x1589();let _0x33a76b=_0x1589e1[_0x52303b];return _0x33a76b;}(function(_0x14bf5e,_0x317502){const _0x536f1b=a0_0x33a7,_0x4e1905=_0x14bf5e();while(!![]){try{const _0x41b742=-parseInt(_0x536f1b(0x11c))/0x1+-parseInt(_0x536f1b(0x123))/0x2*(-parseInt(_0x536f1b(0x126))/0x3)+-parseInt(_0x536f1b(0x112))/0x4+parseInt(_0x536f1b(0x118))/0x5+-parseInt(_0x536f1b(0x11e))/0x6*(parseInt(_0x536f1b(0x113))/0x7)+-parseInt(_0x536f1b(0x127))/0x8+parseInt(_0x536f1b(0x124))/0x9;if(_0x41b742===_0x317502)break;else _0x4e1905['push'](_0x4e1905['shift']());}catch(_0x334db2){_0x4e1905['push'](_0x4e1905['shift']());}}}(a0_0x1589,0xf0653));import a0_0x1bf0e3 from'open';import{createServer}from'http';import{getApiUrl}from'../config/settings.js';import{setToken,setUser,isLoggedIn,logout as a0_0x4515e3}from'../utils/storage.js';export async function login(){const _0x55e3e1=getApiUrl(),_0x4d7b19=0x2694;return new Promise(_0x229574=>{const _0x2aca71=a0_0x33a7,_0x323119=createServer(async(_0x125b6f,_0x5e1f7c)=>{const _0x1ff4d7=a0_0x33a7,_0xaefa1b=new URL(_0x125b6f[_0x1ff4d7(0x114)]||'',_0x1ff4d7(0x11a)+_0x4d7b19);if(_0xaefa1b['pathname']===_0x1ff4d7(0x129)){const _0x289b95=_0xaefa1b[_0x1ff4d7(0x115)][_0x1ff4d7(0x11d)](_0x1ff4d7(0x11b)),_0x57322c=_0xaefa1b['searchParams'][_0x1ff4d7(0x11d)](_0x1ff4d7(0x116)),_0x2a89e8=_0xaefa1b[_0x1ff4d7(0x115)][_0x1ff4d7(0x11d)](_0x1ff4d7(0x122)),_0x5b759b=_0xaefa1b['searchParams']['get'](_0x1ff4d7(0x111));_0x289b95&&_0x57322c?(setToken(_0x289b95),setUser(_0x57322c,_0x2a89e8||'',_0x5b759b||''),_0x5e1f7c[_0x1ff4d7(0x128)](0xc8,{'Content-Type':_0x1ff4d7(0x117)}),_0x5e1f7c[_0x1ff4d7(0x119)](_0x1ff4d7(0x11f)),_0x323119['close'](),_0x229574(!![])):(_0x5e1f7c[_0x1ff4d7(0x128)](0x190,{'Content-Type':'text/html'}),_0x5e1f7c[_0x1ff4d7(0x119)](_0x1ff4d7(0x12a)),_0x323119[_0x1ff4d7(0x121)](),_0x229574(![]));}});_0x323119[_0x2aca71(0x125)](_0x4d7b19,()=>{const _0x327b94=_0x2aca71,_0x391fef=_0x55e3e1+_0x327b94(0x120)+_0x4d7b19+_0x327b94(0x129);a0_0x1bf0e3(_0x391fef);}),setTimeout(()=>{const _0x2624a7=_0x2aca71;_0x323119[_0x2624a7(0x121)](),_0x229574(![]);},0x1d4c0);});}export function logout(){a0_0x4515e3();}export{isLoggedIn};
@@ -1,78 +0,0 @@
1
- export * from './server.js';
2
- export * from './tools.js';
3
- export * from './server.js';
4
- export * from './tools.js';
5
- export declare const tools: ({
6
- name: string;
7
- description: string;
8
- input_schema: {
9
- type: string;
10
- properties: {
11
- tabId: {
12
- type: string;
13
- description: string;
14
- };
15
- query: {
16
- type: string;
17
- description: string;
18
- };
19
- text: {
20
- type: string;
21
- description: string;
22
- };
23
- index?: undefined;
24
- direction?: undefined;
25
- amount?: undefined;
26
- };
27
- required: string[];
28
- };
29
- } | {
30
- name: string;
31
- description: string;
32
- input_schema: {
33
- type: string;
34
- properties: {
35
- tabId: {
36
- type: string;
37
- description: string;
38
- };
39
- query: {
40
- type: string;
41
- description: string;
42
- };
43
- index: {
44
- type: string;
45
- description: string;
46
- };
47
- text?: undefined;
48
- direction?: undefined;
49
- amount?: undefined;
50
- };
51
- required: string[];
52
- };
53
- } | {
54
- name: string;
55
- description: string;
56
- input_schema: {
57
- type: string;
58
- properties: {
59
- tabId: {
60
- type: string;
61
- description: string;
62
- };
63
- direction: {
64
- type: string;
65
- enum: string[];
66
- description: string;
67
- };
68
- amount: {
69
- type: string;
70
- description: string;
71
- };
72
- query?: undefined;
73
- text?: undefined;
74
- index?: undefined;
75
- };
76
- required: string[];
77
- };
78
- })[];
@@ -1 +0,0 @@
1
- const a1_0x52243c=a1_0x1c64;(function(_0x1200a5,_0x3654f0){const _0x1e7474=a1_0x1c64,_0x32da5e=_0x1200a5();while(!![]){try{const _0x5e5132=-parseInt(_0x1e7474(0x1df))/0x1+parseInt(_0x1e7474(0x1d4))/0x2*(-parseInt(_0x1e7474(0x1eb))/0x3)+parseInt(_0x1e7474(0x1ea))/0x4*(-parseInt(_0x1e7474(0x1e7))/0x5)+-parseInt(_0x1e7474(0x1dc))/0x6+parseInt(_0x1e7474(0x1da))/0x7*(parseInt(_0x1e7474(0x1d9))/0x8)+parseInt(_0x1e7474(0x1e4))/0x9*(parseInt(_0x1e7474(0x1e0))/0xa)+parseInt(_0x1e7474(0x1de))/0xb*(parseInt(_0x1e7474(0x1e9))/0xc);if(_0x5e5132===_0x3654f0)break;else _0x32da5e['push'](_0x32da5e['shift']());}catch(_0x4c48c5){_0x32da5e['push'](_0x32da5e['shift']());}}}(a1_0x1d72,0xe1d50));export*from'./server.js';function a1_0x1d72(){const _0x2778af=['40FIjfpN','2060247trzWPq','browser_click','8800632UGGqvM','browser_scroll','11ZXeJhw','957456cMvSXP','10VSMwWY','string','Text\x20to\x20fill','Tab\x20ID\x20from\x20browser_open\x20\x20or\x20browser_snapshot','6861357DAldgy','Scroll\x20the\x20page\x20up\x20or\x20down','Optional:\x20pixels\x20to\x20scroll\x20(default:\x20one\x20page)','333980xEWFax','top','46229700VvJzgu','72jPmQcq','4604667csfeja','CSS\x20selector\x20for\x20the\x20element','number','object','Tab\x20ID\x20from\x20browser_open\x20or\x20browser_snapshot','text','query','direction','tabId','2geinuH','Fill\x20a\x20form\x20field\x20or\x20input\x20element','Direction\x20to\x20scroll','browser_fill','Tab\x20ID'];a1_0x1d72=function(){return _0x2778af;};return a1_0x1d72();}function a1_0x1c64(_0x3f2944,_0x1c6a77){_0x3f2944=_0x3f2944-0x1cf;const _0x1d729e=a1_0x1d72();let _0x1c6490=_0x1d729e[_0x3f2944];return _0x1c6490;}export*from'./tools.js';export*from'./server.js';export*from'./tools.js';export const tools=[{'name':a1_0x52243c(0x1d7),'description':a1_0x52243c(0x1d5),'input_schema':{'type':'object','properties':{'tabId':{'type':'number','description':a1_0x52243c(0x1e3)},'query':{'type':a1_0x52243c(0x1e1),'description':'CSS\x20selector\x20for\x20the\x20element'},'text':{'type':a1_0x52243c(0x1e1),'description':a1_0x52243c(0x1e2)}},'required':[a1_0x52243c(0x1d3),a1_0x52243c(0x1d1),a1_0x52243c(0x1d0)]}},{'name':a1_0x52243c(0x1db),'description':'Click\x20an\x20element\x20on\x20the\x20page','input_schema':{'type':'object','properties':{'tabId':{'type':a1_0x52243c(0x1ed),'description':a1_0x52243c(0x1cf)},'query':{'type':a1_0x52243c(0x1e1),'description':a1_0x52243c(0x1ec)},'index':{'type':'number','description':'Optional:\x20if\x20multiple\x20elements\x20match,\x20click\x20the\x20Nth\x20one\x20(0-indexed)'}},'required':[a1_0x52243c(0x1d3),'query']}},{'name':a1_0x52243c(0x1dd),'description':a1_0x52243c(0x1e5),'input_schema':{'type':a1_0x52243c(0x1ee),'properties':{'tabId':{'type':a1_0x52243c(0x1ed),'description':a1_0x52243c(0x1d8)},'direction':{'type':a1_0x52243c(0x1e1),'enum':['up','down',a1_0x52243c(0x1e8),'bottom'],'description':a1_0x52243c(0x1d6)},'amount':{'type':a1_0x52243c(0x1ed),'description':a1_0x52243c(0x1e6)}},'required':['tabId',a1_0x52243c(0x1d2)]}}];
@@ -1,13 +0,0 @@
1
- import WebSocket from 'ws';
2
- interface BrowserSession {
3
- ws: WebSocket;
4
- userId: string;
5
- userEmail: string;
6
- connectedAt: number;
7
- }
8
- export declare function startBrowserServer(port?: number): Promise<boolean>;
9
- export declare function stopBrowserServer(): void;
10
- export declare function isBrowserServerRunning(): boolean;
11
- export declare function sendBrowserCommand(command: string, args?: Record<string, any>, timeout?: number): Promise<any>;
12
- export declare function getConnectedSessions(): BrowserSession[];
13
- export {};
@@ -1 +0,0 @@
1
- (function(_0x2b97b3,_0x1aea37){const _0x2f4037=a2_0x53c6,_0x315791=_0x2b97b3();while(!![]){try{const _0x33b4a5=parseInt(_0x2f4037(0xfc))/0x1*(parseInt(_0x2f4037(0x102))/0x2)+-parseInt(_0x2f4037(0xfa))/0x3*(-parseInt(_0x2f4037(0x11b))/0x4)+-parseInt(_0x2f4037(0x119))/0x5+-parseInt(_0x2f4037(0x108))/0x6+-parseInt(_0x2f4037(0x114))/0x7*(-parseInt(_0x2f4037(0x103))/0x8)+-parseInt(_0x2f4037(0xf0))/0x9*(parseInt(_0x2f4037(0xfb))/0xa)+-parseInt(_0x2f4037(0xf2))/0xb;if(_0x33b4a5===_0x1aea37)break;else _0x315791['push'](_0x315791['shift']());}catch(_0x19732b){_0x315791['push'](_0x315791['shift']());}}}(a2_0x1a6f,0xc4c54));import{WebSocketServer}from'ws';import*as a2_0x474069 from'../ui/output.js';const sessions=new Map();function a2_0x1a6f(){const _0x53eb49=['6036282EVwJgJ','values','unknown','error','stringify','Browser\x20server\x20already\x20running','reject','requestId','get','now','WebSocket\x20error:','user','133HAPgLW','timeout','forEach','from','clear','401500jXQSIH','parse','989844NzVBEv','userId','Browser\x20server\x20stopped','email','Command\x20timeout\x20after\x20','auth_success','close','Waiting\x20for\x20Woozlit\x20Browser\x20extension\x20to\x20connect...','EADDRINUSE','send','dim','Browser\x20server\x20started\x20on\x20ws://localhost:','Browser\x20server\x20not\x20running','99GOuABk','listening','23976909ZOvNXe','toString','set','type','data','message','warn','connection','18oYbEnF','179710fAFSDY','1211050LfnbJl','delete','info','Failed\x20to\x20start\x20browser\x20server:\x20','success','response','2jgypTY','662696lbxKxM','auth','code','result','Server\x20stopped'];a2_0x1a6f=function(){return _0x53eb49;};return a2_0x1a6f();}function a2_0x53c6(_0x58b0d0,_0x430938){_0x58b0d0=_0x58b0d0-0xe8;const _0x1a6fe5=a2_0x1a6f();let _0x53c61a=_0x1a6fe5[_0x58b0d0];return _0x53c61a;}let server=null,isRunning=![];const pendingRequests=new Map();export function startBrowserServer(_0x1c87e9=0x2408){return new Promise(_0x41ed6d=>{const _0x3b79c6=a2_0x53c6;if(isRunning&&server){a2_0x474069[_0x3b79c6(0xf8)](_0x3b79c6(0x10d)),_0x41ed6d(!![]);return;}try{server=new WebSocketServer({'port':_0x1c87e9}),server['on'](_0x3b79c6(0xf1),()=>{const _0x288c50=_0x3b79c6;isRunning=!![],a2_0x474069[_0x288c50(0x100)](_0x288c50(0xee)+_0x1c87e9),a2_0x474069[_0x288c50(0xed)](_0x288c50(0xea)),_0x41ed6d(!![]);}),server['on'](_0x3b79c6(0xf9),async _0x5ef839=>{const _0x5ae0c8=_0x3b79c6;let _0x443343=null;_0x5ef839['on']('message',async _0x20bce0=>{const _0x4d2f45=a2_0x53c6;try{const _0x3ab6c1=JSON[_0x4d2f45(0x11a)](_0x20bce0[_0x4d2f45(0xf3)]());if(_0x3ab6c1[_0x4d2f45(0xf5)]===_0x4d2f45(0x104))_0x443343={'ws':_0x5ef839,'userId':_0x3ab6c1[_0x4d2f45(0x113)]?.['uid']||_0x4d2f45(0x10a),'userEmail':_0x3ab6c1[_0x4d2f45(0x113)]?.[_0x4d2f45(0x11e)]||'unknown','connectedAt':Date[_0x4d2f45(0x111)]()},sessions[_0x4d2f45(0xf4)](_0x443343[_0x4d2f45(0x11c)],_0x443343),_0x5ef839[_0x4d2f45(0xec)](JSON[_0x4d2f45(0x10c)]({'type':_0x4d2f45(0xe8),'userId':_0x443343[_0x4d2f45(0x11c)]}));else{if(_0x3ab6c1[_0x4d2f45(0xf5)]===_0x4d2f45(0x101)){const _0x5aada3=pendingRequests[_0x4d2f45(0x110)](_0x3ab6c1[_0x4d2f45(0x10f)]);_0x5aada3&&(clearTimeout(_0x5aada3[_0x4d2f45(0x115)]),pendingRequests[_0x4d2f45(0xfd)](_0x3ab6c1[_0x4d2f45(0x10f)]),_0x3ab6c1[_0x4d2f45(0x106)][_0x4d2f45(0x100)]?_0x5aada3['resolve'](_0x3ab6c1['result'][_0x4d2f45(0xf6)]):_0x5aada3[_0x4d2f45(0x10e)](new Error(_0x3ab6c1[_0x4d2f45(0x106)]['error']||'Command\x20failed')));}}}catch(_0x28657b){console['error']('Error\x20processing\x20message:',_0x28657b);}}),_0x5ef839['on'](_0x5ae0c8(0xe9),()=>{const _0xe3f657=_0x5ae0c8;_0x443343&&sessions['delete'](_0x443343[_0xe3f657(0x11c)]);}),_0x5ef839['on'](_0x5ae0c8(0x10b),_0x5ba2ca=>{const _0xdc6a93=_0x5ae0c8;console[_0xdc6a93(0x10b)](_0xdc6a93(0x112),_0x5ba2ca);});}),server['on']('error',_0x529378=>{const _0x7b3f77=_0x3b79c6;_0x529378['code']!==_0x7b3f77(0xeb)&&a2_0x474069[_0x7b3f77(0x10b)]('Browser\x20server\x20error:\x20'+_0x529378[_0x7b3f77(0xf7)]),_0x41ed6d(![]);});}catch(_0x2da6fd){_0x2da6fd[_0x3b79c6(0x105)]!==_0x3b79c6(0xeb)&&a2_0x474069['error'](_0x3b79c6(0xff)+_0x2da6fd[_0x3b79c6(0xf7)]),_0x41ed6d(![]);}});}export function stopBrowserServer(){const _0x39df0c=a2_0x53c6;server&&(sessions['clear'](),pendingRequests[_0x39df0c(0x116)](({timeout:_0x2a9313,reject:_0x5ba270})=>{const _0x2b55b9=_0x39df0c;clearTimeout(_0x2a9313),_0x5ba270(new Error(_0x2b55b9(0x107)));}),pendingRequests[_0x39df0c(0x118)](),server[_0x39df0c(0xe9)](),server=null,isRunning=![],a2_0x474069[_0x39df0c(0xfe)](_0x39df0c(0x11d)));}export function isBrowserServerRunning(){return isRunning;}export async function sendBrowserCommand(_0x566145,_0x458f05={},_0x2e33dd=0x7530){const _0x591628=a2_0x53c6;if(!isRunning)throw new Error(_0x591628(0xef));const _0x47ecf5=Array['from'](sessions['values']())[0x0];if(!_0x47ecf5)throw new Error('No\x20browser\x20extension\x20connected');const _0x55c72e=generateRequestId();return new Promise((_0x347608,_0x5a86cb)=>{const _0x3a1b11=_0x591628,_0x343b89=setTimeout(()=>{const _0x5d2a72=a2_0x53c6;pendingRequests[_0x5d2a72(0xfd)](_0x55c72e),_0x5a86cb(new Error(_0x5d2a72(0x11f)+_0x2e33dd+'ms'));},_0x2e33dd);pendingRequests['set'](_0x55c72e,{'resolve':_0x347608,'reject':_0x5a86cb,'timeout':_0x343b89});const _0x169254={'requestId':_0x55c72e,'command':_0x566145,'args':_0x458f05};_0x47ecf5['ws'][_0x3a1b11(0xec)](JSON[_0x3a1b11(0x10c)](_0x169254));});}function generateRequestId(){const _0x289160=a2_0x53c6;return'req_'+Date[_0x289160(0x111)]()+'_'+Math['random']()[_0x289160(0xf3)](0x24)['substr'](0x2,0x9);}export function getConnectedSessions(){const _0x5eeb6f=a2_0x53c6;return Array[_0x5eeb6f(0x117)](sessions[_0x5eeb6f(0x109)]());}
@@ -1,13 +0,0 @@
1
- export declare function browserOpen(url: string): Promise<any>;
2
- export declare function browserClick(selector: string): Promise<any>;
3
- export declare function browserFill(selector: string, value: string): Promise<any>;
4
- export declare function browserSnapshot(): Promise<any>;
5
- export declare function browserScreenshot(): Promise<any>;
6
- export declare function browserGetText(selector: string): Promise<any>;
7
- export declare function browserGetHtml(selector: string): Promise<any>;
8
- export declare function browserWait(selectorOrMs: string | number): Promise<any>;
9
- export declare function browserBack(): Promise<any>;
10
- export declare function browserForward(): Promise<any>;
11
- export declare function browserReload(): Promise<any>;
12
- export declare function browserScroll(direction: 'up' | 'down' | 'top' | 'bottom', amount?: number): Promise<any>;
13
- export declare function browserClose(): Promise<any>;