happy-coder 0.10.0-2 → 0.10.0-4

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 (46) hide show
  1. package/README.md +10 -1
  2. package/bin/happy-mcp.mjs +32 -0
  3. package/dist/codex/happyMcpStdioBridge.cjs +80 -0
  4. package/dist/codex/happyMcpStdioBridge.d.cts +2 -0
  5. package/dist/codex/happyMcpStdioBridge.d.mts +2 -0
  6. package/dist/codex/happyMcpStdioBridge.mjs +78 -0
  7. package/dist/index-67rskwL7.cjs +6033 -0
  8. package/dist/index-Dw96QD4T.mjs +6025 -0
  9. package/dist/index.cjs +33 -6024
  10. package/dist/index.mjs +33 -6024
  11. package/dist/lib.cjs +2 -1
  12. package/dist/lib.d.cts +54 -112
  13. package/dist/lib.d.mts +54 -112
  14. package/dist/lib.mjs +2 -1
  15. package/dist/runCodex-BLNf5zb1.cjs +1155 -0
  16. package/dist/runCodex-BNH8w4O9.mjs +1153 -0
  17. package/dist/{types-xfXKJHdM.mjs → types-2wHnX7UW.mjs} +311 -170
  18. package/dist/{types-WP9wteZE.cjs → types-BcDnTXMg.cjs} +348 -206
  19. package/package.json +20 -6
  20. package/scripts/ripgrep_launcher.cjs +2 -26
  21. package/scripts/unpack-tools.cjs +163 -0
  22. package/tools/archives/difftastic-LICENSE +21 -0
  23. package/tools/archives/difftastic-arm64-darwin.tar.gz +0 -0
  24. package/tools/archives/difftastic-arm64-linux.tar.gz +0 -0
  25. package/tools/archives/difftastic-x64-darwin.tar.gz +0 -0
  26. package/tools/archives/difftastic-x64-linux.tar.gz +0 -0
  27. package/tools/archives/difftastic-x64-win32.tar.gz +0 -0
  28. package/tools/archives/ripgrep-arm64-darwin.tar.gz +0 -0
  29. package/tools/archives/ripgrep-arm64-linux.tar.gz +0 -0
  30. package/tools/archives/ripgrep-x64-darwin.tar.gz +0 -0
  31. package/tools/archives/ripgrep-x64-linux.tar.gz +0 -0
  32. package/tools/archives/ripgrep-x64-win32.tar.gz +0 -0
  33. package/tools/licenses/difftastic-LICENSE +21 -0
  34. package/tools/licenses/ripgrep-LICENSE +3 -0
  35. package/tools/unpacked/difft +0 -0
  36. package/ripgrep/arm64-linux/rg +0 -0
  37. package/ripgrep/arm64-linux/ripgrep.node +0 -0
  38. package/ripgrep/x64-darwin/rg +0 -0
  39. package/ripgrep/x64-darwin/ripgrep.node +0 -0
  40. package/ripgrep/x64-linux/rg +0 -0
  41. package/ripgrep/x64-linux/ripgrep.node +0 -0
  42. package/ripgrep/x64-win32/rg.exe +0 -0
  43. package/ripgrep/x64-win32/ripgrep.node +0 -0
  44. /package/{ripgrep/COPYING → tools/archives/ripgrep-LICENSE} +0 -0
  45. /package/{ripgrep/arm64-darwin → tools/unpacked}/rg +0 -0
  46. /package/{ripgrep/arm64-darwin → tools/unpacked}/ripgrep.node +0 -0
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "happy-coder",
3
- "version": "0.10.0-2",
4
- "description": "Claude Code session sharing CLI",
3
+ "version": "0.10.0-4",
4
+ "description": "Mobile and Web client for Claude Code and Codex",
5
5
  "author": "Kirill Dubovitskiy",
6
6
  "license": "MIT",
7
7
  "type": "module",
@@ -9,7 +9,8 @@
9
9
  "bugs": "https://github.com/slopus/happy-cli/issues",
10
10
  "repository": "slopus/happy-cli",
11
11
  "bin": {
12
- "happy": "./bin/happy.mjs"
12
+ "happy": "./bin/happy.mjs",
13
+ "happy-mcp": "./bin/happy-mcp.mjs"
13
14
  },
14
15
  "main": "./dist/index.cjs",
15
16
  "module": "./dist/index.mjs",
@@ -34,13 +35,23 @@
34
35
  "types": "./dist/lib.d.mts",
35
36
  "default": "./dist/lib.mjs"
36
37
  }
38
+ },
39
+ "./codex/happyMcpStdioBridge": {
40
+ "require": {
41
+ "types": "./dist/codex/happyMcpStdioBridge.d.cts",
42
+ "default": "./dist/codex/happyMcpStdioBridge.cjs"
43
+ },
44
+ "import": {
45
+ "types": "./dist/codex/happyMcpStdioBridge.d.mts",
46
+ "default": "./dist/codex/happyMcpStdioBridge.mjs"
47
+ }
37
48
  }
