@wangyaoshen/remux 0.3.9-dev.390cb29 → 0.3.10-dev.574c4d2
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/apps/macos/Package.swift +5 -0
- package/apps/macos/Sources/Remux/AppCommand.swift +114 -0
- package/apps/macos/Sources/Remux/AppDelegate.swift +26 -0
- package/apps/macos/Sources/Remux/MainContentView.swift +56 -0
- package/apps/macos/Sources/Remux/MenuBarManager.swift +18 -26
- package/apps/macos/Sources/Remux/NotificationManager.swift +52 -7
- package/apps/macos/Sources/Remux/Views/SplitTree/SplitView.swift +1 -1
- package/apps/macos/Sources/Remux/Views/Terminal/GhosttyNativeView.swift +10 -4
- package/apps/macos/Sources/Remux/Views/Terminal/TerminalContainerView.swift +35 -5
- package/apps/macos/Sources/Remux/WindowObserver.swift +38 -0
- package/apps/macos/Tests/RemuxTests/AppCommandTests.swift +30 -0
- package/apps/macos/Tests/RemuxTests/NotificationManagerTests.swift +28 -0
- package/package.json +1 -1
- package/packages/RemuxKit/Sources/RemuxKit/Storage/KeychainStore.swift +3 -3
- package/packages/RemuxKit/Tests/RemuxKitTests/KeychainStoreTests.swift +3 -3
- package/pty-daemon.js +17 -11
- package/server.js +250 -1467
- package/services/discovery/local-server.js +98 -0
- package/services/discovery/worker.js +125 -0
- package/services/discovery/wrangler.toml +7 -0
- package/src/pty-daemon.ts +17 -11
- package/src/server.ts +205 -1458
- package/src/session.ts +42 -4
- package/tests/auth.test.js +1 -1
- package/tests/e2e/app.spec.js +113 -288
- package/tests/pty-daemon.test.js +20 -1
- package/tests/server.test.js +49 -11
- package/vitest.config.js +1 -0
|
@@ -60,12 +60,12 @@ public struct KeychainStore: Sendable {
|
|
|
60
60
|
}
|
|
61
61
|
|
|
62
62
|
public func preferredCredential(forServer server: String) -> RemuxCredential? {
|
|
63
|
-
if let resumeToken = loadResumeToken(forServer: server) {
|
|
64
|
-
return .resumeToken(resumeToken)
|
|
65
|
-
}
|
|
66
63
|
if let token = loadServerToken(forServer: server) {
|
|
67
64
|
return .token(token)
|
|
68
65
|
}
|
|
66
|
+
if let resumeToken = loadResumeToken(forServer: server) {
|
|
67
|
+
return .resumeToken(resumeToken)
|
|
68
|
+
}
|
|
69
69
|
return nil
|
|
70
70
|
}
|
|
71
71
|
|
|
@@ -95,13 +95,13 @@ struct KeychainStoreTests {
|
|
|
95
95
|
#expect(servers.contains(resumeOnly))
|
|
96
96
|
}
|
|
97
97
|
|
|
98
|
-
@Test("Preferred credential uses
|
|
99
|
-
func
|
|
98
|
+
@Test("Preferred credential uses server token before resume token", .enabled(if: keychainAvailable))
|
|
99
|
+
func preferredCredentialPrefersServerToken() throws {
|
|
100
100
|
try store.saveServerToken("tok", forServer: testServer)
|
|
101
101
|
try store.saveResumeToken("resume", forServer: testServer)
|
|
102
102
|
defer { store.deleteAll(forServer: testServer) }
|
|
103
103
|
|
|
104
104
|
let credential = store.preferredCredential(forServer: testServer)
|
|
105
|
-
#expect(credential == .
|
|
105
|
+
#expect(credential == .token("tok"))
|
|
106
106
|
}
|
|
107
107
|
}
|
package/pty-daemon.js
CHANGED
|
@@ -120,17 +120,23 @@ function main() {
|
|
|
120
120
|
} catch {
|
|
121
121
|
}
|
|
122
122
|
}
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
123
|
+
let ptyProcess;
|
|
124
|
+
try {
|
|
125
|
+
ptyProcess = pty.spawn(args.shell, [], {
|
|
126
|
+
name: "xterm-256color",
|
|
127
|
+
cols: args.cols,
|
|
128
|
+
rows: args.rows,
|
|
129
|
+
cwd: args.cwd,
|
|
130
|
+
env: {
|
|
131
|
+
...process.env,
|
|
132
|
+
TERM: "xterm-256color",
|
|
133
|
+
COLORTERM: "truecolor"
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
} catch (err) {
|
|
137
|
+
console.error(`[pty-daemon] failed to spawn PTY: ${err?.message || err}`);
|
|
138
|
+
process.exit(1);
|
|
139
|
+
}
|
|
134
140
|
const scrollback = new RingBuffer();
|
|
135
141
|
const clients = /* @__PURE__ */ new Set();
|
|
136
142
|
let alive = true;
|