@stardust-bytes/agent-hub 0.1.0
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/README.md +184 -0
- package/backend/.env.example +26 -0
- package/backend/dist/agent/agent.controller.d.ts +23 -0
- package/backend/dist/agent/agent.controller.js +114 -0
- package/backend/dist/agent/agent.controller.js.map +1 -0
- package/backend/dist/agent/agent.module.d.ts +2 -0
- package/backend/dist/agent/agent.module.js +128 -0
- package/backend/dist/agent/agent.module.js.map +1 -0
- package/backend/dist/agent/agent.service.d.ts +25 -0
- package/backend/dist/agent/agent.service.js +198 -0
- package/backend/dist/agent/agent.service.js.map +1 -0
- package/backend/dist/agent/dto/agent-action.dto.d.ts +10 -0
- package/backend/dist/agent/dto/agent-action.dto.js +73 -0
- package/backend/dist/agent/dto/agent-action.dto.js.map +1 -0
- package/backend/dist/agent/dto/agent-command.util.d.ts +4 -0
- package/backend/dist/agent/dto/agent-command.util.js +13 -0
- package/backend/dist/agent/dto/agent-command.util.js.map +1 -0
- package/backend/dist/agent/dto/agent-run-state.d.ts +21 -0
- package/backend/dist/agent/dto/agent-run-state.js +19 -0
- package/backend/dist/agent/dto/agent-run-state.js.map +1 -0
- package/backend/dist/agent/dto/agent-state.enum.d.ts +6 -0
- package/backend/dist/agent/dto/agent-state.enum.js +11 -0
- package/backend/dist/agent/dto/agent-state.enum.js.map +1 -0
- package/backend/dist/agent/dto/approve-tool.dto.d.ts +4 -0
- package/backend/dist/agent/dto/approve-tool.dto.js +25 -0
- package/backend/dist/agent/dto/approve-tool.dto.js.map +1 -0
- package/backend/dist/agent/dto/chat.dto.d.ts +6 -0
- package/backend/dist/agent/dto/chat.dto.js +35 -0
- package/backend/dist/agent/dto/chat.dto.js.map +1 -0
- package/backend/dist/agent/dto/execute-plan.dto.d.ts +4 -0
- package/backend/dist/agent/dto/execute-plan.dto.js +25 -0
- package/backend/dist/agent/dto/execute-plan.dto.js.map +1 -0
- package/backend/dist/agent/dto/permissions-config.d.ts +8 -0
- package/backend/dist/agent/dto/permissions-config.js +11 -0
- package/backend/dist/agent/dto/permissions-config.js.map +1 -0
- package/backend/dist/agent/dto/update-permissions.dto.d.ts +7 -0
- package/backend/dist/agent/dto/update-permissions.dto.js +46 -0
- package/backend/dist/agent/dto/update-permissions.dto.js.map +1 -0
- package/backend/dist/agent/dto/write-stream.interface.d.ts +3 -0
- package/backend/dist/agent/dto/write-stream.interface.js +3 -0
- package/backend/dist/agent/dto/write-stream.interface.js.map +1 -0
- package/backend/dist/agent/dto/yolo-config.dto.d.ts +5 -0
- package/backend/dist/agent/dto/yolo-config.dto.js +33 -0
- package/backend/dist/agent/dto/yolo-config.dto.js.map +1 -0
- package/backend/dist/agent/mcp/mcp-client.service.d.ts +15 -0
- package/backend/dist/agent/mcp/mcp-client.service.js +71 -0
- package/backend/dist/agent/mcp/mcp-client.service.js.map +1 -0
- package/backend/dist/agent/mcp/mcp.module.d.ts +2 -0
- package/backend/dist/agent/mcp/mcp.module.js +24 -0
- package/backend/dist/agent/mcp/mcp.module.js.map +1 -0
- package/backend/dist/agent/mcp/mcp.service.d.ts +23 -0
- package/backend/dist/agent/mcp/mcp.service.js +123 -0
- package/backend/dist/agent/mcp/mcp.service.js.map +1 -0
- package/backend/dist/agent/providers/llm-provider.interface.d.ts +41 -0
- package/backend/dist/agent/providers/llm-provider.interface.js +3 -0
- package/backend/dist/agent/providers/llm-provider.interface.js.map +1 -0
- package/backend/dist/agent/providers/ollama.provider.d.ts +5 -0
- package/backend/dist/agent/providers/ollama.provider.js +92 -0
- package/backend/dist/agent/providers/ollama.provider.js.map +1 -0
- package/backend/dist/agent/providers/openai.provider.d.ts +5 -0
- package/backend/dist/agent/providers/openai.provider.js +169 -0
- package/backend/dist/agent/providers/openai.provider.js.map +1 -0
- package/backend/dist/agent/services/agent-loop.service.d.ts +131 -0
- package/backend/dist/agent/services/agent-loop.service.js +764 -0
- package/backend/dist/agent/services/agent-loop.service.js.map +1 -0
- package/backend/dist/agent/services/approval-manager.service.d.ts +8 -0
- package/backend/dist/agent/services/approval-manager.service.js +50 -0
- package/backend/dist/agent/services/approval-manager.service.js.map +1 -0
- package/backend/dist/agent/services/context-builder.service.d.ts +32 -0
- package/backend/dist/agent/services/context-builder.service.js +118 -0
- package/backend/dist/agent/services/context-builder.service.js.map +1 -0
- package/backend/dist/agent/services/danger-patterns.config.d.ts +10 -0
- package/backend/dist/agent/services/danger-patterns.config.js +82 -0
- package/backend/dist/agent/services/danger-patterns.config.js.map +1 -0
- package/backend/dist/agent/services/denial-tracking.d.ts +12 -0
- package/backend/dist/agent/services/denial-tracking.js +34 -0
- package/backend/dist/agent/services/denial-tracking.js.map +1 -0
- package/backend/dist/agent/services/llm-controller.service.d.ts +19 -0
- package/backend/dist/agent/services/llm-controller.service.js +70 -0
- package/backend/dist/agent/services/llm-controller.service.js.map +1 -0
- package/backend/dist/agent/services/permissions.service.d.ts +24 -0
- package/backend/dist/agent/services/permissions.service.js +106 -0
- package/backend/dist/agent/services/permissions.service.js.map +1 -0
- package/backend/dist/agent/services/yolo-classifier.constants.d.ts +6 -0
- package/backend/dist/agent/services/yolo-classifier.constants.js +39 -0
- package/backend/dist/agent/services/yolo-classifier.constants.js.map +1 -0
- package/backend/dist/agent/services/yolo-classifier.service.d.ts +29 -0
- package/backend/dist/agent/services/yolo-classifier.service.js +139 -0
- package/backend/dist/agent/services/yolo-classifier.service.js.map +1 -0
- package/backend/dist/agent/subagent/subagent-tools.util.d.ts +3 -0
- package/backend/dist/agent/subagent/subagent-tools.util.js +37 -0
- package/backend/dist/agent/subagent/subagent-tools.util.js.map +1 -0
- package/backend/dist/agent/subagent/subagent.service.d.ts +17 -0
- package/backend/dist/agent/subagent/subagent.service.js +89 -0
- package/backend/dist/agent/subagent/subagent.service.js.map +1 -0
- package/backend/dist/agent-output/agent-output.controller.d.ts +20 -0
- package/backend/dist/agent-output/agent-output.controller.js +123 -0
- package/backend/dist/agent-output/agent-output.controller.js.map +1 -0
- package/backend/dist/agent-output/agent-output.module.d.ts +2 -0
- package/backend/dist/agent-output/agent-output.module.js +22 -0
- package/backend/dist/agent-output/agent-output.module.js.map +1 -0
- package/backend/dist/agent-profiles/agent-profiles.controller.d.ts +59 -0
- package/backend/dist/agent-profiles/agent-profiles.controller.js +70 -0
- package/backend/dist/agent-profiles/agent-profiles.controller.js.map +1 -0
- package/backend/dist/agent-profiles/agent-profiles.module.d.ts +2 -0
- package/backend/dist/agent-profiles/agent-profiles.module.js +23 -0
- package/backend/dist/agent-profiles/agent-profiles.module.js.map +1 -0
- package/backend/dist/agent-profiles/agent-profiles.service.d.ts +85 -0
- package/backend/dist/agent-profiles/agent-profiles.service.js +48 -0
- package/backend/dist/agent-profiles/agent-profiles.service.js.map +1 -0
- package/backend/dist/agent-profiles/dto/create-agent-profile.dto.d.ts +9 -0
- package/backend/dist/agent-profiles/dto/create-agent-profile.dto.js +52 -0
- package/backend/dist/agent-profiles/dto/create-agent-profile.dto.js.map +1 -0
- package/backend/dist/agent-profiles/dto/update-agent-profile.dto.d.ts +5 -0
- package/backend/dist/agent-profiles/dto/update-agent-profile.dto.js +9 -0
- package/backend/dist/agent-profiles/dto/update-agent-profile.dto.js.map +1 -0
- package/backend/dist/app.controller.d.ts +10 -0
- package/backend/dist/app.controller.js +39 -0
- package/backend/dist/app.controller.js.map +1 -0
- package/backend/dist/app.module.d.ts +2 -0
- package/backend/dist/app.module.js +68 -0
- package/backend/dist/app.module.js.map +1 -0
- package/backend/dist/connector/connector.controller.d.ts +67 -0
- package/backend/dist/connector/connector.controller.js +150 -0
- package/backend/dist/connector/connector.controller.js.map +1 -0
- package/backend/dist/connector/connector.module.d.ts +2 -0
- package/backend/dist/connector/connector.module.js +28 -0
- package/backend/dist/connector/connector.module.js.map +1 -0
- package/backend/dist/connector/connector.service.d.ts +61 -0
- package/backend/dist/connector/connector.service.js +63 -0
- package/backend/dist/connector/connector.service.js.map +1 -0
- package/backend/dist/connector/dto/oauth-confirm.dto.d.ts +4 -0
- package/backend/dist/connector/dto/oauth-confirm.dto.js +25 -0
- package/backend/dist/connector/dto/oauth-confirm.dto.js.map +1 -0
- package/backend/dist/connector/dto/update-connector.dto.d.ts +5 -0
- package/backend/dist/connector/dto/update-connector.dto.js +9 -0
- package/backend/dist/connector/dto/update-connector.dto.js.map +1 -0
- package/backend/dist/connector/dto/upsert-connector.dto.d.ts +6 -0
- package/backend/dist/connector/dto/upsert-connector.dto.js +35 -0
- package/backend/dist/connector/dto/upsert-connector.dto.js.map +1 -0
- package/backend/dist/connector/providers/google/gmail.service.d.ts +31 -0
- package/backend/dist/connector/providers/google/gmail.service.js +114 -0
- package/backend/dist/connector/providers/google/gmail.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-calendar.service.d.ts +37 -0
- package/backend/dist/connector/providers/google/google-calendar.service.js +105 -0
- package/backend/dist/connector/providers/google/google-calendar.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-drive.service.d.ts +22 -0
- package/backend/dist/connector/providers/google/google-drive.service.js +130 -0
- package/backend/dist/connector/providers/google/google-drive.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-oauth.service.d.ts +23 -0
- package/backend/dist/connector/providers/google/google-oauth.service.js +74 -0
- package/backend/dist/connector/providers/google/google-oauth.service.js.map +1 -0
- package/backend/dist/connector/providers/google/google-sheets.service.d.ts +29 -0
- package/backend/dist/connector/providers/google/google-sheets.service.js +246 -0
- package/backend/dist/connector/providers/google/google-sheets.service.js.map +1 -0
- package/backend/dist/cowork/cowork.controller.d.ts +37 -0
- package/backend/dist/cowork/cowork.controller.js +127 -0
- package/backend/dist/cowork/cowork.controller.js.map +1 -0
- package/backend/dist/cowork/cowork.module.d.ts +2 -0
- package/backend/dist/cowork/cowork.module.js +26 -0
- package/backend/dist/cowork/cowork.module.js.map +1 -0
- package/backend/dist/cowork/cowork.service.d.ts +40 -0
- package/backend/dist/cowork/cowork.service.js +116 -0
- package/backend/dist/cowork/cowork.service.js.map +1 -0
- package/backend/dist/cowork/dto/set-project.dto.d.ts +3 -0
- package/backend/dist/cowork/dto/set-project.dto.js +21 -0
- package/backend/dist/cowork/dto/set-project.dto.js.map +1 -0
- package/backend/dist/excel/excel.module.d.ts +2 -0
- package/backend/dist/excel/excel.module.js +26 -0
- package/backend/dist/excel/excel.module.js.map +1 -0
- package/backend/dist/excel/excel.service.d.ts +33 -0
- package/backend/dist/excel/excel.service.js +204 -0
- package/backend/dist/excel/excel.service.js.map +1 -0
- package/backend/dist/excel/executors/excel-add-sheet.executor.d.ts +12 -0
- package/backend/dist/excel/executors/excel-add-sheet.executor.js +64 -0
- package/backend/dist/excel/executors/excel-add-sheet.executor.js.map +1 -0
- package/backend/dist/excel/executors/excel-chart.executor.d.ts +12 -0
- package/backend/dist/excel/executors/excel-chart.executor.js +68 -0
- package/backend/dist/excel/executors/excel-chart.executor.js.map +1 -0
- package/backend/dist/excel/executors/list-excel-sheets.executor.d.ts +8 -0
- package/backend/dist/excel/executors/list-excel-sheets.executor.js +38 -0
- package/backend/dist/excel/executors/list-excel-sheets.executor.js.map +1 -0
- package/backend/dist/excel/executors/read-excel.executor.d.ts +8 -0
- package/backend/dist/excel/executors/read-excel.executor.js +40 -0
- package/backend/dist/excel/executors/read-excel.executor.js.map +1 -0
- package/backend/dist/excel/executors/write-excel.executor.d.ts +12 -0
- package/backend/dist/excel/executors/write-excel.executor.js +66 -0
- package/backend/dist/excel/executors/write-excel.executor.js.map +1 -0
- package/backend/dist/files/files.controller.d.ts +8 -0
- package/backend/dist/files/files.controller.js +53 -0
- package/backend/dist/files/files.controller.js.map +1 -0
- package/backend/dist/files/files.module.d.ts +2 -0
- package/backend/dist/files/files.module.js +20 -0
- package/backend/dist/files/files.module.js.map +1 -0
- package/backend/dist/http-exception.filter.d.ts +4 -0
- package/backend/dist/http-exception.filter.js +32 -0
- package/backend/dist/http-exception.filter.js.map +1 -0
- package/backend/dist/knowledge/dto/search.dto.d.ts +3 -0
- package/backend/dist/knowledge/dto/search.dto.js +21 -0
- package/backend/dist/knowledge/dto/search.dto.js.map +1 -0
- package/backend/dist/knowledge/knowledge.controller.d.ts +38 -0
- package/backend/dist/knowledge/knowledge.controller.js +91 -0
- package/backend/dist/knowledge/knowledge.controller.js.map +1 -0
- package/backend/dist/knowledge/knowledge.module.d.ts +2 -0
- package/backend/dist/knowledge/knowledge.module.js +25 -0
- package/backend/dist/knowledge/knowledge.module.js.map +1 -0
- package/backend/dist/knowledge/knowledge.service.d.ts +103 -0
- package/backend/dist/knowledge/knowledge.service.js +379 -0
- package/backend/dist/knowledge/knowledge.service.js.map +1 -0
- package/backend/dist/main.d.ts +1 -0
- package/backend/dist/main.js +33 -0
- package/backend/dist/main.js.map +1 -0
- package/backend/dist/memory/dto/create-memory.dto.d.ts +6 -0
- package/backend/dist/memory/dto/create-memory.dto.js +34 -0
- package/backend/dist/memory/dto/create-memory.dto.js.map +1 -0
- package/backend/dist/memory/dto/search-memory.dto.d.ts +5 -0
- package/backend/dist/memory/dto/search-memory.dto.js +32 -0
- package/backend/dist/memory/dto/search-memory.dto.js.map +1 -0
- package/backend/dist/memory/dto/update-memory.dto.d.ts +5 -0
- package/backend/dist/memory/dto/update-memory.dto.js +9 -0
- package/backend/dist/memory/dto/update-memory.dto.js.map +1 -0
- package/backend/dist/memory/memory-extraction.service.d.ts +19 -0
- package/backend/dist/memory/memory-extraction.service.js +87 -0
- package/backend/dist/memory/memory-extraction.service.js.map +1 -0
- package/backend/dist/memory/memory.constants.d.ts +9 -0
- package/backend/dist/memory/memory.constants.js +13 -0
- package/backend/dist/memory/memory.constants.js.map +1 -0
- package/backend/dist/memory/memory.controller.d.ts +53 -0
- package/backend/dist/memory/memory.controller.js +81 -0
- package/backend/dist/memory/memory.controller.js.map +1 -0
- package/backend/dist/memory/memory.gateway.d.ts +8 -0
- package/backend/dist/memory/memory.gateway.js +37 -0
- package/backend/dist/memory/memory.gateway.js.map +1 -0
- package/backend/dist/memory/memory.module.d.ts +2 -0
- package/backend/dist/memory/memory.module.js +25 -0
- package/backend/dist/memory/memory.module.js.map +1 -0
- package/backend/dist/memory/memory.service.d.ts +70 -0
- package/backend/dist/memory/memory.service.js +144 -0
- package/backend/dist/memory/memory.service.js.map +1 -0
- package/backend/dist/mode-policy/mode-policy.config.d.ts +20 -0
- package/backend/dist/mode-policy/mode-policy.config.js +17 -0
- package/backend/dist/mode-policy/mode-policy.config.js.map +1 -0
- package/backend/dist/mode-policy/mode-policy.module.d.ts +2 -0
- package/backend/dist/mode-policy/mode-policy.module.js +21 -0
- package/backend/dist/mode-policy/mode-policy.module.js.map +1 -0
- package/backend/dist/mode-policy/mode-policy.service.d.ts +18 -0
- package/backend/dist/mode-policy/mode-policy.service.js +66 -0
- package/backend/dist/mode-policy/mode-policy.service.js.map +1 -0
- package/backend/dist/notes/dto/create-note.dto.d.ts +4 -0
- package/backend/dist/notes/dto/create-note.dto.js +27 -0
- package/backend/dist/notes/dto/create-note.dto.js.map +1 -0
- package/backend/dist/notes/dto/update-note.dto.d.ts +5 -0
- package/backend/dist/notes/dto/update-note.dto.js +9 -0
- package/backend/dist/notes/dto/update-note.dto.js.map +1 -0
- package/backend/dist/notes/notes.controller.d.ts +35 -0
- package/backend/dist/notes/notes.controller.js +70 -0
- package/backend/dist/notes/notes.controller.js.map +1 -0
- package/backend/dist/notes/notes.gateway.d.ts +8 -0
- package/backend/dist/notes/notes.gateway.js +37 -0
- package/backend/dist/notes/notes.gateway.js.map +1 -0
- package/backend/dist/notes/notes.module.d.ts +2 -0
- package/backend/dist/notes/notes.module.js +24 -0
- package/backend/dist/notes/notes.module.js.map +1 -0
- package/backend/dist/notes/notes.service.d.ts +45 -0
- package/backend/dist/notes/notes.service.js +57 -0
- package/backend/dist/notes/notes.service.js.map +1 -0
- package/backend/dist/plans/plans.controller.d.ts +100 -0
- package/backend/dist/plans/plans.controller.js +80 -0
- package/backend/dist/plans/plans.controller.js.map +1 -0
- package/backend/dist/plans/plans.module.d.ts +2 -0
- package/backend/dist/plans/plans.module.js +23 -0
- package/backend/dist/plans/plans.module.js.map +1 -0
- package/backend/dist/plans/plans.service.d.ts +141 -0
- package/backend/dist/plans/plans.service.js +94 -0
- package/backend/dist/plans/plans.service.js.map +1 -0
- package/backend/dist/prisma/prisma.module.d.ts +2 -0
- package/backend/dist/prisma/prisma.module.js +22 -0
- package/backend/dist/prisma/prisma.module.js.map +1 -0
- package/backend/dist/prisma/prisma.service.d.ts +6 -0
- package/backend/dist/prisma/prisma.service.js +24 -0
- package/backend/dist/prisma/prisma.service.js.map +1 -0
- package/backend/dist/providers/dto/create-provider-model.dto.d.ts +3 -0
- package/backend/dist/providers/dto/create-provider-model.dto.js +22 -0
- package/backend/dist/providers/dto/create-provider-model.dto.js.map +1 -0
- package/backend/dist/providers/dto/create-provider.dto.d.ts +6 -0
- package/backend/dist/providers/dto/create-provider.dto.js +37 -0
- package/backend/dist/providers/dto/create-provider.dto.js.map +1 -0
- package/backend/dist/providers/dto/update-provider.dto.d.ts +5 -0
- package/backend/dist/providers/dto/update-provider.dto.js +9 -0
- package/backend/dist/providers/dto/update-provider.dto.js.map +1 -0
- package/backend/dist/providers/providers.controller.d.ts +60 -0
- package/backend/dist/providers/providers.controller.js +113 -0
- package/backend/dist/providers/providers.controller.js.map +1 -0
- package/backend/dist/providers/providers.module.d.ts +2 -0
- package/backend/dist/providers/providers.module.js +23 -0
- package/backend/dist/providers/providers.module.js.map +1 -0
- package/backend/dist/providers/providers.service.d.ts +86 -0
- package/backend/dist/providers/providers.service.js +100 -0
- package/backend/dist/providers/providers.service.js.map +1 -0
- package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.d.ts +13 -0
- package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.js +81 -0
- package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.js.map +1 -0
- package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.d.ts +5 -0
- package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.js +9 -0
- package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-cron.service.d.ts +8 -0
- package/backend/dist/schedule-tasks/schedule-cron.service.js +50 -0
- package/backend/dist/schedule-tasks/schedule-cron.service.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-runner.service.d.ts +25 -0
- package/backend/dist/schedule-tasks/schedule-runner.service.js +109 -0
- package/backend/dist/schedule-tasks/schedule-runner.service.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-tasks.controller.d.ts +108 -0
- package/backend/dist/schedule-tasks/schedule-tasks.controller.js +85 -0
- package/backend/dist/schedule-tasks/schedule-tasks.controller.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-tasks.module.d.ts +2 -0
- package/backend/dist/schedule-tasks/schedule-tasks.module.js +32 -0
- package/backend/dist/schedule-tasks/schedule-tasks.module.js.map +1 -0
- package/backend/dist/schedule-tasks/schedule-tasks.service.d.ts +141 -0
- package/backend/dist/schedule-tasks/schedule-tasks.service.js +80 -0
- package/backend/dist/schedule-tasks/schedule-tasks.service.js.map +1 -0
- package/backend/dist/sessions/sessions.controller.d.ts +40 -0
- package/backend/dist/sessions/sessions.controller.js +75 -0
- package/backend/dist/sessions/sessions.controller.js.map +1 -0
- package/backend/dist/sessions/sessions.module.d.ts +2 -0
- package/backend/dist/sessions/sessions.module.js +23 -0
- package/backend/dist/sessions/sessions.module.js.map +1 -0
- package/backend/dist/sessions/sessions.service.d.ts +55 -0
- package/backend/dist/sessions/sessions.service.js +73 -0
- package/backend/dist/sessions/sessions.service.js.map +1 -0
- package/backend/dist/settings/settings.controller.d.ts +14 -0
- package/backend/dist/settings/settings.controller.js +56 -0
- package/backend/dist/settings/settings.controller.js.map +1 -0
- package/backend/dist/settings/settings.module.d.ts +2 -0
- package/backend/dist/settings/settings.module.js +24 -0
- package/backend/dist/settings/settings.module.js.map +1 -0
- package/backend/dist/settings/settings.service.d.ts +10 -0
- package/backend/dist/settings/settings.service.js +49 -0
- package/backend/dist/settings/settings.service.js.map +1 -0
- package/backend/dist/tools/executors/convert-note-to-task.executor.d.ts +12 -0
- package/backend/dist/tools/executors/convert-note-to-task.executor.js +59 -0
- package/backend/dist/tools/executors/convert-note-to-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/create-note.executor.d.ts +8 -0
- package/backend/dist/tools/executors/create-note.executor.js +39 -0
- package/backend/dist/tools/executors/create-note.executor.js.map +1 -0
- package/backend/dist/tools/executors/create-plan.executor.d.ts +8 -0
- package/backend/dist/tools/executors/create-plan.executor.js +45 -0
- package/backend/dist/tools/executors/create-plan.executor.js.map +1 -0
- package/backend/dist/tools/executors/create-task.executor.d.ts +10 -0
- package/backend/dist/tools/executors/create-task.executor.js +53 -0
- package/backend/dist/tools/executors/create-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/delete-note.executor.d.ts +8 -0
- package/backend/dist/tools/executors/delete-note.executor.js +38 -0
- package/backend/dist/tools/executors/delete-note.executor.js.map +1 -0
- package/backend/dist/tools/executors/delete-tasks.executor.d.ts +8 -0
- package/backend/dist/tools/executors/delete-tasks.executor.js +33 -0
- package/backend/dist/tools/executors/delete-tasks.executor.js.map +1 -0
- package/backend/dist/tools/executors/get-task.executor.d.ts +8 -0
- package/backend/dist/tools/executors/get-task.executor.js +44 -0
- package/backend/dist/tools/executors/get-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/glob.executor.d.ts +10 -0
- package/backend/dist/tools/executors/glob.executor.js +82 -0
- package/backend/dist/tools/executors/glob.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-availability.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-calendar-availability.executor.js +46 -0
- package/backend/dist/tools/executors/google-calendar-availability.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-create.executor.d.ts +42 -0
- package/backend/dist/tools/executors/google-calendar-create.executor.js +48 -0
- package/backend/dist/tools/executors/google-calendar-create.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-list.executor.d.ts +22 -0
- package/backend/dist/tools/executors/google-calendar-list.executor.js +45 -0
- package/backend/dist/tools/executors/google-calendar-list.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-calendar-update.executor.d.ts +31 -0
- package/backend/dist/tools/executors/google-calendar-update.executor.js +50 -0
- package/backend/dist/tools/executors/google-calendar-update.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-create-folder.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-drive-create-folder.executor.js +44 -0
- package/backend/dist/tools/executors/google-drive-create-folder.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-list.executor.d.ts +18 -0
- package/backend/dist/tools/executors/google-drive-list.executor.js +44 -0
- package/backend/dist/tools/executors/google-drive-list.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-read.executor.d.ts +19 -0
- package/backend/dist/tools/executors/google-drive-read.executor.js +48 -0
- package/backend/dist/tools/executors/google-drive-read.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-search.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-drive-search.executor.js +46 -0
- package/backend/dist/tools/executors/google-drive-search.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-drive-upload.executor.d.ts +30 -0
- package/backend/dist/tools/executors/google-drive-upload.executor.js +49 -0
- package/backend/dist/tools/executors/google-drive-upload.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-draft.executor.d.ts +30 -0
- package/backend/dist/tools/executors/google-gmail-draft.executor.js +45 -0
- package/backend/dist/tools/executors/google-gmail-draft.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-labels.executor.d.ts +13 -0
- package/backend/dist/tools/executors/google-gmail-labels.executor.js +39 -0
- package/backend/dist/tools/executors/google-gmail-labels.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-read.executor.d.ts +19 -0
- package/backend/dist/tools/executors/google-gmail-read.executor.js +43 -0
- package/backend/dist/tools/executors/google-gmail-read.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-search.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-gmail-search.executor.js +46 -0
- package/backend/dist/tools/executors/google-gmail-search.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-gmail-send.executor.d.ts +44 -0
- package/backend/dist/tools/executors/google-gmail-send.executor.js +47 -0
- package/backend/dist/tools/executors/google-gmail-send.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-add-tab.executor.d.ts +23 -0
- package/backend/dist/tools/executors/google-sheets-add-tab.executor.js +44 -0
- package/backend/dist/tools/executors/google-sheets-add-tab.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-append.executor.d.ts +30 -0
- package/backend/dist/tools/executors/google-sheets-append.executor.js +45 -0
- package/backend/dist/tools/executors/google-sheets-append.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-chart.executor.d.ts +40 -0
- package/backend/dist/tools/executors/google-sheets-chart.executor.js +48 -0
- package/backend/dist/tools/executors/google-sheets-chart.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-create.executor.d.ts +27 -0
- package/backend/dist/tools/executors/google-sheets-create.executor.js +44 -0
- package/backend/dist/tools/executors/google-sheets-create.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-format.executor.d.ts +57 -0
- package/backend/dist/tools/executors/google-sheets-format.executor.js +58 -0
- package/backend/dist/tools/executors/google-sheets-format.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-list-tabs.executor.d.ts +19 -0
- package/backend/dist/tools/executors/google-sheets-list-tabs.executor.js +43 -0
- package/backend/dist/tools/executors/google-sheets-list-tabs.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-read.executor.d.ts +27 -0
- package/backend/dist/tools/executors/google-sheets-read.executor.js +45 -0
- package/backend/dist/tools/executors/google-sheets-read.executor.js.map +1 -0
- package/backend/dist/tools/executors/google-sheets-update.executor.d.ts +34 -0
- package/backend/dist/tools/executors/google-sheets-update.executor.js +46 -0
- package/backend/dist/tools/executors/google-sheets-update.executor.js.map +1 -0
- package/backend/dist/tools/executors/grep.executor.d.ts +9 -0
- package/backend/dist/tools/executors/grep.executor.js +82 -0
- package/backend/dist/tools/executors/grep.executor.js.map +1 -0
- package/backend/dist/tools/executors/list-directory.executor.d.ts +8 -0
- package/backend/dist/tools/executors/list-directory.executor.js +37 -0
- package/backend/dist/tools/executors/list-directory.executor.js.map +1 -0
- package/backend/dist/tools/executors/list-notes.executor.d.ts +8 -0
- package/backend/dist/tools/executors/list-notes.executor.js +37 -0
- package/backend/dist/tools/executors/list-notes.executor.js.map +1 -0
- package/backend/dist/tools/executors/list-tasks.executor.d.ts +8 -0
- package/backend/dist/tools/executors/list-tasks.executor.js +32 -0
- package/backend/dist/tools/executors/list-tasks.executor.js.map +1 -0
- package/backend/dist/tools/executors/read-file.executor.d.ts +8 -0
- package/backend/dist/tools/executors/read-file.executor.js +44 -0
- package/backend/dist/tools/executors/read-file.executor.js.map +1 -0
- package/backend/dist/tools/executors/resume-plan.executor.d.ts +8 -0
- package/backend/dist/tools/executors/resume-plan.executor.js +58 -0
- package/backend/dist/tools/executors/resume-plan.executor.js.map +1 -0
- package/backend/dist/tools/executors/run-command.executor.d.ts +5 -0
- package/backend/dist/tools/executors/run-command.executor.js +55 -0
- package/backend/dist/tools/executors/run-command.executor.js.map +1 -0
- package/backend/dist/tools/executors/search-knowledge.executor.d.ts +8 -0
- package/backend/dist/tools/executors/search-knowledge.executor.js +33 -0
- package/backend/dist/tools/executors/search-knowledge.executor.js.map +1 -0
- package/backend/dist/tools/executors/spawn-subagent.executor.d.ts +5 -0
- package/backend/dist/tools/executors/spawn-subagent.executor.js +27 -0
- package/backend/dist/tools/executors/spawn-subagent.executor.js.map +1 -0
- package/backend/dist/tools/executors/tool-executor.interface.d.ts +8 -0
- package/backend/dist/tools/executors/tool-executor.interface.js +3 -0
- package/backend/dist/tools/executors/tool-executor.interface.js.map +1 -0
- package/backend/dist/tools/executors/update-note.executor.d.ts +8 -0
- package/backend/dist/tools/executors/update-note.executor.js +43 -0
- package/backend/dist/tools/executors/update-note.executor.js.map +1 -0
- package/backend/dist/tools/executors/update-task.executor.d.ts +8 -0
- package/backend/dist/tools/executors/update-task.executor.js +50 -0
- package/backend/dist/tools/executors/update-task.executor.js.map +1 -0
- package/backend/dist/tools/executors/web-fetch.executor.d.ts +8 -0
- package/backend/dist/tools/executors/web-fetch.executor.js +57 -0
- package/backend/dist/tools/executors/web-fetch.executor.js.map +1 -0
- package/backend/dist/tools/executors/web-search.executor.d.ts +8 -0
- package/backend/dist/tools/executors/web-search.executor.js +70 -0
- package/backend/dist/tools/executors/web-search.executor.js.map +1 -0
- package/backend/dist/tools/executors/write-file.executor.d.ts +10 -0
- package/backend/dist/tools/executors/write-file.executor.js +60 -0
- package/backend/dist/tools/executors/write-file.executor.js.map +1 -0
- package/backend/dist/tools/tools.controller.d.ts +37 -0
- package/backend/dist/tools/tools.controller.js +63 -0
- package/backend/dist/tools/tools.controller.js.map +1 -0
- package/backend/dist/tools/tools.module.d.ts +2 -0
- package/backend/dist/tools/tools.module.js +128 -0
- package/backend/dist/tools/tools.module.js.map +1 -0
- package/backend/dist/tools/tools.service.d.ts +55 -0
- package/backend/dist/tools/tools.service.js +49 -0
- package/backend/dist/tools/tools.service.js.map +1 -0
- package/backend/dist/usage/dto/create-usage.dto.d.ts +8 -0
- package/backend/dist/usage/dto/create-usage.dto.js +45 -0
- package/backend/dist/usage/dto/create-usage.dto.js.map +1 -0
- package/backend/dist/usage/usage.controller.d.ts +19 -0
- package/backend/dist/usage/usage.controller.js +43 -0
- package/backend/dist/usage/usage.controller.js.map +1 -0
- package/backend/dist/usage/usage.module.d.ts +2 -0
- package/backend/dist/usage/usage.module.js +24 -0
- package/backend/dist/usage/usage.module.js.map +1 -0
- package/backend/dist/usage/usage.service.d.ts +30 -0
- package/backend/dist/usage/usage.service.js +61 -0
- package/backend/dist/usage/usage.service.js.map +1 -0
- package/backend/dist/word/executors/edit-word.executor.d.ts +12 -0
- package/backend/dist/word/executors/edit-word.executor.js +65 -0
- package/backend/dist/word/executors/edit-word.executor.js.map +1 -0
- package/backend/dist/word/executors/read-word.executor.d.ts +10 -0
- package/backend/dist/word/executors/read-word.executor.js +49 -0
- package/backend/dist/word/executors/read-word.executor.js.map +1 -0
- package/backend/dist/word/executors/write-word.executor.d.ts +12 -0
- package/backend/dist/word/executors/write-word.executor.js +63 -0
- package/backend/dist/word/executors/write-word.executor.js.map +1 -0
- package/backend/dist/word/word.module.d.ts +2 -0
- package/backend/dist/word/word.module.js +21 -0
- package/backend/dist/word/word.module.js.map +1 -0
- package/backend/dist/word/word.service.d.ts +22 -0
- package/backend/dist/word/word.service.js +155 -0
- package/backend/dist/word/word.service.js.map +1 -0
- package/backend/dist/workspace/dto/watch.dto.d.ts +3 -0
- package/backend/dist/workspace/dto/watch.dto.js +22 -0
- package/backend/dist/workspace/dto/watch.dto.js.map +1 -0
- package/backend/dist/workspace/indexer.service.d.ts +24 -0
- package/backend/dist/workspace/indexer.service.js +109 -0
- package/backend/dist/workspace/indexer.service.js.map +1 -0
- package/backend/dist/workspace/workspace-watcher.service.d.ts +20 -0
- package/backend/dist/workspace/workspace-watcher.service.js +73 -0
- package/backend/dist/workspace/workspace-watcher.service.js.map +1 -0
- package/backend/dist/workspace/workspace.controller.d.ts +21 -0
- package/backend/dist/workspace/workspace.controller.js +72 -0
- package/backend/dist/workspace/workspace.controller.js.map +1 -0
- package/backend/dist/workspace/workspace.module.d.ts +2 -0
- package/backend/dist/workspace/workspace.module.js +27 -0
- package/backend/dist/workspace/workspace.module.js.map +1 -0
- package/backend/dist/workspace/workspace.service.d.ts +16 -0
- package/backend/dist/workspace/workspace.service.js +70 -0
- package/backend/dist/workspace/workspace.service.js.map +1 -0
- package/backend/package.json +80 -0
- package/backend/prisma/migrations/20260607051149_init/migration.sql +11 -0
- package/backend/prisma/migrations/20260607082131_add_settings/migration.sql +5 -0
- package/backend/prisma/migrations/20260607090628_add_knowledge_file/migration.sql +12 -0
- package/backend/prisma/migrations/20260607102620_add_sessions_chat_messages/migration.sql +17 -0
- package/backend/prisma/migrations/20260607160733_add_tool_fields_to_message/migration.sql +18 -0
- package/backend/prisma/migrations/20260608120000_add_providers/migration.sql +19 -0
- package/backend/prisma/migrations/20260608150513_add_tools/migration.sql +9 -0
- package/backend/prisma/migrations/20260608155121_add_tool_config/migration.sql +3 -0
- package/backend/prisma/migrations/20260609044217_add_error_message/migration.sql +2 -0
- package/backend/prisma/migrations/20260609110505_add_notes/migration.sql +8 -0
- package/backend/prisma/migrations/20260609151214_add_plan_tables/migration.sql +21 -0
- package/backend/prisma/migrations/20260610100714_add_agent_file/migration.sql +9 -0
- package/backend/prisma/migrations/20260611085424_add_session_mode/migration.sql +2 -0
- package/backend/prisma/migrations/20260611120000_add_memory_model/migration.sql +13 -0
- package/backend/prisma/migrations/20260612120000_add_usage_record/migration.sql +12 -0
- package/backend/prisma/migrations/20260612130000_add_project_model/migration.sql +7 -0
- package/backend/prisma/migrations/20260612130000_add_project_model/migration_lock.toml +5 -0
- package/backend/prisma/migrations/20260612140000_add_connector_model/migration.sql +9 -0
- package/backend/prisma/migrations/20260612173937_add_connector_services_account/migration.sql +24 -0
- package/backend/prisma/migrations/20260612181017_remove_connector_services/migration.sql +23 -0
- package/backend/prisma/migrations/20260613135109_add_schedule_tasks/migration.sql +45 -0
- package/backend/prisma/migrations/20260613140915_add_cron_days_of_week/migration.sql +2 -0
- package/backend/prisma/migrations/20260613142809_add_timezone/migration.sql +2 -0
- package/backend/prisma/migrations/20260613163408_remove_task_model/migration.sql +10 -0
- package/backend/prisma/migrations/20260620120025_add_agent_profile/migration.sql +17 -0
- package/backend/prisma/migrations/migration_lock.toml +3 -0
- package/backend/prisma/schema.prisma +208 -0
- package/backend/prisma/seed.cjs +132 -0
- package/bin/workspace-cli.js +296 -0
- package/frontend/dist/assets/index-DRtpgPPc.css +1 -0
- package/frontend/dist/assets/index-Dn28_pkr.js +101 -0
- package/frontend/dist/index.html +19 -0
- package/frontend/dist/logo.png +0 -0
- package/package.json +54 -0
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.GmailService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const googleapis_1 = require("googleapis");
|
|
15
|
+
const google_oauth_service_1 = require("./google-oauth.service");
|
|
16
|
+
let GmailService = class GmailService {
|
|
17
|
+
constructor(googleOAuth) {
|
|
18
|
+
this.googleOAuth = googleOAuth;
|
|
19
|
+
}
|
|
20
|
+
async getGmail() {
|
|
21
|
+
const auth = await this.googleOAuth.getAuthenticatedClient('google_gmail');
|
|
22
|
+
if (!auth)
|
|
23
|
+
throw new Error('Google not connected');
|
|
24
|
+
return googleapis_1.google.gmail({ version: 'v1', auth: auth });
|
|
25
|
+
}
|
|
26
|
+
async search(query, maxResults = 20) {
|
|
27
|
+
const gmail = await this.getGmail();
|
|
28
|
+
const res = await gmail.users.messages.list({ userId: 'me', q: query, maxResults });
|
|
29
|
+
const ids = res.data.messages?.map(m => m.id) ?? [];
|
|
30
|
+
if (ids.length === 0)
|
|
31
|
+
return [];
|
|
32
|
+
return Promise.all(ids.map(id => this.get(id)));
|
|
33
|
+
}
|
|
34
|
+
async get(id) {
|
|
35
|
+
const gmail = await this.getGmail();
|
|
36
|
+
const res = await gmail.users.messages.get({ userId: 'me', id, format: 'full' });
|
|
37
|
+
const headers = (res.data.payload?.headers ?? []).reduce((acc, h) => {
|
|
38
|
+
if (h.name)
|
|
39
|
+
acc[h.name.toLowerCase()] = h.value ?? '';
|
|
40
|
+
return acc;
|
|
41
|
+
}, {});
|
|
42
|
+
let body = '';
|
|
43
|
+
const parts = res.data.payload?.parts ?? [];
|
|
44
|
+
for (const part of parts) {
|
|
45
|
+
if (part.mimeType === 'text/plain' && part.body?.data) {
|
|
46
|
+
body = Buffer.from(part.body.data, 'base64url').toString('utf-8');
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
if (!body && res.data.payload?.body?.data) {
|
|
51
|
+
body = Buffer.from(res.data.payload.body.data, 'base64url').toString('utf-8');
|
|
52
|
+
}
|
|
53
|
+
return {
|
|
54
|
+
id: res.data.id,
|
|
55
|
+
threadId: res.data.threadId,
|
|
56
|
+
subject: headers['subject'] ?? '',
|
|
57
|
+
from: headers['from'] ?? '',
|
|
58
|
+
to: headers['to'] ?? '',
|
|
59
|
+
date: headers['date'] ?? '',
|
|
60
|
+
snippet: res.data.snippet ?? '',
|
|
61
|
+
body,
|
|
62
|
+
labels: res.data.labelIds ?? [],
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
encodeMimeHeader(value) {
|
|
66
|
+
return /[^\x00-\x7F]/.test(value)
|
|
67
|
+
? `=?UTF-8?B?${Buffer.from(value, 'utf-8').toString('base64')}?=`
|
|
68
|
+
: value;
|
|
69
|
+
}
|
|
70
|
+
buildEmail(lines) {
|
|
71
|
+
return lines.join('\r\n');
|
|
72
|
+
}
|
|
73
|
+
async send(to, subject, body, cc, bcc) {
|
|
74
|
+
const gmail = await this.getGmail();
|
|
75
|
+
const headers = [
|
|
76
|
+
`To: ${to.map(a => this.encodeMimeHeader(a)).join(', ')}`,
|
|
77
|
+
cc?.length ? `Cc: ${cc.map(a => this.encodeMimeHeader(a)).join(', ')}` : null,
|
|
78
|
+
bcc?.length ? `Bcc: ${bcc.map(a => this.encodeMimeHeader(a)).join(', ')}` : null,
|
|
79
|
+
`Subject: ${this.encodeMimeHeader(subject)}`,
|
|
80
|
+
'MIME-Version: 1.0',
|
|
81
|
+
'Content-Type: text/plain; charset=utf-8',
|
|
82
|
+
'Content-Transfer-Encoding: base64',
|
|
83
|
+
].filter(Boolean);
|
|
84
|
+
const email = this.buildEmail([...headers, '', Buffer.from(body, 'utf-8').toString('base64')]);
|
|
85
|
+
const encoded = Buffer.from(email, 'utf-8').toString('base64url');
|
|
86
|
+
const res = await gmail.users.messages.send({ userId: 'me', requestBody: { raw: encoded } });
|
|
87
|
+
return { id: res.data.id };
|
|
88
|
+
}
|
|
89
|
+
async createDraft(to, subject, body) {
|
|
90
|
+
const gmail = await this.getGmail();
|
|
91
|
+
const headers = [
|
|
92
|
+
`To: ${to.map(a => this.encodeMimeHeader(a)).join(', ')}`,
|
|
93
|
+
`Subject: ${this.encodeMimeHeader(subject)}`,
|
|
94
|
+
'MIME-Version: 1.0',
|
|
95
|
+
'Content-Type: text/plain; charset=utf-8',
|
|
96
|
+
'Content-Transfer-Encoding: base64',
|
|
97
|
+
];
|
|
98
|
+
const email = this.buildEmail([...headers, '', Buffer.from(body, 'utf-8').toString('base64')]);
|
|
99
|
+
const encoded = Buffer.from(email, 'utf-8').toString('base64url');
|
|
100
|
+
const res = await gmail.users.drafts.create({ userId: 'me', requestBody: { message: { raw: encoded } } });
|
|
101
|
+
return { id: res.data.id };
|
|
102
|
+
}
|
|
103
|
+
async listLabels() {
|
|
104
|
+
const gmail = await this.getGmail();
|
|
105
|
+
const res = await gmail.users.labels.list({ userId: 'me' });
|
|
106
|
+
return (res.data.labels ?? []).map(l => ({ id: l.id, name: l.name }));
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
exports.GmailService = GmailService;
|
|
110
|
+
exports.GmailService = GmailService = __decorate([
|
|
111
|
+
(0, common_1.Injectable)(),
|
|
112
|
+
__metadata("design:paramtypes", [google_oauth_service_1.GoogleOAuthService])
|
|
113
|
+
], GmailService);
|
|
114
|
+
//# sourceMappingURL=gmail.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gmail.service.js","sourceRoot":"","sources":["../../../../src/connector/providers/google/gmail.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { GoogleOAuthService } from './google-oauth.service';
|
|
2
|
+
export interface CalendarEvent {
|
|
3
|
+
id: string;
|
|
4
|
+
summary: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
startTime: string;
|
|
7
|
+
endTime: string;
|
|
8
|
+
location?: string;
|
|
9
|
+
attendees?: string[];
|
|
10
|
+
}
|
|
11
|
+
export declare class GoogleCalendarService {
|
|
12
|
+
private readonly googleOAuth;
|
|
13
|
+
constructor(googleOAuth: GoogleOAuthService);
|
|
14
|
+
private getCalendar;
|
|
15
|
+
listEvents(since?: string, until?: string): Promise<CalendarEvent[]>;
|
|
16
|
+
createEvent(options: {
|
|
17
|
+
title: string;
|
|
18
|
+
startTime: string;
|
|
19
|
+
endTime: string;
|
|
20
|
+
description?: string;
|
|
21
|
+
attendees?: string[];
|
|
22
|
+
location?: string;
|
|
23
|
+
}): Promise<CalendarEvent>;
|
|
24
|
+
updateEvent(id: string, updates: {
|
|
25
|
+
title?: string;
|
|
26
|
+
startTime?: string;
|
|
27
|
+
endTime?: string;
|
|
28
|
+
description?: string;
|
|
29
|
+
}): Promise<CalendarEvent>;
|
|
30
|
+
checkAvailability(startTime: string, endTime: string): Promise<{
|
|
31
|
+
available: boolean;
|
|
32
|
+
busySlots: {
|
|
33
|
+
start: string;
|
|
34
|
+
end: string;
|
|
35
|
+
}[];
|
|
36
|
+
}>;
|
|
37
|
+
}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.GoogleCalendarService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const googleapis_1 = require("googleapis");
|
|
15
|
+
const google_oauth_service_1 = require("./google-oauth.service");
|
|
16
|
+
let GoogleCalendarService = class GoogleCalendarService {
|
|
17
|
+
constructor(googleOAuth) {
|
|
18
|
+
this.googleOAuth = googleOAuth;
|
|
19
|
+
}
|
|
20
|
+
async getCalendar() {
|
|
21
|
+
const auth = await this.googleOAuth.getAuthenticatedClient('google_calendar');
|
|
22
|
+
if (!auth)
|
|
23
|
+
throw new Error('Google not connected');
|
|
24
|
+
return googleapis_1.google.calendar({ version: 'v3', auth: auth });
|
|
25
|
+
}
|
|
26
|
+
async listEvents(since, until) {
|
|
27
|
+
const calendar = await this.getCalendar();
|
|
28
|
+
const res = await calendar.events.list({
|
|
29
|
+
calendarId: 'primary',
|
|
30
|
+
timeMin: since ?? new Date().toISOString(),
|
|
31
|
+
timeMax: until,
|
|
32
|
+
singleEvents: true,
|
|
33
|
+
orderBy: 'startTime',
|
|
34
|
+
});
|
|
35
|
+
return (res.data.items ?? []).map(e => ({
|
|
36
|
+
id: e.id,
|
|
37
|
+
summary: e.summary ?? '',
|
|
38
|
+
description: e.description ?? undefined,
|
|
39
|
+
startTime: e.start?.dateTime ?? e.start?.date ?? '',
|
|
40
|
+
endTime: e.end?.dateTime ?? e.end?.date ?? '',
|
|
41
|
+
location: e.location ?? undefined,
|
|
42
|
+
attendees: e.attendees?.map(a => a.email),
|
|
43
|
+
}));
|
|
44
|
+
}
|
|
45
|
+
async createEvent(options) {
|
|
46
|
+
const calendar = await this.getCalendar();
|
|
47
|
+
const res = await calendar.events.insert({
|
|
48
|
+
calendarId: 'primary',
|
|
49
|
+
requestBody: {
|
|
50
|
+
summary: options.title,
|
|
51
|
+
description: options.description,
|
|
52
|
+
start: { dateTime: options.startTime },
|
|
53
|
+
end: { dateTime: options.endTime },
|
|
54
|
+
location: options.location,
|
|
55
|
+
attendees: options.attendees?.map(email => ({ email })),
|
|
56
|
+
},
|
|
57
|
+
});
|
|
58
|
+
return {
|
|
59
|
+
id: res.data.id,
|
|
60
|
+
summary: res.data.summary ?? '',
|
|
61
|
+
description: res.data.description ?? undefined,
|
|
62
|
+
startTime: res.data.start?.dateTime ?? '',
|
|
63
|
+
endTime: res.data.end?.dateTime ?? '',
|
|
64
|
+
location: res.data.location ?? undefined,
|
|
65
|
+
attendees: res.data.attendees?.map(a => a.email),
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
async updateEvent(id, updates) {
|
|
69
|
+
const calendar = await this.getCalendar();
|
|
70
|
+
const body = {};
|
|
71
|
+
if (updates.title)
|
|
72
|
+
body.summary = updates.title;
|
|
73
|
+
if (updates.description !== undefined)
|
|
74
|
+
body.description = updates.description;
|
|
75
|
+
if (updates.startTime)
|
|
76
|
+
body.start = { dateTime: updates.startTime };
|
|
77
|
+
if (updates.endTime)
|
|
78
|
+
body.end = { dateTime: updates.endTime };
|
|
79
|
+
const res = await calendar.events.patch({ calendarId: 'primary', eventId: id, requestBody: body });
|
|
80
|
+
return {
|
|
81
|
+
id: res.data.id,
|
|
82
|
+
summary: res.data.summary ?? '',
|
|
83
|
+
startTime: res.data.start?.dateTime ?? '',
|
|
84
|
+
endTime: res.data.end?.dateTime ?? '',
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
async checkAvailability(startTime, endTime) {
|
|
88
|
+
const calendar = await this.getCalendar();
|
|
89
|
+
const res = await calendar.freebusy.query({
|
|
90
|
+
requestBody: {
|
|
91
|
+
timeMin: startTime,
|
|
92
|
+
timeMax: endTime,
|
|
93
|
+
items: [{ id: 'primary' }],
|
|
94
|
+
},
|
|
95
|
+
});
|
|
96
|
+
const busy = res.data.calendars?.['primary']?.busy ?? [];
|
|
97
|
+
return { available: busy.length === 0, busySlots: busy.map(b => ({ start: b.start, end: b.end })) };
|
|
98
|
+
}
|
|
99
|
+
};
|
|
100
|
+
exports.GoogleCalendarService = GoogleCalendarService;
|
|
101
|
+
exports.GoogleCalendarService = GoogleCalendarService = __decorate([
|
|
102
|
+
(0, common_1.Injectable)(),
|
|
103
|
+
__metadata("design:paramtypes", [google_oauth_service_1.GoogleOAuthService])
|
|
104
|
+
], GoogleCalendarService);
|
|
105
|
+
//# sourceMappingURL=google-calendar.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"google-calendar.service.js","sourceRoot":"","sources":["../../../../src/connector/providers/google/google-calendar.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { GoogleOAuthService } from './google-oauth.service';
|
|
2
|
+
export interface DriveFile {
|
|
3
|
+
id: string;
|
|
4
|
+
name: string;
|
|
5
|
+
mimeType: string;
|
|
6
|
+
size?: string;
|
|
7
|
+
modifiedTime?: string;
|
|
8
|
+
webViewLink?: string;
|
|
9
|
+
}
|
|
10
|
+
export declare class GoogleDriveService {
|
|
11
|
+
private readonly googleOAuth;
|
|
12
|
+
constructor(googleOAuth: GoogleOAuthService);
|
|
13
|
+
private getDrive;
|
|
14
|
+
search(query: string, pageSize?: number): Promise<DriveFile[]>;
|
|
15
|
+
get(id: string): Promise<DriveFile & {
|
|
16
|
+
content?: string;
|
|
17
|
+
}>;
|
|
18
|
+
listFiles(folderId?: string, pageSize?: number): Promise<DriveFile[]>;
|
|
19
|
+
createFolder(name: string, parentFolderId?: string): Promise<DriveFile>;
|
|
20
|
+
upload(name: string, contentBase64: string, mimeType?: string): Promise<DriveFile>;
|
|
21
|
+
uploadFromPath(filePath: string, fileName?: string): Promise<DriveFile>;
|
|
22
|
+
}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.GoogleDriveService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const googleapis_1 = require("googleapis");
|
|
15
|
+
const google_oauth_service_1 = require("./google-oauth.service");
|
|
16
|
+
const fs = require("fs");
|
|
17
|
+
const path = require("path");
|
|
18
|
+
const MIME_MAP = {
|
|
19
|
+
'.txt': 'text/plain', '.html': 'text/html', '.css': 'text/css', '.js': 'application/javascript',
|
|
20
|
+
'.json': 'application/json', '.xml': 'application/xml', '.csv': 'text/csv',
|
|
21
|
+
'.png': 'image/png', '.jpg': 'image/jpeg', '.jpeg': 'image/jpeg', '.gif': 'image/gif', '.svg': 'image/svg+xml', '.webp': 'image/webp',
|
|
22
|
+
'.pdf': 'application/pdf', '.doc': 'application/msword', '.docx': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
|
|
23
|
+
'.xls': 'application/vnd.ms-excel', '.xlsx': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
|
|
24
|
+
'.zip': 'application/zip', '.tar': 'application/x-tar', '.gz': 'application/gzip',
|
|
25
|
+
'.mp3': 'audio/mpeg', '.mp4': 'video/mp4', '.mov': 'video/quicktime',
|
|
26
|
+
};
|
|
27
|
+
let GoogleDriveService = class GoogleDriveService {
|
|
28
|
+
constructor(googleOAuth) {
|
|
29
|
+
this.googleOAuth = googleOAuth;
|
|
30
|
+
}
|
|
31
|
+
async getDrive() {
|
|
32
|
+
const auth = await this.googleOAuth.getAuthenticatedClient('google_drive');
|
|
33
|
+
if (!auth)
|
|
34
|
+
throw new Error('Google not connected');
|
|
35
|
+
return googleapis_1.google.drive({ version: 'v3', auth: auth });
|
|
36
|
+
}
|
|
37
|
+
async search(query, pageSize = 20) {
|
|
38
|
+
const drive = await this.getDrive();
|
|
39
|
+
const escaped = query.replace(/'/g, "\\'").replace(/\\/g, '\\\\');
|
|
40
|
+
const res = await drive.files.list({
|
|
41
|
+
q: `name contains '${escaped}'`,
|
|
42
|
+
pageSize,
|
|
43
|
+
fields: 'files(id,name,mimeType,size,modifiedTime,webViewLink)',
|
|
44
|
+
});
|
|
45
|
+
return (res.data.files ?? []).map(f => ({
|
|
46
|
+
id: f.id,
|
|
47
|
+
name: f.name,
|
|
48
|
+
mimeType: f.mimeType,
|
|
49
|
+
size: f.size ?? undefined,
|
|
50
|
+
modifiedTime: f.modifiedTime ?? undefined,
|
|
51
|
+
webViewLink: f.webViewLink ?? undefined,
|
|
52
|
+
}));
|
|
53
|
+
}
|
|
54
|
+
async get(id) {
|
|
55
|
+
const drive = await this.getDrive();
|
|
56
|
+
const meta = await drive.files.get({ fileId: id, fields: 'id,name,mimeType,size,modifiedTime,webViewLink' });
|
|
57
|
+
let content;
|
|
58
|
+
if (meta.data.mimeType === 'text/plain' || meta.data.mimeType?.includes('text')) {
|
|
59
|
+
const resp = await drive.files.get({ fileId: id, alt: 'media' }, { responseType: 'text' });
|
|
60
|
+
content = resp.data;
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
id: meta.data.id,
|
|
64
|
+
name: meta.data.name,
|
|
65
|
+
mimeType: meta.data.mimeType,
|
|
66
|
+
size: meta.data.size ?? undefined,
|
|
67
|
+
modifiedTime: meta.data.modifiedTime ?? undefined,
|
|
68
|
+
webViewLink: meta.data.webViewLink ?? undefined,
|
|
69
|
+
content,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
async listFiles(folderId, pageSize = 50) {
|
|
73
|
+
const drive = await this.getDrive();
|
|
74
|
+
const params = { pageSize, fields: 'files(id,name,mimeType,size,modifiedTime,webViewLink)' };
|
|
75
|
+
if (folderId)
|
|
76
|
+
params.q = `'${folderId}' in parents`;
|
|
77
|
+
const res = await drive.files.list(params);
|
|
78
|
+
return (res.data.files ?? []).map(f => ({
|
|
79
|
+
id: f.id,
|
|
80
|
+
name: f.name,
|
|
81
|
+
mimeType: f.mimeType,
|
|
82
|
+
size: f.size ?? undefined,
|
|
83
|
+
modifiedTime: f.modifiedTime ?? undefined,
|
|
84
|
+
webViewLink: f.webViewLink ?? undefined,
|
|
85
|
+
}));
|
|
86
|
+
}
|
|
87
|
+
async createFolder(name, parentFolderId) {
|
|
88
|
+
const drive = await this.getDrive();
|
|
89
|
+
const body = {
|
|
90
|
+
name,
|
|
91
|
+
mimeType: 'application/vnd.google-apps.folder',
|
|
92
|
+
};
|
|
93
|
+
if (parentFolderId)
|
|
94
|
+
body.parents = [parentFolderId];
|
|
95
|
+
const res = await drive.files.create({
|
|
96
|
+
requestBody: body,
|
|
97
|
+
fields: 'id,name,mimeType,size,modifiedTime,webViewLink',
|
|
98
|
+
});
|
|
99
|
+
return { id: res.data.id, name: res.data.name, mimeType: res.data.mimeType, webViewLink: res.data.webViewLink ?? undefined };
|
|
100
|
+
}
|
|
101
|
+
async upload(name, contentBase64, mimeType = 'text/plain') {
|
|
102
|
+
const drive = await this.getDrive();
|
|
103
|
+
const body = Buffer.from(contentBase64, 'base64');
|
|
104
|
+
const res = await drive.files.create({
|
|
105
|
+
requestBody: { name },
|
|
106
|
+
media: { mimeType, body },
|
|
107
|
+
fields: 'id,name,mimeType,size,modifiedTime,webViewLink',
|
|
108
|
+
}, { timeout: 300000 });
|
|
109
|
+
return { id: res.data.id, name: res.data.name, mimeType: res.data.mimeType };
|
|
110
|
+
}
|
|
111
|
+
async uploadFromPath(filePath, fileName) {
|
|
112
|
+
const ext = path.extname(filePath).toLowerCase();
|
|
113
|
+
const mimeType = MIME_MAP[ext] ?? 'application/octet-stream';
|
|
114
|
+
const name = fileName ?? path.basename(filePath);
|
|
115
|
+
const drive = await this.getDrive();
|
|
116
|
+
const body = fs.readFileSync(filePath);
|
|
117
|
+
const res = await drive.files.create({
|
|
118
|
+
requestBody: { name },
|
|
119
|
+
media: { mimeType, body },
|
|
120
|
+
fields: 'id,name,mimeType,size,modifiedTime,webViewLink',
|
|
121
|
+
}, { timeout: 300000 });
|
|
122
|
+
return { id: res.data.id, name: res.data.name, mimeType: res.data.mimeType };
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
exports.GoogleDriveService = GoogleDriveService;
|
|
126
|
+
exports.GoogleDriveService = GoogleDriveService = __decorate([
|
|
127
|
+
(0, common_1.Injectable)(),
|
|
128
|
+
__metadata("design:paramtypes", [google_oauth_service_1.GoogleOAuthService])
|
|
129
|
+
], GoogleDriveService);
|
|
130
|
+
//# sourceMappingURL=google-drive.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"google-drive.service.js","sourceRoot":"","sources":["../../../../src/connector/providers/google/google-drive.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ConnectorService } from '../../connector.service';
|
|
2
|
+
export interface GoogleTokens {
|
|
3
|
+
access_token: string;
|
|
4
|
+
refresh_token?: string;
|
|
5
|
+
expiry_date?: number;
|
|
6
|
+
}
|
|
7
|
+
export declare class GoogleOAuthService {
|
|
8
|
+
private readonly connector;
|
|
9
|
+
constructor(connector: ConnectorService);
|
|
10
|
+
private getClient;
|
|
11
|
+
getScopes(type: string): string[];
|
|
12
|
+
getAuthUrl(type: string, config: {
|
|
13
|
+
clientId: string;
|
|
14
|
+
clientSecret: string;
|
|
15
|
+
redirectUri: string;
|
|
16
|
+
}): string;
|
|
17
|
+
handleCallback(code: string, config: {
|
|
18
|
+
clientId: string;
|
|
19
|
+
clientSecret: string;
|
|
20
|
+
redirectUri: string;
|
|
21
|
+
}): Promise<GoogleTokens>;
|
|
22
|
+
getAuthenticatedClient(type: string): Promise<import("googleapis-common").OAuth2Client>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.GoogleOAuthService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const googleapis_1 = require("googleapis");
|
|
15
|
+
const connector_service_1 = require("../../connector.service");
|
|
16
|
+
const SCOPE_MAP = {
|
|
17
|
+
google_gmail: ['https://mail.google.com/'],
|
|
18
|
+
google_calendar: ['https://www.googleapis.com/auth/calendar'],
|
|
19
|
+
google_drive: ['https://www.googleapis.com/auth/drive'],
|
|
20
|
+
google_sheets: [
|
|
21
|
+
'https://www.googleapis.com/auth/spreadsheets',
|
|
22
|
+
'https://www.googleapis.com/auth/drive.readonly',
|
|
23
|
+
],
|
|
24
|
+
};
|
|
25
|
+
let GoogleOAuthService = class GoogleOAuthService {
|
|
26
|
+
constructor(connector) {
|
|
27
|
+
this.connector = connector;
|
|
28
|
+
}
|
|
29
|
+
getClient(config) {
|
|
30
|
+
return new googleapis_1.google.auth.OAuth2(config.clientId, config.clientSecret, config.redirectUri);
|
|
31
|
+
}
|
|
32
|
+
getScopes(type) {
|
|
33
|
+
return SCOPE_MAP[type] ?? [];
|
|
34
|
+
}
|
|
35
|
+
getAuthUrl(type, config) {
|
|
36
|
+
const client = this.getClient(config);
|
|
37
|
+
return client.generateAuthUrl({
|
|
38
|
+
access_type: 'offline',
|
|
39
|
+
scope: this.getScopes(type),
|
|
40
|
+
prompt: 'consent',
|
|
41
|
+
state: type,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
async handleCallback(code, config) {
|
|
45
|
+
const client = this.getClient(config);
|
|
46
|
+
const { tokens } = await client.getToken(code);
|
|
47
|
+
return tokens;
|
|
48
|
+
}
|
|
49
|
+
async getAuthenticatedClient(type) {
|
|
50
|
+
const connector = await this.connector.findByType(type);
|
|
51
|
+
if (!connector)
|
|
52
|
+
return null;
|
|
53
|
+
const parsed = JSON.parse(connector.config);
|
|
54
|
+
const tokens = parsed.tokens;
|
|
55
|
+
if (!tokens?.access_token)
|
|
56
|
+
return null;
|
|
57
|
+
const oauth2 = new googleapis_1.google.auth.OAuth2(parsed.clientId, parsed.clientSecret, parsed.redirectUri);
|
|
58
|
+
oauth2.setCredentials(tokens);
|
|
59
|
+
oauth2.on('tokens', async (newTokens) => {
|
|
60
|
+
const current = JSON.parse(connector.config);
|
|
61
|
+
if (newTokens.refresh_token)
|
|
62
|
+
current.tokens.refresh_token = newTokens.refresh_token;
|
|
63
|
+
current.tokens = { ...current.tokens, ...newTokens };
|
|
64
|
+
await this.connector.update(connector.id, { config: current });
|
|
65
|
+
});
|
|
66
|
+
return oauth2;
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
exports.GoogleOAuthService = GoogleOAuthService;
|
|
70
|
+
exports.GoogleOAuthService = GoogleOAuthService = __decorate([
|
|
71
|
+
(0, common_1.Injectable)(),
|
|
72
|
+
__metadata("design:paramtypes", [connector_service_1.ConnectorService])
|
|
73
|
+
], GoogleOAuthService);
|
|
74
|
+
//# sourceMappingURL=google-oauth.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"google-oauth.service.js","sourceRoot":"","sources":["../../../../src/connector/providers/google/google-oauth.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,2CAAoC;AACpC,+DAA2D;AAQ3D,MAAM,SAAS,GAA6B;IAC1C,YAAY,EAAE,CAAC,0BAA0B,CAAC;IAC1C,eAAe,EAAE,CAAC,0CAA0C,CAAC;IAC7D,YAAY,EAAE,CAAC,uCAAuC,CAAC;IACvD,aAAa,EAAE;QACb,8CAA8C;QAC9C,gDAAgD;KACjD;CACF,CAAC;AAGK,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC7B,YAA6B,SAA2B;QAA3B,cAAS,GAAT,SAAS,CAAkB;IAAG,CAAC;IAEpD,SAAS,CAAC,MAAuE;QACvF,OAAO,IAAI,mBAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;IAC1F,CAAC;IAED,SAAS,CAAC,IAAY;QACpB,OAAO,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;IAED,UAAU,CAAC,IAAY,EAAE,MAAuE;QAC9F,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACtC,OAAO,MAAM,CAAC,eAAe,CAAC;YAC5B,WAAW,EAAE,SAAS;YACtB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAC3B,MAAM,EAAE,SAAS;YACjB,KAAK,EAAE,IAAI;SACZ,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,IAAY,EAAE,MAAuE;QACxG,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACtC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC/C,OAAO,MAAsB,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,sBAAsB,CAAC,IAAY;QACvC,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACxD,IAAI,CAAC,SAAS;YAAE,OAAO,IAAI,CAAC;QAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC5C,MAAM,MAAM,GAAiB,MAAM,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,MAAM,EAAE,YAAY;YAAE,OAAO,IAAI,CAAC;QAEvC,MAAM,MAAM,GAAG,IAAI,mBAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,WAAW,CAAC,CAAC;QAChG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAC9B,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE;YACtC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YAC7C,IAAI,SAAS,CAAC,aAAa;gBAAE,OAAO,CAAC,MAAM,CAAC,aAAa,GAAG,SAAS,CAAC,aAAa,CAAC;YACpF,OAAO,CAAC,MAAM,GAAG,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,GAAG,SAAS,EAAE,CAAC;YACrD,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC;IAChB,CAAC;CACF,CAAA;AA7CY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;qCAE6B,oCAAgB;GAD7C,kBAAkB,CA6C9B"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { GoogleOAuthService } from './google-oauth.service';
|
|
2
|
+
export interface SheetFormat {
|
|
3
|
+
bold?: boolean;
|
|
4
|
+
italic?: boolean;
|
|
5
|
+
fontSize?: number;
|
|
6
|
+
fontColor?: string;
|
|
7
|
+
fillColor?: string;
|
|
8
|
+
numberFormat?: string;
|
|
9
|
+
border?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare class GoogleSheetsService {
|
|
12
|
+
private readonly googleOAuth;
|
|
13
|
+
constructor(googleOAuth: GoogleOAuthService);
|
|
14
|
+
private getAuth;
|
|
15
|
+
private getSheets;
|
|
16
|
+
private getDrive;
|
|
17
|
+
resolveSpreadsheetId(spreadsheet: string): Promise<string>;
|
|
18
|
+
read(spreadsheetId: string, tab: string, range: string): Promise<string>;
|
|
19
|
+
listTabs(spreadsheetId: string): Promise<string>;
|
|
20
|
+
update(spreadsheetId: string, tab: string, range: string, values: unknown[][]): Promise<string>;
|
|
21
|
+
append(spreadsheetId: string, tab: string, values: unknown[][]): Promise<string>;
|
|
22
|
+
create(title: string, initialTab?: string, parentFolderId?: string): Promise<string>;
|
|
23
|
+
addTab(spreadsheetId: string, tabName: string): Promise<string>;
|
|
24
|
+
private getSheetId;
|
|
25
|
+
private hexToRgb;
|
|
26
|
+
private parseA1;
|
|
27
|
+
format(spreadsheetId: string, tab: string, range: string, fmt: SheetFormat): Promise<string>;
|
|
28
|
+
chart(spreadsheetId: string, tab: string, type: 'BAR' | 'LINE' | 'PIE' | 'COLUMN', dataRange: string, categoriesRange?: string, title?: string): Promise<string>;
|
|
29
|
+
}
|