opendevbrowser 0.0.10 → 0.0.11
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 +150 -24
- package/dist/index.js +108 -2
- package/dist/index.js.map +1 -1
- package/dist/opendevbrowser.js +108 -2
- package/dist/opendevbrowser.js.map +1 -1
- package/extension/dist/popup.js +58 -11
- package/extension/dist/relay-settings.js +1 -0
- package/extension/manifest.json +1 -1
- package/package.json +2 -2
package/extension/dist/popup.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DEFAULT_AUTO_PAIR, DEFAULT_PAIRING_ENABLED, DEFAULT_PAIRING_TOKEN, DEFAULT_RELAY_PORT } from "./relay-settings.js";
|
|
1
|
+
import { DEFAULT_AUTO_PAIR, DEFAULT_DISCOVERY_PORT, DEFAULT_PAIRING_ENABLED, DEFAULT_PAIRING_TOKEN, DEFAULT_RELAY_PORT } from "./relay-settings.js";
|
|
2
2
|
const statusEl = document.getElementById("status");
|
|
3
3
|
const statusIndicator = document.getElementById("statusIndicator");
|
|
4
4
|
const toggleButton = document.getElementById("toggle");
|
|
@@ -47,6 +47,46 @@ const fetchTokenFromPlugin = async (port) => {
|
|
|
47
47
|
return null;
|
|
48
48
|
}
|
|
49
49
|
};
|
|
50
|
+
const parsePort = (value) => {
|
|
51
|
+
if (typeof value === "number" && Number.isInteger(value) && value > 0 && value <= 65535) {
|
|
52
|
+
return value;
|
|
53
|
+
}
|
|
54
|
+
if (typeof value === "string" && value.trim()) {
|
|
55
|
+
const parsed = Number(value);
|
|
56
|
+
if (Number.isInteger(parsed) && parsed > 0 && parsed <= 65535) {
|
|
57
|
+
return parsed;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return null;
|
|
61
|
+
};
|
|
62
|
+
const fetchRelayConfig = async (port) => {
|
|
63
|
+
try {
|
|
64
|
+
const response = await fetch(`http://127.0.0.1:${port}/config`, {
|
|
65
|
+
method: "GET",
|
|
66
|
+
headers: { "Accept": "application/json" }
|
|
67
|
+
});
|
|
68
|
+
if (!response.ok) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
const data = await response.json();
|
|
72
|
+
const relayPort = parsePort(data.relayPort);
|
|
73
|
+
if (!relayPort) {
|
|
74
|
+
return null;
|
|
75
|
+
}
|
|
76
|
+
const pairingRequired = typeof data.pairingRequired === "boolean" ? data.pairingRequired : true;
|
|
77
|
+
return { relayPort, pairingRequired };
|
|
78
|
+
}
|
|
79
|
+
catch {
|
|
80
|
+
return null;
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
const applyRelayPort = (port) => {
|
|
84
|
+
const nextValue = String(port);
|
|
85
|
+
if (relayPortInput.value !== nextValue) {
|
|
86
|
+
relayPortInput.value = nextValue;
|
|
87
|
+
}
|
|
88
|
+
chrome.storage.local.set({ relayPort: port });
|
|
89
|
+
};
|
|
50
90
|
const loadSettings = async () => {
|
|
51
91
|
const data = await new Promise((resolve) => {
|
|
52
92
|
chrome.storage.local.get(["pairingToken", "pairingEnabled", "relayPort", "autoPair"], (items) => {
|
|
@@ -59,7 +99,7 @@ const loadSettings = async () => {
|
|
|
59
99
|
: DEFAULT_PAIRING_ENABLED;
|
|
60
100
|
const rawToken = typeof data.pairingToken === "string" ? data.pairingToken.trim() : "";
|
|
61
101
|
const tokenValue = pairingEnabled ? (rawToken || DEFAULT_PAIRING_TOKEN || "") : rawToken;
|
|
62
|
-
const portValue =
|
|
102
|
+
const portValue = parsePort(data.relayPort) ?? DEFAULT_RELAY_PORT;
|
|
63
103
|
autoPairInput.checked = autoPair;
|
|
64
104
|
pairingEnabledInput.checked = pairingEnabled;
|
|
65
105
|
pairingTokenInput.disabled = !pairingEnabled || autoPair;
|
|
@@ -79,16 +119,23 @@ const loadSettings = async () => {
|
|
|
79
119
|
const toggle = async () => {
|
|
80
120
|
const isConnected = statusEl.textContent === "Connected";
|
|
81
121
|
if (!isConnected && autoPairInput.checked && pairingEnabledInput.checked) {
|
|
82
|
-
const
|
|
83
|
-
const
|
|
84
|
-
if (
|
|
85
|
-
|
|
86
|
-
chrome.storage.local.set({ pairingToken: fetchedToken });
|
|
122
|
+
const config = await fetchRelayConfig(DEFAULT_DISCOVERY_PORT);
|
|
123
|
+
const relayPort = config?.relayPort ?? parsePort(relayPortInput.value) ?? DEFAULT_RELAY_PORT;
|
|
124
|
+
if (config?.relayPort) {
|
|
125
|
+
applyRelayPort(config.relayPort);
|
|
87
126
|
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
127
|
+
const pairingRequired = config?.pairingRequired ?? true;
|
|
128
|
+
if (pairingRequired) {
|
|
129
|
+
const fetchedToken = await fetchTokenFromPlugin(relayPort);
|
|
130
|
+
if (fetchedToken) {
|
|
131
|
+
pairingTokenInput.value = fetchedToken;
|
|
132
|
+
chrome.storage.local.set({ pairingToken: fetchedToken });
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
statusEl.textContent = "Failed to fetch token from plugin";
|
|
136
|
+
setTimeout(() => refreshStatus(), 2000);
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
92
139
|
}
|
|
93
140
|
}
|
|
94
141
|
const response = await sendMessage({
|
package/extension/manifest.json
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "opendevbrowser",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.11",
|
|
4
4
|
"description": "OpenCode plugin for browser automation via CDP with snapshot-refs-actions workflow",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -44,7 +44,7 @@
|
|
|
44
44
|
"extension:build": "npm run extension:sync && tsc -p extension/tsconfig.json",
|
|
45
45
|
"extension:pack": "cd extension && zip -r ../opendevbrowser-extension.zip manifest.json popup.html dist/ icons/",
|
|
46
46
|
"version:check": "node scripts/verify-versions.mjs",
|
|
47
|
-
"prepack": "npm run build && npm run extension:build"
|
|
47
|
+
"prepack": "npm run version:check && npm run build && npm run extension:build"
|
|
48
48
|
},
|
|
49
49
|
"dependencies": {
|
|
50
50
|
"@opencode-ai/plugin": "^1.0.203",
|