@mcp-z/mcp-sheets 1.0.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/LICENSE +21 -0
- package/README.md +181 -0
- package/bin/server.js +5 -0
- package/dist/cjs/constants.d.cts +7 -0
- package/dist/cjs/constants.d.ts +7 -0
- package/dist/cjs/constants.js +18 -0
- package/dist/cjs/constants.js.map +1 -0
- package/dist/cjs/index.d.cts +8 -0
- package/dist/cjs/index.d.ts +8 -0
- package/dist/cjs/index.js +314 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/lib/create-store.d.cts +2 -0
- package/dist/cjs/lib/create-store.d.ts +2 -0
- package/dist/cjs/lib/create-store.js +166 -0
- package/dist/cjs/lib/create-store.js.map +1 -0
- package/dist/cjs/mcp/index.d.cts +3 -0
- package/dist/cjs/mcp/index.d.ts +3 -0
- package/dist/cjs/mcp/index.js +66 -0
- package/dist/cjs/mcp/index.js.map +1 -0
- package/dist/cjs/mcp/prompts/a1-notation.d.cts +19 -0
- package/dist/cjs/mcp/prompts/a1-notation.d.ts +19 -0
- package/dist/cjs/mcp/prompts/a1-notation.js +169 -0
- package/dist/cjs/mcp/prompts/a1-notation.js.map +1 -0
- package/dist/cjs/mcp/prompts/index.d.cts +1 -0
- package/dist/cjs/mcp/prompts/index.d.ts +1 -0
- package/dist/cjs/mcp/prompts/index.js +17 -0
- package/dist/cjs/mcp/prompts/index.js.map +1 -0
- package/dist/cjs/mcp/resources/index.d.cts +1 -0
- package/dist/cjs/mcp/resources/index.d.ts +1 -0
- package/dist/cjs/mcp/resources/index.js +17 -0
- package/dist/cjs/mcp/resources/index.js.map +1 -0
- package/dist/cjs/mcp/resources/spreadsheet.d.cts +2 -0
- package/dist/cjs/mcp/resources/spreadsheet.d.ts +2 -0
- package/dist/cjs/mcp/resources/spreadsheet.js +258 -0
- package/dist/cjs/mcp/resources/spreadsheet.js.map +1 -0
- package/dist/cjs/mcp/tools/cells-format.d.cts +144 -0
- package/dist/cjs/mcp/tools/cells-format.d.ts +144 -0
- package/dist/cjs/mcp/tools/cells-format.js +484 -0
- package/dist/cjs/mcp/tools/cells-format.js.map +1 -0
- package/dist/cjs/mcp/tools/chart-create.d.cts +94 -0
- package/dist/cjs/mcp/tools/chart-create.d.ts +94 -0
- package/dist/cjs/mcp/tools/chart-create.js +575 -0
- package/dist/cjs/mcp/tools/chart-create.js.map +1 -0
- package/dist/cjs/mcp/tools/columns-get.d.cts +55 -0
- package/dist/cjs/mcp/tools/columns-get.d.ts +55 -0
- package/dist/cjs/mcp/tools/columns-get.js +289 -0
- package/dist/cjs/mcp/tools/columns-get.js.map +1 -0
- package/dist/cjs/mcp/tools/columns-update.d.cts +86 -0
- package/dist/cjs/mcp/tools/columns-update.d.ts +86 -0
- package/dist/cjs/mcp/tools/columns-update.js +482 -0
- package/dist/cjs/mcp/tools/columns-update.js.map +1 -0
- package/dist/cjs/mcp/tools/csv-get-columns.d.cts +43 -0
- package/dist/cjs/mcp/tools/csv-get-columns.d.ts +43 -0
- package/dist/cjs/mcp/tools/csv-get-columns.js +386 -0
- package/dist/cjs/mcp/tools/csv-get-columns.js.map +1 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.d.cts +118 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.d.ts +118 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.js +504 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.js.map +1 -0
- package/dist/cjs/mcp/tools/dimensions-move.d.cts +86 -0
- package/dist/cjs/mcp/tools/dimensions-move.d.ts +86 -0
- package/dist/cjs/mcp/tools/dimensions-move.js +359 -0
- package/dist/cjs/mcp/tools/dimensions-move.js.map +1 -0
- package/dist/cjs/mcp/tools/index.d.cts +26 -0
- package/dist/cjs/mcp/tools/index.d.ts +26 -0
- package/dist/cjs/mcp/tools/index.js +122 -0
- package/dist/cjs/mcp/tools/index.js.map +1 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.d.cts +48 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.d.ts +48 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.js +177 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.js.map +1 -0
- package/dist/cjs/mcp/tools/rows-append.d.cts +58 -0
- package/dist/cjs/mcp/tools/rows-append.d.ts +58 -0
- package/dist/cjs/mcp/tools/rows-append.js +335 -0
- package/dist/cjs/mcp/tools/rows-append.js.map +1 -0
- package/dist/cjs/mcp/tools/rows-csv-append.d.cts +67 -0
- package/dist/cjs/mcp/tools/rows-csv-append.d.ts +67 -0
- package/dist/cjs/mcp/tools/rows-csv-append.js +859 -0
- package/dist/cjs/mcp/tools/rows-csv-append.js.map +1 -0
- package/dist/cjs/mcp/tools/rows-get.d.cts +56 -0
- package/dist/cjs/mcp/tools/rows-get.d.ts +56 -0
- package/dist/cjs/mcp/tools/rows-get.js +292 -0
- package/dist/cjs/mcp/tools/rows-get.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.d.cts +68 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.d.ts +68 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.js +341 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-copy.d.cts +80 -0
- package/dist/cjs/mcp/tools/sheet-copy.d.ts +80 -0
- package/dist/cjs/mcp/tools/sheet-copy.js +394 -0
- package/dist/cjs/mcp/tools/sheet-copy.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-create.d.cts +56 -0
- package/dist/cjs/mcp/tools/sheet-create.d.ts +56 -0
- package/dist/cjs/mcp/tools/sheet-create.js +283 -0
- package/dist/cjs/mcp/tools/sheet-create.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-delete.d.cts +62 -0
- package/dist/cjs/mcp/tools/sheet-delete.d.ts +62 -0
- package/dist/cjs/mcp/tools/sheet-delete.js +341 -0
- package/dist/cjs/mcp/tools/sheet-delete.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-find.d.cts +48 -0
- package/dist/cjs/mcp/tools/sheet-find.d.ts +48 -0
- package/dist/cjs/mcp/tools/sheet-find.js +261 -0
- package/dist/cjs/mcp/tools/sheet-find.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-rename.d.cts +60 -0
- package/dist/cjs/mcp/tools/sheet-rename.d.ts +60 -0
- package/dist/cjs/mcp/tools/sheet-rename.js +305 -0
- package/dist/cjs/mcp/tools/sheet-rename.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.d.cts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.d.ts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.js +319 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.d.cts +52 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.d.ts +52 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.js +270 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.d.cts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.d.ts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.js +334 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.d.cts +56 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.d.ts +56 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.js +289 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.js.map +1 -0
- package/dist/cjs/mcp/tools/validation-set.d.cts +144 -0
- package/dist/cjs/mcp/tools/validation-set.d.ts +144 -0
- package/dist/cjs/mcp/tools/validation-set.js +564 -0
- package/dist/cjs/mcp/tools/validation-set.js.map +1 -0
- package/dist/cjs/mcp/tools/values-batch-update.d.cts +102 -0
- package/dist/cjs/mcp/tools/values-batch-update.d.ts +102 -0
- package/dist/cjs/mcp/tools/values-batch-update.js +409 -0
- package/dist/cjs/mcp/tools/values-batch-update.js.map +1 -0
- package/dist/cjs/mcp/tools/values-clear.d.cts +56 -0
- package/dist/cjs/mcp/tools/values-clear.d.ts +56 -0
- package/dist/cjs/mcp/tools/values-clear.js +308 -0
- package/dist/cjs/mcp/tools/values-clear.js.map +1 -0
- package/dist/cjs/mcp/tools/values-csv-update.d.cts +75 -0
- package/dist/cjs/mcp/tools/values-csv-update.d.ts +75 -0
- package/dist/cjs/mcp/tools/values-csv-update.js +500 -0
- package/dist/cjs/mcp/tools/values-csv-update.js.map +1 -0
- package/dist/cjs/mcp/tools/values-replace.d.cts +68 -0
- package/dist/cjs/mcp/tools/values-replace.d.ts +68 -0
- package/dist/cjs/mcp/tools/values-replace.js +378 -0
- package/dist/cjs/mcp/tools/values-replace.js.map +1 -0
- package/dist/cjs/mcp/tools/values-search.d.cts +74 -0
- package/dist/cjs/mcp/tools/values-search.d.ts +74 -0
- package/dist/cjs/mcp/tools/values-search.js +470 -0
- package/dist/cjs/mcp/tools/values-search.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/schemas/index.d.cts +14 -0
- package/dist/cjs/schemas/index.d.ts +14 -0
- package/dist/cjs/schemas/index.js +64 -0
- package/dist/cjs/schemas/index.js.map +1 -0
- package/dist/cjs/setup/config.d.cts +44 -0
- package/dist/cjs/setup/config.d.ts +44 -0
- package/dist/cjs/setup/config.js +201 -0
- package/dist/cjs/setup/config.js.map +1 -0
- package/dist/cjs/setup/http.d.cts +8 -0
- package/dist/cjs/setup/http.d.ts +8 -0
- package/dist/cjs/setup/http.js +260 -0
- package/dist/cjs/setup/http.js.map +1 -0
- package/dist/cjs/setup/index.d.cts +5 -0
- package/dist/cjs/setup/index.d.ts +5 -0
- package/dist/cjs/setup/index.js +46 -0
- package/dist/cjs/setup/index.js.map +1 -0
- package/dist/cjs/setup/oauth-google.d.cts +54 -0
- package/dist/cjs/setup/oauth-google.d.ts +54 -0
- package/dist/cjs/setup/oauth-google.js +332 -0
- package/dist/cjs/setup/oauth-google.js.map +1 -0
- package/dist/cjs/setup/runtime.d.cts +10 -0
- package/dist/cjs/setup/runtime.d.ts +10 -0
- package/dist/cjs/setup/runtime.js +353 -0
- package/dist/cjs/setup/runtime.js.map +1 -0
- package/dist/cjs/setup/stdio.d.cts +7 -0
- package/dist/cjs/setup/stdio.d.ts +7 -0
- package/dist/cjs/setup/stdio.js +239 -0
- package/dist/cjs/setup/stdio.js.map +1 -0
- package/dist/cjs/spreadsheet/column-utilities.d.cts +1 -0
- package/dist/cjs/spreadsheet/column-utilities.d.ts +1 -0
- package/dist/cjs/spreadsheet/column-utilities.js +21 -0
- package/dist/cjs/spreadsheet/column-utilities.js.map +1 -0
- package/dist/cjs/spreadsheet/csv-streaming.d.cts +19 -0
- package/dist/cjs/spreadsheet/csv-streaming.d.ts +19 -0
- package/dist/cjs/spreadsheet/csv-streaming.js +188 -0
- package/dist/cjs/spreadsheet/csv-streaming.js.map +1 -0
- package/dist/cjs/spreadsheet/data-operations.d.cts +115 -0
- package/dist/cjs/spreadsheet/data-operations.d.ts +115 -0
- package/dist/cjs/spreadsheet/data-operations.js +1515 -0
- package/dist/cjs/spreadsheet/data-operations.js.map +1 -0
- package/dist/cjs/spreadsheet/deduplication-utils.d.cts +31 -0
- package/dist/cjs/spreadsheet/deduplication-utils.d.ts +31 -0
- package/dist/cjs/spreadsheet/deduplication-utils.js +65 -0
- package/dist/cjs/spreadsheet/deduplication-utils.js.map +1 -0
- package/dist/cjs/spreadsheet/range-operations.d.cts +184 -0
- package/dist/cjs/spreadsheet/range-operations.d.ts +184 -0
- package/dist/cjs/spreadsheet/range-operations.js +672 -0
- package/dist/cjs/spreadsheet/range-operations.js.map +1 -0
- package/dist/cjs/spreadsheet/sheet-operations.d.cts +30 -0
- package/dist/cjs/spreadsheet/sheet-operations.d.ts +30 -0
- package/dist/cjs/spreadsheet/sheet-operations.js +811 -0
- package/dist/cjs/spreadsheet/sheet-operations.js.map +1 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.d.cts +21 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.d.ts +21 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.js +310 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.js.map +1 -0
- package/dist/cjs/types.d.cts +53 -0
- package/dist/cjs/types.d.ts +53 -0
- package/dist/cjs/types.js +5 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/esm/constants.d.ts +7 -0
- package/dist/esm/constants.js +7 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/index.d.ts +8 -0
- package/dist/esm/index.js +34 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/create-store.d.ts +2 -0
- package/dist/esm/lib/create-store.js +6 -0
- package/dist/esm/lib/create-store.js.map +1 -0
- package/dist/esm/mcp/index.d.ts +3 -0
- package/dist/esm/mcp/index.js +6 -0
- package/dist/esm/mcp/index.js.map +1 -0
- package/dist/esm/mcp/prompts/a1-notation.d.ts +19 -0
- package/dist/esm/mcp/prompts/a1-notation.js +49 -0
- package/dist/esm/mcp/prompts/a1-notation.js.map +1 -0
- package/dist/esm/mcp/prompts/index.d.ts +1 -0
- package/dist/esm/mcp/prompts/index.js +1 -0
- package/dist/esm/mcp/prompts/index.js.map +1 -0
- package/dist/esm/mcp/resources/index.d.ts +1 -0
- package/dist/esm/mcp/resources/index.js +1 -0
- package/dist/esm/mcp/resources/index.js.map +1 -0
- package/dist/esm/mcp/resources/spreadsheet.d.ts +2 -0
- package/dist/esm/mcp/resources/spreadsheet.js +88 -0
- package/dist/esm/mcp/resources/spreadsheet.js.map +1 -0
- package/dist/esm/mcp/tools/cells-format.d.ts +144 -0
- package/dist/esm/mcp/tools/cells-format.js +288 -0
- package/dist/esm/mcp/tools/cells-format.js.map +1 -0
- package/dist/esm/mcp/tools/chart-create.d.ts +94 -0
- package/dist/esm/mcp/tools/chart-create.js +408 -0
- package/dist/esm/mcp/tools/chart-create.js.map +1 -0
- package/dist/esm/mcp/tools/columns-get.d.ts +55 -0
- package/dist/esm/mcp/tools/columns-get.js +113 -0
- package/dist/esm/mcp/tools/columns-get.js.map +1 -0
- package/dist/esm/mcp/tools/columns-update.d.ts +86 -0
- package/dist/esm/mcp/tools/columns-update.js +296 -0
- package/dist/esm/mcp/tools/columns-update.js.map +1 -0
- package/dist/esm/mcp/tools/csv-get-columns.d.ts +43 -0
- package/dist/esm/mcp/tools/csv-get-columns.js +95 -0
- package/dist/esm/mcp/tools/csv-get-columns.js.map +1 -0
- package/dist/esm/mcp/tools/dimensions-batch-update.d.ts +118 -0
- package/dist/esm/mcp/tools/dimensions-batch-update.js +321 -0
- package/dist/esm/mcp/tools/dimensions-batch-update.js.map +1 -0
- package/dist/esm/mcp/tools/dimensions-move.d.ts +86 -0
- package/dist/esm/mcp/tools/dimensions-move.js +183 -0
- package/dist/esm/mcp/tools/dimensions-move.js.map +1 -0
- package/dist/esm/mcp/tools/index.d.ts +26 -0
- package/dist/esm/mcp/tools/index.js +26 -0
- package/dist/esm/mcp/tools/index.js.map +1 -0
- package/dist/esm/mcp/tools/lib/dimension-operations.d.ts +48 -0
- package/dist/esm/mcp/tools/lib/dimension-operations.js +93 -0
- package/dist/esm/mcp/tools/lib/dimension-operations.js.map +1 -0
- package/dist/esm/mcp/tools/rows-append.d.ts +58 -0
- package/dist/esm/mcp/tools/rows-append.js +151 -0
- package/dist/esm/mcp/tools/rows-append.js.map +1 -0
- package/dist/esm/mcp/tools/rows-csv-append.d.ts +67 -0
- package/dist/esm/mcp/tools/rows-csv-append.js +342 -0
- package/dist/esm/mcp/tools/rows-csv-append.js.map +1 -0
- package/dist/esm/mcp/tools/rows-get.d.ts +56 -0
- package/dist/esm/mcp/tools/rows-get.js +116 -0
- package/dist/esm/mcp/tools/rows-get.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-copy-to.d.ts +68 -0
- package/dist/esm/mcp/tools/sheet-copy-to.js +156 -0
- package/dist/esm/mcp/tools/sheet-copy-to.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-copy.d.ts +80 -0
- package/dist/esm/mcp/tools/sheet-copy.js +177 -0
- package/dist/esm/mcp/tools/sheet-copy.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-create.d.ts +56 -0
- package/dist/esm/mcp/tools/sheet-create.js +110 -0
- package/dist/esm/mcp/tools/sheet-create.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-delete.d.ts +62 -0
- package/dist/esm/mcp/tools/sheet-delete.js +125 -0
- package/dist/esm/mcp/tools/sheet-delete.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-find.d.ts +48 -0
- package/dist/esm/mcp/tools/sheet-find.js +90 -0
- package/dist/esm/mcp/tools/sheet-find.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-rename.d.ts +60 -0
- package/dist/esm/mcp/tools/sheet-rename.js +128 -0
- package/dist/esm/mcp/tools/sheet-rename.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-copy.d.ts +58 -0
- package/dist/esm/mcp/tools/spreadsheet-copy.js +117 -0
- package/dist/esm/mcp/tools/spreadsheet-copy.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-create.d.ts +52 -0
- package/dist/esm/mcp/tools/spreadsheet-create.js +97 -0
- package/dist/esm/mcp/tools/spreadsheet-create.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-find.d.ts +58 -0
- package/dist/esm/mcp/tools/spreadsheet-find.js +113 -0
- package/dist/esm/mcp/tools/spreadsheet-find.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-rename.d.ts +56 -0
- package/dist/esm/mcp/tools/spreadsheet-rename.js +112 -0
- package/dist/esm/mcp/tools/spreadsheet-rename.js.map +1 -0
- package/dist/esm/mcp/tools/validation-set.d.ts +144 -0
- package/dist/esm/mcp/tools/validation-set.js +366 -0
- package/dist/esm/mcp/tools/validation-set.js.map +1 -0
- package/dist/esm/mcp/tools/values-batch-update.d.ts +102 -0
- package/dist/esm/mcp/tools/values-batch-update.js +224 -0
- package/dist/esm/mcp/tools/values-batch-update.js.map +1 -0
- package/dist/esm/mcp/tools/values-clear.d.ts +56 -0
- package/dist/esm/mcp/tools/values-clear.js +131 -0
- package/dist/esm/mcp/tools/values-clear.js.map +1 -0
- package/dist/esm/mcp/tools/values-csv-update.d.ts +75 -0
- package/dist/esm/mcp/tools/values-csv-update.js +202 -0
- package/dist/esm/mcp/tools/values-csv-update.js.map +1 -0
- package/dist/esm/mcp/tools/values-replace.d.ts +68 -0
- package/dist/esm/mcp/tools/values-replace.js +171 -0
- package/dist/esm/mcp/tools/values-replace.js.map +1 -0
- package/dist/esm/mcp/tools/values-search.d.ts +74 -0
- package/dist/esm/mcp/tools/values-search.js +229 -0
- package/dist/esm/mcp/tools/values-search.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/esm/schemas/index.d.ts +14 -0
- package/dist/esm/schemas/index.js +35 -0
- package/dist/esm/schemas/index.js.map +1 -0
- package/dist/esm/setup/config.d.ts +44 -0
- package/dist/esm/setup/config.js +151 -0
- package/dist/esm/setup/config.js.map +1 -0
- package/dist/esm/setup/http.d.ts +8 -0
- package/dist/esm/setup/http.js +54 -0
- package/dist/esm/setup/http.js.map +1 -0
- package/dist/esm/setup/index.d.ts +5 -0
- package/dist/esm/setup/index.js +5 -0
- package/dist/esm/setup/index.js.map +1 -0
- package/dist/esm/setup/oauth-google.d.ts +54 -0
- package/dist/esm/setup/oauth-google.js +142 -0
- package/dist/esm/setup/oauth-google.js.map +1 -0
- package/dist/esm/setup/runtime.d.ts +10 -0
- package/dist/esm/setup/runtime.js +84 -0
- package/dist/esm/setup/runtime.js.map +1 -0
- package/dist/esm/setup/stdio.d.ts +7 -0
- package/dist/esm/setup/stdio.js +38 -0
- package/dist/esm/setup/stdio.js.map +1 -0
- package/dist/esm/spreadsheet/column-utilities.d.ts +1 -0
- package/dist/esm/spreadsheet/column-utilities.js +10 -0
- package/dist/esm/spreadsheet/column-utilities.js.map +1 -0
- package/dist/esm/spreadsheet/csv-streaming.d.ts +19 -0
- package/dist/esm/spreadsheet/csv-streaming.js +43 -0
- package/dist/esm/spreadsheet/csv-streaming.js.map +1 -0
- package/dist/esm/spreadsheet/data-operations.d.ts +115 -0
- package/dist/esm/spreadsheet/data-operations.js +712 -0
- package/dist/esm/spreadsheet/data-operations.js.map +1 -0
- package/dist/esm/spreadsheet/deduplication-utils.d.ts +31 -0
- package/dist/esm/spreadsheet/deduplication-utils.js +54 -0
- package/dist/esm/spreadsheet/deduplication-utils.js.map +1 -0
- package/dist/esm/spreadsheet/range-operations.d.ts +184 -0
- package/dist/esm/spreadsheet/range-operations.js +591 -0
- package/dist/esm/spreadsheet/range-operations.js.map +1 -0
- package/dist/esm/spreadsheet/sheet-operations.d.ts +30 -0
- package/dist/esm/spreadsheet/sheet-operations.js +359 -0
- package/dist/esm/spreadsheet/sheet-operations.js.map +1 -0
- package/dist/esm/spreadsheet/spreadsheet-management.d.ts +21 -0
- package/dist/esm/spreadsheet/spreadsheet-management.js +73 -0
- package/dist/esm/spreadsheet/spreadsheet-management.js.map +1 -0
- package/dist/esm/types.d.ts +53 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm/types.js.map +1 -0
- package/package.json +108 -0
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import { schemas } from '@mcp-z/oauth-google';
|
|
2
|
+
const { AuthRequiredBranchSchema } = schemas;
|
|
3
|
+
import { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';
|
|
4
|
+
import { google } from 'googleapis';
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import { A1NotationSchema, SheetCellSchema, SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';
|
|
7
|
+
// Input schema for values batch update requests
|
|
8
|
+
const ValuesBatchUpdateRequestSchema = z.object({
|
|
9
|
+
range: A1NotationSchema.describe('A1 notation range defining the bounded target area. Data dimensions must match range dimensions. Example: D1:D100 requires exactly 100 rows of data. Use open-ended ranges like D1:D to write any number of rows.'),
|
|
10
|
+
values: z.array(z.array(SheetCellSchema)).min(1).describe('2D array of values. Row count must match range height, column count must match range width. Use null to skip a cell (preserve existing value), empty string "" to clear it.'),
|
|
11
|
+
majorDimension: z.enum([
|
|
12
|
+
'ROWS',
|
|
13
|
+
'COLUMNS'
|
|
14
|
+
]).describe('Whether values represent rows or columns')
|
|
15
|
+
});
|
|
16
|
+
const inputSchema = z.object({
|
|
17
|
+
id: SpreadsheetIdSchema,
|
|
18
|
+
gid: SheetGidSchema,
|
|
19
|
+
requests: z.array(ValuesBatchUpdateRequestSchema).min(1).describe('Array of value update requests'),
|
|
20
|
+
valueInputOption: z.enum([
|
|
21
|
+
'RAW',
|
|
22
|
+
'USER_ENTERED'
|
|
23
|
+
]).describe('How input data should be interpreted (RAW = exact values, USER_ENTERED = parsed like user input)'),
|
|
24
|
+
includeData: z.boolean().describe('Whether to include updated cell values in the response')
|
|
25
|
+
});
|
|
26
|
+
const successBranchSchema = z.object({
|
|
27
|
+
type: z.literal('success'),
|
|
28
|
+
id: SpreadsheetIdOutput,
|
|
29
|
+
gid: SheetGidOutput,
|
|
30
|
+
spreadsheetTitle: z.string().describe('Title of the updated spreadsheet'),
|
|
31
|
+
spreadsheetUrl: z.string().describe('URL of the updated spreadsheet'),
|
|
32
|
+
sheetTitle: z.string().describe('Title of the updated sheet'),
|
|
33
|
+
sheetUrl: z.string().describe('URL of the updated sheet'),
|
|
34
|
+
totalUpdatedRows: z.number().int().nonnegative().describe('Total number of rows updated across all requests'),
|
|
35
|
+
totalUpdatedColumns: z.number().int().nonnegative().describe('Total number of columns updated across all requests'),
|
|
36
|
+
totalUpdatedCells: z.number().int().nonnegative().describe('Total number of cells updated across all requests'),
|
|
37
|
+
updatedRanges: z.array(z.string()).describe('A1 notation ranges that were updated'),
|
|
38
|
+
updatedData: z.array(z.object({
|
|
39
|
+
range: z.string().describe('A1 notation range that was updated'),
|
|
40
|
+
majorDimension: z.enum([
|
|
41
|
+
'ROWS',
|
|
42
|
+
'COLUMNS'
|
|
43
|
+
]).describe('Dimension of the updated data'),
|
|
44
|
+
values: z.array(z.array(SheetCellSchema)).optional().describe('Updated values (if includeData was true)')
|
|
45
|
+
})).optional().describe('Detailed information about updated data (if includeData was true)')
|
|
46
|
+
});
|
|
47
|
+
const outputSchema = z.discriminatedUnion('type', [
|
|
48
|
+
successBranchSchema,
|
|
49
|
+
AuthRequiredBranchSchema
|
|
50
|
+
]);
|
|
51
|
+
const config = {
|
|
52
|
+
description: 'Batch update multiple cell ranges. RAW=exact values, USER_ENTERED=parsed like user input. Use a1-notation prompt for range syntax.',
|
|
53
|
+
inputSchema,
|
|
54
|
+
outputSchema: z.object({
|
|
55
|
+
result: outputSchema
|
|
56
|
+
})
|
|
57
|
+
};
|
|
58
|
+
async function handler({ id, gid, requests, valueInputOption = 'USER_ENTERED', includeData = false }, extra) {
|
|
59
|
+
const logger = extra.logger;
|
|
60
|
+
logger.info('sheets.values.batchUpdate called', {
|
|
61
|
+
id,
|
|
62
|
+
gid,
|
|
63
|
+
requestCount: requests.length,
|
|
64
|
+
valueInputOption,
|
|
65
|
+
includeData
|
|
66
|
+
});
|
|
67
|
+
try {
|
|
68
|
+
var _ref, _spreadsheetData_spreadsheetUrl, _sheet_properties_title, _sheet_properties_sheetId;
|
|
69
|
+
var _spreadsheetData_properties, _spreadsheetData_sheets;
|
|
70
|
+
const sheets = google.sheets({
|
|
71
|
+
version: 'v4',
|
|
72
|
+
auth: extra.authContext.auth
|
|
73
|
+
});
|
|
74
|
+
// Get spreadsheet and sheet info in single API call
|
|
75
|
+
const spreadsheetResponse = await sheets.spreadsheets.get({
|
|
76
|
+
spreadsheetId: id,
|
|
77
|
+
fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title'
|
|
78
|
+
});
|
|
79
|
+
const spreadsheetData = spreadsheetResponse.data;
|
|
80
|
+
const spreadsheetTitle = (_ref = (_spreadsheetData_properties = spreadsheetData.properties) === null || _spreadsheetData_properties === void 0 ? void 0 : _spreadsheetData_properties.title) !== null && _ref !== void 0 ? _ref : '';
|
|
81
|
+
const spreadsheetUrl = (_spreadsheetData_spreadsheetUrl = spreadsheetData.spreadsheetUrl) !== null && _spreadsheetData_spreadsheetUrl !== void 0 ? _spreadsheetData_spreadsheetUrl : '';
|
|
82
|
+
// Find sheet by gid
|
|
83
|
+
const sheet = (_spreadsheetData_sheets = spreadsheetData.sheets) === null || _spreadsheetData_sheets === void 0 ? void 0 : _spreadsheetData_sheets.find((s)=>{
|
|
84
|
+
var _s_properties;
|
|
85
|
+
return String((_s_properties = s.properties) === null || _s_properties === void 0 ? void 0 : _s_properties.sheetId) === gid;
|
|
86
|
+
});
|
|
87
|
+
if (!(sheet === null || sheet === void 0 ? void 0 : sheet.properties)) {
|
|
88
|
+
logger.info('Sheet not found for batch update', {
|
|
89
|
+
id,
|
|
90
|
+
gid,
|
|
91
|
+
requestCount: requests.length
|
|
92
|
+
});
|
|
93
|
+
throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);
|
|
94
|
+
}
|
|
95
|
+
const sheetTitle = (_sheet_properties_title = sheet.properties.title) !== null && _sheet_properties_title !== void 0 ? _sheet_properties_title : gid;
|
|
96
|
+
const sheetGid = (_sheet_properties_sheetId = sheet.properties.sheetId) !== null && _sheet_properties_sheetId !== void 0 ? _sheet_properties_sheetId : 0;
|
|
97
|
+
const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetGid}`;
|
|
98
|
+
// Build batch update request with prefixed ranges
|
|
99
|
+
const batchUpdateData = requests.map((req)=>({
|
|
100
|
+
range: `${sheetTitle}!${req.range}`,
|
|
101
|
+
values: req.values,
|
|
102
|
+
majorDimension: req.majorDimension || 'ROWS'
|
|
103
|
+
}));
|
|
104
|
+
logger.info('sheets.values.batchUpdate executing batch request', {
|
|
105
|
+
spreadsheetId: id,
|
|
106
|
+
sheetTitle,
|
|
107
|
+
batchUpdateDataCount: batchUpdateData.length
|
|
108
|
+
});
|
|
109
|
+
// Execute the batch update
|
|
110
|
+
const batchUpdateResponse = await sheets.spreadsheets.values.batchUpdate({
|
|
111
|
+
spreadsheetId: id,
|
|
112
|
+
requestBody: {
|
|
113
|
+
valueInputOption,
|
|
114
|
+
data: batchUpdateData,
|
|
115
|
+
includeValuesInResponse: includeData,
|
|
116
|
+
responseDateTimeRenderOption: 'FORMATTED_STRING',
|
|
117
|
+
responseValueRenderOption: 'FORMATTED_VALUE'
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
const updateResult = batchUpdateResponse.data;
|
|
121
|
+
// Validate batch operation results and detect partial failures
|
|
122
|
+
const responses = updateResult.responses || [];
|
|
123
|
+
const expectedCount = requests.length;
|
|
124
|
+
const actualCount = responses.length;
|
|
125
|
+
if (actualCount !== expectedCount) {
|
|
126
|
+
logger.error('Partial batch failure detected', {
|
|
127
|
+
expectedOperations: expectedCount,
|
|
128
|
+
completedOperations: actualCount,
|
|
129
|
+
spreadsheetId: id,
|
|
130
|
+
sheetTitle
|
|
131
|
+
});
|
|
132
|
+
throw new McpError(ErrorCode.InternalError, `Batch operation partially failed: ${actualCount}/${expectedCount} operations completed`);
|
|
133
|
+
}
|
|
134
|
+
// Check for any failed operations (empty or null responses)
|
|
135
|
+
const failedOperations = responses.filter((response, index)=>{
|
|
136
|
+
if (!response || !response.updatedRange) {
|
|
137
|
+
var _requests_index;
|
|
138
|
+
logger.error('Failed operation detected', {
|
|
139
|
+
operationIndex: index,
|
|
140
|
+
requestedRange: (_requests_index = requests[index]) === null || _requests_index === void 0 ? void 0 : _requests_index.range,
|
|
141
|
+
spreadsheetId: id,
|
|
142
|
+
sheetTitle
|
|
143
|
+
});
|
|
144
|
+
return true;
|
|
145
|
+
}
|
|
146
|
+
return false;
|
|
147
|
+
});
|
|
148
|
+
if (failedOperations.length > 0) {
|
|
149
|
+
throw new McpError(ErrorCode.InternalError, `${failedOperations.length} operations failed to update ranges`);
|
|
150
|
+
}
|
|
151
|
+
// Extract updated ranges and calculate totals
|
|
152
|
+
const updatedRanges = responses.map((response)=>response.updatedRange || '').filter((range)=>range);
|
|
153
|
+
const totalUpdatedRows = updateResult.totalUpdatedRows || 0;
|
|
154
|
+
const totalUpdatedColumns = updateResult.totalUpdatedColumns || 0;
|
|
155
|
+
const totalUpdatedCells = updateResult.totalUpdatedCells || 0;
|
|
156
|
+
// Build updated data response if requested
|
|
157
|
+
let updatedData;
|
|
158
|
+
if (includeData && updateResult.responses) {
|
|
159
|
+
updatedData = updateResult.responses.filter((response)=>response.updatedData).map((response)=>{
|
|
160
|
+
var _response_updatedData, _response_updatedData1;
|
|
161
|
+
const item = {
|
|
162
|
+
range: response.updatedRange || '',
|
|
163
|
+
majorDimension: ((_response_updatedData = response.updatedData) === null || _response_updatedData === void 0 ? void 0 : _response_updatedData.majorDimension) || 'ROWS'
|
|
164
|
+
};
|
|
165
|
+
const values = (_response_updatedData1 = response.updatedData) === null || _response_updatedData1 === void 0 ? void 0 : _response_updatedData1.values;
|
|
166
|
+
if (values !== undefined) {
|
|
167
|
+
// Map undefined values to null for JSON Schema compatibility
|
|
168
|
+
item.values = values.map((row)=>row.map((cell)=>cell === undefined ? null : cell));
|
|
169
|
+
}
|
|
170
|
+
return item;
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
logger.info('sheets.values.batchUpdate completed successfully', {
|
|
174
|
+
totalUpdatedRows,
|
|
175
|
+
totalUpdatedColumns,
|
|
176
|
+
totalUpdatedCells,
|
|
177
|
+
updatedRangesCount: updatedRanges.length
|
|
178
|
+
});
|
|
179
|
+
const result = {
|
|
180
|
+
type: 'success',
|
|
181
|
+
id,
|
|
182
|
+
gid: String(sheetGid),
|
|
183
|
+
spreadsheetTitle: spreadsheetTitle || '',
|
|
184
|
+
spreadsheetUrl: spreadsheetUrl || '',
|
|
185
|
+
sheetTitle,
|
|
186
|
+
sheetUrl,
|
|
187
|
+
totalUpdatedRows,
|
|
188
|
+
totalUpdatedColumns,
|
|
189
|
+
totalUpdatedCells,
|
|
190
|
+
updatedRanges,
|
|
191
|
+
updatedData
|
|
192
|
+
};
|
|
193
|
+
return {
|
|
194
|
+
content: [
|
|
195
|
+
{
|
|
196
|
+
type: 'text',
|
|
197
|
+
text: JSON.stringify(result)
|
|
198
|
+
}
|
|
199
|
+
],
|
|
200
|
+
structuredContent: {
|
|
201
|
+
result
|
|
202
|
+
}
|
|
203
|
+
};
|
|
204
|
+
} catch (error) {
|
|
205
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
206
|
+
logger.error('Batch update operation failed', {
|
|
207
|
+
id,
|
|
208
|
+
gid,
|
|
209
|
+
requestCount: requests.length,
|
|
210
|
+
valueInputOption,
|
|
211
|
+
error: message
|
|
212
|
+
});
|
|
213
|
+
throw new McpError(ErrorCode.InternalError, `Error batch updating values: ${message}`, {
|
|
214
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
export default function createTool() {
|
|
219
|
+
return {
|
|
220
|
+
name: 'values-batch-update',
|
|
221
|
+
config,
|
|
222
|
+
handler
|
|
223
|
+
};
|
|
224
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/values-batch-update.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport type { ToolModule } from '@mcp-z/server';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { A1NotationSchema, SheetCellSchema, SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\n\n// Types for updated data response\ninterface UpdatedDataItem {\n range: string;\n majorDimension: 'ROWS' | 'COLUMNS';\n values?: (string | number | boolean | null)[][];\n}\n\n// Input schema for values batch update requests\nconst ValuesBatchUpdateRequestSchema = z.object({\n range: A1NotationSchema.describe('A1 notation range defining the bounded target area. Data dimensions must match range dimensions. Example: D1:D100 requires exactly 100 rows of data. Use open-ended ranges like D1:D to write any number of rows.'),\n values: z.array(z.array(SheetCellSchema)).min(1).describe('2D array of values. Row count must match range height, column count must match range width. Use null to skip a cell (preserve existing value), empty string \"\" to clear it.'),\n majorDimension: z.enum(['ROWS', 'COLUMNS']).describe('Whether values represent rows or columns'),\n});\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n requests: z.array(ValuesBatchUpdateRequestSchema).min(1).describe('Array of value update requests'),\n valueInputOption: z.enum(['RAW', 'USER_ENTERED']).describe('How input data should be interpreted (RAW = exact values, USER_ENTERED = parsed like user input)'),\n includeData: z.boolean().describe('Whether to include updated cell values in the response'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n spreadsheetTitle: z.string().describe('Title of the updated spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the updated spreadsheet'),\n sheetTitle: z.string().describe('Title of the updated sheet'),\n sheetUrl: z.string().describe('URL of the updated sheet'),\n totalUpdatedRows: z.number().int().nonnegative().describe('Total number of rows updated across all requests'),\n totalUpdatedColumns: z.number().int().nonnegative().describe('Total number of columns updated across all requests'),\n totalUpdatedCells: z.number().int().nonnegative().describe('Total number of cells updated across all requests'),\n updatedRanges: z.array(z.string()).describe('A1 notation ranges that were updated'),\n updatedData: z\n .array(\n z.object({\n range: z.string().describe('A1 notation range that was updated'),\n majorDimension: z.enum(['ROWS', 'COLUMNS']).describe('Dimension of the updated data'),\n values: z.array(z.array(SheetCellSchema)).optional().describe('Updated values (if includeData was true)'),\n })\n )\n .optional()\n .describe('Detailed information about updated data (if includeData was true)'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Batch update multiple cell ranges. RAW=exact values, USER_ENTERED=parsed like user input. Use a1-notation prompt for range syntax.',\n inputSchema,\n outputSchema: z.object({\n result: outputSchema,\n }),\n} as const;\n\nexport type Input = z.infer<typeof inputSchema>;\nexport type Output = z.infer<typeof outputSchema>;\n\nasync function handler({ id, gid, requests, valueInputOption = 'USER_ENTERED', includeData = false }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.values.batchUpdate called', {\n id,\n gid,\n requestCount: requests.length,\n valueInputOption,\n includeData,\n });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get spreadsheet and sheet info in single API call\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title',\n });\n\n const spreadsheetData = spreadsheetResponse.data;\n const spreadsheetTitle = spreadsheetData.properties?.title ?? '';\n const spreadsheetUrl = spreadsheetData.spreadsheetUrl ?? '';\n\n // Find sheet by gid\n const sheet = spreadsheetData.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheet?.properties) {\n logger.info('Sheet not found for batch update', { id, gid, requestCount: requests.length });\n throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);\n }\n\n const sheetTitle = sheet.properties.title ?? gid;\n const sheetGid = sheet.properties.sheetId ?? 0;\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetGid}`;\n\n // Build batch update request with prefixed ranges\n const batchUpdateData = requests.map((req) => ({\n range: `${sheetTitle}!${req.range}`,\n values: req.values,\n majorDimension: req.majorDimension || 'ROWS',\n }));\n\n logger.info('sheets.values.batchUpdate executing batch request', {\n spreadsheetId: id,\n sheetTitle,\n batchUpdateDataCount: batchUpdateData.length,\n });\n\n // Execute the batch update\n const batchUpdateResponse = await sheets.spreadsheets.values.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n valueInputOption,\n data: batchUpdateData,\n includeValuesInResponse: includeData,\n responseDateTimeRenderOption: 'FORMATTED_STRING',\n responseValueRenderOption: 'FORMATTED_VALUE',\n },\n });\n\n const updateResult = batchUpdateResponse.data;\n\n // Validate batch operation results and detect partial failures\n const responses = updateResult.responses || [];\n const expectedCount = requests.length;\n const actualCount = responses.length;\n\n if (actualCount !== expectedCount) {\n logger.error('Partial batch failure detected', {\n expectedOperations: expectedCount,\n completedOperations: actualCount,\n spreadsheetId: id,\n sheetTitle,\n });\n\n throw new McpError(ErrorCode.InternalError, `Batch operation partially failed: ${actualCount}/${expectedCount} operations completed`);\n }\n\n // Check for any failed operations (empty or null responses)\n const failedOperations = responses.filter((response, index) => {\n if (!response || !response.updatedRange) {\n logger.error('Failed operation detected', {\n operationIndex: index,\n requestedRange: requests[index]?.range,\n spreadsheetId: id,\n sheetTitle,\n });\n return true;\n }\n return false;\n });\n\n if (failedOperations.length > 0) {\n throw new McpError(ErrorCode.InternalError, `${failedOperations.length} operations failed to update ranges`);\n }\n\n // Extract updated ranges and calculate totals\n const updatedRanges = responses.map((response) => response.updatedRange || '').filter((range) => range);\n const totalUpdatedRows = updateResult.totalUpdatedRows || 0;\n const totalUpdatedColumns = updateResult.totalUpdatedColumns || 0;\n const totalUpdatedCells = updateResult.totalUpdatedCells || 0;\n\n // Build updated data response if requested\n let updatedData: UpdatedDataItem[] | undefined;\n if (includeData && updateResult.responses) {\n updatedData = updateResult.responses\n .filter((response) => response.updatedData)\n .map((response) => {\n const item: UpdatedDataItem = {\n range: response.updatedRange || '',\n majorDimension: (response.updatedData?.majorDimension as 'ROWS' | 'COLUMNS' | undefined) || 'ROWS',\n };\n const values = response.updatedData?.values as (string | number | boolean | null | undefined)[][] | undefined;\n if (values !== undefined) {\n // Map undefined values to null for JSON Schema compatibility\n item.values = values.map((row) => row.map((cell) => (cell === undefined ? null : cell)));\n }\n return item;\n });\n }\n\n logger.info('sheets.values.batchUpdate completed successfully', {\n totalUpdatedRows,\n totalUpdatedColumns,\n totalUpdatedCells,\n updatedRangesCount: updatedRanges.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetGid),\n spreadsheetTitle: spreadsheetTitle || '',\n spreadsheetUrl: spreadsheetUrl || '',\n sheetTitle,\n sheetUrl,\n totalUpdatedRows,\n totalUpdatedColumns,\n totalUpdatedCells,\n updatedRanges,\n updatedData,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('Batch update operation failed', {\n id,\n gid,\n requestCount: requests.length,\n valueInputOption,\n error: message,\n });\n\n throw new McpError(ErrorCode.InternalError, `Error batch updating values: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'values-batch-update',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["schemas","AuthRequiredBranchSchema","ErrorCode","McpError","google","z","A1NotationSchema","SheetCellSchema","SheetGidOutput","SheetGidSchema","SpreadsheetIdOutput","SpreadsheetIdSchema","ValuesBatchUpdateRequestSchema","object","range","describe","values","array","min","majorDimension","enum","inputSchema","id","gid","requests","valueInputOption","includeData","boolean","successBranchSchema","type","literal","spreadsheetTitle","string","spreadsheetUrl","sheetTitle","sheetUrl","totalUpdatedRows","number","int","nonnegative","totalUpdatedColumns","totalUpdatedCells","updatedRanges","updatedData","optional","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","info","requestCount","length","spreadsheetData","sheet","sheets","version","auth","authContext","spreadsheetResponse","spreadsheets","get","spreadsheetId","fields","data","properties","title","find","s","String","sheetId","InvalidParams","sheetGid","batchUpdateData","map","req","batchUpdateDataCount","batchUpdateResponse","batchUpdate","requestBody","includeValuesInResponse","responseDateTimeRenderOption","responseValueRenderOption","updateResult","responses","expectedCount","actualCount","error","expectedOperations","completedOperations","InternalError","failedOperations","filter","response","index","updatedRange","operationIndex","requestedRange","item","undefined","row","cell","updatedRangesCount","content","text","JSON","stringify","structuredContent","message","Error","stack","createTool","name"],"mappings":"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"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import type { EnrichedExtra } from '@mcp-z/oauth-google';
|
|
2
|
+
import type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
declare const inputSchema: z.ZodObject<{
|
|
5
|
+
id: z.ZodString;
|
|
6
|
+
gid: z.ZodCoercedString<unknown>;
|
|
7
|
+
ranges: z.ZodArray<z.ZodString>;
|
|
8
|
+
}, z.core.$strip>;
|
|
9
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
10
|
+
type: z.ZodLiteral<"success">;
|
|
11
|
+
id: z.ZodString;
|
|
12
|
+
gid: z.ZodString;
|
|
13
|
+
spreadsheetTitle: z.ZodString;
|
|
14
|
+
spreadsheetUrl: z.ZodString;
|
|
15
|
+
sheetTitle: z.ZodString;
|
|
16
|
+
sheetUrl: z.ZodString;
|
|
17
|
+
clearedRanges: z.ZodArray<z.ZodString>;
|
|
18
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
19
|
+
type: z.ZodLiteral<"auth_required">;
|
|
20
|
+
provider: z.ZodString;
|
|
21
|
+
message: z.ZodString;
|
|
22
|
+
url: z.ZodOptional<z.ZodString>;
|
|
23
|
+
}, z.core.$strip>], "type">;
|
|
24
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
25
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
26
|
+
declare function handler({ id, gid, ranges }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
27
|
+
export default function createTool(): {
|
|
28
|
+
name: string;
|
|
29
|
+
config: {
|
|
30
|
+
readonly description: "Clear cell values from one or more ranges. Clears values only - preserves formatting, validation, and other cell properties. Use a1-notation prompt for range syntax.";
|
|
31
|
+
readonly inputSchema: z.ZodObject<{
|
|
32
|
+
id: z.ZodString;
|
|
33
|
+
gid: z.ZodCoercedString<unknown>;
|
|
34
|
+
ranges: z.ZodArray<z.ZodString>;
|
|
35
|
+
}, z.core.$strip>;
|
|
36
|
+
readonly outputSchema: z.ZodObject<{
|
|
37
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
38
|
+
type: z.ZodLiteral<"success">;
|
|
39
|
+
id: z.ZodString;
|
|
40
|
+
gid: z.ZodString;
|
|
41
|
+
spreadsheetTitle: z.ZodString;
|
|
42
|
+
spreadsheetUrl: z.ZodString;
|
|
43
|
+
sheetTitle: z.ZodString;
|
|
44
|
+
sheetUrl: z.ZodString;
|
|
45
|
+
clearedRanges: z.ZodArray<z.ZodString>;
|
|
46
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
47
|
+
type: z.ZodLiteral<"auth_required">;
|
|
48
|
+
provider: z.ZodString;
|
|
49
|
+
message: z.ZodString;
|
|
50
|
+
url: z.ZodOptional<z.ZodString>;
|
|
51
|
+
}, z.core.$strip>], "type">;
|
|
52
|
+
}, z.core.$strip>;
|
|
53
|
+
};
|
|
54
|
+
handler: typeof handler;
|
|
55
|
+
};
|
|
56
|
+
export {};
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { schemas } from '@mcp-z/oauth-google';
|
|
2
|
+
const { AuthRequiredBranchSchema } = schemas;
|
|
3
|
+
import { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';
|
|
4
|
+
import { google } from 'googleapis';
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import { A1NotationSchema, SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';
|
|
7
|
+
const inputSchema = z.object({
|
|
8
|
+
id: SpreadsheetIdSchema,
|
|
9
|
+
gid: SheetGidSchema,
|
|
10
|
+
ranges: z.array(A1NotationSchema).min(1).describe('A1 notation ranges to clear (e.g., ["A1:B5", "D3:D10"]). Clears values only, preserves formatting.')
|
|
11
|
+
});
|
|
12
|
+
const successBranchSchema = z.object({
|
|
13
|
+
type: z.literal('success'),
|
|
14
|
+
id: SpreadsheetIdOutput,
|
|
15
|
+
gid: SheetGidOutput,
|
|
16
|
+
spreadsheetTitle: z.string().describe('Title of the spreadsheet'),
|
|
17
|
+
spreadsheetUrl: z.string().describe('URL of the spreadsheet'),
|
|
18
|
+
sheetTitle: z.string().describe('Title of the sheet'),
|
|
19
|
+
sheetUrl: z.string().describe('URL of the sheet'),
|
|
20
|
+
clearedRanges: z.array(z.string()).describe('A1 notation ranges that were cleared')
|
|
21
|
+
});
|
|
22
|
+
const outputSchema = z.discriminatedUnion('type', [
|
|
23
|
+
successBranchSchema,
|
|
24
|
+
AuthRequiredBranchSchema
|
|
25
|
+
]);
|
|
26
|
+
const config = {
|
|
27
|
+
description: 'Clear cell values from one or more ranges. Clears values only - preserves formatting, validation, and other cell properties. Use a1-notation prompt for range syntax.',
|
|
28
|
+
inputSchema,
|
|
29
|
+
outputSchema: z.object({
|
|
30
|
+
result: outputSchema
|
|
31
|
+
})
|
|
32
|
+
};
|
|
33
|
+
async function handler({ id, gid, ranges }, extra) {
|
|
34
|
+
const logger = extra.logger;
|
|
35
|
+
logger.info('sheets.values.clear called', {
|
|
36
|
+
id,
|
|
37
|
+
gid,
|
|
38
|
+
rangeCount: ranges.length
|
|
39
|
+
});
|
|
40
|
+
try {
|
|
41
|
+
var _ref, _spreadsheetData_spreadsheetUrl, _sheet_properties_title, _sheet_properties_sheetId;
|
|
42
|
+
var _spreadsheetData_properties, _spreadsheetData_sheets;
|
|
43
|
+
const sheets = google.sheets({
|
|
44
|
+
version: 'v4',
|
|
45
|
+
auth: extra.authContext.auth
|
|
46
|
+
});
|
|
47
|
+
// Get spreadsheet and sheet info in single API call
|
|
48
|
+
const spreadsheetResponse = await sheets.spreadsheets.get({
|
|
49
|
+
spreadsheetId: id,
|
|
50
|
+
fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title'
|
|
51
|
+
});
|
|
52
|
+
const spreadsheetData = spreadsheetResponse.data;
|
|
53
|
+
const spreadsheetTitle = (_ref = (_spreadsheetData_properties = spreadsheetData.properties) === null || _spreadsheetData_properties === void 0 ? void 0 : _spreadsheetData_properties.title) !== null && _ref !== void 0 ? _ref : '';
|
|
54
|
+
const spreadsheetUrl = (_spreadsheetData_spreadsheetUrl = spreadsheetData.spreadsheetUrl) !== null && _spreadsheetData_spreadsheetUrl !== void 0 ? _spreadsheetData_spreadsheetUrl : '';
|
|
55
|
+
// Find sheet by gid
|
|
56
|
+
const sheet = (_spreadsheetData_sheets = spreadsheetData.sheets) === null || _spreadsheetData_sheets === void 0 ? void 0 : _spreadsheetData_sheets.find((s)=>{
|
|
57
|
+
var _s_properties;
|
|
58
|
+
return String((_s_properties = s.properties) === null || _s_properties === void 0 ? void 0 : _s_properties.sheetId) === gid;
|
|
59
|
+
});
|
|
60
|
+
if (!(sheet === null || sheet === void 0 ? void 0 : sheet.properties)) {
|
|
61
|
+
logger.info('Sheet not found for clear', {
|
|
62
|
+
id,
|
|
63
|
+
gid,
|
|
64
|
+
rangeCount: ranges.length
|
|
65
|
+
});
|
|
66
|
+
throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);
|
|
67
|
+
}
|
|
68
|
+
const sheetTitle = (_sheet_properties_title = sheet.properties.title) !== null && _sheet_properties_title !== void 0 ? _sheet_properties_title : gid;
|
|
69
|
+
const sheetGid = (_sheet_properties_sheetId = sheet.properties.sheetId) !== null && _sheet_properties_sheetId !== void 0 ? _sheet_properties_sheetId : 0;
|
|
70
|
+
const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetGid}`;
|
|
71
|
+
// Prefix ranges with sheet title
|
|
72
|
+
const prefixedRanges = ranges.map((range)=>`${sheetTitle}!${range}`);
|
|
73
|
+
logger.info('sheets.values.clear executing', {
|
|
74
|
+
spreadsheetId: id,
|
|
75
|
+
sheetTitle,
|
|
76
|
+
prefixedRanges
|
|
77
|
+
});
|
|
78
|
+
// Use batchClear for efficiency (works for single or multiple ranges)
|
|
79
|
+
const clearResponse = await sheets.spreadsheets.values.batchClear({
|
|
80
|
+
spreadsheetId: id,
|
|
81
|
+
requestBody: {
|
|
82
|
+
ranges: prefixedRanges
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
const clearedRanges = clearResponse.data.clearedRanges || [];
|
|
86
|
+
logger.info('sheets.values.clear completed successfully', {
|
|
87
|
+
spreadsheetId: id,
|
|
88
|
+
sheetTitle,
|
|
89
|
+
clearedRangesCount: clearedRanges.length
|
|
90
|
+
});
|
|
91
|
+
const result = {
|
|
92
|
+
type: 'success',
|
|
93
|
+
id,
|
|
94
|
+
gid: String(sheetGid),
|
|
95
|
+
spreadsheetTitle: spreadsheetTitle || '',
|
|
96
|
+
spreadsheetUrl: spreadsheetUrl || '',
|
|
97
|
+
sheetTitle,
|
|
98
|
+
sheetUrl,
|
|
99
|
+
clearedRanges
|
|
100
|
+
};
|
|
101
|
+
return {
|
|
102
|
+
content: [
|
|
103
|
+
{
|
|
104
|
+
type: 'text',
|
|
105
|
+
text: JSON.stringify(result)
|
|
106
|
+
}
|
|
107
|
+
],
|
|
108
|
+
structuredContent: {
|
|
109
|
+
result
|
|
110
|
+
}
|
|
111
|
+
};
|
|
112
|
+
} catch (error) {
|
|
113
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
114
|
+
logger.error('Clear operation failed', {
|
|
115
|
+
id,
|
|
116
|
+
gid,
|
|
117
|
+
rangeCount: ranges.length,
|
|
118
|
+
error: message
|
|
119
|
+
});
|
|
120
|
+
throw new McpError(ErrorCode.InternalError, `Error clearing values: ${message}`, {
|
|
121
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
export default function createTool() {
|
|
126
|
+
return {
|
|
127
|
+
name: 'values-clear',
|
|
128
|
+
config,
|
|
129
|
+
handler
|
|
130
|
+
};
|
|
131
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/values-clear.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport type { ToolModule } from '@mcp-z/server';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { A1NotationSchema, SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n ranges: z.array(A1NotationSchema).min(1).describe('A1 notation ranges to clear (e.g., [\"A1:B5\", \"D3:D10\"]). Clears values only, preserves formatting.'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n spreadsheetTitle: z.string().describe('Title of the spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the spreadsheet'),\n sheetTitle: z.string().describe('Title of the sheet'),\n sheetUrl: z.string().describe('URL of the sheet'),\n clearedRanges: z.array(z.string()).describe('A1 notation ranges that were cleared'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Clear cell values from one or more ranges. Clears values only - preserves formatting, validation, and other cell properties. Use a1-notation prompt for range syntax.',\n inputSchema,\n outputSchema: z.object({\n result: outputSchema,\n }),\n} as const;\n\nexport type Input = z.infer<typeof inputSchema>;\nexport type Output = z.infer<typeof outputSchema>;\n\nasync function handler({ id, gid, ranges }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.values.clear called', { id, gid, rangeCount: ranges.length });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get spreadsheet and sheet info in single API call\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title',\n });\n\n const spreadsheetData = spreadsheetResponse.data;\n const spreadsheetTitle = spreadsheetData.properties?.title ?? '';\n const spreadsheetUrl = spreadsheetData.spreadsheetUrl ?? '';\n\n // Find sheet by gid\n const sheet = spreadsheetData.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheet?.properties) {\n logger.info('Sheet not found for clear', { id, gid, rangeCount: ranges.length });\n throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);\n }\n\n const sheetTitle = sheet.properties.title ?? gid;\n const sheetGid = sheet.properties.sheetId ?? 0;\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetGid}`;\n\n // Prefix ranges with sheet title\n const prefixedRanges = ranges.map((range) => `${sheetTitle}!${range}`);\n\n logger.info('sheets.values.clear executing', { spreadsheetId: id, sheetTitle, prefixedRanges });\n\n // Use batchClear for efficiency (works for single or multiple ranges)\n const clearResponse = await sheets.spreadsheets.values.batchClear({\n spreadsheetId: id,\n requestBody: {\n ranges: prefixedRanges,\n },\n });\n\n const clearedRanges = clearResponse.data.clearedRanges || [];\n\n logger.info('sheets.values.clear completed successfully', {\n spreadsheetId: id,\n sheetTitle,\n clearedRangesCount: clearedRanges.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetGid),\n spreadsheetTitle: spreadsheetTitle || '',\n spreadsheetUrl: spreadsheetUrl || '',\n sheetTitle,\n sheetUrl,\n clearedRanges,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('Clear operation failed', { id, gid, rangeCount: ranges.length, error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error clearing values: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'values-clear',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["schemas","AuthRequiredBranchSchema","ErrorCode","McpError","google","z","A1NotationSchema","SheetGidOutput","SheetGidSchema","SpreadsheetIdOutput","SpreadsheetIdSchema","inputSchema","object","id","gid","ranges","array","min","describe","successBranchSchema","type","literal","spreadsheetTitle","string","spreadsheetUrl","sheetTitle","sheetUrl","clearedRanges","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","info","rangeCount","length","spreadsheetData","sheet","sheets","version","auth","authContext","spreadsheetResponse","spreadsheets","get","spreadsheetId","fields","data","properties","title","find","s","String","sheetId","InvalidParams","sheetGid","prefixedRanges","map","range","clearResponse","values","batchClear","requestBody","clearedRangesCount","content","text","JSON","stringify","structuredContent","error","message","Error","InternalError","stack","undefined","createTool","name"],"mappings":"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"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
/** Import CSV data to Google Sheets with range-based update (no deduplication) */
|
|
2
|
+
import type { EnrichedExtra } from '@mcp-z/oauth-google';
|
|
3
|
+
import type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';
|
|
4
|
+
import { z } from 'zod';
|
|
5
|
+
declare const inputSchema: z.ZodObject<{
|
|
6
|
+
id: z.ZodString;
|
|
7
|
+
gid: z.ZodCoercedString<unknown>;
|
|
8
|
+
sourceUri: z.ZodString;
|
|
9
|
+
startRange: z.ZodDefault<z.ZodString>;
|
|
10
|
+
valueInputOption: z.ZodDefault<z.ZodEnum<{
|
|
11
|
+
RAW: "RAW";
|
|
12
|
+
USER_ENTERED: "USER_ENTERED";
|
|
13
|
+
}>>;
|
|
14
|
+
sourceHasHeaders: z.ZodDefault<z.ZodBoolean>;
|
|
15
|
+
}, z.core.$strip>;
|
|
16
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
17
|
+
type: z.ZodLiteral<"success">;
|
|
18
|
+
id: z.ZodString;
|
|
19
|
+
gid: z.ZodString;
|
|
20
|
+
spreadsheetTitle: z.ZodString;
|
|
21
|
+
spreadsheetUrl: z.ZodString;
|
|
22
|
+
sheetTitle: z.ZodString;
|
|
23
|
+
sheetUrl: z.ZodString;
|
|
24
|
+
updatedRange: z.ZodString;
|
|
25
|
+
updatedRows: z.ZodNumber;
|
|
26
|
+
updatedColumns: z.ZodNumber;
|
|
27
|
+
updatedCells: z.ZodNumber;
|
|
28
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
29
|
+
type: z.ZodLiteral<"auth_required">;
|
|
30
|
+
provider: z.ZodString;
|
|
31
|
+
message: z.ZodString;
|
|
32
|
+
url: z.ZodOptional<z.ZodString>;
|
|
33
|
+
}, z.core.$strip>], "type">;
|
|
34
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
35
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
36
|
+
declare function handler({ id, gid, sourceUri, startRange, valueInputOption, sourceHasHeaders }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
37
|
+
export default function createTool(): {
|
|
38
|
+
name: string;
|
|
39
|
+
config: {
|
|
40
|
+
readonly description: "Import CSV to sheet range. Overwrites existing data at startRange. Use rows-csv-append for database-style appends with deduplication.";
|
|
41
|
+
readonly inputSchema: z.ZodObject<{
|
|
42
|
+
id: z.ZodString;
|
|
43
|
+
gid: z.ZodCoercedString<unknown>;
|
|
44
|
+
sourceUri: z.ZodString;
|
|
45
|
+
startRange: z.ZodDefault<z.ZodString>;
|
|
46
|
+
valueInputOption: z.ZodDefault<z.ZodEnum<{
|
|
47
|
+
RAW: "RAW";
|
|
48
|
+
USER_ENTERED: "USER_ENTERED";
|
|
49
|
+
}>>;
|
|
50
|
+
sourceHasHeaders: z.ZodDefault<z.ZodBoolean>;
|
|
51
|
+
}, z.core.$strip>;
|
|
52
|
+
readonly outputSchema: z.ZodObject<{
|
|
53
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
54
|
+
type: z.ZodLiteral<"success">;
|
|
55
|
+
id: z.ZodString;
|
|
56
|
+
gid: z.ZodString;
|
|
57
|
+
spreadsheetTitle: z.ZodString;
|
|
58
|
+
spreadsheetUrl: z.ZodString;
|
|
59
|
+
sheetTitle: z.ZodString;
|
|
60
|
+
sheetUrl: z.ZodString;
|
|
61
|
+
updatedRange: z.ZodString;
|
|
62
|
+
updatedRows: z.ZodNumber;
|
|
63
|
+
updatedColumns: z.ZodNumber;
|
|
64
|
+
updatedCells: z.ZodNumber;
|
|
65
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
66
|
+
type: z.ZodLiteral<"auth_required">;
|
|
67
|
+
provider: z.ZodString;
|
|
68
|
+
message: z.ZodString;
|
|
69
|
+
url: z.ZodOptional<z.ZodString>;
|
|
70
|
+
}, z.core.$strip>], "type">;
|
|
71
|
+
}, z.core.$strip>;
|
|
72
|
+
};
|
|
73
|
+
handler: typeof handler;
|
|
74
|
+
};
|
|
75
|
+
export {};
|