pubblue 0.4.12 → 0.6.1
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/dist/chunk-BBJOOZHS.js +676 -0
- package/dist/chunk-WXNNDR4T.js +1313 -0
- package/dist/index.js +457 -1265
- package/dist/tunnel-daemon-BR5XKNEA.js +7 -0
- package/dist/tunnel-daemon-entry.js +14 -12
- package/package.json +4 -4
- package/dist/chunk-4YTJ2WKF.js +0 -60
- package/dist/chunk-7NFHPJ76.js +0 -79
- package/dist/chunk-HJ5LTUHS.js +0 -56
- package/dist/chunk-UW7JILRJ.js +0 -677
- package/dist/tunnel-bridge-entry.d.ts +0 -2
- package/dist/tunnel-bridge-entry.js +0 -703
- package/dist/tunnel-daemon-RKWEA5BV.js +0 -14
|
@@ -1,25 +1,27 @@
|
|
|
1
1
|
import {
|
|
2
2
|
startDaemon
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-WXNNDR4T.js";
|
|
4
4
|
import {
|
|
5
|
-
|
|
6
|
-
} from "./chunk-
|
|
7
|
-
import "./chunk-4YTJ2WKF.js";
|
|
5
|
+
PubApiClient
|
|
6
|
+
} from "./chunk-BBJOOZHS.js";
|
|
8
7
|
|
|
9
8
|
// src/tunnel-daemon-entry.ts
|
|
10
|
-
var tunnelId = process.env.PUBBLUE_DAEMON_TUNNEL_ID;
|
|
11
9
|
var baseUrl = process.env.PUBBLUE_DAEMON_BASE_URL;
|
|
12
10
|
var apiKey = process.env.PUBBLUE_DAEMON_API_KEY;
|
|
13
11
|
var socketPath = process.env.PUBBLUE_DAEMON_SOCKET;
|
|
14
12
|
var infoPath = process.env.PUBBLUE_DAEMON_INFO;
|
|
15
13
|
var cliVersion = process.env.PUBBLUE_CLI_VERSION;
|
|
16
|
-
|
|
14
|
+
var agentName = process.env.PUBBLUE_DAEMON_AGENT_NAME;
|
|
15
|
+
var bridgeMode = process.env.PUBBLUE_DAEMON_BRIDGE_MODE || "openclaw";
|
|
16
|
+
if (!baseUrl || !apiKey || !socketPath || !infoPath) {
|
|
17
17
|
console.error("Missing required env vars for daemon.");
|
|
18
18
|
process.exit(1);
|
|
19
19
|
}
|
|
20
|
-
var apiClient = new
|
|
21
|
-
void startDaemon({
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
20
|
+
var apiClient = new PubApiClient(baseUrl, apiKey);
|
|
21
|
+
void startDaemon({ apiClient, socketPath, infoPath, cliVersion, bridgeMode, agentName }).catch(
|
|
22
|
+
(error) => {
|
|
23
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
24
|
+
console.error(`Daemon failed to start: ${message}`);
|
|
25
|
+
process.exit(1);
|
|
26
|
+
}
|
|
27
|
+
);
|
package/package.json
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "pubblue",
|
|
3
|
-
"version": "0.
|
|
4
|
-
"description": "CLI tool for publishing
|
|
3
|
+
"version": "0.6.1",
|
|
4
|
+
"description": "CLI tool for publishing content and running interactive sessions via pub.blue",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
7
7
|
"pubblue": "./dist/index.js"
|
|
8
8
|
},
|
|
9
9
|
"scripts": {
|
|
10
|
-
"build": "tsup src/index.ts src/tunnel-daemon-entry.ts
|
|
11
|
-
"dev": "tsup src/index.ts src/tunnel-daemon-entry.ts
|
|
10
|
+
"build": "tsup src/index.ts src/tunnel-daemon-entry.ts --format esm --dts --clean",
|
|
11
|
+
"dev": "tsup src/index.ts src/tunnel-daemon-entry.ts --format esm --watch",
|
|
12
12
|
"test": "vitest run",
|
|
13
13
|
"test:watch": "vitest",
|
|
14
14
|
"lint": "tsc --noEmit"
|
package/dist/chunk-4YTJ2WKF.js
DELETED
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
// ../shared/bridge-protocol-core.ts
|
|
2
|
-
var CONTROL_CHANNEL = "_control";
|
|
3
|
-
var CHANNELS = {
|
|
4
|
-
CHAT: "chat",
|
|
5
|
-
CANVAS: "canvas",
|
|
6
|
-
AUDIO: "audio",
|
|
7
|
-
MEDIA: "media",
|
|
8
|
-
FILE: "file"
|
|
9
|
-
};
|
|
10
|
-
var idCounter = 0;
|
|
11
|
-
function generateMessageId() {
|
|
12
|
-
const ts = Date.now().toString(36);
|
|
13
|
-
const seq = (idCounter++).toString(36);
|
|
14
|
-
const rand = Math.random().toString(36).slice(2, 6);
|
|
15
|
-
return `${ts}-${seq}-${rand}`;
|
|
16
|
-
}
|
|
17
|
-
function encodeMessage(msg) {
|
|
18
|
-
return JSON.stringify(msg);
|
|
19
|
-
}
|
|
20
|
-
function decodeMessage(raw) {
|
|
21
|
-
try {
|
|
22
|
-
const parsed = JSON.parse(raw);
|
|
23
|
-
if (parsed && typeof parsed.id === "string" && typeof parsed.type === "string") {
|
|
24
|
-
return parsed;
|
|
25
|
-
}
|
|
26
|
-
return null;
|
|
27
|
-
} catch {
|
|
28
|
-
return null;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
function makeEventMessage(event, meta) {
|
|
32
|
-
return { id: generateMessageId(), type: "event", data: event, meta };
|
|
33
|
-
}
|
|
34
|
-
function makeAckMessage(messageId, channel) {
|
|
35
|
-
return makeEventMessage("ack", { messageId, channel, receivedAt: Date.now() });
|
|
36
|
-
}
|
|
37
|
-
function parseAckMessage(msg) {
|
|
38
|
-
if (msg.type !== "event" || msg.data !== "ack" || !msg.meta) return null;
|
|
39
|
-
const messageId = typeof msg.meta.messageId === "string" ? msg.meta.messageId : null;
|
|
40
|
-
const channel = typeof msg.meta.channel === "string" ? msg.meta.channel : null;
|
|
41
|
-
if (!messageId || !channel) return null;
|
|
42
|
-
const receivedAt = typeof msg.meta.receivedAt === "number" ? msg.meta.receivedAt : void 0;
|
|
43
|
-
return { messageId, channel, receivedAt };
|
|
44
|
-
}
|
|
45
|
-
function shouldAcknowledgeMessage(channel, msg) {
|
|
46
|
-
return channel !== CONTROL_CHANNEL && parseAckMessage(msg) === null;
|
|
47
|
-
}
|
|
48
|
-
var MAX_TUNNEL_EXPIRY_MS = 7 * 24 * 60 * 60 * 1e3;
|
|
49
|
-
var DEFAULT_TUNNEL_EXPIRY_MS = 24 * 60 * 60 * 1e3;
|
|
50
|
-
|
|
51
|
-
export {
|
|
52
|
-
CONTROL_CHANNEL,
|
|
53
|
-
CHANNELS,
|
|
54
|
-
generateMessageId,
|
|
55
|
-
encodeMessage,
|
|
56
|
-
decodeMessage,
|
|
57
|
-
makeAckMessage,
|
|
58
|
-
parseAckMessage,
|
|
59
|
-
shouldAcknowledgeMessage
|
|
60
|
-
};
|
package/dist/chunk-7NFHPJ76.js
DELETED
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
// src/lib/tunnel-api.ts
|
|
2
|
-
var TunnelApiError = class extends Error {
|
|
3
|
-
constructor(message, status, retryAfterSeconds) {
|
|
4
|
-
super(message);
|
|
5
|
-
this.status = status;
|
|
6
|
-
this.retryAfterSeconds = retryAfterSeconds;
|
|
7
|
-
this.name = "TunnelApiError";
|
|
8
|
-
}
|
|
9
|
-
};
|
|
10
|
-
var TunnelApiClient = class {
|
|
11
|
-
constructor(baseUrl, apiKey) {
|
|
12
|
-
this.baseUrl = baseUrl;
|
|
13
|
-
this.apiKey = apiKey;
|
|
14
|
-
}
|
|
15
|
-
async request(path, options = {}) {
|
|
16
|
-
const url = new URL(path, this.baseUrl);
|
|
17
|
-
const res = await fetch(url, {
|
|
18
|
-
...options,
|
|
19
|
-
headers: {
|
|
20
|
-
"Content-Type": "application/json",
|
|
21
|
-
Authorization: `Bearer ${this.apiKey}`,
|
|
22
|
-
...options.headers
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
const retryAfterHeader = res.headers.get("Retry-After");
|
|
26
|
-
const parsedRetryAfterSeconds = typeof retryAfterHeader === "string" ? Number.parseInt(retryAfterHeader, 10) : void 0;
|
|
27
|
-
const retryAfterSeconds = parsedRetryAfterSeconds !== void 0 && Number.isFinite(parsedRetryAfterSeconds) ? parsedRetryAfterSeconds : void 0;
|
|
28
|
-
let data;
|
|
29
|
-
try {
|
|
30
|
-
data = await res.json();
|
|
31
|
-
} catch {
|
|
32
|
-
data = {};
|
|
33
|
-
}
|
|
34
|
-
if (!res.ok) {
|
|
35
|
-
if (res.status === 429) {
|
|
36
|
-
const retrySuffix = retryAfterSeconds !== void 0 ? ` Retry after ${retryAfterSeconds}s.` : "";
|
|
37
|
-
throw new TunnelApiError(
|
|
38
|
-
`Rate limit exceeded.${retrySuffix}`,
|
|
39
|
-
res.status,
|
|
40
|
-
retryAfterSeconds
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
throw new TunnelApiError(data.error || `Request failed: ${res.status}`, res.status);
|
|
44
|
-
}
|
|
45
|
-
return data;
|
|
46
|
-
}
|
|
47
|
-
async create(opts) {
|
|
48
|
-
return this.request("/api/v1/tunnels", {
|
|
49
|
-
method: "POST",
|
|
50
|
-
body: JSON.stringify(opts)
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
async get(tunnelId) {
|
|
54
|
-
const data = await this.request(
|
|
55
|
-
`/api/v1/tunnels/${encodeURIComponent(tunnelId)}`
|
|
56
|
-
);
|
|
57
|
-
return data.tunnel;
|
|
58
|
-
}
|
|
59
|
-
async list() {
|
|
60
|
-
const data = await this.request("/api/v1/tunnels/");
|
|
61
|
-
return data.tunnels;
|
|
62
|
-
}
|
|
63
|
-
async signal(tunnelId, opts) {
|
|
64
|
-
await this.request(`/api/v1/tunnels/${encodeURIComponent(tunnelId)}/signal`, {
|
|
65
|
-
method: "PATCH",
|
|
66
|
-
body: JSON.stringify(opts)
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
async close(tunnelId) {
|
|
70
|
-
await this.request(`/api/v1/tunnels/${encodeURIComponent(tunnelId)}`, {
|
|
71
|
-
method: "DELETE"
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
export {
|
|
77
|
-
TunnelApiError,
|
|
78
|
-
TunnelApiClient
|
|
79
|
-
};
|
package/dist/chunk-HJ5LTUHS.js
DELETED
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
// src/lib/tunnel-ipc.ts
|
|
2
|
-
import * as net from "net";
|
|
3
|
-
function getSocketPath(tunnelId) {
|
|
4
|
-
return `/tmp/pubblue-${tunnelId}.sock`;
|
|
5
|
-
}
|
|
6
|
-
async function ipcCall(socketPath, request) {
|
|
7
|
-
return new Promise((resolve, reject) => {
|
|
8
|
-
let settled = false;
|
|
9
|
-
let timeoutId = null;
|
|
10
|
-
const finish = (fn) => {
|
|
11
|
-
if (settled) return;
|
|
12
|
-
settled = true;
|
|
13
|
-
if (timeoutId) clearTimeout(timeoutId);
|
|
14
|
-
fn();
|
|
15
|
-
};
|
|
16
|
-
const client = net.createConnection(socketPath, () => {
|
|
17
|
-
client.write(`${JSON.stringify(request)}
|
|
18
|
-
`);
|
|
19
|
-
});
|
|
20
|
-
let data = "";
|
|
21
|
-
client.on("data", (chunk) => {
|
|
22
|
-
data += chunk.toString();
|
|
23
|
-
const newlineIdx = data.indexOf("\n");
|
|
24
|
-
if (newlineIdx !== -1) {
|
|
25
|
-
const line = data.slice(0, newlineIdx);
|
|
26
|
-
client.end();
|
|
27
|
-
try {
|
|
28
|
-
finish(() => resolve(JSON.parse(line)));
|
|
29
|
-
} catch {
|
|
30
|
-
finish(() => reject(new Error("Invalid response from daemon")));
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
});
|
|
34
|
-
client.on("error", (err) => {
|
|
35
|
-
if (err.code === "ECONNREFUSED" || err.code === "ENOENT") {
|
|
36
|
-
finish(() => reject(new Error("Daemon not running. Is the tunnel still active?")));
|
|
37
|
-
} else {
|
|
38
|
-
finish(() => reject(err));
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
client.on("end", () => {
|
|
42
|
-
if (!data.includes("\n")) {
|
|
43
|
-
finish(() => reject(new Error("Daemon closed connection unexpectedly")));
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
timeoutId = setTimeout(() => {
|
|
47
|
-
client.destroy();
|
|
48
|
-
finish(() => reject(new Error("Daemon request timed out")));
|
|
49
|
-
}, 1e4);
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
export {
|
|
54
|
-
getSocketPath,
|
|
55
|
-
ipcCall
|
|
56
|
-
};
|