@pixelbyte-software/pixcode 1.30.2 → 1.31.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.
Files changed (209) hide show
  1. package/LICENSE +718 -718
  2. package/README.de.md +248 -248
  3. package/README.ja.md +240 -240
  4. package/README.ko.md +240 -240
  5. package/README.md +295 -285
  6. package/README.ru.md +248 -248
  7. package/README.tr.md +250 -250
  8. package/README.zh-CN.md +240 -240
  9. package/dist/api-docs.html +879 -879
  10. package/dist/assets/index-BtOeB3cE.js +837 -0
  11. package/dist/assets/index-CDpePeIN.css +32 -0
  12. package/dist/assets/vendor-codemirror-CzYAOTxS.js +41 -0
  13. package/dist/clear-cache.html +85 -85
  14. package/dist/convert-icons.md +52 -52
  15. package/dist/favicon.png +0 -0
  16. package/dist/favicon.svg +7 -8
  17. package/dist/generate-icons.js +48 -48
  18. package/dist/icons/codex-white.svg +3 -3
  19. package/dist/icons/codex.svg +3 -3
  20. package/dist/icons/cursor-white.svg +11 -11
  21. package/dist/icons/icon-128x128.png +0 -0
  22. package/dist/icons/icon-128x128.svg +9 -12
  23. package/dist/icons/icon-144x144.png +0 -0
  24. package/dist/icons/icon-144x144.svg +9 -12
  25. package/dist/icons/icon-152x152.png +0 -0
  26. package/dist/icons/icon-152x152.svg +9 -12
  27. package/dist/icons/icon-192x192.png +0 -0
  28. package/dist/icons/icon-192x192.svg +9 -12
  29. package/dist/icons/icon-384x384.png +0 -0
  30. package/dist/icons/icon-384x384.svg +9 -12
  31. package/dist/icons/icon-512x512.png +0 -0
  32. package/dist/icons/icon-512x512.svg +9 -12
  33. package/dist/icons/icon-72x72.png +0 -0
  34. package/dist/icons/icon-72x72.svg +9 -12
  35. package/dist/icons/icon-96x96.png +0 -0
  36. package/dist/icons/icon-96x96.svg +9 -12
  37. package/dist/icons/icon-template.svg +9 -12
  38. package/dist/icons/qwen-ai-icon.png +0 -0
  39. package/dist/index.html +60 -50
  40. package/dist/logo.png +0 -0
  41. package/dist/logo.svg +11 -16
  42. package/dist/manifest.json +60 -60
  43. package/dist/sw.js +124 -124
  44. package/dist-server/server/claude-sdk.js +28 -5
  45. package/dist-server/server/claude-sdk.js.map +1 -1
  46. package/dist-server/server/cli.js +100 -97
  47. package/dist-server/server/cli.js.map +1 -1
  48. package/dist-server/server/daemon/manager.js +33 -33
  49. package/dist-server/server/daemon-manager.js +62 -62
  50. package/dist-server/server/database/db.js +114 -22
  51. package/dist-server/server/database/db.js.map +1 -1
  52. package/dist-server/server/database/schema.js +122 -89
  53. package/dist-server/server/database/schema.js.map +1 -1
  54. package/dist-server/server/gemini-cli.js +6 -1
  55. package/dist-server/server/gemini-cli.js.map +1 -1
  56. package/dist-server/server/index.js +346 -61
  57. package/dist-server/server/index.js.map +1 -1
  58. package/dist-server/server/modules/providers/list/claude/claude-auth.provider.js +29 -2
  59. package/dist-server/server/modules/providers/list/claude/claude-auth.provider.js.map +1 -1
  60. package/dist-server/server/modules/providers/list/codex/codex-auth.provider.js +22 -2
  61. package/dist-server/server/modules/providers/list/codex/codex-auth.provider.js.map +1 -1
  62. package/dist-server/server/modules/providers/list/cursor/cursor-auth.provider.js +2 -2
  63. package/dist-server/server/modules/providers/list/cursor/cursor-auth.provider.js.map +1 -1
  64. package/dist-server/server/modules/providers/list/gemini/gemini-auth.provider.js +14 -2
  65. package/dist-server/server/modules/providers/list/gemini/gemini-auth.provider.js.map +1 -1
  66. package/dist-server/server/modules/providers/list/qwen/qwen-auth.provider.js +132 -0
  67. package/dist-server/server/modules/providers/list/qwen/qwen-auth.provider.js.map +1 -0
  68. package/dist-server/server/modules/providers/list/qwen/qwen-mcp.provider.js +87 -0
  69. package/dist-server/server/modules/providers/list/qwen/qwen-mcp.provider.js.map +1 -0
  70. package/dist-server/server/modules/providers/list/qwen/qwen-sessions.provider.js +201 -0
  71. package/dist-server/server/modules/providers/list/qwen/qwen-sessions.provider.js.map +1 -0
  72. package/dist-server/server/modules/providers/list/qwen/qwen.provider.js +19 -0
  73. package/dist-server/server/modules/providers/list/qwen/qwen.provider.js.map +1 -0
  74. package/dist-server/server/modules/providers/provider.registry.js +2 -0
  75. package/dist-server/server/modules/providers/provider.registry.js.map +1 -1
  76. package/dist-server/server/modules/providers/provider.routes.js +478 -1
  77. package/dist-server/server/modules/providers/provider.routes.js.map +1 -1
  78. package/dist-server/server/modules/providers/shared/provider-configs.js +105 -0
  79. package/dist-server/server/modules/providers/shared/provider-configs.js.map +1 -0
  80. package/dist-server/server/projects.js +197 -6
  81. package/dist-server/server/projects.js.map +1 -1
  82. package/dist-server/server/qwen-code-cli.js +350 -0
  83. package/dist-server/server/qwen-code-cli.js.map +1 -0
  84. package/dist-server/server/qwen-response-handler.js +70 -0
  85. package/dist-server/server/qwen-response-handler.js.map +1 -0
  86. package/dist-server/server/routes/commands.js +25 -25
  87. package/dist-server/server/routes/git.js +17 -17
  88. package/dist-server/server/routes/network.js +116 -0
  89. package/dist-server/server/routes/network.js.map +1 -0
  90. package/dist-server/server/routes/projects.js +166 -1
  91. package/dist-server/server/routes/projects.js.map +1 -1
  92. package/dist-server/server/routes/qwen.js +23 -0
  93. package/dist-server/server/routes/qwen.js.map +1 -0
  94. package/dist-server/server/routes/taskmaster.js +419 -419
  95. package/dist-server/server/routes/telegram.js +119 -0
  96. package/dist-server/server/routes/telegram.js.map +1 -0
  97. package/dist-server/server/services/external-access.js +228 -0
  98. package/dist-server/server/services/external-access.js.map +1 -0
  99. package/dist-server/server/services/install-jobs.js +552 -0
  100. package/dist-server/server/services/install-jobs.js.map +1 -0
  101. package/dist-server/server/services/notification-orchestrator.js +19 -5
  102. package/dist-server/server/services/notification-orchestrator.js.map +1 -1
  103. package/dist-server/server/services/provider-credentials.js +154 -0
  104. package/dist-server/server/services/provider-credentials.js.map +1 -0
  105. package/dist-server/server/services/provider-models.js +218 -0
  106. package/dist-server/server/services/provider-models.js.map +1 -0
  107. package/dist-server/server/services/telegram/bot.js +259 -0
  108. package/dist-server/server/services/telegram/bot.js.map +1 -0
  109. package/dist-server/server/services/telegram/translations.js +160 -0
  110. package/dist-server/server/services/telegram/translations.js.map +1 -0
  111. package/dist-server/server/utils/port-access.js +196 -0
  112. package/dist-server/server/utils/port-access.js.map +1 -0
  113. package/dist-server/shared/modelConstants.js +18 -0
  114. package/dist-server/shared/modelConstants.js.map +1 -1
  115. package/package.json +177 -168
  116. package/scripts/fix-node-pty.js +67 -67
  117. package/server/claude-sdk.js +857 -834
  118. package/server/cli.js +940 -937
  119. package/server/constants/config.js +4 -4
  120. package/server/cursor-cli.js +342 -342
  121. package/server/daemon/manager.js +564 -564
  122. package/server/daemon-manager.js +920 -920
  123. package/server/database/db.js +696 -593
  124. package/server/database/schema.js +138 -102
  125. package/server/gemini-cli.js +475 -469
  126. package/server/gemini-response-handler.js +79 -79
  127. package/server/index.js +2854 -2556
  128. package/server/load-env.js +34 -34
  129. package/server/middleware/auth.js +132 -132
  130. package/server/modules/providers/list/claude/claude-auth.provider.ts +145 -123
  131. package/server/modules/providers/list/claude/claude-mcp.provider.ts +135 -135
  132. package/server/modules/providers/list/claude/claude-sessions.provider.ts +306 -306
  133. package/server/modules/providers/list/claude/claude.provider.ts +15 -15
  134. package/server/modules/providers/list/codex/codex-auth.provider.ts +115 -100
  135. package/server/modules/providers/list/codex/codex-mcp.provider.ts +135 -135
  136. package/server/modules/providers/list/codex/codex-sessions.provider.ts +319 -319
  137. package/server/modules/providers/list/codex/codex.provider.ts +15 -15
  138. package/server/modules/providers/list/cursor/cursor-auth.provider.ts +143 -143
  139. package/server/modules/providers/list/cursor/cursor-mcp.provider.ts +108 -108
  140. package/server/modules/providers/list/cursor/cursor-sessions.provider.ts +421 -421
  141. package/server/modules/providers/list/cursor/cursor.provider.ts +15 -15
  142. package/server/modules/providers/list/gemini/gemini-auth.provider.ts +163 -151
  143. package/server/modules/providers/list/gemini/gemini-mcp.provider.ts +110 -110
  144. package/server/modules/providers/list/gemini/gemini-sessions.provider.ts +227 -227
  145. package/server/modules/providers/list/gemini/gemini.provider.ts +15 -15
  146. package/server/modules/providers/list/qwen/qwen-auth.provider.ts +145 -0
  147. package/server/modules/providers/list/qwen/qwen-mcp.provider.ts +114 -0
  148. package/server/modules/providers/list/qwen/qwen-sessions.provider.ts +218 -0
  149. package/server/modules/providers/list/qwen/qwen.provider.ts +21 -0
  150. package/server/modules/providers/provider.registry.ts +38 -36
  151. package/server/modules/providers/provider.routes.ts +781 -217
  152. package/server/modules/providers/services/mcp.service.ts +94 -94
  153. package/server/modules/providers/services/provider-auth.service.ts +26 -26
  154. package/server/modules/providers/services/sessions.service.ts +45 -45
  155. package/server/modules/providers/shared/base/abstract.provider.ts +20 -20
  156. package/server/modules/providers/shared/mcp/mcp.provider.ts +151 -151
  157. package/server/modules/providers/shared/provider-configs.ts +118 -0
  158. package/server/modules/providers/tests/mcp.test.ts +293 -293
  159. package/server/openai-codex.js +426 -426
  160. package/server/projects.js +2993 -2792
  161. package/server/qwen-code-cli.js +392 -0
  162. package/server/qwen-response-handler.js +73 -0
  163. package/server/routes/agent.js +1245 -1245
  164. package/server/routes/auth.js +134 -134
  165. package/server/routes/codex.js +19 -19
  166. package/server/routes/commands.js +554 -554
  167. package/server/routes/cursor.js +52 -52
  168. package/server/routes/gemini.js +24 -24
  169. package/server/routes/git.js +1488 -1488
  170. package/server/routes/mcp-utils.js +31 -31
  171. package/server/routes/messages.js +61 -61
  172. package/server/routes/network.js +128 -0
  173. package/server/routes/plugins.js +307 -307
  174. package/server/routes/projects.js +795 -627
  175. package/server/routes/qwen.js +27 -0
  176. package/server/routes/settings.js +286 -286
  177. package/server/routes/taskmaster.js +1471 -1471
  178. package/server/routes/telegram.js +125 -0
  179. package/server/routes/user.js +123 -123
  180. package/server/services/external-access.js +240 -0
  181. package/server/services/install-jobs.js +569 -0
  182. package/server/services/notification-orchestrator.js +242 -227
  183. package/server/services/provider-credentials.js +151 -0
  184. package/server/services/provider-models.js +225 -0
  185. package/server/services/telegram/bot.js +280 -0
  186. package/server/services/telegram/translations.js +170 -0
  187. package/server/services/vapid-keys.js +35 -35
  188. package/server/sessionManager.js +225 -225
  189. package/server/shared/interfaces.ts +54 -54
  190. package/server/shared/types.ts +172 -172
  191. package/server/shared/utils.ts +193 -193
  192. package/server/tsconfig.json +36 -36
  193. package/server/utils/colors.js +21 -21
  194. package/server/utils/commandParser.js +303 -303
  195. package/server/utils/frontmatter.js +18 -18
  196. package/server/utils/gitConfig.js +34 -34
  197. package/server/utils/mcp-detector.js +147 -147
  198. package/server/utils/plugin-loader.js +457 -457
  199. package/server/utils/plugin-process-manager.js +184 -184
  200. package/server/utils/port-access.js +209 -0
  201. package/server/utils/runtime-paths.js +37 -37
  202. package/server/utils/taskmaster-websocket.js +128 -128
  203. package/server/utils/url-detection.js +71 -71
  204. package/server/vite-daemon.js +78 -78
  205. package/shared/modelConstants.js +117 -97
  206. package/shared/networkHosts.js +22 -22
  207. package/dist/assets/index-C2c9QNwK.css +0 -32
  208. package/dist/assets/index-DyXDZED-.js +0 -1277
  209. package/dist/assets/vendor-codemirror-NA4v81it.js +0 -41
