@elevasis/core 0.7.0 → 0.8.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/package.json +3 -3
- package/src/README.md +41 -41
- package/src/__tests__/publish.test.ts +18 -18
- package/src/__tests__/{template-foundations-compatibility.test.ts → template-core-compatibility.test.ts} +99 -99
- package/src/_gen/__tests__/__snapshots__/contracts.md.snap +1135 -1131
- package/src/_gen/__tests__/scaffold-contracts.test.ts +53 -53
- package/src/_gen/scaffold-contracts.ts +45 -45
- package/src/auth/multi-tenancy/credentials/README.md +38 -38
- package/src/auth/multi-tenancy/credentials/index.ts +6 -6
- package/src/auth/multi-tenancy/credentials/server/encryption.ts +39 -39
- package/src/auth/multi-tenancy/credentials/server/service.ts +60 -60
- package/src/auth/multi-tenancy/index.ts +17 -17
- package/src/auth/multi-tenancy/invitations/api-schemas.ts +107 -107
- package/src/auth/multi-tenancy/invitations/index.ts +37 -37
- package/src/auth/multi-tenancy/invitations/invitation.ts +86 -86
- package/src/auth/multi-tenancy/invitations/server/index.ts +25 -25
- package/src/auth/multi-tenancy/invitations/server/transforms.ts +24 -24
- package/src/auth/multi-tenancy/invitations/server/workos.ts +24 -24
- package/src/auth/multi-tenancy/invitations/supabase.ts +50 -50
- package/src/auth/multi-tenancy/memberships/api-schemas.ts +126 -126
- package/src/auth/multi-tenancy/memberships/index.ts +21 -21
- package/src/auth/multi-tenancy/memberships/membership.ts +138 -138
- package/src/auth/multi-tenancy/memberships/server/index.ts +15 -15
- package/src/auth/multi-tenancy/memberships/server/transforms.ts +32 -32
- package/src/auth/multi-tenancy/memberships/server/workos.ts +21 -21
- package/src/auth/multi-tenancy/memberships/supabase.ts +46 -46
- package/src/auth/multi-tenancy/organizations/api-schemas.ts +128 -128
- package/src/auth/multi-tenancy/organizations/index.ts +23 -23
- package/src/auth/multi-tenancy/organizations/organization.ts +24 -24
- package/src/auth/multi-tenancy/organizations/server/index.ts +10 -10
- package/src/auth/multi-tenancy/organizations/server/transforms.ts +35 -35
- package/src/auth/multi-tenancy/organizations/server/workos.ts +20 -20
- package/src/auth/multi-tenancy/types.ts +83 -83
- package/src/auth/multi-tenancy/users/api-schemas.ts +194 -194
- package/src/auth/multi-tenancy/users/index.ts +27 -27
- package/src/auth/multi-tenancy/users/server/index.ts +19 -19
- package/src/auth/multi-tenancy/users/server/transforms.ts +21 -21
- package/src/auth/multi-tenancy/users/server/workos.ts +16 -16
- package/src/auth/multi-tenancy/users/user.ts +65 -65
- package/src/business/README.md +52 -52
- package/src/business/__tests__/entities-published.test.ts +33 -33
- package/src/business/acquisition/api-schemas.ts +759 -759
- package/src/business/acquisition/index.ts +109 -109
- package/src/business/acquisition/types.ts +402 -402
- package/src/business/base-entities.test.ts +481 -481
- package/src/business/base-entities.ts +241 -241
- package/src/business/entities-published.ts +24 -24
- package/src/business/index.ts +15 -15
- package/src/business/pdf/browser/pdfmake-browser.ts +229 -229
- package/src/business/pdf/index.ts +10 -10
- package/src/business/pdf/server/index.ts +21 -21
- package/src/business/pdf/server/themes/default.ts +8 -8
- package/src/business/pdf/server/themes/index.ts +9 -9
- package/src/business/pdf/server/themes/types.ts +8 -8
- package/src/business/pdf/types.ts +272 -272
- package/src/business/projects/index.ts +2 -1
- package/src/business/projects/sse-events.ts +21 -0
- package/src/business/projects/types.ts +89 -89
- package/src/business/sales/api-schemas.ts +75 -75
- package/src/business/seo/__tests__/linking.test.ts +549 -549
- package/src/business/seo/__tests__/types.test.ts +404 -404
- package/src/business/seo/index.ts +2 -2
- package/src/business/seo/linking.ts +281 -281
- package/src/business/seo/types.ts +199 -199
- package/src/commands/queue/index.ts +3 -3
- package/src/commands/queue/schemas.test.ts +593 -593
- package/src/commands/queue/schemas.ts +125 -125
- package/src/commands/queue/sse-events.ts +61 -61
- package/src/commands/queue/types/action.ts +52 -52
- package/src/commands/queue/types/checkpoint.ts +44 -44
- package/src/commands/queue/types/index.ts +7 -7
- package/src/commands/queue/types/task.ts +116 -116
- package/src/commands/queue/types.ts +14 -14
- package/src/content/distribution-metadata.ts +61 -61
- package/src/content/index.ts +10 -10
- package/src/deployments/index.ts +22 -22
- package/src/execution/core/__tests__/archived-logs.test.ts +72 -72
- package/src/execution/core/index.ts +11 -11
- package/src/execution/core/runner-types.ts +80 -80
- package/src/execution/core/server/environment.ts +31 -31
- package/src/execution/core/sse-executions.ts +119 -119
- package/src/execution/core/types.ts +29 -29
- package/src/execution/engine/__tests__/fixtures/test-agents.ts +4 -4
- package/src/execution/engine/__tests__/timeout.test.ts +565 -565
- package/src/execution/engine/agent/__tests__/errors.test.ts +508 -508
- package/src/execution/engine/agent/actions/__tests__/processor.test.ts +531 -531
- package/src/execution/engine/agent/actions/executor.ts +205 -205
- package/src/execution/engine/agent/actions/navigate-knowledge-executor.ts +230 -230
- package/src/execution/engine/agent/actions/processor.ts +116 -116
- package/src/execution/engine/agent/actions/types.ts +70 -70
- package/src/execution/engine/agent/core/agent.ts +810 -810
- package/src/execution/engine/agent/core/types.ts +155 -155
- package/src/execution/engine/agent/errors.ts +251 -251
- package/src/execution/engine/agent/index.ts +78 -78
- package/src/execution/engine/agent/knowledge-map/types.ts +106 -106
- package/src/execution/engine/agent/knowledge-map/utils.ts +101 -101
- package/src/execution/engine/agent/memory/__tests__/manager.test.ts +754 -754
- package/src/execution/engine/agent/memory/domains.ts +99 -99
- package/src/execution/engine/agent/memory/manager.ts +365 -365
- package/src/execution/engine/agent/memory/processor.ts +66 -66
- package/src/execution/engine/agent/memory/types.ts +90 -90
- package/src/execution/engine/agent/memory/utils.ts +134 -134
- package/src/execution/engine/agent/observability/logging.ts +467 -467
- package/src/execution/engine/agent/observability/types.ts +64 -64
- package/src/execution/engine/agent/reasoning/adapters/agent-adapter-helpers.ts +349 -349
- package/src/execution/engine/agent/reasoning/processor.ts +92 -92
- package/src/execution/engine/agent/reasoning/prompt-sections/base-actions.ts +134 -134
- package/src/execution/engine/agent/reasoning/prompt-sections/completion.ts +49 -49
- package/src/execution/engine/agent/reasoning/prompt-sections/knowledge-map.ts +93 -93
- package/src/execution/engine/agent/reasoning/prompt-sections/memory.ts +65 -65
- package/src/execution/engine/agent/reasoning/prompt-sections/tools.ts +44 -44
- package/src/execution/engine/agent/reasoning/request-builder.ts +169 -169
- package/src/execution/engine/agent/reasoning/types.ts +18 -18
- package/src/execution/engine/base/errors.ts +118 -118
- package/src/execution/engine/base/index.ts +2 -2
- package/src/execution/engine/base/logging.ts +31 -31
- package/src/execution/engine/base/serialization.ts +324 -324
- package/src/execution/engine/base/types.ts +126 -126
- package/src/execution/engine/base/utils.ts +41 -41
- package/src/execution/engine/index.ts +434 -434
- package/src/execution/engine/interface/index.ts +1 -1
- package/src/execution/engine/interface/types.ts +62 -62
- package/src/execution/engine/llm/__tests__/model-info.test.ts +50 -50
- package/src/execution/engine/llm/__tests__/model-validation.test.ts +321 -321
- package/src/execution/engine/llm/__tests__/response-schema-validator.test.ts +115 -115
- package/src/execution/engine/llm/adapters/__tests__/adapter-factory.test.ts +375 -375
- package/src/execution/engine/llm/adapters/__tests__/anthropic-adapter.test.ts +463 -463
- package/src/execution/engine/llm/adapters/__tests__/anthropic.integration.test.ts +177 -177
- package/src/execution/engine/llm/adapters/__tests__/google-adapter.test.ts +722 -722
- package/src/execution/engine/llm/adapters/__tests__/google.integration.test.ts +376 -376
- package/src/execution/engine/llm/adapters/__tests__/openai-adapter.test.ts +551 -551
- package/src/execution/engine/llm/adapters/__tests__/openrouter-adapter.test.ts +563 -563
- package/src/execution/engine/llm/adapters/__tests__/openrouter.integration.test.ts +105 -105
- package/src/execution/engine/llm/adapters/__tests__/universal-adapter.test.ts +537 -537
- package/src/execution/engine/llm/adapters/circuit-breaker.ts +147 -147
- package/src/execution/engine/llm/adapters/index.ts +17 -17
- package/src/execution/engine/llm/adapters/mock-adapter.ts +116 -116
- package/src/execution/engine/llm/adapters/server/adapter-factory.ts +130 -130
- package/src/execution/engine/llm/adapters/server/anthropic.ts +137 -137
- package/src/execution/engine/llm/adapters/server/google.ts +283 -283
- package/src/execution/engine/llm/adapters/server/index.ts +12 -12
- package/src/execution/engine/llm/adapters/server/openai.ts +206 -206
- package/src/execution/engine/llm/adapters/server/openrouter.ts +235 -235
- package/src/execution/engine/llm/adapters/universal-adapter.ts +230 -230
- package/src/execution/engine/llm/errors.ts +186 -186
- package/src/execution/engine/llm/model-info.ts +332 -332
- package/src/execution/engine/llm/response-schema-validator.ts +113 -113
- package/src/execution/engine/llm/types.ts +86 -86
- package/src/execution/engine/test-utils/index.ts +6 -6
- package/src/execution/engine/test-utils/mocks.ts +56 -56
- package/src/execution/engine/tools/integration/base-integration-adapter.ts +50 -50
- package/src/execution/engine/tools/integration/index.ts +53 -53
- package/src/execution/engine/tools/integration/server/adapters/anymailfinder/anymailfinder-adapter.ts +73 -73
- package/src/execution/engine/tools/integration/server/adapters/anymailfinder/anymailfinder-tools.ts +209 -209
- package/src/execution/engine/tools/integration/server/adapters/anymailfinder/fetch/find-company-email/index.ts +82 -82
- package/src/execution/engine/tools/integration/server/adapters/anymailfinder/fetch/find-decision-maker-email/index.ts +122 -122
- package/src/execution/engine/tools/integration/server/adapters/anymailfinder/fetch/find-person-email/index.ts +89 -89
- package/src/execution/engine/tools/integration/server/adapters/anymailfinder/fetch/verify-email/index.ts +84 -84
- package/src/execution/engine/tools/integration/server/adapters/anymailfinder/index.ts +16 -16
- package/src/execution/engine/tools/integration/server/adapters/apify/__tests__/apify-run-actor.integration.test.ts +293 -293
- package/src/execution/engine/tools/integration/server/adapters/apify/apify-adapter.ts +100 -100
- package/src/execution/engine/tools/integration/server/adapters/apify/apify-tools.ts +217 -217
- package/src/execution/engine/tools/integration/server/adapters/apify/fetch/get-dataset-items/index.ts +92 -92
- package/src/execution/engine/tools/integration/server/adapters/apify/fetch/run-actor/index.ts +218 -218
- package/src/execution/engine/tools/integration/server/adapters/apify/fetch/start-actor/index.ts +87 -87
- package/src/execution/engine/tools/integration/server/adapters/apify/index.ts +11 -11
- package/src/execution/engine/tools/integration/server/adapters/attio/__tests__/attio-crud.integration.test.ts +361 -361
- package/src/execution/engine/tools/integration/server/adapters/attio/attio-adapter.ts +162 -162
- package/src/execution/engine/tools/integration/server/adapters/attio/attio-tools.ts +594 -594
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/create-attribute/index.ts +214 -214
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/create-note/index.ts +152 -152
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/create-record/index.ts +141 -141
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/delete-note/index.ts +86 -86
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/delete-record/index.ts +105 -105
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/get-record/index.ts +118 -118
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/list-attributes/index.ts +165 -165
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/list-notes/index.ts +96 -96
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/list-objects/index.ts +104 -104
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/list-records/index.ts +156 -156
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/update-attribute/index.ts +220 -220
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/update-record/index.ts +140 -140
- package/src/execution/engine/tools/integration/server/adapters/attio/fetch/utils/types.ts +146 -146
- package/src/execution/engine/tools/integration/server/adapters/attio/index.ts +31 -31
- package/src/execution/engine/tools/integration/server/adapters/gmail/gmail-adapter.ts +210 -210
- package/src/execution/engine/tools/integration/server/adapters/gmail/gmail-tools.ts +104 -104
- package/src/execution/engine/tools/integration/server/adapters/google-sheets/__tests__/google-sheets.integration.test.ts +261 -261
- package/src/execution/engine/tools/integration/server/adapters/google-sheets/google-sheets-adapter.ts +1189 -1189
- package/src/execution/engine/tools/integration/server/adapters/google-sheets/google-sheets-tools.ts +641 -641
- package/src/execution/engine/tools/integration/server/adapters/google-sheets/index.ts +18 -18
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/activate-campaign/index.ts +86 -86
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/add-to-campaign/__tests__/index.test.ts +289 -289
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/add-to-campaign/index.ts +154 -154
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/bulk-add-leads/__tests__/index.test.ts +325 -325
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/bulk-add-leads/index.ts +153 -153
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/bulk-delete-leads/index.ts +84 -84
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/create-campaign/index.ts +125 -125
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/create-inbox-test/index.ts +107 -107
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/delete-campaign/index.ts +85 -85
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-account-health/index.ts +91 -91
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-campaign/index.ts +92 -92
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-campaign-analytics/__tests__/index.test.ts +195 -195
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-campaign-analytics/index.ts +113 -113
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-daily-campaign-analytics/index.ts +104 -104
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-emails/index.ts +155 -155
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-step-analytics/__tests__/index.test.ts +196 -196
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/get-step-analytics/index.ts +102 -102
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/list-campaigns/__tests__/index.test.ts +189 -189
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/list-campaigns/index.ts +87 -87
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/list-leads/index.ts +112 -112
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/patch-lead/index.ts +76 -76
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/pause-campaign/index.ts +86 -86
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/remove-from-subsequence/index.ts +98 -98
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/send-reply/index.ts +126 -126
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/update-campaign/__tests__/index.test.ts +193 -193
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/update-campaign/index.ts +99 -99
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/update-interest-status/__tests__/index.test.ts +621 -621
- package/src/execution/engine/tools/integration/server/adapters/instantly/fetch/update-interest-status/index.ts +125 -125
- package/src/execution/engine/tools/integration/server/adapters/instantly/index.ts +29 -29
- package/src/execution/engine/tools/integration/server/adapters/instantly/instantly-adapter.ts +178 -178
- package/src/execution/engine/tools/integration/server/adapters/instantly/instantly-tools.ts +1473 -1473
- package/src/execution/engine/tools/integration/server/adapters/millionverifier/fetch/check-credits/index.ts +59 -59
- package/src/execution/engine/tools/integration/server/adapters/millionverifier/fetch/verify-email/index.ts +102 -102
- package/src/execution/engine/tools/integration/server/adapters/millionverifier/index.ts +17 -17
- package/src/execution/engine/tools/integration/server/adapters/millionverifier/millionverifier-adapter.ts +80 -80
- package/src/execution/engine/tools/integration/server/adapters/millionverifier/millionverifier-tools.ts +102 -102
- package/src/execution/engine/tools/integration/server/adapters/resend/fetch/get-email/index.ts +102 -102
- package/src/execution/engine/tools/integration/server/adapters/resend/fetch/send-email/index.ts +134 -134
- package/src/execution/engine/tools/integration/server/adapters/resend/fetch/utils/types.ts +75 -75
- package/src/execution/engine/tools/integration/server/adapters/resend/index.ts +27 -27
- package/src/execution/engine/tools/integration/server/adapters/resend/resend-adapter.ts +108 -108
- package/src/execution/engine/tools/integration/server/adapters/resend/resend-tools.ts +132 -132
- package/src/execution/engine/tools/integration/server/adapters/signature-api/fetch/create-envelope/index.ts +274 -274
- package/src/execution/engine/tools/integration/server/adapters/signature-api/fetch/download-document/index.ts +230 -230
- package/src/execution/engine/tools/integration/server/adapters/signature-api/fetch/get-envelope/index.ts +133 -133
- package/src/execution/engine/tools/integration/server/adapters/signature-api/fetch/void-envelope/index.ts +90 -90
- package/src/execution/engine/tools/integration/server/adapters/stripe/fetch/utils/types.ts +210 -210
- package/src/execution/engine/tools/integration/server/adapters/stripe/stripe-adapter.ts +517 -517
- package/src/execution/engine/tools/integration/server/adapters/stripe/stripe-tools.ts +309 -309
- package/src/execution/engine/tools/integration/server/adapters/tomba/fetch/domain-search/index.ts +133 -133
- package/src/execution/engine/tools/integration/server/adapters/tomba/fetch/email-finder/index.ts +122 -122
- package/src/execution/engine/tools/integration/server/adapters/tomba/fetch/email-verifier/index.ts +111 -111
- package/src/execution/engine/tools/integration/server/adapters/tomba/index.ts +11 -11
- package/src/execution/engine/tools/integration/server/adapters/tomba/tomba-adapter.ts +78 -78
- package/src/execution/engine/tools/integration/server/adapters/tomba/tomba-tools.ts +222 -222
- package/src/execution/engine/tools/integration/server/index.ts +61 -61
- package/src/execution/engine/tools/integration/service.ts +161 -161
- package/src/execution/engine/tools/integration/tool.ts +253 -253
- package/src/execution/engine/tools/integration/types/anymailfinder.ts +74 -74
- package/src/execution/engine/tools/integration/types/apify.ts +92 -92
- package/src/execution/engine/tools/integration/types/index.ts +19 -19
- package/src/execution/engine/tools/integration/types/instantly.ts +557 -557
- package/src/execution/engine/tools/integration/types/millionverifier.ts +56 -56
- package/src/execution/engine/tools/integration/types/stripe.ts +162 -162
- package/src/execution/engine/tools/integration/types/tomba.ts +94 -94
- package/src/execution/engine/tools/lead-service-types.ts +884 -884
- package/src/execution/engine/tools/llm/index.ts +11 -11
- package/src/execution/engine/tools/llm/server/index.ts +8 -8
- package/src/execution/engine/tools/llm/server/llm-call-tool.ts +118 -118
- package/src/execution/engine/tools/platform/__tests__/pdf.test.ts +441 -441
- package/src/execution/engine/tools/platform/acquisition/company-tools.ts +248 -248
- package/src/execution/engine/tools/platform/acquisition/contact-tools.ts +319 -319
- package/src/execution/engine/tools/platform/acquisition/index.ts +43 -43
- package/src/execution/engine/tools/platform/acquisition/list-tools.ts +148 -148
- package/src/execution/engine/tools/platform/acquisition/types.ts +260 -260
- package/src/execution/engine/tools/platform/email/index.ts +122 -122
- package/src/execution/engine/tools/platform/email/types.ts +96 -96
- package/src/execution/engine/tools/platform/index.ts +157 -157
- package/src/execution/engine/tools/platform/notification.ts +81 -81
- package/src/execution/engine/tools/platform/pdf/index.ts +110 -110
- package/src/execution/engine/tools/platform/pdf/types.ts +77 -77
- package/src/execution/engine/tools/platform/scheduler.ts +87 -87
- package/src/execution/engine/tools/platform/storage/index.ts +370 -370
- package/src/execution/engine/tools/platform/types.ts +148 -148
- package/src/execution/engine/tools/registry.ts +700 -699
- package/src/execution/engine/tools/tool-maps.ts +786 -786
- package/src/execution/engine/tools/types.ts +233 -233
- package/src/execution/engine/workflow/__tests__/errors.test.ts +139 -139
- package/src/execution/engine/workflow/errors.ts +63 -63
- package/src/execution/engine/workflow/helpers/index.ts +11 -11
- package/src/execution/engine/workflow/helpers/server/index.ts +8 -8
- package/src/execution/engine/workflow/helpers/server/llm-call.ts +93 -93
- package/src/execution/engine/workflow/index.ts +19 -19
- package/src/execution/engine/workflow/log-truncate.ts +26 -26
- package/src/execution/engine/workflow/logging.ts +191 -191
- package/src/execution/engine/workflow/types.ts +182 -182
- package/src/execution/engine/workflow/utils.ts +280 -280
- package/src/execution/engine/workflow/workflow.ts +168 -168
- package/src/execution/index.ts +3 -3
- package/src/execution/scheduler/__tests__/api-schemas.test.ts +733 -733
- package/src/execution/scheduler/__tests__/utils.test.ts +1009 -1009
- package/src/execution/scheduler/api-schemas.ts +296 -296
- package/src/execution/scheduler/index.ts +50 -50
- package/src/execution/scheduler/schemas.ts +264 -264
- package/src/execution/scheduler/types.ts +111 -111
- package/src/execution/scheduler/utils.ts +364 -364
- package/src/forms/index.ts +7 -7
- package/src/forms/schemas.ts +69 -69
- package/src/forms/types.ts +70 -70
- package/src/index.ts +71 -60
- package/src/integrations/credentials/__tests__/schemas.test.ts +82 -82
- package/src/integrations/credentials/__tests__/utils.test.ts +144 -144
- package/src/integrations/credentials/api-schemas.ts +143 -143
- package/src/integrations/credentials/index.ts +32 -32
- package/src/integrations/credentials/schemas.ts +164 -164
- package/src/integrations/credentials/utils.ts +59 -59
- package/src/integrations/oauth/__tests__/provider-registry.test.ts +59 -59
- package/src/integrations/oauth/api-schemas.ts +92 -92
- package/src/integrations/oauth/index.ts +19 -19
- package/src/integrations/oauth/provider-registry.ts +61 -61
- package/src/integrations/oauth/server/__tests__/refresh-concurrent.test.ts +183 -183
- package/src/integrations/oauth/server/__tests__/refresh.test.ts +577 -577
- package/src/integrations/oauth/server/credentials.ts +39 -39
- package/src/integrations/oauth/server/refresh.ts +214 -214
- package/src/integrations/oauth/types.ts +34 -34
- package/src/integrations/webhook-endpoints/__tests__/api-schemas.test.ts +318 -318
- package/src/integrations/webhook-endpoints/api-schemas.ts +102 -102
- package/src/integrations/webhook-endpoints/index.ts +28 -28
- package/src/integrations/webhook-endpoints/types.ts +51 -51
- package/src/operations/activities/api-schemas.ts +79 -79
- package/src/operations/activities/index.ts +9 -9
- package/src/operations/activities/sse-events.ts +30 -30
- package/src/operations/activities/types.ts +63 -63
- package/src/operations/debug-logs/client.ts +60 -60
- package/src/operations/debug-logs/debug-logger.ts +83 -83
- package/src/operations/debug-logs/index.ts +8 -8
- package/src/operations/debug-logs/server.ts +19 -19
- package/src/operations/debug-logs/types.ts +33 -33
- package/src/operations/index.ts +50 -50
- package/src/operations/notifications/api-schemas.ts +91 -91
- package/src/operations/notifications/index.ts +3 -3
- package/src/operations/notifications/sse-events.ts +21 -21
- package/src/operations/notifications/types.ts +47 -47
- package/src/operations/observability/__tests__/openrouter-cost-flow.test.ts +297 -297
- package/src/operations/observability/__tests__/utils.test.ts +54 -54
- package/src/operations/observability/ai-usage-collector.ts +64 -64
- package/src/operations/observability/index.ts +13 -13
- package/src/operations/observability/metrics-collector.ts +49 -49
- package/src/operations/observability/schemas.ts +39 -39
- package/src/operations/observability/types.ts +463 -463
- package/src/operations/observability/utils.ts +77 -77
- package/src/operations/sessions/__tests__/manager.test.ts +821 -821
- package/src/operations/sessions/index.ts +26 -26
- package/src/operations/sessions/server/manager.ts +90 -90
- package/src/operations/sessions/server/session.ts +180 -180
- package/src/operations/sessions/types.ts +98 -98
- package/src/operations/triggers/index.ts +12 -12
- package/src/operations/triggers/webhook/definitions/instantly-account-error.ts +44 -44
- package/src/operations/triggers/webhook/definitions/instantly-auto-reply-received.ts +51 -51
- package/src/operations/triggers/webhook/definitions/instantly-campaign-completed.ts +45 -45
- package/src/operations/triggers/webhook/definitions/instantly-email-bounced.ts +49 -49
- package/src/operations/triggers/webhook/definitions/instantly-lead-unsubscribed.ts +45 -45
- package/src/operations/triggers/webhook/definitions/instantly-reply-received.ts +54 -54
- package/src/operations/triggers/webhook/index.ts +35 -35
- package/src/operations/triggers/webhook/types.ts +74 -74
- package/src/organization-model/README.md +97 -97
- package/src/organization-model/__tests__/defaults.test.ts +175 -175
- package/src/organization-model/__tests__/domains/customers.test.ts +295 -295
- package/src/organization-model/__tests__/domains/goals.test.ts +479 -479
- package/src/organization-model/__tests__/domains/identity.test.ts +279 -279
- package/src/organization-model/__tests__/domains/navigation.test.ts +212 -212
- package/src/organization-model/__tests__/domains/offerings.test.ts +419 -419
- package/src/organization-model/__tests__/domains/operations.test.ts +203 -203
- package/src/organization-model/__tests__/domains/resource-mappings.test.ts +362 -362
- package/src/organization-model/__tests__/domains/roles.test.ts +347 -347
- package/src/organization-model/__tests__/domains/statuses.test.ts +243 -243
- package/src/organization-model/__tests__/foundation.test.ts +105 -105
- package/src/organization-model/__tests__/graph.test.ts +894 -894
- package/src/organization-model/__tests__/resolve.test.ts +690 -690
- package/src/organization-model/__tests__/schema.test.ts +407 -407
- package/src/organization-model/contracts.ts +14 -14
- package/src/organization-model/defaults.ts +148 -148
- package/src/organization-model/domains/branding.ts +22 -22
- package/src/organization-model/domains/customers.ts +75 -75
- package/src/organization-model/domains/features.ts +22 -22
- package/src/organization-model/domains/goals.ts +80 -80
- package/src/organization-model/domains/identity.ts +94 -94
- package/src/organization-model/domains/navigation.ts +391 -391
- package/src/organization-model/domains/offerings.ts +66 -66
- package/src/organization-model/domains/operations.ts +85 -85
- package/src/organization-model/domains/projects.ts +48 -48
- package/src/organization-model/domains/prospecting.ts +33 -33
- package/src/organization-model/domains/roles.ts +55 -55
- package/src/organization-model/domains/sales.ts +94 -94
- package/src/organization-model/domains/shared.ts +62 -62
- package/src/organization-model/domains/statuses.ts +130 -130
- package/src/organization-model/foundation.ts +97 -97
- package/src/organization-model/graph/build.ts +399 -399
- package/src/organization-model/graph/index.ts +4 -4
- package/src/organization-model/graph/schema.ts +48 -48
- package/src/organization-model/graph/types.ts +40 -40
- package/src/organization-model/index.ts +13 -13
- package/src/organization-model/organization-graph.mdx +272 -272
- package/src/organization-model/organization-model.mdx +320 -320
- package/src/organization-model/published.ts +85 -85
- package/src/organization-model/resolve.ts +66 -66
- package/src/organization-model/schema.ts +287 -287
- package/src/organization-model/types.ts +46 -46
- package/src/platform/api/index.ts +1 -1
- package/src/platform/api/types.ts +35 -35
- package/src/platform/constants/http.ts +37 -37
- package/src/platform/constants/index.ts +5 -5
- package/src/platform/constants/limits.ts +32 -32
- package/src/platform/constants/resilience.ts +51 -51
- package/src/platform/constants/timeouts.ts +20 -20
- package/src/platform/constants/versions.ts +3 -3
- package/src/platform/registry/__tests__/resource-registry-static.test.ts +347 -347
- package/src/platform/registry/__tests__/resource-registry.integration.test.ts +1028 -1028
- package/src/platform/registry/__tests__/resource-registry.list-executable.test.ts +393 -393
- package/src/platform/registry/__tests__/resource-registry.test.ts +2005 -2005
- package/src/platform/registry/__tests__/serialization.test.ts +1127 -1127
- package/src/platform/registry/command-view.ts +180 -180
- package/src/platform/registry/domains.ts +165 -165
- package/src/platform/registry/index.ts +93 -93
- package/src/platform/registry/reserved.ts +24 -24
- package/src/platform/registry/resource-metadata.ts +59 -59
- package/src/platform/registry/resource-registry.command-queue-groups.test.ts +129 -129
- package/src/platform/registry/resource-registry.ts +876 -876
- package/src/platform/registry/serialization.ts +273 -273
- package/src/platform/registry/serialized-types.ts +231 -231
- package/src/platform/registry/stats-types.ts +66 -66
- package/src/platform/registry/types.ts +404 -404
- package/src/platform/registry/validation.ts +513 -513
- package/src/platform/resilience/__tests__/rate-limiter.test.ts +471 -471
- package/src/platform/resilience/circuit-breaker.ts +164 -164
- package/src/platform/resilience/errors.ts +68 -68
- package/src/platform/resilience/http-error-mapper.ts +129 -129
- package/src/platform/resilience/index.ts +93 -93
- package/src/platform/resilience/rate-limiter-types.ts +46 -46
- package/src/platform/resilience/rate-limiter.ts +140 -140
- package/src/platform/resilience/retry.ts +89 -89
- package/src/platform/resilience/timeout.ts +63 -63
- package/src/platform/sse/events.ts +37 -34
- package/src/platform/sse/index.ts +7 -7
- package/src/platform/utils/__tests__/validation.test.ts +1083 -1083
- package/src/platform/utils/currency.ts +96 -96
- package/src/platform/utils/debounce.ts +52 -52
- package/src/platform/utils/error.ts +41 -41
- package/src/platform/utils/hmac.test.ts +97 -97
- package/src/platform/utils/index.ts +32 -32
- package/src/platform/utils/server/betterstack-logger.ts +210 -210
- package/src/platform/utils/server/hmac.ts +44 -44
- package/src/platform/utils/server/unsubscribe.ts +111 -111
- package/src/platform/utils/token-counter.ts +96 -96
- package/src/platform/utils/validation.ts +425 -425
- package/src/projects/api-schemas.ts +268 -268
- package/src/published.ts +1 -1
- package/src/reference/_generated/contracts.md +611 -607
- package/src/reference/glossary.md +105 -105
- package/src/requests/__tests__/api-schemas.test.ts +277 -277
- package/src/requests/api-schemas.ts +83 -83
- package/src/requests/index.ts +1 -1
- package/src/scaffold-registry/__tests__/index.test.ts +17 -0
- package/src/scaffold-registry/__tests__/schema.test.ts +329 -230
- package/src/scaffold-registry/index.ts +205 -189
- package/src/scaffold-registry/schema.ts +196 -128
- package/src/server.ts +272 -272
- package/src/supabase/database.types.ts +2719 -2719
- package/src/supabase/helpers.ts +20 -20
- package/src/supabase/index.ts +52 -52
- package/src/supabase/server/client.ts +58 -58
- package/src/test-utils/README.md +38 -38
- package/src/test-utils/browser-mocks.ts +54 -54
- package/src/test-utils/fixtures/api-keys.ts +52 -52
- package/src/test-utils/fixtures/index.ts +4 -4
- package/src/test-utils/fixtures/memberships.ts +80 -80
- package/src/test-utils/fixtures/organizations.ts +69 -69
- package/src/test-utils/fixtures/users.ts +79 -79
- package/src/test-utils/index.ts +11 -11
- package/src/test-utils/mocks/index.ts +2 -2
- package/src/test-utils/mocks/supabase.ts +142 -142
- package/src/test-utils/mocks/workos.ts +108 -108
- package/src/test-utils/rls/RLSTestContext.ts +556 -556
- package/src/test-utils/rls/index.ts +1 -1
package/src/execution/engine/tools/integration/server/adapters/google-sheets/google-sheets-tools.ts
CHANGED
|
@@ -1,641 +1,641 @@
|
|
|
1
|
-
import { z } from 'zod'
|
|
2
|
-
import { createIntegrationTool } from '../../../tool'
|
|
3
|
-
import type { Tool } from '../../../../types'
|
|
4
|
-
|
|
5
|
-
// ============================================
|
|
6
|
-
// Core Methods - Direct API Operations
|
|
7
|
-
// ============================================
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Create Google Sheets read tool
|
|
11
|
-
*
|
|
12
|
-
* Reads data from a spreadsheet range using A1 notation.
|
|
13
|
-
*
|
|
14
|
-
* @param credentialName - Name of credential in credentials table
|
|
15
|
-
* @returns Tool that reads spreadsheet data
|
|
16
|
-
*
|
|
17
|
-
* @example
|
|
18
|
-
* const readTool = createGoogleSheetsReadTool('elevasis-google-sheets')
|
|
19
|
-
*/
|
|
20
|
-
export function createGoogleSheetsReadTool(credentialName: string): Tool {
|
|
21
|
-
return createIntegrationTool({
|
|
22
|
-
name: 'google_sheets_read',
|
|
23
|
-
description: `Read data from a Google Sheets range. Returns 2D array of cell values.
|
|
24
|
-
|
|
25
|
-
USAGE:
|
|
26
|
-
Specify spreadsheet ID and range in A1 notation to retrieve cell values.
|
|
27
|
-
|
|
28
|
-
A1 NOTATION EXAMPLES:
|
|
29
|
-
- "Sheet1!A1:C10" - Cells A1 through C10 on Sheet1
|
|
30
|
-
- "Sheet1!A:A" - Entire column A on Sheet1
|
|
31
|
-
- "Sheet1!1:2" - Rows 1 and 2 on Sheet1
|
|
32
|
-
- "'Sheet Name'!A1:B2" - Sheet names with spaces need single quotes
|
|
33
|
-
|
|
34
|
-
OUTPUT:
|
|
35
|
-
Returns 2D array where each inner array is a row:
|
|
36
|
-
[["Name", "Id"], ["Alice", "1"], ["Bob", "2"]]
|
|
37
|
-
|
|
38
|
-
TIP: Get spreadsheet ID from URL:
|
|
39
|
-
https://docs.google.com/spreadsheets/d/{SPREADSHEET_ID}/edit`,
|
|
40
|
-
|
|
41
|
-
inputSchema: z.object({
|
|
42
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
43
|
-
range: z.string().describe('A1 notation range (e.g., "Sheet1!A1:C10")')
|
|
44
|
-
}),
|
|
45
|
-
|
|
46
|
-
outputSchema: z.object({
|
|
47
|
-
values: z.array(z.array(z.string())).describe('2D array of cell values')
|
|
48
|
-
}),
|
|
49
|
-
|
|
50
|
-
integration: 'google-sheets' as const,
|
|
51
|
-
method: 'readSheet' as const,
|
|
52
|
-
credentialName
|
|
53
|
-
})
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* Create Google Sheets write tool
|
|
58
|
-
*
|
|
59
|
-
* Writes data to a spreadsheet range, overwriting existing data.
|
|
60
|
-
*
|
|
61
|
-
* @param credentialName - Name of credential in credentials table
|
|
62
|
-
* @returns Tool that writes spreadsheet data
|
|
63
|
-
*/
|
|
64
|
-
export function createGoogleSheetsWriteTool(credentialName: string): Tool {
|
|
65
|
-
return createIntegrationTool({
|
|
66
|
-
name: 'google_sheets_write',
|
|
67
|
-
description: `Write data to a Google Sheets range. Overwrites existing data in the range.
|
|
68
|
-
|
|
69
|
-
USAGE:
|
|
70
|
-
Provide 2D array of values to write to the specified range.
|
|
71
|
-
|
|
72
|
-
INPUT FORMAT:
|
|
73
|
-
Values must be a 2D array (array of rows):
|
|
74
|
-
[["Name", "Id"], ["Alice", "1"], ["Bob", "2"]]
|
|
75
|
-
|
|
76
|
-
FORMULAS:
|
|
77
|
-
Use USER_ENTERED format - formulas like "=SUM(A1:A10)" will execute.
|
|
78
|
-
|
|
79
|
-
EXAMPLE:
|
|
80
|
-
{
|
|
81
|
-
"spreadsheetId": "1abc...",
|
|
82
|
-
"range": "Sheet1!A1:B3",
|
|
83
|
-
"values": [["Header1", "Header2"], ["Value1", "Value2"]]
|
|
84
|
-
}`,
|
|
85
|
-
|
|
86
|
-
inputSchema: z.object({
|
|
87
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
88
|
-
range: z.string().describe('A1 notation range to write to'),
|
|
89
|
-
values: z.array(z.array(z.string())).describe('2D array of values to write')
|
|
90
|
-
}),
|
|
91
|
-
|
|
92
|
-
outputSchema: z.object({
|
|
93
|
-
updatedCells: z.number().describe('Number of cells updated')
|
|
94
|
-
}),
|
|
95
|
-
|
|
96
|
-
integration: 'google-sheets' as const,
|
|
97
|
-
method: 'writeSheet' as const,
|
|
98
|
-
credentialName
|
|
99
|
-
})
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* Create Google Sheets append tool
|
|
104
|
-
*
|
|
105
|
-
* Appends rows to the end of a table without overwriting existing data.
|
|
106
|
-
*
|
|
107
|
-
* @param credentialName - Name of credential in credentials table
|
|
108
|
-
* @returns Tool that appends rows to spreadsheet
|
|
109
|
-
*/
|
|
110
|
-
export function createGoogleSheetsAppendTool(credentialName: string): Tool {
|
|
111
|
-
return createIntegrationTool({
|
|
112
|
-
name: 'google_sheets_append',
|
|
113
|
-
description: `Append rows to the end of a Google Sheets table. Finds the first empty row and writes there.
|
|
114
|
-
|
|
115
|
-
USE CASES:
|
|
116
|
-
- Add new records to a data table
|
|
117
|
-
- Log entries to a tracking sheet
|
|
118
|
-
- Append items without knowing the last row
|
|
119
|
-
|
|
120
|
-
RANGE FORMAT:
|
|
121
|
-
Specify the table range (columns), e.g., "Sheet1!A:E" for a 5-column table.
|
|
122
|
-
The API finds the first empty row automatically.
|
|
123
|
-
|
|
124
|
-
EXAMPLE:
|
|
125
|
-
{
|
|
126
|
-
"spreadsheetId": "1abc...",
|
|
127
|
-
"range": "Sheet1!A:C",
|
|
128
|
-
"values": [["NewItem", "123", "Description"]]
|
|
129
|
-
}`,
|
|
130
|
-
|
|
131
|
-
inputSchema: z.object({
|
|
132
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
133
|
-
range: z.string().describe('Table range to append to (e.g., "Sheet1!A:E")'),
|
|
134
|
-
values: z.array(z.array(z.string())).describe('Rows to append (2D array)')
|
|
135
|
-
}),
|
|
136
|
-
|
|
137
|
-
outputSchema: z.object({
|
|
138
|
-
updatedRows: z.number().describe('Number of rows appended')
|
|
139
|
-
}),
|
|
140
|
-
|
|
141
|
-
integration: 'google-sheets' as const,
|
|
142
|
-
method: 'appendRows' as const,
|
|
143
|
-
credentialName
|
|
144
|
-
})
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
/**
|
|
148
|
-
* Create Google Sheets clear tool
|
|
149
|
-
*
|
|
150
|
-
* Clears values from a range while preserving formatting.
|
|
151
|
-
*
|
|
152
|
-
* @param credentialName - Name of credential in credentials table
|
|
153
|
-
* @returns Tool that clears spreadsheet range
|
|
154
|
-
*/
|
|
155
|
-
export function createGoogleSheetsClearTool(credentialName: string): Tool {
|
|
156
|
-
return createIntegrationTool({
|
|
157
|
-
name: 'google_sheets_clear',
|
|
158
|
-
description: `Clear all values from a Google Sheets range. Preserves formatting and data validation.
|
|
159
|
-
|
|
160
|
-
USE CASES:
|
|
161
|
-
- Clear data while keeping headers (e.g., clear A2:E100, keep row 1)
|
|
162
|
-
- Reset a section before writing new data
|
|
163
|
-
- Remove sensitive data while preserving structure
|
|
164
|
-
|
|
165
|
-
EXAMPLE:
|
|
166
|
-
{
|
|
167
|
-
"spreadsheetId": "1abc...",
|
|
168
|
-
"range": "Sheet1!A2:E100"
|
|
169
|
-
}`,
|
|
170
|
-
|
|
171
|
-
inputSchema: z.object({
|
|
172
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
173
|
-
range: z.string().describe('A1 notation range to clear')
|
|
174
|
-
}),
|
|
175
|
-
|
|
176
|
-
outputSchema: z.object({
|
|
177
|
-
clearedRange: z.string().describe('The range that was cleared')
|
|
178
|
-
}),
|
|
179
|
-
|
|
180
|
-
integration: 'google-sheets' as const,
|
|
181
|
-
method: 'clearRange' as const,
|
|
182
|
-
credentialName
|
|
183
|
-
})
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
/**
|
|
187
|
-
* Create Google Sheets metadata tool
|
|
188
|
-
*
|
|
189
|
-
* Gets spreadsheet metadata including title and list of sheets.
|
|
190
|
-
*
|
|
191
|
-
* @param credentialName - Name of credential in credentials table
|
|
192
|
-
* @returns Tool that retrieves spreadsheet metadata
|
|
193
|
-
*/
|
|
194
|
-
export function createGoogleSheetsMetadataTool(credentialName: string): Tool {
|
|
195
|
-
return createIntegrationTool({
|
|
196
|
-
name: 'google_sheets_metadata',
|
|
197
|
-
description: `Get spreadsheet metadata including title and list of sheets.
|
|
198
|
-
|
|
199
|
-
USE CASES:
|
|
200
|
-
- Discover available sheets before reading data
|
|
201
|
-
- Get sheet names for building ranges
|
|
202
|
-
- Verify spreadsheet access
|
|
203
|
-
|
|
204
|
-
OUTPUT:
|
|
205
|
-
Returns spreadsheet title and array of sheet info:
|
|
206
|
-
{
|
|
207
|
-
"title": "My Spreadsheet",
|
|
208
|
-
"sheets": [
|
|
209
|
-
{ "sheetId": 0, "title": "Sheet1", "index": 0 },
|
|
210
|
-
{ "sheetId": 123, "title": "Data", "index": 1 }
|
|
211
|
-
]
|
|
212
|
-
}`,
|
|
213
|
-
|
|
214
|
-
inputSchema: z.object({
|
|
215
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL')
|
|
216
|
-
}),
|
|
217
|
-
|
|
218
|
-
outputSchema: z.object({
|
|
219
|
-
title: z.string().describe('Spreadsheet title'),
|
|
220
|
-
sheets: z.array(z.object({
|
|
221
|
-
sheetId: z.number(),
|
|
222
|
-
title: z.string(),
|
|
223
|
-
index: z.number()
|
|
224
|
-
})).describe('List of sheets in the spreadsheet')
|
|
225
|
-
}),
|
|
226
|
-
|
|
227
|
-
integration: 'google-sheets' as const,
|
|
228
|
-
method: 'getSpreadsheetMetadata' as const,
|
|
229
|
-
credentialName
|
|
230
|
-
})
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
/**
|
|
234
|
-
* Create Google Sheets batch update tool
|
|
235
|
-
*
|
|
236
|
-
* Updates multiple ranges in a single request for efficiency.
|
|
237
|
-
*
|
|
238
|
-
* @param credentialName - Name of credential in credentials table
|
|
239
|
-
* @returns Tool that batch updates spreadsheet
|
|
240
|
-
*/
|
|
241
|
-
export function createGoogleSheetsBatchUpdateTool(credentialName: string): Tool {
|
|
242
|
-
return createIntegrationTool({
|
|
243
|
-
name: 'google_sheets_batch_update',
|
|
244
|
-
description: `Update multiple ranges in a single request. More efficient than multiple write calls.
|
|
245
|
-
|
|
246
|
-
USE CASES:
|
|
247
|
-
- Update cells in multiple sheets at once
|
|
248
|
-
- Write to non-contiguous ranges
|
|
249
|
-
- Batch multiple small updates for efficiency
|
|
250
|
-
|
|
251
|
-
EXAMPLE:
|
|
252
|
-
{
|
|
253
|
-
"spreadsheetId": "1abc...",
|
|
254
|
-
"data": [
|
|
255
|
-
{ "range": "Sheet1!A1", "values": [["Updated"]] },
|
|
256
|
-
{ "range": "Sheet2!B2:C3", "values": [["X", "Y"], ["Z", "W"]] }
|
|
257
|
-
]
|
|
258
|
-
}`,
|
|
259
|
-
|
|
260
|
-
inputSchema: z.object({
|
|
261
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
262
|
-
data: z.array(z.object({
|
|
263
|
-
range: z.string().describe('A1 notation range'),
|
|
264
|
-
values: z.array(z.array(z.string())).describe('2D array of values')
|
|
265
|
-
})).describe('Array of range/values pairs to update')
|
|
266
|
-
}),
|
|
267
|
-
|
|
268
|
-
outputSchema: z.object({
|
|
269
|
-
totalUpdatedCells: z.number().describe('Total number of cells updated'),
|
|
270
|
-
totalUpdatedRows: z.number().describe('Total number of rows updated')
|
|
271
|
-
}),
|
|
272
|
-
|
|
273
|
-
integration: 'google-sheets' as const,
|
|
274
|
-
method: 'batchUpdate' as const,
|
|
275
|
-
credentialName
|
|
276
|
-
})
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
// ============================================
|
|
280
|
-
// Workflow-Friendly Methods - Higher-Level Abstractions
|
|
281
|
-
// ============================================
|
|
282
|
-
|
|
283
|
-
/**
|
|
284
|
-
* Create Google Sheets get headers tool
|
|
285
|
-
*
|
|
286
|
-
* Gets column headers from the first row of a sheet.
|
|
287
|
-
*
|
|
288
|
-
* @param credentialName - Name of credential in credentials table
|
|
289
|
-
* @returns Tool that retrieves headers
|
|
290
|
-
*/
|
|
291
|
-
export function createGoogleSheetsGetHeadersTool(credentialName: string): Tool {
|
|
292
|
-
return createIntegrationTool({
|
|
293
|
-
name: 'google_sheets_get_headers',
|
|
294
|
-
description: `Get column headers from the first row of a sheet.
|
|
295
|
-
|
|
296
|
-
USE CASES:
|
|
297
|
-
- Discover column structure before reading/writing
|
|
298
|
-
- Get column mapping for workflow operations
|
|
299
|
-
- Validate expected columns exist
|
|
300
|
-
|
|
301
|
-
OUTPUT:
|
|
302
|
-
Returns headers array and column map (header name to column letter):
|
|
303
|
-
{
|
|
304
|
-
"headers": ["Name", "Id", "Description"],
|
|
305
|
-
"columnCount": 3,
|
|
306
|
-
"columnMap": { "Name": "A", "Id": "B", "Description": "C" }
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
TIP: Use columnMap to build ranges dynamically based on header names.`,
|
|
310
|
-
|
|
311
|
-
inputSchema: z.object({
|
|
312
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
313
|
-
sheetName: z.string().describe('Sheet name (e.g., "Sheet1")')
|
|
314
|
-
}),
|
|
315
|
-
|
|
316
|
-
outputSchema: z.object({
|
|
317
|
-
headers: z.array(z.string()).describe('Column headers from first row'),
|
|
318
|
-
columnCount: z.number().describe('Number of columns'),
|
|
319
|
-
columnMap: z.record(z.string(), z.string()).describe('Map of header name to column letter')
|
|
320
|
-
}),
|
|
321
|
-
|
|
322
|
-
integration: 'google-sheets' as const,
|
|
323
|
-
method: 'getHeaders' as const,
|
|
324
|
-
credentialName
|
|
325
|
-
})
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
/**
|
|
329
|
-
* Create Google Sheets get last row tool
|
|
330
|
-
*
|
|
331
|
-
* Finds the last row with data in a column.
|
|
332
|
-
*
|
|
333
|
-
* @param credentialName - Name of credential in credentials table
|
|
334
|
-
* @returns Tool that finds last row
|
|
335
|
-
*/
|
|
336
|
-
export function createGoogleSheetsGetLastRowTool(credentialName: string): Tool {
|
|
337
|
-
return createIntegrationTool({
|
|
338
|
-
name: 'google_sheets_get_last_row',
|
|
339
|
-
description: `Find the last row with data in a sheet.
|
|
340
|
-
|
|
341
|
-
USE CASES:
|
|
342
|
-
- Determine where to write next row
|
|
343
|
-
- Check if sheet has any data
|
|
344
|
-
- Get row count for a column
|
|
345
|
-
|
|
346
|
-
OUTPUT:
|
|
347
|
-
{
|
|
348
|
-
"lastRow": 50,
|
|
349
|
-
"isEmpty": false
|
|
350
|
-
}`,
|
|
351
|
-
|
|
352
|
-
inputSchema: z.object({
|
|
353
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
354
|
-
sheetName: z.string().describe('Sheet name'),
|
|
355
|
-
column: z.string().optional().describe('Column to check (default: "A")')
|
|
356
|
-
}),
|
|
357
|
-
|
|
358
|
-
outputSchema: z.object({
|
|
359
|
-
lastRow: z.number().describe('Last row number with data'),
|
|
360
|
-
isEmpty: z.boolean().describe('True if column is empty')
|
|
361
|
-
}),
|
|
362
|
-
|
|
363
|
-
integration: 'google-sheets' as const,
|
|
364
|
-
method: 'getLastRow' as const,
|
|
365
|
-
credentialName
|
|
366
|
-
})
|
|
367
|
-
}
|
|
368
|
-
|
|
369
|
-
/**
|
|
370
|
-
* Create Google Sheets find row tool
|
|
371
|
-
*
|
|
372
|
-
* Finds a row by searching for a value in a column.
|
|
373
|
-
*
|
|
374
|
-
* @param credentialName - Name of credential in credentials table
|
|
375
|
-
* @returns Tool that finds rows by value
|
|
376
|
-
*/
|
|
377
|
-
export function createGoogleSheetsFindRowTool(credentialName: string): Tool {
|
|
378
|
-
return createIntegrationTool({
|
|
379
|
-
name: 'google_sheets_find_row',
|
|
380
|
-
description: `Find a row by searching for a value in a specific column.
|
|
381
|
-
|
|
382
|
-
USE CASES:
|
|
383
|
-
- Look up a record by ID or name
|
|
384
|
-
- Find a row to update
|
|
385
|
-
- Check if a value exists in the sheet
|
|
386
|
-
|
|
387
|
-
OUTPUT (when found):
|
|
388
|
-
{
|
|
389
|
-
"found": true,
|
|
390
|
-
"rowNumber": 5,
|
|
391
|
-
"rowData": ["John", "123", "john@example.com"],
|
|
392
|
-
"headers": ["Name", "Id", "Email"]
|
|
393
|
-
}
|
|
394
|
-
|
|
395
|
-
OUTPUT (not found):
|
|
396
|
-
{
|
|
397
|
-
"found": false,
|
|
398
|
-
"rowNumber": null,
|
|
399
|
-
"rowData": null,
|
|
400
|
-
"headers": ["Name", "Id", "Email"]
|
|
401
|
-
}`,
|
|
402
|
-
|
|
403
|
-
inputSchema: z.object({
|
|
404
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
405
|
-
sheetName: z.string().describe('Sheet name'),
|
|
406
|
-
searchColumn: z.string().describe('Column letter to search (e.g., "A", "B")'),
|
|
407
|
-
searchValue: z.string().describe('Value to search for')
|
|
408
|
-
}),
|
|
409
|
-
|
|
410
|
-
outputSchema: z.object({
|
|
411
|
-
found: z.boolean().describe('Whether the value was found'),
|
|
412
|
-
rowNumber: z.number().nullable().describe('Row number if found'),
|
|
413
|
-
rowData: z.array(z.string()).nullable().describe('Full row data if found'),
|
|
414
|
-
headers: z.array(z.string()).describe('Column headers')
|
|
415
|
-
}),
|
|
416
|
-
|
|
417
|
-
integration: 'google-sheets' as const,
|
|
418
|
-
method: 'getRowByValue' as const,
|
|
419
|
-
credentialName
|
|
420
|
-
})
|
|
421
|
-
}
|
|
422
|
-
|
|
423
|
-
/**
|
|
424
|
-
* Create Google Sheets update row tool
|
|
425
|
-
*
|
|
426
|
-
* Updates a row found by searching for a value.
|
|
427
|
-
*
|
|
428
|
-
* @param credentialName - Name of credential in credentials table
|
|
429
|
-
* @returns Tool that updates rows by value
|
|
430
|
-
*/
|
|
431
|
-
export function createGoogleSheetsUpdateRowTool(credentialName: string): Tool {
|
|
432
|
-
return createIntegrationTool({
|
|
433
|
-
name: 'google_sheets_update_row',
|
|
434
|
-
description: `Update a row found by searching for a value in a column.
|
|
435
|
-
|
|
436
|
-
USE CASES:
|
|
437
|
-
- Update a record by ID
|
|
438
|
-
- Modify specific fields in a row
|
|
439
|
-
- Change status of an item
|
|
440
|
-
|
|
441
|
-
EXAMPLE:
|
|
442
|
-
{
|
|
443
|
-
"spreadsheetId": "1abc...",
|
|
444
|
-
"sheetName": "Sheet1",
|
|
445
|
-
"searchColumn": "A",
|
|
446
|
-
"searchValue": "John",
|
|
447
|
-
"updates": { "Email": "newemail@example.com", "Status": "Active" }
|
|
448
|
-
}
|
|
449
|
-
|
|
450
|
-
NOTE: Updates use header names as keys, not column letters.`,
|
|
451
|
-
|
|
452
|
-
inputSchema: z.object({
|
|
453
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
454
|
-
sheetName: z.string().describe('Sheet name'),
|
|
455
|
-
searchColumn: z.string().describe('Column letter to search'),
|
|
456
|
-
searchValue: z.string().describe('Value to search for'),
|
|
457
|
-
updates: z.record(z.string(), z.string()).describe('Map of header name to new value')
|
|
458
|
-
}),
|
|
459
|
-
|
|
460
|
-
outputSchema: z.object({
|
|
461
|
-
found: z.boolean().describe('Whether the row was found'),
|
|
462
|
-
rowNumber: z.number().nullable().describe('Row number if found'),
|
|
463
|
-
updatedCells: z.number().describe('Number of cells updated')
|
|
464
|
-
}),
|
|
465
|
-
|
|
466
|
-
integration: 'google-sheets' as const,
|
|
467
|
-
method: 'updateRowByValue' as const,
|
|
468
|
-
credentialName
|
|
469
|
-
})
|
|
470
|
-
}
|
|
471
|
-
|
|
472
|
-
/**
|
|
473
|
-
* Create Google Sheets upsert row tool
|
|
474
|
-
*
|
|
475
|
-
* Inserts a new row or updates existing row based on key column.
|
|
476
|
-
*
|
|
477
|
-
* @param credentialName - Name of credential in credentials table
|
|
478
|
-
* @returns Tool that upserts rows
|
|
479
|
-
*/
|
|
480
|
-
export function createGoogleSheetsUpsertRowTool(credentialName: string): Tool {
|
|
481
|
-
return createIntegrationTool({
|
|
482
|
-
name: 'google_sheets_upsert_row',
|
|
483
|
-
description: `Insert or update a row based on a key column value.
|
|
484
|
-
|
|
485
|
-
BEHAVIOR:
|
|
486
|
-
- If key value exists: Updates the existing row
|
|
487
|
-
- If key value doesn't exist: Inserts a new row
|
|
488
|
-
|
|
489
|
-
USE CASES:
|
|
490
|
-
- Sync data where records may or may not exist
|
|
491
|
-
- Idempotent writes (safe to call multiple times)
|
|
492
|
-
- Create-or-update workflows
|
|
493
|
-
|
|
494
|
-
EXAMPLE:
|
|
495
|
-
{
|
|
496
|
-
"spreadsheetId": "1abc...",
|
|
497
|
-
"sheetName": "Sheet1",
|
|
498
|
-
"keyColumn": "A",
|
|
499
|
-
"keyValue": "user-123",
|
|
500
|
-
"rowData": { "Name": "John", "Email": "john@example.com", "Status": "Active" }
|
|
501
|
-
}
|
|
502
|
-
|
|
503
|
-
OUTPUT:
|
|
504
|
-
{
|
|
505
|
-
"action": "inserted" | "updated",
|
|
506
|
-
"rowNumber": 10,
|
|
507
|
-
"updatedCells": 3
|
|
508
|
-
}`,
|
|
509
|
-
|
|
510
|
-
inputSchema: z.object({
|
|
511
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
512
|
-
sheetName: z.string().describe('Sheet name'),
|
|
513
|
-
keyColumn: z.string().describe('Column letter to match on'),
|
|
514
|
-
keyValue: z.string().describe('Key value to find or create'),
|
|
515
|
-
rowData: z.record(z.string(), z.string()).describe('Map of header name to value')
|
|
516
|
-
}),
|
|
517
|
-
|
|
518
|
-
outputSchema: z.object({
|
|
519
|
-
action: z.enum(['inserted', 'updated']).describe('Whether row was inserted or updated'),
|
|
520
|
-
rowNumber: z.number().describe('Row number'),
|
|
521
|
-
updatedCells: z.number().describe('Number of cells written')
|
|
522
|
-
}),
|
|
523
|
-
|
|
524
|
-
integration: 'google-sheets' as const,
|
|
525
|
-
method: 'upsertRow' as const,
|
|
526
|
-
credentialName
|
|
527
|
-
})
|
|
528
|
-
}
|
|
529
|
-
|
|
530
|
-
/**
|
|
531
|
-
* Create Google Sheets filter rows tool
|
|
532
|
-
*
|
|
533
|
-
* Gets all rows matching a filter condition.
|
|
534
|
-
*
|
|
535
|
-
* @param credentialName - Name of credential in credentials table
|
|
536
|
-
* @returns Tool that filters rows
|
|
537
|
-
*/
|
|
538
|
-
export function createGoogleSheetsFilterRowsTool(credentialName: string): Tool {
|
|
539
|
-
return createIntegrationTool({
|
|
540
|
-
name: 'google_sheets_filter_rows',
|
|
541
|
-
description: `Get all rows matching a filter condition.
|
|
542
|
-
|
|
543
|
-
OPERATORS:
|
|
544
|
-
- "equals" (default): Exact match
|
|
545
|
-
- "contains": Value contains the filter string
|
|
546
|
-
- "startsWith": Value starts with the filter string
|
|
547
|
-
- "endsWith": Value ends with the filter string
|
|
548
|
-
|
|
549
|
-
EXAMPLE:
|
|
550
|
-
{
|
|
551
|
-
"spreadsheetId": "1abc...",
|
|
552
|
-
"sheetName": "Sheet1",
|
|
553
|
-
"filterColumn": "B",
|
|
554
|
-
"filterValue": "Active",
|
|
555
|
-
"operator": "equals"
|
|
556
|
-
}
|
|
557
|
-
|
|
558
|
-
OUTPUT:
|
|
559
|
-
{
|
|
560
|
-
"rows": [
|
|
561
|
-
{ "rowNumber": 5, "data": ["John", "Active", "john@example.com"] },
|
|
562
|
-
{ "rowNumber": 8, "data": ["Jane", "Active", "jane@example.com"] }
|
|
563
|
-
],
|
|
564
|
-
"matchCount": 2,
|
|
565
|
-
"headers": ["Name", "Status", "Email"]
|
|
566
|
-
}`,
|
|
567
|
-
|
|
568
|
-
inputSchema: z.object({
|
|
569
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
570
|
-
sheetName: z.string().describe('Sheet name'),
|
|
571
|
-
filterColumn: z.string().describe('Column letter to filter'),
|
|
572
|
-
filterValue: z.string().describe('Value to filter by'),
|
|
573
|
-
operator: z.enum(['equals', 'contains', 'startsWith', 'endsWith']).optional().describe('Filter operator (default: equals)')
|
|
574
|
-
}),
|
|
575
|
-
|
|
576
|
-
outputSchema: z.object({
|
|
577
|
-
rows: z.array(z.object({
|
|
578
|
-
rowNumber: z.number(),
|
|
579
|
-
data: z.array(z.string())
|
|
580
|
-
})).describe('Matching rows with row numbers'),
|
|
581
|
-
matchCount: z.number().describe('Number of matching rows'),
|
|
582
|
-
headers: z.array(z.string()).describe('Column headers')
|
|
583
|
-
}),
|
|
584
|
-
|
|
585
|
-
integration: 'google-sheets' as const,
|
|
586
|
-
method: 'filterRows' as const,
|
|
587
|
-
credentialName
|
|
588
|
-
})
|
|
589
|
-
}
|
|
590
|
-
|
|
591
|
-
/**
|
|
592
|
-
* Create Google Sheets delete row tool
|
|
593
|
-
*
|
|
594
|
-
* Deletes a row found by searching for a value.
|
|
595
|
-
*
|
|
596
|
-
* @param credentialName - Name of credential in credentials table
|
|
597
|
-
* @returns Tool that deletes rows by value
|
|
598
|
-
*/
|
|
599
|
-
export function createGoogleSheetsDeleteRowTool(credentialName: string): Tool {
|
|
600
|
-
return createIntegrationTool({
|
|
601
|
-
name: 'google_sheets_delete_row',
|
|
602
|
-
description: `Delete a row found by searching for a value in a column.
|
|
603
|
-
|
|
604
|
-
WARNING: This permanently removes the row. Other rows shift up.
|
|
605
|
-
|
|
606
|
-
USE CASES:
|
|
607
|
-
- Remove a record by ID
|
|
608
|
-
- Delete processed items
|
|
609
|
-
- Clean up test data
|
|
610
|
-
|
|
611
|
-
EXAMPLE:
|
|
612
|
-
{
|
|
613
|
-
"spreadsheetId": "1abc...",
|
|
614
|
-
"sheetName": "Sheet1",
|
|
615
|
-
"searchColumn": "A",
|
|
616
|
-
"searchValue": "user-to-delete"
|
|
617
|
-
}
|
|
618
|
-
|
|
619
|
-
OUTPUT:
|
|
620
|
-
{
|
|
621
|
-
"found": true,
|
|
622
|
-
"deletedRowNumber": 5
|
|
623
|
-
}`,
|
|
624
|
-
|
|
625
|
-
inputSchema: z.object({
|
|
626
|
-
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
627
|
-
sheetName: z.string().describe('Sheet name'),
|
|
628
|
-
searchColumn: z.string().describe('Column letter to search'),
|
|
629
|
-
searchValue: z.string().describe('Value to search for')
|
|
630
|
-
}),
|
|
631
|
-
|
|
632
|
-
outputSchema: z.object({
|
|
633
|
-
found: z.boolean().describe('Whether the row was found'),
|
|
634
|
-
deletedRowNumber: z.number().nullable().describe('Row number that was deleted')
|
|
635
|
-
}),
|
|
636
|
-
|
|
637
|
-
integration: 'google-sheets' as const,
|
|
638
|
-
method: 'deleteRowByValue' as const,
|
|
639
|
-
credentialName
|
|
640
|
-
})
|
|
641
|
-
}
|
|
1
|
+
import { z } from 'zod'
|
|
2
|
+
import { createIntegrationTool } from '../../../tool'
|
|
3
|
+
import type { Tool } from '../../../../types'
|
|
4
|
+
|
|
5
|
+
// ============================================
|
|
6
|
+
// Core Methods - Direct API Operations
|
|
7
|
+
// ============================================
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Create Google Sheets read tool
|
|
11
|
+
*
|
|
12
|
+
* Reads data from a spreadsheet range using A1 notation.
|
|
13
|
+
*
|
|
14
|
+
* @param credentialName - Name of credential in credentials table
|
|
15
|
+
* @returns Tool that reads spreadsheet data
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* const readTool = createGoogleSheetsReadTool('elevasis-google-sheets')
|
|
19
|
+
*/
|
|
20
|
+
export function createGoogleSheetsReadTool(credentialName: string): Tool {
|
|
21
|
+
return createIntegrationTool({
|
|
22
|
+
name: 'google_sheets_read',
|
|
23
|
+
description: `Read data from a Google Sheets range. Returns 2D array of cell values.
|
|
24
|
+
|
|
25
|
+
USAGE:
|
|
26
|
+
Specify spreadsheet ID and range in A1 notation to retrieve cell values.
|
|
27
|
+
|
|
28
|
+
A1 NOTATION EXAMPLES:
|
|
29
|
+
- "Sheet1!A1:C10" - Cells A1 through C10 on Sheet1
|
|
30
|
+
- "Sheet1!A:A" - Entire column A on Sheet1
|
|
31
|
+
- "Sheet1!1:2" - Rows 1 and 2 on Sheet1
|
|
32
|
+
- "'Sheet Name'!A1:B2" - Sheet names with spaces need single quotes
|
|
33
|
+
|
|
34
|
+
OUTPUT:
|
|
35
|
+
Returns 2D array where each inner array is a row:
|
|
36
|
+
[["Name", "Id"], ["Alice", "1"], ["Bob", "2"]]
|
|
37
|
+
|
|
38
|
+
TIP: Get spreadsheet ID from URL:
|
|
39
|
+
https://docs.google.com/spreadsheets/d/{SPREADSHEET_ID}/edit`,
|
|
40
|
+
|
|
41
|
+
inputSchema: z.object({
|
|
42
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
43
|
+
range: z.string().describe('A1 notation range (e.g., "Sheet1!A1:C10")')
|
|
44
|
+
}),
|
|
45
|
+
|
|
46
|
+
outputSchema: z.object({
|
|
47
|
+
values: z.array(z.array(z.string())).describe('2D array of cell values')
|
|
48
|
+
}),
|
|
49
|
+
|
|
50
|
+
integration: 'google-sheets' as const,
|
|
51
|
+
method: 'readSheet' as const,
|
|
52
|
+
credentialName
|
|
53
|
+
})
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Create Google Sheets write tool
|
|
58
|
+
*
|
|
59
|
+
* Writes data to a spreadsheet range, overwriting existing data.
|
|
60
|
+
*
|
|
61
|
+
* @param credentialName - Name of credential in credentials table
|
|
62
|
+
* @returns Tool that writes spreadsheet data
|
|
63
|
+
*/
|
|
64
|
+
export function createGoogleSheetsWriteTool(credentialName: string): Tool {
|
|
65
|
+
return createIntegrationTool({
|
|
66
|
+
name: 'google_sheets_write',
|
|
67
|
+
description: `Write data to a Google Sheets range. Overwrites existing data in the range.
|
|
68
|
+
|
|
69
|
+
USAGE:
|
|
70
|
+
Provide 2D array of values to write to the specified range.
|
|
71
|
+
|
|
72
|
+
INPUT FORMAT:
|
|
73
|
+
Values must be a 2D array (array of rows):
|
|
74
|
+
[["Name", "Id"], ["Alice", "1"], ["Bob", "2"]]
|
|
75
|
+
|
|
76
|
+
FORMULAS:
|
|
77
|
+
Use USER_ENTERED format - formulas like "=SUM(A1:A10)" will execute.
|
|
78
|
+
|
|
79
|
+
EXAMPLE:
|
|
80
|
+
{
|
|
81
|
+
"spreadsheetId": "1abc...",
|
|
82
|
+
"range": "Sheet1!A1:B3",
|
|
83
|
+
"values": [["Header1", "Header2"], ["Value1", "Value2"]]
|
|
84
|
+
}`,
|
|
85
|
+
|
|
86
|
+
inputSchema: z.object({
|
|
87
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
88
|
+
range: z.string().describe('A1 notation range to write to'),
|
|
89
|
+
values: z.array(z.array(z.string())).describe('2D array of values to write')
|
|
90
|
+
}),
|
|
91
|
+
|
|
92
|
+
outputSchema: z.object({
|
|
93
|
+
updatedCells: z.number().describe('Number of cells updated')
|
|
94
|
+
}),
|
|
95
|
+
|
|
96
|
+
integration: 'google-sheets' as const,
|
|
97
|
+
method: 'writeSheet' as const,
|
|
98
|
+
credentialName
|
|
99
|
+
})
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Create Google Sheets append tool
|
|
104
|
+
*
|
|
105
|
+
* Appends rows to the end of a table without overwriting existing data.
|
|
106
|
+
*
|
|
107
|
+
* @param credentialName - Name of credential in credentials table
|
|
108
|
+
* @returns Tool that appends rows to spreadsheet
|
|
109
|
+
*/
|
|
110
|
+
export function createGoogleSheetsAppendTool(credentialName: string): Tool {
|
|
111
|
+
return createIntegrationTool({
|
|
112
|
+
name: 'google_sheets_append',
|
|
113
|
+
description: `Append rows to the end of a Google Sheets table. Finds the first empty row and writes there.
|
|
114
|
+
|
|
115
|
+
USE CASES:
|
|
116
|
+
- Add new records to a data table
|
|
117
|
+
- Log entries to a tracking sheet
|
|
118
|
+
- Append items without knowing the last row
|
|
119
|
+
|
|
120
|
+
RANGE FORMAT:
|
|
121
|
+
Specify the table range (columns), e.g., "Sheet1!A:E" for a 5-column table.
|
|
122
|
+
The API finds the first empty row automatically.
|
|
123
|
+
|
|
124
|
+
EXAMPLE:
|
|
125
|
+
{
|
|
126
|
+
"spreadsheetId": "1abc...",
|
|
127
|
+
"range": "Sheet1!A:C",
|
|
128
|
+
"values": [["NewItem", "123", "Description"]]
|
|
129
|
+
}`,
|
|
130
|
+
|
|
131
|
+
inputSchema: z.object({
|
|
132
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
133
|
+
range: z.string().describe('Table range to append to (e.g., "Sheet1!A:E")'),
|
|
134
|
+
values: z.array(z.array(z.string())).describe('Rows to append (2D array)')
|
|
135
|
+
}),
|
|
136
|
+
|
|
137
|
+
outputSchema: z.object({
|
|
138
|
+
updatedRows: z.number().describe('Number of rows appended')
|
|
139
|
+
}),
|
|
140
|
+
|
|
141
|
+
integration: 'google-sheets' as const,
|
|
142
|
+
method: 'appendRows' as const,
|
|
143
|
+
credentialName
|
|
144
|
+
})
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
/**
|
|
148
|
+
* Create Google Sheets clear tool
|
|
149
|
+
*
|
|
150
|
+
* Clears values from a range while preserving formatting.
|
|
151
|
+
*
|
|
152
|
+
* @param credentialName - Name of credential in credentials table
|
|
153
|
+
* @returns Tool that clears spreadsheet range
|
|
154
|
+
*/
|
|
155
|
+
export function createGoogleSheetsClearTool(credentialName: string): Tool {
|
|
156
|
+
return createIntegrationTool({
|
|
157
|
+
name: 'google_sheets_clear',
|
|
158
|
+
description: `Clear all values from a Google Sheets range. Preserves formatting and data validation.
|
|
159
|
+
|
|
160
|
+
USE CASES:
|
|
161
|
+
- Clear data while keeping headers (e.g., clear A2:E100, keep row 1)
|
|
162
|
+
- Reset a section before writing new data
|
|
163
|
+
- Remove sensitive data while preserving structure
|
|
164
|
+
|
|
165
|
+
EXAMPLE:
|
|
166
|
+
{
|
|
167
|
+
"spreadsheetId": "1abc...",
|
|
168
|
+
"range": "Sheet1!A2:E100"
|
|
169
|
+
}`,
|
|
170
|
+
|
|
171
|
+
inputSchema: z.object({
|
|
172
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
173
|
+
range: z.string().describe('A1 notation range to clear')
|
|
174
|
+
}),
|
|
175
|
+
|
|
176
|
+
outputSchema: z.object({
|
|
177
|
+
clearedRange: z.string().describe('The range that was cleared')
|
|
178
|
+
}),
|
|
179
|
+
|
|
180
|
+
integration: 'google-sheets' as const,
|
|
181
|
+
method: 'clearRange' as const,
|
|
182
|
+
credentialName
|
|
183
|
+
})
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
/**
|
|
187
|
+
* Create Google Sheets metadata tool
|
|
188
|
+
*
|
|
189
|
+
* Gets spreadsheet metadata including title and list of sheets.
|
|
190
|
+
*
|
|
191
|
+
* @param credentialName - Name of credential in credentials table
|
|
192
|
+
* @returns Tool that retrieves spreadsheet metadata
|
|
193
|
+
*/
|
|
194
|
+
export function createGoogleSheetsMetadataTool(credentialName: string): Tool {
|
|
195
|
+
return createIntegrationTool({
|
|
196
|
+
name: 'google_sheets_metadata',
|
|
197
|
+
description: `Get spreadsheet metadata including title and list of sheets.
|
|
198
|
+
|
|
199
|
+
USE CASES:
|
|
200
|
+
- Discover available sheets before reading data
|
|
201
|
+
- Get sheet names for building ranges
|
|
202
|
+
- Verify spreadsheet access
|
|
203
|
+
|
|
204
|
+
OUTPUT:
|
|
205
|
+
Returns spreadsheet title and array of sheet info:
|
|
206
|
+
{
|
|
207
|
+
"title": "My Spreadsheet",
|
|
208
|
+
"sheets": [
|
|
209
|
+
{ "sheetId": 0, "title": "Sheet1", "index": 0 },
|
|
210
|
+
{ "sheetId": 123, "title": "Data", "index": 1 }
|
|
211
|
+
]
|
|
212
|
+
}`,
|
|
213
|
+
|
|
214
|
+
inputSchema: z.object({
|
|
215
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL')
|
|
216
|
+
}),
|
|
217
|
+
|
|
218
|
+
outputSchema: z.object({
|
|
219
|
+
title: z.string().describe('Spreadsheet title'),
|
|
220
|
+
sheets: z.array(z.object({
|
|
221
|
+
sheetId: z.number(),
|
|
222
|
+
title: z.string(),
|
|
223
|
+
index: z.number()
|
|
224
|
+
})).describe('List of sheets in the spreadsheet')
|
|
225
|
+
}),
|
|
226
|
+
|
|
227
|
+
integration: 'google-sheets' as const,
|
|
228
|
+
method: 'getSpreadsheetMetadata' as const,
|
|
229
|
+
credentialName
|
|
230
|
+
})
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
/**
|
|
234
|
+
* Create Google Sheets batch update tool
|
|
235
|
+
*
|
|
236
|
+
* Updates multiple ranges in a single request for efficiency.
|
|
237
|
+
*
|
|
238
|
+
* @param credentialName - Name of credential in credentials table
|
|
239
|
+
* @returns Tool that batch updates spreadsheet
|
|
240
|
+
*/
|
|
241
|
+
export function createGoogleSheetsBatchUpdateTool(credentialName: string): Tool {
|
|
242
|
+
return createIntegrationTool({
|
|
243
|
+
name: 'google_sheets_batch_update',
|
|
244
|
+
description: `Update multiple ranges in a single request. More efficient than multiple write calls.
|
|
245
|
+
|
|
246
|
+
USE CASES:
|
|
247
|
+
- Update cells in multiple sheets at once
|
|
248
|
+
- Write to non-contiguous ranges
|
|
249
|
+
- Batch multiple small updates for efficiency
|
|
250
|
+
|
|
251
|
+
EXAMPLE:
|
|
252
|
+
{
|
|
253
|
+
"spreadsheetId": "1abc...",
|
|
254
|
+
"data": [
|
|
255
|
+
{ "range": "Sheet1!A1", "values": [["Updated"]] },
|
|
256
|
+
{ "range": "Sheet2!B2:C3", "values": [["X", "Y"], ["Z", "W"]] }
|
|
257
|
+
]
|
|
258
|
+
}`,
|
|
259
|
+
|
|
260
|
+
inputSchema: z.object({
|
|
261
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
262
|
+
data: z.array(z.object({
|
|
263
|
+
range: z.string().describe('A1 notation range'),
|
|
264
|
+
values: z.array(z.array(z.string())).describe('2D array of values')
|
|
265
|
+
})).describe('Array of range/values pairs to update')
|
|
266
|
+
}),
|
|
267
|
+
|
|
268
|
+
outputSchema: z.object({
|
|
269
|
+
totalUpdatedCells: z.number().describe('Total number of cells updated'),
|
|
270
|
+
totalUpdatedRows: z.number().describe('Total number of rows updated')
|
|
271
|
+
}),
|
|
272
|
+
|
|
273
|
+
integration: 'google-sheets' as const,
|
|
274
|
+
method: 'batchUpdate' as const,
|
|
275
|
+
credentialName
|
|
276
|
+
})
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// ============================================
|
|
280
|
+
// Workflow-Friendly Methods - Higher-Level Abstractions
|
|
281
|
+
// ============================================
|
|
282
|
+
|
|
283
|
+
/**
|
|
284
|
+
* Create Google Sheets get headers tool
|
|
285
|
+
*
|
|
286
|
+
* Gets column headers from the first row of a sheet.
|
|
287
|
+
*
|
|
288
|
+
* @param credentialName - Name of credential in credentials table
|
|
289
|
+
* @returns Tool that retrieves headers
|
|
290
|
+
*/
|
|
291
|
+
export function createGoogleSheetsGetHeadersTool(credentialName: string): Tool {
|
|
292
|
+
return createIntegrationTool({
|
|
293
|
+
name: 'google_sheets_get_headers',
|
|
294
|
+
description: `Get column headers from the first row of a sheet.
|
|
295
|
+
|
|
296
|
+
USE CASES:
|
|
297
|
+
- Discover column structure before reading/writing
|
|
298
|
+
- Get column mapping for workflow operations
|
|
299
|
+
- Validate expected columns exist
|
|
300
|
+
|
|
301
|
+
OUTPUT:
|
|
302
|
+
Returns headers array and column map (header name to column letter):
|
|
303
|
+
{
|
|
304
|
+
"headers": ["Name", "Id", "Description"],
|
|
305
|
+
"columnCount": 3,
|
|
306
|
+
"columnMap": { "Name": "A", "Id": "B", "Description": "C" }
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
TIP: Use columnMap to build ranges dynamically based on header names.`,
|
|
310
|
+
|
|
311
|
+
inputSchema: z.object({
|
|
312
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
313
|
+
sheetName: z.string().describe('Sheet name (e.g., "Sheet1")')
|
|
314
|
+
}),
|
|
315
|
+
|
|
316
|
+
outputSchema: z.object({
|
|
317
|
+
headers: z.array(z.string()).describe('Column headers from first row'),
|
|
318
|
+
columnCount: z.number().describe('Number of columns'),
|
|
319
|
+
columnMap: z.record(z.string(), z.string()).describe('Map of header name to column letter')
|
|
320
|
+
}),
|
|
321
|
+
|
|
322
|
+
integration: 'google-sheets' as const,
|
|
323
|
+
method: 'getHeaders' as const,
|
|
324
|
+
credentialName
|
|
325
|
+
})
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
/**
|
|
329
|
+
* Create Google Sheets get last row tool
|
|
330
|
+
*
|
|
331
|
+
* Finds the last row with data in a column.
|
|
332
|
+
*
|
|
333
|
+
* @param credentialName - Name of credential in credentials table
|
|
334
|
+
* @returns Tool that finds last row
|
|
335
|
+
*/
|
|
336
|
+
export function createGoogleSheetsGetLastRowTool(credentialName: string): Tool {
|
|
337
|
+
return createIntegrationTool({
|
|
338
|
+
name: 'google_sheets_get_last_row',
|
|
339
|
+
description: `Find the last row with data in a sheet.
|
|
340
|
+
|
|
341
|
+
USE CASES:
|
|
342
|
+
- Determine where to write next row
|
|
343
|
+
- Check if sheet has any data
|
|
344
|
+
- Get row count for a column
|
|
345
|
+
|
|
346
|
+
OUTPUT:
|
|
347
|
+
{
|
|
348
|
+
"lastRow": 50,
|
|
349
|
+
"isEmpty": false
|
|
350
|
+
}`,
|
|
351
|
+
|
|
352
|
+
inputSchema: z.object({
|
|
353
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
354
|
+
sheetName: z.string().describe('Sheet name'),
|
|
355
|
+
column: z.string().optional().describe('Column to check (default: "A")')
|
|
356
|
+
}),
|
|
357
|
+
|
|
358
|
+
outputSchema: z.object({
|
|
359
|
+
lastRow: z.number().describe('Last row number with data'),
|
|
360
|
+
isEmpty: z.boolean().describe('True if column is empty')
|
|
361
|
+
}),
|
|
362
|
+
|
|
363
|
+
integration: 'google-sheets' as const,
|
|
364
|
+
method: 'getLastRow' as const,
|
|
365
|
+
credentialName
|
|
366
|
+
})
|
|
367
|
+
}
|
|
368
|
+
|
|
369
|
+
/**
|
|
370
|
+
* Create Google Sheets find row tool
|
|
371
|
+
*
|
|
372
|
+
* Finds a row by searching for a value in a column.
|
|
373
|
+
*
|
|
374
|
+
* @param credentialName - Name of credential in credentials table
|
|
375
|
+
* @returns Tool that finds rows by value
|
|
376
|
+
*/
|
|
377
|
+
export function createGoogleSheetsFindRowTool(credentialName: string): Tool {
|
|
378
|
+
return createIntegrationTool({
|
|
379
|
+
name: 'google_sheets_find_row',
|
|
380
|
+
description: `Find a row by searching for a value in a specific column.
|
|
381
|
+
|
|
382
|
+
USE CASES:
|
|
383
|
+
- Look up a record by ID or name
|
|
384
|
+
- Find a row to update
|
|
385
|
+
- Check if a value exists in the sheet
|
|
386
|
+
|
|
387
|
+
OUTPUT (when found):
|
|
388
|
+
{
|
|
389
|
+
"found": true,
|
|
390
|
+
"rowNumber": 5,
|
|
391
|
+
"rowData": ["John", "123", "john@example.com"],
|
|
392
|
+
"headers": ["Name", "Id", "Email"]
|
|
393
|
+
}
|
|
394
|
+
|
|
395
|
+
OUTPUT (not found):
|
|
396
|
+
{
|
|
397
|
+
"found": false,
|
|
398
|
+
"rowNumber": null,
|
|
399
|
+
"rowData": null,
|
|
400
|
+
"headers": ["Name", "Id", "Email"]
|
|
401
|
+
}`,
|
|
402
|
+
|
|
403
|
+
inputSchema: z.object({
|
|
404
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
405
|
+
sheetName: z.string().describe('Sheet name'),
|
|
406
|
+
searchColumn: z.string().describe('Column letter to search (e.g., "A", "B")'),
|
|
407
|
+
searchValue: z.string().describe('Value to search for')
|
|
408
|
+
}),
|
|
409
|
+
|
|
410
|
+
outputSchema: z.object({
|
|
411
|
+
found: z.boolean().describe('Whether the value was found'),
|
|
412
|
+
rowNumber: z.number().nullable().describe('Row number if found'),
|
|
413
|
+
rowData: z.array(z.string()).nullable().describe('Full row data if found'),
|
|
414
|
+
headers: z.array(z.string()).describe('Column headers')
|
|
415
|
+
}),
|
|
416
|
+
|
|
417
|
+
integration: 'google-sheets' as const,
|
|
418
|
+
method: 'getRowByValue' as const,
|
|
419
|
+
credentialName
|
|
420
|
+
})
|
|
421
|
+
}
|
|
422
|
+
|
|
423
|
+
/**
|
|
424
|
+
* Create Google Sheets update row tool
|
|
425
|
+
*
|
|
426
|
+
* Updates a row found by searching for a value.
|
|
427
|
+
*
|
|
428
|
+
* @param credentialName - Name of credential in credentials table
|
|
429
|
+
* @returns Tool that updates rows by value
|
|
430
|
+
*/
|
|
431
|
+
export function createGoogleSheetsUpdateRowTool(credentialName: string): Tool {
|
|
432
|
+
return createIntegrationTool({
|
|
433
|
+
name: 'google_sheets_update_row',
|
|
434
|
+
description: `Update a row found by searching for a value in a column.
|
|
435
|
+
|
|
436
|
+
USE CASES:
|
|
437
|
+
- Update a record by ID
|
|
438
|
+
- Modify specific fields in a row
|
|
439
|
+
- Change status of an item
|
|
440
|
+
|
|
441
|
+
EXAMPLE:
|
|
442
|
+
{
|
|
443
|
+
"spreadsheetId": "1abc...",
|
|
444
|
+
"sheetName": "Sheet1",
|
|
445
|
+
"searchColumn": "A",
|
|
446
|
+
"searchValue": "John",
|
|
447
|
+
"updates": { "Email": "newemail@example.com", "Status": "Active" }
|
|
448
|
+
}
|
|
449
|
+
|
|
450
|
+
NOTE: Updates use header names as keys, not column letters.`,
|
|
451
|
+
|
|
452
|
+
inputSchema: z.object({
|
|
453
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
454
|
+
sheetName: z.string().describe('Sheet name'),
|
|
455
|
+
searchColumn: z.string().describe('Column letter to search'),
|
|
456
|
+
searchValue: z.string().describe('Value to search for'),
|
|
457
|
+
updates: z.record(z.string(), z.string()).describe('Map of header name to new value')
|
|
458
|
+
}),
|
|
459
|
+
|
|
460
|
+
outputSchema: z.object({
|
|
461
|
+
found: z.boolean().describe('Whether the row was found'),
|
|
462
|
+
rowNumber: z.number().nullable().describe('Row number if found'),
|
|
463
|
+
updatedCells: z.number().describe('Number of cells updated')
|
|
464
|
+
}),
|
|
465
|
+
|
|
466
|
+
integration: 'google-sheets' as const,
|
|
467
|
+
method: 'updateRowByValue' as const,
|
|
468
|
+
credentialName
|
|
469
|
+
})
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
/**
|
|
473
|
+
* Create Google Sheets upsert row tool
|
|
474
|
+
*
|
|
475
|
+
* Inserts a new row or updates existing row based on key column.
|
|
476
|
+
*
|
|
477
|
+
* @param credentialName - Name of credential in credentials table
|
|
478
|
+
* @returns Tool that upserts rows
|
|
479
|
+
*/
|
|
480
|
+
export function createGoogleSheetsUpsertRowTool(credentialName: string): Tool {
|
|
481
|
+
return createIntegrationTool({
|
|
482
|
+
name: 'google_sheets_upsert_row',
|
|
483
|
+
description: `Insert or update a row based on a key column value.
|
|
484
|
+
|
|
485
|
+
BEHAVIOR:
|
|
486
|
+
- If key value exists: Updates the existing row
|
|
487
|
+
- If key value doesn't exist: Inserts a new row
|
|
488
|
+
|
|
489
|
+
USE CASES:
|
|
490
|
+
- Sync data where records may or may not exist
|
|
491
|
+
- Idempotent writes (safe to call multiple times)
|
|
492
|
+
- Create-or-update workflows
|
|
493
|
+
|
|
494
|
+
EXAMPLE:
|
|
495
|
+
{
|
|
496
|
+
"spreadsheetId": "1abc...",
|
|
497
|
+
"sheetName": "Sheet1",
|
|
498
|
+
"keyColumn": "A",
|
|
499
|
+
"keyValue": "user-123",
|
|
500
|
+
"rowData": { "Name": "John", "Email": "john@example.com", "Status": "Active" }
|
|
501
|
+
}
|
|
502
|
+
|
|
503
|
+
OUTPUT:
|
|
504
|
+
{
|
|
505
|
+
"action": "inserted" | "updated",
|
|
506
|
+
"rowNumber": 10,
|
|
507
|
+
"updatedCells": 3
|
|
508
|
+
}`,
|
|
509
|
+
|
|
510
|
+
inputSchema: z.object({
|
|
511
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
512
|
+
sheetName: z.string().describe('Sheet name'),
|
|
513
|
+
keyColumn: z.string().describe('Column letter to match on'),
|
|
514
|
+
keyValue: z.string().describe('Key value to find or create'),
|
|
515
|
+
rowData: z.record(z.string(), z.string()).describe('Map of header name to value')
|
|
516
|
+
}),
|
|
517
|
+
|
|
518
|
+
outputSchema: z.object({
|
|
519
|
+
action: z.enum(['inserted', 'updated']).describe('Whether row was inserted or updated'),
|
|
520
|
+
rowNumber: z.number().describe('Row number'),
|
|
521
|
+
updatedCells: z.number().describe('Number of cells written')
|
|
522
|
+
}),
|
|
523
|
+
|
|
524
|
+
integration: 'google-sheets' as const,
|
|
525
|
+
method: 'upsertRow' as const,
|
|
526
|
+
credentialName
|
|
527
|
+
})
|
|
528
|
+
}
|
|
529
|
+
|
|
530
|
+
/**
|
|
531
|
+
* Create Google Sheets filter rows tool
|
|
532
|
+
*
|
|
533
|
+
* Gets all rows matching a filter condition.
|
|
534
|
+
*
|
|
535
|
+
* @param credentialName - Name of credential in credentials table
|
|
536
|
+
* @returns Tool that filters rows
|
|
537
|
+
*/
|
|
538
|
+
export function createGoogleSheetsFilterRowsTool(credentialName: string): Tool {
|
|
539
|
+
return createIntegrationTool({
|
|
540
|
+
name: 'google_sheets_filter_rows',
|
|
541
|
+
description: `Get all rows matching a filter condition.
|
|
542
|
+
|
|
543
|
+
OPERATORS:
|
|
544
|
+
- "equals" (default): Exact match
|
|
545
|
+
- "contains": Value contains the filter string
|
|
546
|
+
- "startsWith": Value starts with the filter string
|
|
547
|
+
- "endsWith": Value ends with the filter string
|
|
548
|
+
|
|
549
|
+
EXAMPLE:
|
|
550
|
+
{
|
|
551
|
+
"spreadsheetId": "1abc...",
|
|
552
|
+
"sheetName": "Sheet1",
|
|
553
|
+
"filterColumn": "B",
|
|
554
|
+
"filterValue": "Active",
|
|
555
|
+
"operator": "equals"
|
|
556
|
+
}
|
|
557
|
+
|
|
558
|
+
OUTPUT:
|
|
559
|
+
{
|
|
560
|
+
"rows": [
|
|
561
|
+
{ "rowNumber": 5, "data": ["John", "Active", "john@example.com"] },
|
|
562
|
+
{ "rowNumber": 8, "data": ["Jane", "Active", "jane@example.com"] }
|
|
563
|
+
],
|
|
564
|
+
"matchCount": 2,
|
|
565
|
+
"headers": ["Name", "Status", "Email"]
|
|
566
|
+
}`,
|
|
567
|
+
|
|
568
|
+
inputSchema: z.object({
|
|
569
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
570
|
+
sheetName: z.string().describe('Sheet name'),
|
|
571
|
+
filterColumn: z.string().describe('Column letter to filter'),
|
|
572
|
+
filterValue: z.string().describe('Value to filter by'),
|
|
573
|
+
operator: z.enum(['equals', 'contains', 'startsWith', 'endsWith']).optional().describe('Filter operator (default: equals)')
|
|
574
|
+
}),
|
|
575
|
+
|
|
576
|
+
outputSchema: z.object({
|
|
577
|
+
rows: z.array(z.object({
|
|
578
|
+
rowNumber: z.number(),
|
|
579
|
+
data: z.array(z.string())
|
|
580
|
+
})).describe('Matching rows with row numbers'),
|
|
581
|
+
matchCount: z.number().describe('Number of matching rows'),
|
|
582
|
+
headers: z.array(z.string()).describe('Column headers')
|
|
583
|
+
}),
|
|
584
|
+
|
|
585
|
+
integration: 'google-sheets' as const,
|
|
586
|
+
method: 'filterRows' as const,
|
|
587
|
+
credentialName
|
|
588
|
+
})
|
|
589
|
+
}
|
|
590
|
+
|
|
591
|
+
/**
|
|
592
|
+
* Create Google Sheets delete row tool
|
|
593
|
+
*
|
|
594
|
+
* Deletes a row found by searching for a value.
|
|
595
|
+
*
|
|
596
|
+
* @param credentialName - Name of credential in credentials table
|
|
597
|
+
* @returns Tool that deletes rows by value
|
|
598
|
+
*/
|
|
599
|
+
export function createGoogleSheetsDeleteRowTool(credentialName: string): Tool {
|
|
600
|
+
return createIntegrationTool({
|
|
601
|
+
name: 'google_sheets_delete_row',
|
|
602
|
+
description: `Delete a row found by searching for a value in a column.
|
|
603
|
+
|
|
604
|
+
WARNING: This permanently removes the row. Other rows shift up.
|
|
605
|
+
|
|
606
|
+
USE CASES:
|
|
607
|
+
- Remove a record by ID
|
|
608
|
+
- Delete processed items
|
|
609
|
+
- Clean up test data
|
|
610
|
+
|
|
611
|
+
EXAMPLE:
|
|
612
|
+
{
|
|
613
|
+
"spreadsheetId": "1abc...",
|
|
614
|
+
"sheetName": "Sheet1",
|
|
615
|
+
"searchColumn": "A",
|
|
616
|
+
"searchValue": "user-to-delete"
|
|
617
|
+
}
|
|
618
|
+
|
|
619
|
+
OUTPUT:
|
|
620
|
+
{
|
|
621
|
+
"found": true,
|
|
622
|
+
"deletedRowNumber": 5
|
|
623
|
+
}`,
|
|
624
|
+
|
|
625
|
+
inputSchema: z.object({
|
|
626
|
+
spreadsheetId: z.string().describe('Spreadsheet ID from URL'),
|
|
627
|
+
sheetName: z.string().describe('Sheet name'),
|
|
628
|
+
searchColumn: z.string().describe('Column letter to search'),
|
|
629
|
+
searchValue: z.string().describe('Value to search for')
|
|
630
|
+
}),
|
|
631
|
+
|
|
632
|
+
outputSchema: z.object({
|
|
633
|
+
found: z.boolean().describe('Whether the row was found'),
|
|
634
|
+
deletedRowNumber: z.number().nullable().describe('Row number that was deleted')
|
|
635
|
+
}),
|
|
636
|
+
|
|
637
|
+
integration: 'google-sheets' as const,
|
|
638
|
+
method: 'deleteRowByValue' as const,
|
|
639
|
+
credentialName
|
|
640
|
+
})
|
|
641
|
+
}
|