cowork-os 0.3.21 → 0.3.23

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 (170) hide show
  1. package/README.md +293 -6
  2. package/connectors/README.md +20 -0
  3. package/connectors/asana-mcp/README.md +24 -0
  4. package/connectors/asana-mcp/dist/index.js +427 -0
  5. package/connectors/asana-mcp/package.json +15 -0
  6. package/connectors/asana-mcp/src/index.ts +553 -0
  7. package/connectors/asana-mcp/tsconfig.json +13 -0
  8. package/connectors/hubspot-mcp/README.md +35 -0
  9. package/connectors/hubspot-mcp/dist/index.js +454 -0
  10. package/connectors/hubspot-mcp/package.json +15 -0
  11. package/connectors/hubspot-mcp/src/index.ts +562 -0
  12. package/connectors/hubspot-mcp/tsconfig.json +13 -0
  13. package/connectors/jira-mcp/README.md +49 -0
  14. package/connectors/jira-mcp/dist/index.js +588 -0
  15. package/connectors/jira-mcp/package.json +15 -0
  16. package/connectors/jira-mcp/src/index.ts +711 -0
  17. package/connectors/jira-mcp/tsconfig.json +13 -0
  18. package/connectors/linear-mcp/README.md +22 -0
  19. package/connectors/linear-mcp/dist/index.js +402 -0
  20. package/connectors/linear-mcp/package.json +15 -0
  21. package/connectors/linear-mcp/src/index.ts +522 -0
  22. package/connectors/linear-mcp/tsconfig.json +13 -0
  23. package/connectors/okta-mcp/README.md +24 -0
  24. package/connectors/okta-mcp/dist/index.js +411 -0
  25. package/connectors/okta-mcp/package.json +15 -0
  26. package/connectors/okta-mcp/src/index.ts +520 -0
  27. package/connectors/okta-mcp/tsconfig.json +13 -0
  28. package/connectors/salesforce-mcp/README.md +47 -0
  29. package/connectors/salesforce-mcp/dist/index.js +584 -0
  30. package/connectors/salesforce-mcp/package.json +15 -0
  31. package/connectors/salesforce-mcp/src/index.ts +722 -0
  32. package/connectors/salesforce-mcp/tsconfig.json +13 -0
  33. package/connectors/servicenow-mcp/README.md +26 -0
  34. package/connectors/servicenow-mcp/dist/index.js +400 -0
  35. package/connectors/servicenow-mcp/package.json +15 -0
  36. package/connectors/servicenow-mcp/src/index.ts +500 -0
  37. package/connectors/servicenow-mcp/tsconfig.json +13 -0
  38. package/connectors/templates/mcp-connector/README.md +31 -0
  39. package/connectors/templates/mcp-connector/package.json +15 -0
  40. package/connectors/templates/mcp-connector/src/index.ts +330 -0
  41. package/connectors/templates/mcp-connector/tsconfig.json +13 -0
  42. package/connectors/zendesk-mcp/README.md +40 -0
  43. package/connectors/zendesk-mcp/dist/index.js +431 -0
  44. package/connectors/zendesk-mcp/package.json +15 -0
  45. package/connectors/zendesk-mcp/src/index.ts +543 -0
  46. package/connectors/zendesk-mcp/tsconfig.json +13 -0
  47. package/dist/electron/electron/agent/daemon.js +25 -0
  48. package/dist/electron/electron/agent/executor.js +181 -26
  49. package/dist/electron/electron/agent/llm/anthropic-compatible-provider.js +177 -0
  50. package/dist/electron/electron/agent/llm/github-copilot-provider.js +97 -0
  51. package/dist/electron/electron/agent/llm/groq-provider.js +33 -0
  52. package/dist/electron/electron/agent/llm/index.js +11 -1
  53. package/dist/electron/electron/agent/llm/kimi-provider.js +33 -0
  54. package/dist/electron/electron/agent/llm/openai-compatible-provider.js +116 -0
  55. package/dist/electron/electron/agent/llm/openai-compatible.js +111 -0
  56. package/dist/electron/electron/agent/llm/openai-oauth.js +2 -1
  57. package/dist/electron/electron/agent/llm/openrouter-provider.js +1 -1
  58. package/dist/electron/electron/agent/llm/provider-factory.js +318 -4
  59. package/dist/electron/electron/agent/llm/types.js +66 -1
  60. package/dist/electron/electron/agent/llm/xai-provider.js +33 -0
  61. package/dist/electron/electron/agent/tools/box-tools.js +231 -0
  62. package/dist/electron/electron/agent/tools/builtin-settings.js +28 -0
  63. package/dist/electron/electron/agent/tools/dropbox-tools.js +237 -0
  64. package/dist/electron/electron/agent/tools/google-drive-tools.js +227 -0
  65. package/dist/electron/electron/agent/tools/notion-tools.js +312 -0
  66. package/dist/electron/electron/agent/tools/onedrive-tools.js +217 -0
  67. package/dist/electron/electron/agent/tools/registry.js +541 -0
  68. package/dist/electron/electron/agent/tools/sharepoint-tools.js +243 -0
  69. package/dist/electron/electron/agent/tools/shell-tools.js +12 -3
  70. package/dist/electron/electron/agent/tools/x-tools.js +1 -1
  71. package/dist/electron/electron/gateway/index.js +1 -0
  72. package/dist/electron/electron/gateway/router.js +123 -143
  73. package/dist/electron/electron/ipc/canvas-handlers.js +5 -0
  74. package/dist/electron/electron/ipc/handlers.js +627 -158
  75. package/dist/electron/electron/main.js +63 -0
  76. package/dist/electron/electron/mcp/oauth/connector-oauth.js +333 -0
  77. package/dist/electron/electron/mcp/registry/MCPRegistryManager.js +503 -154
  78. package/dist/electron/electron/memory/MemoryService.js +1 -1
  79. package/dist/electron/electron/preload.js +74 -1
  80. package/dist/electron/electron/settings/box-manager.js +54 -0
  81. package/dist/electron/electron/settings/dropbox-manager.js +54 -0
  82. package/dist/electron/electron/settings/google-drive-manager.js +54 -0
  83. package/dist/electron/electron/settings/notion-manager.js +56 -0
  84. package/dist/electron/electron/settings/onedrive-manager.js +54 -0
  85. package/dist/electron/electron/settings/sharepoint-manager.js +54 -0
  86. package/dist/electron/electron/utils/box-api.js +153 -0
  87. package/dist/electron/electron/utils/dropbox-api.js +144 -0
  88. package/dist/electron/electron/utils/env-migration.js +19 -0
  89. package/dist/electron/electron/utils/google-drive-api.js +152 -0
  90. package/dist/electron/electron/utils/notion-api.js +103 -0
  91. package/dist/electron/electron/utils/onedrive-api.js +113 -0
  92. package/dist/electron/electron/utils/sharepoint-api.js +109 -0
  93. package/dist/electron/electron/utils/validation.js +82 -3
  94. package/dist/electron/electron/utils/x-cli.js +1 -1
  95. package/dist/electron/shared/channelMessages.js +284 -3
  96. package/dist/electron/shared/llm-provider-catalog.js +198 -0
  97. package/dist/electron/shared/types.js +88 -1
  98. package/package.json +12 -2
  99. package/src/electron/agent/executor.ts +205 -28
  100. package/src/electron/agent/llm/anthropic-compatible-provider.ts +214 -0
  101. package/src/electron/agent/llm/github-copilot-provider.ts +117 -0
  102. package/src/electron/agent/llm/groq-provider.ts +39 -0
  103. package/src/electron/agent/llm/index.ts +5 -0
  104. package/src/electron/agent/llm/kimi-provider.ts +39 -0
  105. package/src/electron/agent/llm/openai-compatible-provider.ts +153 -0
  106. package/src/electron/agent/llm/openai-compatible.ts +133 -0
  107. package/src/electron/agent/llm/openai-oauth.ts +2 -1
  108. package/src/electron/agent/llm/openrouter-provider.ts +2 -1
  109. package/src/electron/agent/llm/provider-factory.ts +414 -6
  110. package/src/electron/agent/llm/types.ts +90 -1
  111. package/src/electron/agent/llm/xai-provider.ts +39 -0
  112. package/src/electron/agent/tools/box-tools.ts +239 -0
  113. package/src/electron/agent/tools/builtin-settings.ts +34 -0
  114. package/src/electron/agent/tools/dropbox-tools.ts +237 -0
  115. package/src/electron/agent/tools/google-drive-tools.ts +228 -0
  116. package/src/electron/agent/tools/notion-tools.ts +330 -0
  117. package/src/electron/agent/tools/onedrive-tools.ts +217 -0
  118. package/src/electron/agent/tools/registry.ts +565 -0
  119. package/src/electron/agent/tools/sharepoint-tools.ts +247 -0
  120. package/src/electron/agent/tools/shell-tools.ts +11 -3
  121. package/src/electron/agent/tools/x-tools.ts +1 -1
  122. package/src/electron/database/SecureSettingsRepository.ts +7 -1
  123. package/src/electron/gateway/index.ts +1 -0
  124. package/src/electron/gateway/router.ts +134 -149
  125. package/src/electron/ipc/canvas-handlers.ts +10 -0
  126. package/src/electron/ipc/handlers.ts +673 -153
  127. package/src/electron/main.ts +35 -0
  128. package/src/electron/mcp/oauth/connector-oauth.ts +448 -0
  129. package/src/electron/mcp/registry/MCPRegistryManager.ts +343 -12
  130. package/src/electron/memory/MemoryService.ts +5 -1
  131. package/src/electron/preload.ts +167 -4
  132. package/src/electron/settings/box-manager.ts +58 -0
  133. package/src/electron/settings/dropbox-manager.ts +58 -0
  134. package/src/electron/settings/google-drive-manager.ts +58 -0
  135. package/src/electron/settings/notion-manager.ts +60 -0
  136. package/src/electron/settings/onedrive-manager.ts +58 -0
  137. package/src/electron/settings/sharepoint-manager.ts +58 -0
  138. package/src/electron/utils/box-api.ts +184 -0
  139. package/src/electron/utils/dropbox-api.ts +171 -0
  140. package/src/electron/utils/env-migration.ts +22 -0
  141. package/src/electron/utils/google-drive-api.ts +183 -0
  142. package/src/electron/utils/notion-api.ts +126 -0
  143. package/src/electron/utils/onedrive-api.ts +137 -0
  144. package/src/electron/utils/sharepoint-api.ts +132 -0
  145. package/src/electron/utils/validation.ts +102 -1
  146. package/src/electron/utils/x-cli.ts +1 -1
  147. package/src/renderer/App.tsx +20 -2
  148. package/src/renderer/components/BoxSettings.tsx +203 -0
  149. package/src/renderer/components/BrowserView.tsx +101 -0
  150. package/src/renderer/components/BuiltinToolsSettings.tsx +105 -0
  151. package/src/renderer/components/CanvasPreview.tsx +68 -1
  152. package/src/renderer/components/ConnectorEnvModal.tsx +116 -0
  153. package/src/renderer/components/ConnectorSetupModal.tsx +566 -0
  154. package/src/renderer/components/ConnectorsSettings.tsx +397 -0
  155. package/src/renderer/components/DropboxSettings.tsx +202 -0
  156. package/src/renderer/components/GoogleDriveSettings.tsx +201 -0
  157. package/src/renderer/components/MCPSettings.tsx +56 -0
  158. package/src/renderer/components/MainContent.tsx +270 -34
  159. package/src/renderer/components/NotionSettings.tsx +231 -0
  160. package/src/renderer/components/Onboarding/Onboarding.tsx +13 -1
  161. package/src/renderer/components/OnboardingModal.tsx +70 -1
  162. package/src/renderer/components/OneDriveSettings.tsx +212 -0
  163. package/src/renderer/components/Settings.tsx +611 -8
  164. package/src/renderer/components/SharePointSettings.tsx +224 -0
  165. package/src/renderer/components/Sidebar.tsx +25 -9
  166. package/src/renderer/hooks/useOnboardingFlow.ts +21 -0
  167. package/src/renderer/styles/index.css +438 -25
  168. package/src/shared/channelMessages.ts +367 -4
  169. package/src/shared/llm-provider-catalog.ts +217 -0
  170. package/src/shared/types.ts +226 -1