@@ -1,135 +1,135 @@
1
- import express from 'express';
2
- import bcrypt from 'bcrypt';
3
- import { userDb, db } from '../database/db.js';
4
- import { generateToken, authenticateToken } from '../middleware/auth.js';
5
-
6
- const router = express.Router();
7
-
8
- // Check auth status and setup requirements
9
- router.get('/status', async (req, res) => {
10
- try {
11
- const hasUsers = await userDb.hasUsers();
12
- res.json({
13
- needsSetup: !hasUsers,
14
- isAuthenticated: false // Will be overridden by frontend if token exists
15
- });
16
- } catch (error) {
17
- console.error('Auth status error:', error);
18
- res.status(500).json({ error: 'Internal server error' });
19
- }
20
- });
21
-
22
- // User registration (setup) - only allowed if no users exist
23
- router.post('/register', async (req, res) => {
24
- try {
25
- const { username, password } = req.body;
26
-
27
- // Validate input
28
- if (!username || !password) {
29
- return res.status(400).json({ error: 'Username and password are required' });
30
- }
31
-
32
- if (username.length < 3 || password.length < 6) {
33
- return res.status(400).json({ error: 'Username must be at least 3 characters, password at least 6 characters' });
34
- }
35
-
36
- // Use a transaction to prevent race conditions
37
- db.prepare('BEGIN').run();
38
- try {
39
- // Check if users already exist (only allow one user)
40
- const hasUsers = userDb.hasUsers();
41
- if (hasUsers) {
42
- db.prepare('ROLLBACK').run();
43
- return res.status(403).json({ error: 'User already exists. This is a single-user system.' });
44
- }
45
-
46
- // Hash password
47
- const saltRounds = 12;
48
- const passwordHash = await bcrypt.hash(password, saltRounds);
49
-
50
- // Create user
51
- const user = userDb.createUser(username, passwordHash);
52
-
53
- // Generate token
54
- const token = generateToken(user);
55
-
56
- db.prepare('COMMIT').run();
57
-
58
- // Update last login (non-fatal, outside transaction)
59
- userDb.updateLastLogin(user.id);
60
-
61
- res.json({
62
- success: true,
63
- user: { id: user.id, username: user.username },
64
- token
65
- });
66
- } catch (error) {
67
- db.prepare('ROLLBACK').run();
68
- throw error;
69
- }
70
-
71
- } catch (error) {
72
- console.error('Registration error:', error);
73
- if (error.code === 'SQLITE_CONSTRAINT_UNIQUE') {
74
- res.status(409).json({ error: 'Username already exists' });
75
- } else {
76
- res.status(500).json({ error: 'Internal server error' });
77
- }
78
- }
79
- });
80
-
81
- // User login
82
- router.post('/login', async (req, res) => {
83
- try {
84
- const { username, password } = req.body;
85
-
86
- // Validate input
87
- if (!username || !password) {
88
- return res.status(400).json({ error: 'Username and password are required' });
89
- }
90
-
91
- // Get user from database
92
- const user = userDb.getUserByUsername(username);
93
- if (!user) {
94
- return res.status(401).json({ error: 'Invalid username or password' });
95
- }
96
-
97
- // Verify password
98
- const isValidPassword = await bcrypt.compare(password, user.password_hash);
99
- if (!isValidPassword) {
100
- return res.status(401).json({ error: 'Invalid username or password' });
101
- }
102
-
103
- // Generate token
104
- const token = generateToken(user);
105
-
106
- // Update last login
107
- userDb.updateLastLogin(user.id);
108
-
109
- res.json({
110
- success: true,
111
- user: { id: user.id, username: user.username },
112
- token
113
- });
114
-
115
- } catch (error) {
116
- console.error('Login error:', error);
117
- res.status(500).json({ error: 'Internal server error' });
118
- }
119
- });
120
-
121
- // Get current user (protected route)
122
- router.get('/user', authenticateToken, (req, res) => {
123
- res.json({
124
- user: req.user
125
- });
126
- });
127
-
128
- // Logout (client-side token removal, but this endpoint can be used for logging)
129
- router.post('/logout', authenticateToken, (req, res) => {
130
- // In a simple JWT system, logout is mainly client-side
131
- // This endpoint exists for consistency and potential future logging
132
- res.json({ success: true, message: 'Logged out successfully' });
133
- });
134
-
1
+ import express from 'express';
2
+ import bcrypt from 'bcrypt';
3
+ import { userDb, db } from '../database/db.js';
4
+ import { generateToken, authenticateToken } from '../middleware/auth.js';
5
+
6
+ const router = express.Router();
7
+
8
+ // Check auth status and setup requirements
9
+ router.get('/status', async (req, res) => {
10
+ try {
11
+ const hasUsers = await userDb.hasUsers();
12
+ res.json({
13
+ needsSetup: !hasUsers,
14
+ isAuthenticated: false // Will be overridden by frontend if token exists
15
+ });
16
+ } catch (error) {
17
+ console.error('Auth status error:', error);
18
+ res.status(500).json({ error: 'Internal server error' });
19
+ }
20
+ });
21
+
22
+ // User registration (setup) - only allowed if no users exist
23
+ router.post('/register', async (req, res) => {
24
+ try {
25
+ const { username, password } = req.body;
26
+
27
+ // Validate input
28
+ if (!username || !password) {
29
+ return res.status(400).json({ error: 'Username and password are required' });
30
+ }
31
+
32
+ if (username.length < 3 || password.length < 6) {
33
+ return res.status(400).json({ error: 'Username must be at least 3 characters, password at least 6 characters' });
34
+ }
35
+
36
+ // Use a transaction to prevent race conditions
37
+ db.prepare('BEGIN').run();
38
+ try {
39
+ // Check if users already exist (only allow one user)
40
+ const hasUsers = userDb.hasUsers();
41
+ if (hasUsers) {
42
+ db.prepare('ROLLBACK').run();
43
+ return res.status(403).json({ error: 'User already exists. This is a single-user system.' });
44
+ }
45
+
46
+ // Hash password
47
+ const saltRounds = 12;
48
+ const passwordHash = await bcrypt.hash(password, saltRounds);
49
+
50
+ // Create user
51
+ const user = userDb.createUser(username, passwordHash);
52
+
53
+ // Generate token
54
+ const token = generateToken(user);
55
+
56
+ db.prepare('COMMIT').run();
57
+
58
+ // Update last login (non-fatal, outside transaction)
59
+ userDb.updateLastLogin(user.id);
60
+
61
+ res.json({
62
+ success: true,
63
+ user: { id: user.id, username: user.username },
64
+ token
65
+ });
66
+ } catch (error) {
67
+ db.prepare('ROLLBACK').run();
68
+ throw error;
69
+ }
70
+
71
+ } catch (error) {
72
+ console.error('Registration error:', error);
73
+ if (error.code === 'SQLITE_CONSTRAINT_UNIQUE') {
74
+ res.status(409).json({ error: 'Username already exists' });
75
+ } else {
76
+ res.status(500).json({ error: 'Internal server error' });
77
+ }
78
+ }
79
+ });
80
+
81
+ // User login
82
+ router.post('/login', async (req, res) => {
83
+ try {
84
+ const { username, password } = req.body;
85
+
86
+ // Validate input
87
+ if (!username || !password) {
88
+ return res.status(400).json({ error: 'Username and password are required' });
89
+ }
90
+
91
+ // Get user from database
92
+ const user = userDb.getUserByUsername(username);
93
+ if (!user) {
94
+ return res.status(401).json({ error: 'Invalid username or password' });
95
+ }
96
+
97
+ // Verify password
98
+ const isValidPassword = await bcrypt.compare(password, user.password_hash);
99
+ if (!isValidPassword) {
100
+ return res.status(401).json({ error: 'Invalid username or password' });
101
+ }
102
+
103
+ // Generate token
104
+ const token = generateToken(user);
105
+
106
+ // Update last login
107
+ userDb.updateLastLogin(user.id);
108
+
109
+ res.json({
110
+ success: true,
111
+ user: { id: user.id, username: user.username },
112
+ token
113
+ });
114
+
115
+ } catch (error) {
116
+ console.error('Login error:', error);
117
+ res.status(500).json({ error: 'Internal server error' });
118
+ }
119
+ });
120
+
121
+ // Get current user (protected route)
122
+ router.get('/user', authenticateToken, (req, res) => {
123
+ res.json({
124
+ user: req.user
125
+ });
126
+ });
127
+
128
+ // Logout (client-side token removal, but this endpoint can be used for logging)
129
+ router.post('/logout', authenticateToken, (req, res) => {
130
+ // In a simple JWT system, logout is mainly client-side
131
+ // This endpoint exists for consistency and potential future logging
132
+ res.json({ success: true, message: 'Logged out successfully' });
133
+ });
134
+
135
135
  export default router;