38
49
  },
39
50
  "files": [
40
51
  "dist",
41
52
  "bin",
42
53
  "scripts",
43
- "ripgrep",
54
+ "tools",
44
55
  "package.json"
45
56
  ],
46
57
  "scripts": {
@@ -49,17 +60,19 @@
49
60
  "build": "shx rm -rf dist && npx tsc --noEmit && pkgroll",
50
61
  "test": "yarn build && tsx --env-file .env.integration-test node_modules/.bin/vitest run",
51
62
  "start": "yarn build && ./bin/happy.mjs",
52
- "dev": "yarn build && tsx --env-file .env.dev src/index.ts",
63
+ "dev": "tsx --env-file .env.dev src/index.ts",
53
64
  "dev:local-server": "yarn build && tsx --env-file .env.dev-local-server src/index.ts",
54
65
  "dev:integration-test-env": "yarn build && tsx --env-file .env.integration-test src/index.ts",
55
66
  "prepublishOnly": "yarn build && yarn test",
56
- "release": "release-it"
67
+ "release": "release-it",
68
+ "postinstall": "node scripts/unpack-tools.cjs"
57
69
  },
58
70
  "dependencies": {
59
71
  "@anthropic-ai/claude-code": "^1.0.102",
60
72
  "@anthropic-ai/sdk": "^0.56.0",
61
73
  "@modelcontextprotocol/sdk": "^1.15.1",
62
74
  "@stablelib/base64": "^2.0.1",
75
+ "@stablelib/hex": "^2.0.1",
63
76
  "@types/cross-spawn": "^6.0.6",
64
77
  "@types/http-proxy": "^1.17.16",
65
78
  "@types/ps-list": "^6.2.1",
@@ -79,6 +92,7 @@
79
92
  "qrcode-terminal": "^0.12.0",
80
93
  "react": "^19.1.1",
81
94
  "socket.io-client": "^4.8.1",
95
+ "tar": "^7.4.3",
82
96
  "tweetnacl": "^1.0.3",
83
97
  "zod": "^3.23.8"
84
98
  },
@@ -6,33 +6,9 @@
6
6
  */
7
7
 
8
8
  const path = require('path');
9
- const os = require('os');
10
9
 
11
- // Determine platform-specific path
12
- function getPlatformDir() {
13
- const platform = os.platform();
14
- const arch = os.arch();
15
- const platformKey = `${arch}-${platform}`;
16
-
17
- const platformMap = {
18
- 'arm64-darwin': 'arm64-darwin',
19
- 'x64-darwin': 'x64-darwin',
20
- 'arm64-linux': 'arm64-linux',
21
- 'x64-linux': 'x64-linux',
22
- 'x64-win32': 'x64-win32'
23
- };
24
-
25
- return platformMap[platformKey];
26
- }
27
-
28
- // Load the native module
29
- const platformDir = getPlatformDir();
30
- if (!platformDir) {
31
- console.error(`Unsupported platform: ${os.arch()}-${os.platform()}`);
32
- process.exit(1);
33
- }
34
-
35
- const modulePath = path.join(__dirname, '..', 'ripgrep', platformDir, 'ripgrep.node');
10
+ // Load the native module from unpacked directory
11
+ const modulePath = path.join(__dirname, '..', 'tools', 'unpacked', 'ripgrep.node');
36
12
  const ripgrepNative = require(modulePath);
37
13
 
38
14
  // Get arguments from command line (skip node and script name)