@@ -0,0 +1,217 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ import { Workspace } from '../../../shared/types';
4
+ import { AgentDaemon } from '../daemon';
5
+ import { OneDriveSettingsManager } from '../../settings/onedrive-manager';
6
+ import { onedriveRequest } from '../../utils/onedrive-api';
7
+
8
+ type OneDriveAction =
9
+ | 'get_drive'
10
+ | 'search'
11
+ | 'list_children'
12
+ | 'get_item'
13
+ | 'create_folder'
14
+ | 'upload_file'
15
+ | 'delete_item';
16
+
17
+ interface OneDriveActionInput {
18
+ action: OneDriveAction;
19
+ drive_id?: string;
20
+ item_id?: string;
21
+ query?: string;
22
+ parent_id?: string;
23
+ name?: string;
24
+ conflict_behavior?: 'rename' | 'fail' | 'replace';
25
+ file_path?: string;
26
+ remote_path?: string;
27
+ }
28
+
29
+ export class OneDriveTools {
30
+ constructor(
31
+ private workspace: Workspace,
32
+ private daemon: AgentDaemon,
33
+ private taskId: string
34
+ ) {}
35
+
36
+ setWorkspace(workspace: Workspace): void {
37
+ this.workspace = workspace;
38
+ }
39
+
40
+ static isEnabled(): boolean {
41
+ return OneDriveSettingsManager.loadSettings().enabled;
42
+ }
43
+
44
+ private async requireApproval(summary: string, details: Record<string, unknown>): Promise<void> {
45
+ const approved = await this.daemon.requestApproval(
46
+ this.taskId,
47
+ 'external_service',
48
+ summary,
49
+ details
50
+ );
51
+
52
+ if (!approved) {
53
+ throw new Error('User denied OneDrive action');
54
+ }
55
+ }
56
+
57
+ private resolveFilePath(inputPath: string): string {
58
+ if (!this.workspace.permissions.read) {
59
+ throw new Error('Read permission not granted for uploads');
60
+ }
61
+
62
+ const workspaceRoot = path.resolve(this.workspace.path);
63
+ const allowedPaths = this.workspace.permissions.allowedPaths || [];
64
+ const canReadOutside = this.workspace.isTemp || this.workspace.permissions.unrestrictedFileAccess;
65
+
66
+ const isPathAllowed = (absolutePath: string): boolean => {
67
+ if (allowedPaths.length === 0) return false;
68
+ const normalizedPath = path.normalize(absolutePath);
69
+ return allowedPaths.some((allowed) => {
70
+ const normalizedAllowed = path.normalize(allowed);
71
+ return normalizedPath === normalizedAllowed || normalizedPath.startsWith(normalizedAllowed + path.sep);
72
+ });
73
+ };
74
+
75
+ const candidate = path.isAbsolute(inputPath)
76
+ ? path.normalize(inputPath)
77
+ : path.resolve(workspaceRoot, inputPath);
78
+
79
+ const relative = path.relative(workspaceRoot, candidate);
80
+ const isInsideWorkspace = !(relative.startsWith('..') || path.isAbsolute(relative));
81
+ if (!isInsideWorkspace && !canReadOutside && !isPathAllowed(candidate)) {
82
+ throw new Error('File path must be inside the workspace or in Allowed Paths');
83
+ }
84
+ if (!fs.existsSync(candidate)) {
85
+ throw new Error(`File not found: ${inputPath}`);
86
+ }
87
+ const stats = fs.statSync(candidate);
88
+ if (!stats.isFile()) {
89
+ throw new Error(`Path is not a file: ${inputPath}`);
90
+ }
91
+ return candidate;
92
+ }
93
+
94
+ private getDrivePrefix(inputDriveId?: string): string {
95
+ const settingsDriveId = OneDriveSettingsManager.loadSettings().driveId;
96
+ const driveId = inputDriveId || settingsDriveId;
97
+ return driveId ? `/drives/${driveId}` : '/me/drive';
98
+ }
99
+
100
+ async executeAction(input: OneDriveActionInput): Promise<any> {
101
+ const settings = OneDriveSettingsManager.loadSettings();
102
+ if (!settings.enabled) {
103
+ throw new Error('OneDrive integration is disabled. Enable it in Settings > Integrations > OneDrive.');
104
+ }
105
+
106
+ const action = input.action;
107
+ if (!action) {
108
+ throw new Error('Missing required "action" parameter');
109
+ }
110
+
111
+ let result;
112
+ const drivePrefix = this.getDrivePrefix(input.drive_id);
113
+
114
+ switch (action) {
115
+ case 'get_drive': {
116
+ result = await onedriveRequest(settings, { method: 'GET', path: drivePrefix });
117
+ break;
118
+ }
119
+ case 'search': {
120
+ if (!input.query) throw new Error('Missing query for search');
121
+ const escaped = input.query.replace(/'/g, "''");
122
+ result = await onedriveRequest(settings, { method: 'GET', path: `${drivePrefix}/root/search(q='${escaped}')` });
123
+ break;
124
+ }
125
+ case 'list_children': {
126
+ const pathSuffix = input.item_id
127
+ ? `/items/${input.item_id}/children`
128
+ : '/root/children';
129
+ result = await onedriveRequest(settings, { method: 'GET', path: `${drivePrefix}${pathSuffix}` });
130
+ break;
131
+ }
132
+ case 'get_item': {
133
+ if (!input.item_id) throw new Error('Missing item_id for get_item');
134
+ result = await onedriveRequest(settings, { method: 'GET', path: `${drivePrefix}/items/${input.item_id}` });
135
+ break;
136
+ }
137
+ case 'create_folder': {
138
+ if (!input.name) throw new Error('Missing name for create_folder');
139
+ const parentPath = input.parent_id
140
+ ? `/items/${input.parent_id}/children`
141
+ : '/root/children';
142
+ await this.requireApproval('Create a OneDrive folder', {
143
+ action: 'create_folder',
144
+ parent_id: input.parent_id || 'root',
145
+ name: input.name,
146
+ });
147
+ result = await onedriveRequest(settings, {
148
+ method: 'POST',
149
+ path: `${drivePrefix}${parentPath}`,
150
+ body: {
151
+ name: input.name,
152
+ folder: {},
153
+ '@microsoft.graph.conflictBehavior': input.conflict_behavior || 'rename',
154
+ },
155
+ });
156
+ break;
157
+ }
158
+ case 'upload_file': {
159
+ if (!input.file_path) throw new Error('Missing file_path for upload_file');
160
+ const resolved = this.resolveFilePath(input.file_path);
161
+ const data = fs.readFileSync(resolved);
162
+ const fileName = input.name || path.basename(resolved);
163
+ let uploadPath: string;
164
+ if (input.remote_path) {
165
+ const cleaned = input.remote_path.replace(/^\/+/, '');
166
+ const encoded = cleaned
167
+ .split('/')
168
+ .map(segment => encodeURIComponent(segment))
169
+ .join('/');
170
+ uploadPath = `${drivePrefix}/root:/${encoded}:/content`;
171
+ } else if (input.parent_id) {
172
+ uploadPath = `${drivePrefix}/items/${input.parent_id}:/${encodeURIComponent(fileName)}:/content`;
173
+ } else {
174
+ uploadPath = `${drivePrefix}/root:/${encodeURIComponent(fileName)}:/content`;
175
+ }
176
+ await this.requireApproval(`Upload file to OneDrive: ${fileName}`, {
177
+ action: 'upload_file',
178
+ destination: input.remote_path || input.parent_id || 'root',
179
+ file: fileName,
180
+ });
181
+ result = await onedriveRequest(settings, {
182
+ method: 'PUT',
183
+ path: uploadPath,
184
+ body: data,
185
+ headers: { 'Content-Type': 'application/octet-stream' },
186
+ });
187
+ break;
188
+ }
189
+ case 'delete_item': {
190
+ if (!input.item_id) throw new Error('Missing item_id for delete_item');
191
+ await this.requireApproval('Delete a OneDrive item', {
192
+ action: 'delete_item',
193
+ item_id: input.item_id,
194
+ });
195
+ result = await onedriveRequest(settings, { method: 'DELETE', path: `${drivePrefix}/items/${input.item_id}` });
196
+ break;
197
+ }
198
+ default:
199
+ throw new Error(`Unsupported action: ${action}`);
200
+ }
201
+
202
+ this.daemon.logEvent(this.taskId, 'tool_result', {
203
+ tool: 'onedrive_action',
204
+ action,
205
+ status: result?.status,
206
+ hasData: result?.data ? true : false,
207
+ });
208
+
209
+ return {
210
+ success: true,
211
+ action,
212
+ status: result?.status,
213
+ data: result?.data,
214
+ raw: result?.raw,
215
+ };
216
+ }
217
+ }