@@ -1,19 +1,19 @@
1
- import express from 'express';
2
- import { deleteCodexSession } from '../projects.js';
3
- import { sessionNamesDb } from '../database/db.js';
4
-
5
- const router = express.Router();
6
-
7
- router.delete('/sessions/:sessionId', async (req, res) => {
8
- try {
9
- const { sessionId } = req.params;
10
- await deleteCodexSession(sessionId);
11
- sessionNamesDb.deleteName(sessionId, 'codex');
12
- res.json({ success: true });
13
- } catch (error) {
14
- console.error(`Error deleting Codex session ${req.params.sessionId}:`, error);
15
- res.status(500).json({ success: false, error: error.message });
16
- }
17
- });
18
-
19
- export default router;
1
+ import express from 'express';
2
+ import { deleteCodexSession } from '../projects.js';
3
+ import { sessionNamesDb } from '../database/db.js';
4
+
5
+ const router = express.Router();
6
+
7
+ router.delete('/sessions/:sessionId', async (req, res) => {
8
+ try {
9
+ const { sessionId } = req.params;
10
+ await deleteCodexSession(sessionId);
11
+ sessionNamesDb.deleteName(sessionId, 'codex');
12
+ res.json({ success: true });
13
+ } catch (error) {
14
+ console.error(`Error deleting Codex session ${req.params.sessionId}:`, error);
15
+ res.status(500).json({ success: false, error: error.message });
16
+ }
17
+ });
18
+
19
+ export default router;