@@ -0,0 +1,163 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * Unpacks platform-specific binaries from compressed archives
5
+ * This script extracts the necessary tools for the current platform
6
+ */
7
+
8
+ const fs = require('fs');
9
+ const path = require('path');
10
+ const zlib = require('zlib');
11
+ const tar = require('tar');
12
+ const os = require('os');
13
+
14
+ /**
15
+ * Get the platform-specific directory name
16
+ */
17
+ function getPlatformDir() {
18
+ const platform = os.platform();
19
+ const arch = os.arch();
20
+
21
+ if (platform === 'darwin') {
22
+ if (arch === 'arm64') return 'arm64-darwin';
23
+ if (arch === 'x64') return 'x64-darwin';
24
+ } else if (platform === 'linux') {
25
+ if (arch === 'arm64') return 'arm64-linux';
26
+ if (arch === 'x64') return 'x64-linux';
27
+ } else if (platform === 'win32') {
28
+ if (arch === 'x64') return 'x64-win32';
29
+ }
30
+
31
+ throw new Error(`Unsupported platform: ${arch}-${platform}`);
32
+ }
33
+
34
+ /**
35
+ * Get the root tools directory
36
+ */
37
+ function getToolsDir() {
38
+ // Handle both direct execution and require() calls
39
+ const scriptDir = __dirname;
40
+ return path.resolve(scriptDir, '..', 'tools');
41
+ }
42
+
43
+ /**
44
+ * Check if tools are already unpacked for current platform
45
+ */
46
+ function areToolsUnpacked(toolsDir) {
47
+ const unpackedPath = path.join(toolsDir, 'unpacked');
48
+
49
+ if (!fs.existsSync(unpackedPath)) {
50
+ return false;
51
+ }
52
+
53
+ // Check for expected binaries
54
+ const isWin = os.platform() === 'win32';
55
+ const difftBinary = isWin ? 'difft.exe' : 'difft';
56
+ const rgBinary = isWin ? 'rg.exe' : 'rg';
57
+
58
+ const expectedFiles = [
59
+ path.join(unpackedPath, difftBinary),
60
+ path.join(unpackedPath, rgBinary),
61
+ path.join(unpackedPath, 'ripgrep.node')
62
+ ];
63
+
64
+ return expectedFiles.every(file => fs.existsSync(file));
65
+ }
66
+
67
+ /**
68
+ * Unpack a tar.gz archive to a destination directory
69
+ */
70
+ async function unpackArchive(archivePath, destDir) {
71
+ return new Promise((resolve, reject) => {
72
+ // Ensure destination directory exists
73
+ if (!fs.existsSync(destDir)) {
74
+ fs.mkdirSync(destDir, { recursive: true });
75
+ }
76
+
77
+ // Create read stream and extract
78
+ fs.createReadStream(archivePath)
79
+ .pipe(zlib.createGunzip())
80
+ .pipe(tar.extract({
81
+ cwd: destDir,
82
+ preserveMode: true,
83
+ preserveOwner: false
84
+ }))
85
+ .on('finish', () => {
86
+ // Set executable permissions for Unix systems
87
+ if (os.platform() !== 'win32') {
88
+ const files = fs.readdirSync(destDir);
89
+ files.forEach(file => {
90
+ const filePath = path.join(destDir, file);
91
+ const stats = fs.statSync(filePath);
92
+ if (stats.isFile() && !file.endsWith('.node')) {
93
+ // Make binary files executable
94
+ fs.chmodSync(filePath, 0o755);
95
+ }
96
+ });
97
+ }
98
+ resolve();
99
+ })
100
+ .on('error', reject);
101
+ });
102
+ }
103
+
104
+ /**
105
+ * Main unpacking function
106
+ */
107
+ async function unpackTools() {
108
+ try {
109
+ const platformDir = getPlatformDir();
110
+ const toolsDir = getToolsDir();
111
+ const archivesDir = path.join(toolsDir, 'archives');
112
+ const unpackedPath = path.join(toolsDir, 'unpacked');
113
+
114
+ // Check if already unpacked
115
+ if (areToolsUnpacked(toolsDir)) {
116
+ console.log(`Tools already unpacked for ${platformDir}`);
117
+ return { success: true, alreadyUnpacked: true };
118
+ }
119
+
120
+ console.log(`Unpacking tools for ${platformDir}...`);
121
+
122
+ // Create unpacked directory
123
+ if (!fs.existsSync(unpackedPath)) {
124
+ fs.mkdirSync(unpackedPath, { recursive: true });
125
+ }
126
+
127
+ // Unpack difftastic
128
+ const difftasticArchive = path.join(archivesDir, `difftastic-${platformDir}.tar.gz`);
129
+ if (!fs.existsSync(difftasticArchive)) {
130
+ throw new Error(`Archive not found: ${difftasticArchive}`);
131
+ }
132
+ await unpackArchive(difftasticArchive, unpackedPath);
133
+
134
+ // Unpack ripgrep
135
+ const ripgrepArchive = path.join(archivesDir, `ripgrep-${platformDir}.tar.gz`);
136
+ if (!fs.existsSync(ripgrepArchive)) {
137
+ throw new Error(`Archive not found: ${ripgrepArchive}`);
138
+ }
139
+ await unpackArchive(ripgrepArchive, unpackedPath);
140
+
141
+ console.log(`Tools unpacked successfully to ${unpackedPath}`);
142
+ return { success: true, alreadyUnpacked: false };
143
+
144
+ } catch (error) {
145
+ console.error('Failed to unpack tools:', error.message);
146
+ throw error;
147
+ }
148
+ }
149
+
150
+ // Export for use as module
151
+ module.exports = { unpackTools, getPlatformDir, getToolsDir };
152
+
153
+ // Run if executed directly
154
+ if (require.main === module) {
155
+ unpackTools()
156
+ .then(result => {
157
+ process.exit(0);
158
+ })
159
+ .catch(error => {
160
+ console.error('Error:', error);
161
+ process.exit(1);
162
+ });
163
+ }
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2021-2025 Wilfred Hughes
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.
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2021-2025 Wilfred Hughes
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.
@@ -0,0 +1,3 @@
1
+ This project is dual-licensed under the Unlicense and MIT licenses.
2
+
3
+ You may use this code under the terms of either license.
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
File without changes