@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 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/chart-create.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, type sheets_v4 } from 'googleapis';\nimport { z } from 'zod';\nimport { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\nimport { parseA1Notation, rangeReferenceToGridRange } from '../../spreadsheet/range-operations.js';\n\n// Input schema for chart position\nconst ChartPositionSchema = z.object({\n anchorCell: z.string().min(1).describe('A1 notation cell where chart top-left anchors (e.g., \"F2\")'),\n offsetX: z.number().int().default(0).describe('Horizontal pixel offset from anchor'),\n offsetY: z.number().int().default(0).describe('Vertical pixel offset from anchor'),\n});\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n chartType: z.enum(['PIE', 'BAR', 'COLUMN', 'LINE']).describe('Type of chart to create'),\n dataRange: z.string().min(1).describe('A1 notation range containing chart data including headers (e.g., \"A1:C10\")'),\n title: z.string().optional().describe('Chart title displayed at top'),\n position: ChartPositionSchema,\n legend: z.enum(['BOTTOM', 'RIGHT', 'TOP', 'LEFT', 'NONE']).default('BOTTOM').describe('Legend position'),\n is3D: z.boolean().default(false).describe('Render as 3D chart (PIE only)'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n sheetTitle: z.string().describe('Title of the sheet containing the chart'),\n sheetUrl: z.string().describe('URL of the sheet containing the chart'),\n chartId: z.number().int().describe('Unique chart ID for future updates/deletion'),\n anchorCell: z.string().describe('Where chart was anchored'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Create charts (pie, bar, column, line) from spreadsheet data ranges. Charts anchor to specific cells with optional pixel offsets. Data range should include headers. PIE charts use 2 columns (labels, values). BAR/COLUMN/LINE charts use first row as headers. Best for visualizing spreadsheet data.',\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\n// Parse A1 notation anchor cell to row/column indices\nfunction parseAnchorCell(anchorCell: string): { rowIndex: number; columnIndex: number } {\n // Simple A1 notation parser for single cells\n const match = anchorCell.match(/^([A-Z]+)(\\d+)$/);\n if (!match || !match[1] || !match[2]) {\n throw new Error(`Invalid anchor cell format: ${anchorCell}`);\n }\n\n const colLetters = match[1];\n const rowNumber = match[2];\n\n // Convert column letters to index (A=0, B=1, ..., Z=25, AA=26, etc.)\n let columnIndex = 0;\n for (let i = 0; i < colLetters.length; i++) {\n columnIndex = columnIndex * 26 + (colLetters.charCodeAt(i) - 65 + 1);\n }\n columnIndex--; // Convert to 0-based\n\n // Convert row number to index (1-based to 0-based)\n const rowIndex = Number.parseInt(rowNumber, 10) - 1;\n\n return { rowIndex, columnIndex };\n}\n\nasync function handler({ id, gid, chartType, dataRange, title, position, legend = 'BOTTOM', is3D = false }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.chart.create called', {\n id,\n gid,\n chartType,\n dataRange,\n title,\n position,\n legend,\n is3D,\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: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n // Find sheet by gid\n const sheet = spreadsheetResponse.data.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheet?.properties) {\n logger.info('Sheet not found for chart create', { id, gid, chartType });\n throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);\n }\n\n const sheetTitle = sheet.properties.title ?? gid;\n const sheetId = sheet.properties.sheetId;\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetId}`;\n\n // Validate 3D only for PIE charts\n // Note: Google Sheets API only supports 3D for PIE charts, not COLUMN/BAR/LINE\n if (is3D && chartType !== 'PIE') {\n logger.info('3D mode not supported for this chart type', {\n chartType,\n is3D,\n });\n throw new McpError(ErrorCode.InvalidParams, `3D mode is only supported for PIE charts, not ${chartType}`);\n }\n\n // Parse anchor cell to row/column indices\n let anchorRowIndex: number;\n let anchorColumnIndex: number;\n try {\n const anchorIndices = parseAnchorCell(position.anchorCell);\n anchorRowIndex = anchorIndices.rowIndex;\n anchorColumnIndex = anchorIndices.columnIndex;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.info('Failed to parse anchor cell', {\n anchorCell: position.anchorCell,\n error: message,\n });\n throw new McpError(ErrorCode.InvalidParams, `Failed to parse anchor cell: ${message}`);\n }\n\n // Parse data range to grid range\n let dataGridRange: sheets_v4.Schema$GridRange;\n try {\n const rangeRef = parseA1Notation(dataRange);\n dataGridRange = rangeReferenceToGridRange(rangeRef, sheetId);\n\n // Validate that required properties are defined for chart creation\n if (dataGridRange.startColumnIndex === undefined || dataGridRange.startColumnIndex === null) {\n throw new Error('Data range must include column information');\n }\n if (dataGridRange.endColumnIndex === undefined || dataGridRange.endColumnIndex === null) {\n throw new Error('Data range must include column information');\n }\n if (dataGridRange.startRowIndex === undefined || dataGridRange.startRowIndex === null) {\n throw new Error('Data range must include row information');\n }\n if (dataGridRange.endRowIndex === undefined || dataGridRange.endRowIndex === null) {\n throw new Error('Data range must include row information');\n }\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.info('Failed to parse data range', {\n dataRange,\n error: message,\n });\n throw new McpError(ErrorCode.InvalidParams, `Failed to parse data range: ${message}`);\n }\n\n // Extract validated properties with defined types\n const dataStartRowIndex = dataGridRange.startRowIndex as number;\n const dataEndRowIndex = dataGridRange.endRowIndex as number;\n const dataStartColumnIndex = dataGridRange.startColumnIndex as number;\n const dataEndColumnIndex = dataGridRange.endColumnIndex as number;\n const dataSheetId = dataGridRange.sheetId ?? sheetId;\n\n // Build chart spec with properly split domain and series ranges\n let chartSpec: sheets_v4.Schema$ChartSpec;\n\n logger.info('Building chart spec', {\n chartType,\n dataGridRange,\n sheetId,\n });\n\n // Map legend position to API format (add _LEGEND suffix)\n const legendPositionMap: Record<string, string> = {\n BOTTOM: 'BOTTOM_LEGEND',\n RIGHT: 'RIGHT_LEGEND',\n TOP: 'TOP_LEGEND',\n LEFT: 'LEFT_LEGEND',\n NONE: 'NO_LEGEND',\n };\n const apiLegendPosition = legendPositionMap[legend] || 'BOTTOM_LEGEND';\n\n if (chartType === 'PIE') {\n // PIE charts use a separate pieChart property, not basicChart\n const baseSheetId = dataSheetId;\n\n const domainRange = {\n sheetId: baseSheetId,\n startRowIndex: dataStartRowIndex,\n endRowIndex: dataEndRowIndex,\n startColumnIndex: dataStartColumnIndex,\n endColumnIndex: dataStartColumnIndex + 1, // First column only (labels)\n };\n\n const seriesRange = {\n sheetId: baseSheetId,\n startRowIndex: dataStartRowIndex,\n endRowIndex: dataEndRowIndex,\n startColumnIndex: dataStartColumnIndex + 1, // Second column (values)\n endColumnIndex: dataStartColumnIndex + 2,\n };\n\n logger.info('PIE chart ranges', {\n dataGridRange,\n domainRange,\n seriesRange,\n apiLegendPosition,\n });\n\n chartSpec = {\n pieChart: {\n // Use pieChart for PIE charts\n legendPosition: legend === 'NONE' ? 'NO_LEGEND' : apiLegendPosition,\n domain: {\n // Note: domain/series are direct objects, not arrays\n sourceRange: {\n sources: [domainRange],\n },\n },\n series: {\n sourceRange: {\n sources: [seriesRange],\n },\n },\n threeDimensional: is3D, // 3D is directly on pieChart\n },\n };\n if (title) {\n chartSpec.title = title;\n }\n } else {\n // For BAR, COLUMN, LINE charts: domain is first column, each subsequent column is a series\n const baseSheetId = dataSheetId;\n\n const domainRange = {\n sheetId: baseSheetId,\n startRowIndex: dataStartRowIndex,\n endRowIndex: dataEndRowIndex,\n startColumnIndex: dataStartColumnIndex,\n endColumnIndex: dataStartColumnIndex + 1, // First column only\n };\n\n // Calculate number of data columns (excluding the first domain column)\n const numDataColumns = dataEndColumnIndex - dataStartColumnIndex - 1;\n const series = [];\n\n // Create a series for each data column\n for (let i = 0; i < numDataColumns; i++) {\n const seriesRange = {\n sheetId: baseSheetId,\n startRowIndex: dataStartRowIndex,\n endRowIndex: dataEndRowIndex,\n startColumnIndex: dataStartColumnIndex + 1 + i,\n endColumnIndex: dataStartColumnIndex + 2 + i,\n };\n\n series.push({\n series: {\n sourceRange: {\n sources: [seriesRange],\n },\n },\n });\n }\n\n // If no data columns were found, default to using the entire range as a fallback\n if (series.length === 0) {\n series.push({\n series: {\n sourceRange: {\n sources: [dataGridRange],\n },\n },\n });\n }\n\n const basicChart: sheets_v4.Schema$BasicChartSpec = {\n chartType, // BAR, COLUMN, LINE are valid for basicChart\n headerCount: 1, // First row is headers\n // Note: Google Sheets API does not support threeDimensional for basicChart (BAR/COLUMN/LINE)\n // threeDimensional is only supported for pieChart\n domains: [\n {\n domain: {\n sourceRange: {\n sources: [domainRange],\n },\n },\n },\n ],\n series,\n };\n if (legend !== 'NONE') {\n basicChart.legendPosition = apiLegendPosition;\n }\n\n chartSpec = { basicChart };\n if (title) {\n chartSpec.title = title;\n }\n }\n\n // Build embedded object position\n const embeddedObjectPosition = {\n overlayPosition: {\n anchorCell: {\n sheetId,\n rowIndex: anchorRowIndex,\n columnIndex: anchorColumnIndex,\n },\n offsetXPixels: position.offsetX,\n offsetYPixels: position.offsetY,\n },\n };\n\n const requestBody = {\n requests: [\n {\n addChart: {\n chart: {\n spec: chartSpec,\n position: embeddedObjectPosition,\n },\n },\n },\n ],\n };\n\n logger.info('sheets.chart.create executing addChart request', {\n spreadsheetId: id,\n sheetTitle,\n chartType,\n dataRange,\n anchorCell: position.anchorCell,\n requestBody: JSON.stringify(requestBody),\n });\n\n // Execute the addChart request\n const response = await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody,\n });\n\n // Extract chart ID from response\n const replies = response.data.replies || [];\n if (replies.length === 0 || !replies[0]?.addChart?.chart?.chartId) {\n logger.error('Chart creation failed - no chart ID returned', {\n spreadsheetId: id,\n sheetTitle,\n chartType,\n });\n throw new McpError(ErrorCode.InternalError, 'Chart creation failed: no chart ID returned from Google Sheets API');\n }\n\n const chartId = replies[0].addChart.chart.chartId;\n\n logger.info('sheets.chart.create completed successfully', {\n chartId,\n chartType,\n anchorCell: position.anchorCell,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetId),\n sheetTitle,\n sheetUrl,\n chartId,\n anchorCell: position.anchorCell,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n } catch (e) {\n const error = e as Error & { response?: { data?: unknown; status?: number } };\n const message = error.message || String(e);\n logger.error('Chart create operation failed', {\n id,\n gid,\n chartType,\n dataRange,\n error: message,\n response: error.response?.data,\n status: error.response?.status,\n });\n\n throw new McpError(ErrorCode.InternalError, `Error creating chart: ${message}`, {\n stack: e instanceof Error ? e.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'chart-create',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","ChartPositionSchema","z","object","anchorCell","string","min","describe","offsetX","number","int","default","offsetY","inputSchema","id","SpreadsheetIdSchema","gid","SheetGidSchema","chartType","enum","dataRange","title","optional","position","legend","is3D","boolean","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","sheetTitle","sheetUrl","chartId","outputSchema","discriminatedUnion","config","description","result","parseAnchorCell","match","Error","colLetters","rowNumber","columnIndex","i","length","charCodeAt","rowIndex","Number","parseInt","handler","extra","logger","sheet","dataGridRange","spreadsheetResponse","replies","sheets","sheetId","anchorRowIndex","anchorColumnIndex","anchorIndices","message","rangeRef","dataStartRowIndex","dataEndRowIndex","dataStartColumnIndex","dataEndColumnIndex","dataSheetId","chartSpec","legendPositionMap","apiLegendPosition","baseSheetId","domainRange","seriesRange","numDataColumns","series","basicChart","embeddedObjectPosition","requestBody","response","e","error","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","String","properties","McpError","ErrorCode","InvalidParams","parseA1Notation","rangeReferenceToGridRange","startColumnIndex","undefined","endColumnIndex","startRowIndex","endRowIndex","BOTTOM","RIGHT","TOP","LEFT","NONE","pieChart","legendPosition","domain","sourceRange","sources","threeDimensional","push","headerCount","domains","overlayPosition","offsetXPixels","offsetYPixels","requests","addChart","chart","spec","JSON","stringify","batchUpdate","InternalError","content","text","structuredContent","status","stack","name"],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/** Get column names from Google Sheet (peek at first row only) */
|
|
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
|
+
render: z.ZodOptional<z.ZodEnum<{
|
|
9
|
+
FORMATTED_VALUE: "FORMATTED_VALUE";
|
|
10
|
+
UNFORMATTED_VALUE: "UNFORMATTED_VALUE";
|
|
11
|
+
FORMULA: "FORMULA";
|
|
12
|
+
}>>;
|
|
13
|
+
}, z.core.$strip>;
|
|
14
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
15
|
+
type: z.ZodLiteral<"success">;
|
|
16
|
+
columns: z.ZodArray<z.ZodString>;
|
|
17
|
+
isEmpty: z.ZodBoolean;
|
|
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, render }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
27
|
+
export default function createTool(): {
|
|
28
|
+
name: string;
|
|
29
|
+
config: {
|
|
30
|
+
readonly description: "Get first row from Google Sheet. Returns columns array and isEmpty flag.";
|
|
31
|
+
readonly inputSchema: z.ZodObject<{
|
|
32
|
+
id: z.ZodString;
|
|
33
|
+
gid: z.ZodCoercedString<unknown>;
|
|
34
|
+
render: z.ZodOptional<z.ZodEnum<{
|
|
35
|
+
FORMATTED_VALUE: "FORMATTED_VALUE";
|
|
36
|
+
UNFORMATTED_VALUE: "UNFORMATTED_VALUE";
|
|
37
|
+
FORMULA: "FORMULA";
|
|
38
|
+
}>>;
|
|
39
|
+
}, z.core.$strip>;
|
|
40
|
+
readonly outputSchema: z.ZodObject<{
|
|
41
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
42
|
+
type: z.ZodLiteral<"success">;
|
|
43
|
+
columns: z.ZodArray<z.ZodString>;
|
|
44
|
+
isEmpty: z.ZodBoolean;
|
|
45
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
46
|
+
type: z.ZodLiteral<"auth_required">;
|
|
47
|
+
provider: z.ZodString;
|
|
48
|
+
message: z.ZodString;
|
|
49
|
+
url: z.ZodOptional<z.ZodString>;
|
|
50
|
+
}, z.core.$strip>], "type">;
|
|
51
|
+
}, z.core.$strip>;
|
|
52
|
+
};
|
|
53
|
+
handler: typeof handler;
|
|
54
|
+
};
|
|
55
|
+
export {};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/** Get column names from Google Sheet (peek at first row only) */
|
|
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
|
+
render: z.ZodOptional<z.ZodEnum<{
|
|
9
|
+
FORMATTED_VALUE: "FORMATTED_VALUE";
|
|
10
|
+
UNFORMATTED_VALUE: "UNFORMATTED_VALUE";
|
|
11
|
+
FORMULA: "FORMULA";
|
|
12
|
+
}>>;
|
|
13
|
+
}, z.core.$strip>;
|
|
14
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
15
|
+
type: z.ZodLiteral<"success">;
|
|
16
|
+
columns: z.ZodArray<z.ZodString>;
|
|
17
|
+
isEmpty: z.ZodBoolean;
|
|
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, render }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
27
|
+
export default function createTool(): {
|
|
28
|
+
name: string;
|
|
29
|
+
config: {
|
|
30
|
+
readonly description: "Get first row from Google Sheet. Returns columns array and isEmpty flag.";
|
|
31
|
+
readonly inputSchema: z.ZodObject<{
|
|
32
|
+
id: z.ZodString;
|
|
33
|
+
gid: z.ZodCoercedString<unknown>;
|
|
34
|
+
render: z.ZodOptional<z.ZodEnum<{
|
|
35
|
+
FORMATTED_VALUE: "FORMATTED_VALUE";
|
|
36
|
+
UNFORMATTED_VALUE: "UNFORMATTED_VALUE";
|
|
37
|
+
FORMULA: "FORMULA";
|
|
38
|
+
}>>;
|
|
39
|
+
}, z.core.$strip>;
|
|
40
|
+
readonly outputSchema: z.ZodObject<{
|
|
41
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
42
|
+
type: z.ZodLiteral<"success">;
|
|
43
|
+
columns: z.ZodArray<z.ZodString>;
|
|
44
|
+
isEmpty: z.ZodBoolean;
|
|
45
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
46
|
+
type: z.ZodLiteral<"auth_required">;
|
|
47
|
+
provider: z.ZodString;
|
|
48
|
+
message: z.ZodString;
|
|
49
|
+
url: z.ZodOptional<z.ZodString>;
|
|
50
|
+
}, z.core.$strip>], "type">;
|
|
51
|
+
}, z.core.$strip>;
|
|
52
|
+
};
|
|
53
|
+
handler: typeof handler;
|
|
54
|
+
};
|
|
55
|
+
export {};
|
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
/** Get column names from Google Sheet (peek at first row only) */ "use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return createTool;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
12
|
+
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
|
+
var _googleapis = require("googleapis");
|
|
14
|
+
var _zod = require("zod");
|
|
15
|
+
var _index = require("../../schemas/index.js");
|
|
16
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
17
|
+
try {
|
|
18
|
+
var info = gen[key](arg);
|
|
19
|
+
var value = info.value;
|
|
20
|
+
} catch (error) {
|
|
21
|
+
reject(error);
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
if (info.done) {
|
|
25
|
+
resolve(value);
|
|
26
|
+
} else {
|
|
27
|
+
Promise.resolve(value).then(_next, _throw);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
function _async_to_generator(fn) {
|
|
31
|
+
return function() {
|
|
32
|
+
var self = this, args = arguments;
|
|
33
|
+
return new Promise(function(resolve, reject) {
|
|
34
|
+
var gen = fn.apply(self, args);
|
|
35
|
+
function _next(value) {
|
|
36
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
37
|
+
}
|
|
38
|
+
function _throw(err) {
|
|
39
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
40
|
+
}
|
|
41
|
+
_next(undefined);
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
function _instanceof(left, right) {
|
|
46
|
+
if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
|
|
47
|
+
return !!right[Symbol.hasInstance](left);
|
|
48
|
+
} else {
|
|
49
|
+
return left instanceof right;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
function _ts_generator(thisArg, body) {
|
|
53
|
+
var f, y, t, _ = {
|
|
54
|
+
label: 0,
|
|
55
|
+
sent: function() {
|
|
56
|
+
if (t[0] & 1) throw t[1];
|
|
57
|
+
return t[1];
|
|
58
|
+
},
|
|
59
|
+
trys: [],
|
|
60
|
+
ops: []
|
|
61
|
+
}, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype), d = Object.defineProperty;
|
|
62
|
+
return d(g, "next", {
|
|
63
|
+
value: verb(0)
|
|
64
|
+
}), d(g, "throw", {
|
|
65
|
+
value: verb(1)
|
|
66
|
+
}), d(g, "return", {
|
|
67
|
+
value: verb(2)
|
|
68
|
+
}), typeof Symbol === "function" && d(g, Symbol.iterator, {
|
|
69
|
+
value: function() {
|
|
70
|
+
return this;
|
|
71
|
+
}
|
|
72
|
+
}), g;
|
|
73
|
+
function verb(n) {
|
|
74
|
+
return function(v) {
|
|
75
|
+
return step([
|
|
76
|
+
n,
|
|
77
|
+
v
|
|
78
|
+
]);
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
function step(op) {
|
|
82
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
83
|
+
while(g && (g = 0, op[0] && (_ = 0)), _)try {
|
|
84
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
85
|
+
if (y = 0, t) op = [
|
|
86
|
+
op[0] & 2,
|
|
87
|
+
t.value
|
|
88
|
+
];
|
|
89
|
+
switch(op[0]){
|
|
90
|
+
case 0:
|
|
91
|
+
case 1:
|
|
92
|
+
t = op;
|
|
93
|
+
break;
|
|
94
|
+
case 4:
|
|
95
|
+
_.label++;
|
|
96
|
+
return {
|
|
97
|
+
value: op[1],
|
|
98
|
+
done: false
|
|
99
|
+
};
|
|
100
|
+
case 5:
|
|
101
|
+
_.label++;
|
|
102
|
+
y = op[1];
|
|
103
|
+
op = [
|
|
104
|
+
0
|
|
105
|
+
];
|
|
106
|
+
continue;
|
|
107
|
+
case 7:
|
|
108
|
+
op = _.ops.pop();
|
|
109
|
+
_.trys.pop();
|
|
110
|
+
continue;
|
|
111
|
+
default:
|
|
112
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
113
|
+
_ = 0;
|
|
114
|
+
continue;
|
|
115
|
+
}
|
|
116
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
117
|
+
_.label = op[1];
|
|
118
|
+
break;
|
|
119
|
+
}
|
|
120
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
121
|
+
_.label = t[1];
|
|
122
|
+
t = op;
|
|
123
|
+
break;
|
|
124
|
+
}
|
|
125
|
+
if (t && _.label < t[2]) {
|
|
126
|
+
_.label = t[2];
|
|
127
|
+
_.ops.push(op);
|
|
128
|
+
break;
|
|
129
|
+
}
|
|
130
|
+
if (t[2]) _.ops.pop();
|
|
131
|
+
_.trys.pop();
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
op = body.call(thisArg, _);
|
|
135
|
+
} catch (e) {
|
|
136
|
+
op = [
|
|
137
|
+
6,
|
|
138
|
+
e
|
|
139
|
+
];
|
|
140
|
+
y = 0;
|
|
141
|
+
} finally{
|
|
142
|
+
f = t = 0;
|
|
143
|
+
}
|
|
144
|
+
if (op[0] & 5) throw op[1];
|
|
145
|
+
return {
|
|
146
|
+
value: op[0] ? op[1] : void 0,
|
|
147
|
+
done: true
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
152
|
+
var inputSchema = _zod.z.object({
|
|
153
|
+
id: _index.SpreadsheetIdSchema,
|
|
154
|
+
gid: _index.SheetGidSchema,
|
|
155
|
+
render: _zod.z.enum([
|
|
156
|
+
'FORMATTED_VALUE',
|
|
157
|
+
'UNFORMATTED_VALUE',
|
|
158
|
+
'FORMULA'
|
|
159
|
+
]).optional().describe('How to render cell values. FORMATTED_VALUE (default): calculated with formatting. UNFORMATTED_VALUE: calculated without formatting. FORMULA: show formula text instead of result.')
|
|
160
|
+
});
|
|
161
|
+
// Success branch schema - uses columns: for consistency with standard vocabulary
|
|
162
|
+
var successBranchSchema = _zod.z.object({
|
|
163
|
+
type: _zod.z.literal('success'),
|
|
164
|
+
columns: _zod.z.array(_zod.z.string()).describe('First row values (column names) or empty if no rows'),
|
|
165
|
+
isEmpty: _zod.z.boolean().describe('True if sheet has zero rows')
|
|
166
|
+
});
|
|
167
|
+
var outputSchema = _zod.z.discriminatedUnion('type', [
|
|
168
|
+
successBranchSchema,
|
|
169
|
+
AuthRequiredBranchSchema
|
|
170
|
+
]);
|
|
171
|
+
var config = {
|
|
172
|
+
description: 'Get first row from Google Sheet. Returns columns array and isEmpty flag.',
|
|
173
|
+
inputSchema: inputSchema,
|
|
174
|
+
outputSchema: _zod.z.object({
|
|
175
|
+
result: outputSchema
|
|
176
|
+
})
|
|
177
|
+
};
|
|
178
|
+
function handler(_0, _1) {
|
|
179
|
+
return _async_to_generator(function(param, extra) {
|
|
180
|
+
var id, gid, render, _logger_debug, logger, _sheet_properties_title, _spreadsheetResponse_data_sheets, _logger_info, sheets, spreadsheetResponse, sheet, sheetTitle, range, response, rows, isEmpty, firstRow, columns, result, error, _logger_error, message;
|
|
181
|
+
return _ts_generator(this, function(_state) {
|
|
182
|
+
switch(_state.label){
|
|
183
|
+
case 0:
|
|
184
|
+
id = param.id, gid = param.gid, render = param.render;
|
|
185
|
+
logger = extra.logger;
|
|
186
|
+
(_logger_debug = logger.debug) === null || _logger_debug === void 0 ? void 0 : _logger_debug.call(logger, 'sheets.columns.get called', {
|
|
187
|
+
id: id,
|
|
188
|
+
gid: gid,
|
|
189
|
+
render: render
|
|
190
|
+
});
|
|
191
|
+
_state.label = 1;
|
|
192
|
+
case 1:
|
|
193
|
+
_state.trys.push([
|
|
194
|
+
1,
|
|
195
|
+
4,
|
|
196
|
+
,
|
|
197
|
+
5
|
|
198
|
+
]);
|
|
199
|
+
sheets = _googleapis.google.sheets({
|
|
200
|
+
version: 'v4',
|
|
201
|
+
auth: extra.authContext.auth
|
|
202
|
+
});
|
|
203
|
+
return [
|
|
204
|
+
4,
|
|
205
|
+
sheets.spreadsheets.get({
|
|
206
|
+
spreadsheetId: id,
|
|
207
|
+
fields: 'sheets.properties.sheetId,sheets.properties.title'
|
|
208
|
+
})
|
|
209
|
+
];
|
|
210
|
+
case 2:
|
|
211
|
+
spreadsheetResponse = _state.sent();
|
|
212
|
+
// Find sheet by gid
|
|
213
|
+
sheet = (_spreadsheetResponse_data_sheets = spreadsheetResponse.data.sheets) === null || _spreadsheetResponse_data_sheets === void 0 ? void 0 : _spreadsheetResponse_data_sheets.find(function(s) {
|
|
214
|
+
var _s_properties;
|
|
215
|
+
return String((_s_properties = s.properties) === null || _s_properties === void 0 ? void 0 : _s_properties.sheetId) === gid;
|
|
216
|
+
});
|
|
217
|
+
if (!(sheet === null || sheet === void 0 ? void 0 : sheet.properties)) {
|
|
218
|
+
throw new _types.McpError(_types.ErrorCode.InvalidParams, "Sheet not found: ".concat(gid));
|
|
219
|
+
}
|
|
220
|
+
sheetTitle = (_sheet_properties_title = sheet.properties.title) !== null && _sheet_properties_title !== void 0 ? _sheet_properties_title : '';
|
|
221
|
+
// Read first row only (A1:ZZZ1 should cover most reasonable sheets)
|
|
222
|
+
range = "'".concat(sheetTitle, "'!A1:ZZZ1");
|
|
223
|
+
return [
|
|
224
|
+
4,
|
|
225
|
+
sheets.spreadsheets.values.get({
|
|
226
|
+
spreadsheetId: id,
|
|
227
|
+
range: range,
|
|
228
|
+
valueRenderOption: render || 'FORMATTED_VALUE'
|
|
229
|
+
})
|
|
230
|
+
];
|
|
231
|
+
case 3:
|
|
232
|
+
response = _state.sent();
|
|
233
|
+
rows = response.data.values || [];
|
|
234
|
+
isEmpty = rows.length === 0;
|
|
235
|
+
// Extract first row and convert to strings (column names)
|
|
236
|
+
firstRow = rows[0] || [];
|
|
237
|
+
columns = firstRow.map(function(value) {
|
|
238
|
+
return String(value !== null && value !== void 0 ? value : '');
|
|
239
|
+
});
|
|
240
|
+
result = {
|
|
241
|
+
type: 'success',
|
|
242
|
+
columns: columns,
|
|
243
|
+
isEmpty: isEmpty
|
|
244
|
+
};
|
|
245
|
+
(_logger_info = logger.info) === null || _logger_info === void 0 ? void 0 : _logger_info.call(logger, 'sheets.columns.get completed', {
|
|
246
|
+
id: id,
|
|
247
|
+
gid: gid,
|
|
248
|
+
columnCount: columns.length,
|
|
249
|
+
isEmpty: isEmpty
|
|
250
|
+
});
|
|
251
|
+
return [
|
|
252
|
+
2,
|
|
253
|
+
{
|
|
254
|
+
content: [
|
|
255
|
+
{
|
|
256
|
+
type: 'text',
|
|
257
|
+
text: JSON.stringify(result)
|
|
258
|
+
}
|
|
259
|
+
],
|
|
260
|
+
structuredContent: {
|
|
261
|
+
result: result
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
];
|
|
265
|
+
case 4:
|
|
266
|
+
error = _state.sent();
|
|
267
|
+
message = _instanceof(error, Error) ? error.message : String(error);
|
|
268
|
+
(_logger_error = logger.error) === null || _logger_error === void 0 ? void 0 : _logger_error.call(logger, 'sheets.columns.get error', {
|
|
269
|
+
error: message
|
|
270
|
+
});
|
|
271
|
+
throw new _types.McpError(_types.ErrorCode.InternalError, "Error getting sheet columns: ".concat(message), {
|
|
272
|
+
stack: _instanceof(error, Error) ? error.stack : undefined
|
|
273
|
+
});
|
|
274
|
+
case 5:
|
|
275
|
+
return [
|
|
276
|
+
2
|
|
277
|
+
];
|
|
278
|
+
}
|
|
279
|
+
});
|
|
280
|
+
}).apply(this, arguments);
|
|
281
|
+
}
|
|
282
|
+
function createTool() {
|
|
283
|
+
return {
|
|
284
|
+
name: 'columns-get',
|
|
285
|
+
config: config,
|
|
286
|
+
handler: handler
|
|
287
|
+
};
|
|
288
|
+
}
|
|
289
|
+
/* CJS INTEROP */ if (exports.__esModule && exports.default) { try { Object.defineProperty(exports.default, '__esModule', { value: true }); for (var key in exports) { exports.default[key] = exports[key]; } } catch (_) {}; module.exports = exports.default; }
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/columns-get.ts"],"sourcesContent":["/** Get column names from Google Sheet (peek at first row only) */\n\nimport 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 { SheetGidSchema, SpreadsheetIdSchema } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n render: z.enum(['FORMATTED_VALUE', 'UNFORMATTED_VALUE', 'FORMULA']).optional().describe('How to render cell values. FORMATTED_VALUE (default): calculated with formatting. UNFORMATTED_VALUE: calculated without formatting. FORMULA: show formula text instead of result.'),\n});\n\n// Success branch schema - uses columns: for consistency with standard vocabulary\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n columns: z.array(z.string()).describe('First row values (column names) or empty if no rows'),\n isEmpty: z.boolean().describe('True if sheet has zero rows'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Get first row from Google Sheet. Returns columns array and isEmpty flag.',\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, render }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.debug?.('sheets.columns.get called', { id, gid, render });\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: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n // Find sheet by gid\n const sheet = spreadsheetResponse.data.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheet?.properties) {\n throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);\n }\n\n const sheetTitle = sheet.properties.title ?? '';\n\n // Read first row only (A1:ZZZ1 should cover most reasonable sheets)\n const range = `'${sheetTitle}'!A1:ZZZ1`;\n const response = await sheets.spreadsheets.values.get({\n spreadsheetId: id,\n range,\n valueRenderOption: render || 'FORMATTED_VALUE',\n });\n\n const rows = response.data.values || [];\n const isEmpty = rows.length === 0;\n\n // Extract first row and convert to strings (column names)\n const firstRow = rows[0] || [];\n const columns = firstRow.map((value) => String(value ?? ''));\n\n const result: Output = {\n type: 'success' as const,\n columns,\n isEmpty,\n };\n\n logger.info?.('sheets.columns.get completed', { id, gid, columnCount: columns.length, isEmpty });\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?.('sheets.columns.get error', { error: message });\n throw new McpError(ErrorCode.InternalError, `Error getting sheet columns: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'columns-get',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","render","enum","optional","describe","successBranchSchema","type","literal","columns","array","string","isEmpty","boolean","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sheet","spreadsheetResponse","sheets","sheetTitle","range","response","rows","firstRow","error","message","debug","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","String","properties","sheetId","McpError","ErrorCode","InvalidParams","title","values","valueRenderOption","length","map","value","info","columnCount","content","text","JSON","stringify","structuredContent","Error","InternalError","stack","undefined","name"],"mappings":"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"}
|
|
@@ -0,0 +1,86 @@
|
|
|
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
|
+
rows: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
8
|
+
headers: z.ZodArray<z.ZodString>;
|
|
9
|
+
updateBy: z.ZodArray<z.ZodString>;
|
|
10
|
+
behavior: z.ZodDefault<z.ZodEnum<{
|
|
11
|
+
"add-or-update": "add-or-update";
|
|
12
|
+
"update-only": "update-only";
|
|
13
|
+
"add-only": "add-only";
|
|
14
|
+
}>>;
|
|
15
|
+
valueInputOption: z.ZodDefault<z.ZodEnum<{
|
|
16
|
+
RAW: "RAW";
|
|
17
|
+
USER_ENTERED: "USER_ENTERED";
|
|
18
|
+
}>>;
|
|
19
|
+
}, z.core.$strip>;
|
|
20
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
21
|
+
type: z.ZodLiteral<"success">;
|
|
22
|
+
id: z.ZodString;
|
|
23
|
+
gid: z.ZodString;
|
|
24
|
+
spreadsheetTitle: z.ZodString;
|
|
25
|
+
spreadsheetUrl: z.ZodString;
|
|
26
|
+
sheetTitle: z.ZodString;
|
|
27
|
+
sheetUrl: z.ZodString;
|
|
28
|
+
updatedRows: z.ZodNumber;
|
|
29
|
+
insertedKeys: z.ZodArray<z.ZodString>;
|
|
30
|
+
rowsSkipped: z.ZodNumber;
|
|
31
|
+
headersAdded: z.ZodArray<z.ZodString>;
|
|
32
|
+
errors: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
33
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
34
|
+
type: z.ZodLiteral<"auth_required">;
|
|
35
|
+
provider: z.ZodString;
|
|
36
|
+
message: z.ZodString;
|
|
37
|
+
url: z.ZodOptional<z.ZodString>;
|
|
38
|
+
}, z.core.$strip>], "type">;
|
|
39
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
40
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
41
|
+
declare function handler({ id, gid, rows, headers, updateBy, behavior, valueInputOption }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
42
|
+
export default function createTool(): {
|
|
43
|
+
name: string;
|
|
44
|
+
config: {
|
|
45
|
+
readonly description: "Update spreadsheet data by column headers with intelligent upsert logic. Supports adding missing columns, flexible update behaviors, and robust error handling. Uses column names as keys for matching existing rows, enabling context-aware data synchronization workflows.";
|
|
46
|
+
readonly inputSchema: z.ZodObject<{
|
|
47
|
+
id: z.ZodString;
|
|
48
|
+
gid: z.ZodCoercedString<unknown>;
|
|
49
|
+
rows: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
50
|
+
headers: z.ZodArray<z.ZodString>;
|
|
51
|
+
updateBy: z.ZodArray<z.ZodString>;
|
|
52
|
+
behavior: z.ZodDefault<z.ZodEnum<{
|
|
53
|
+
"add-or-update": "add-or-update";
|
|
54
|
+
"update-only": "update-only";
|
|
55
|
+
"add-only": "add-only";
|
|
56
|
+
}>>;
|
|
57
|
+
valueInputOption: z.ZodDefault<z.ZodEnum<{
|
|
58
|
+
RAW: "RAW";
|
|
59
|
+
USER_ENTERED: "USER_ENTERED";
|
|
60
|
+
}>>;
|
|
61
|
+
}, z.core.$strip>;
|
|
62
|
+
readonly outputSchema: z.ZodObject<{
|
|
63
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
64
|
+
type: z.ZodLiteral<"success">;
|
|
65
|
+
id: z.ZodString;
|
|
66
|
+
gid: z.ZodString;
|
|
67
|
+
spreadsheetTitle: z.ZodString;
|
|
68
|
+
spreadsheetUrl: z.ZodString;
|
|
69
|
+
sheetTitle: z.ZodString;
|
|
70
|
+
sheetUrl: z.ZodString;
|
|
71
|
+
updatedRows: z.ZodNumber;
|
|
72
|
+
insertedKeys: z.ZodArray<z.ZodString>;
|
|
73
|
+
rowsSkipped: z.ZodNumber;
|
|
74
|
+
headersAdded: z.ZodArray<z.ZodString>;
|
|
75
|
+
errors: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
76
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
77
|
+
type: z.ZodLiteral<"auth_required">;
|
|
78
|
+
provider: z.ZodString;
|
|
79
|
+
message: z.ZodString;
|
|
80
|
+
url: z.ZodOptional<z.ZodString>;
|
|
81
|
+
}, z.core.$strip>], "type">;
|
|
82
|
+
}, z.core.$strip>;
|
|
83
|
+
};
|
|
84
|
+
handler: typeof handler;
|
|
85
|
+
};
|
|
86
|
+
export {};
|
|
@@ -0,0 +1,86 @@
|
|
|
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
|
+
rows: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
8
|
+
headers: z.ZodArray<z.ZodString>;
|
|
9
|
+
updateBy: z.ZodArray<z.ZodString>;
|
|
10
|
+
behavior: z.ZodDefault<z.ZodEnum<{
|
|
11
|
+
"add-or-update": "add-or-update";
|
|
12
|
+
"update-only": "update-only";
|
|
13
|
+
"add-only": "add-only";
|
|
14
|
+
}>>;
|
|
15
|
+
valueInputOption: z.ZodDefault<z.ZodEnum<{
|
|
16
|
+
RAW: "RAW";
|
|
17
|
+
USER_ENTERED: "USER_ENTERED";
|
|
18
|
+
}>>;
|
|
19
|
+
}, z.core.$strip>;
|
|
20
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
21
|
+
type: z.ZodLiteral<"success">;
|
|
22
|
+
id: z.ZodString;
|
|
23
|
+
gid: z.ZodString;
|
|
24
|
+
spreadsheetTitle: z.ZodString;
|
|
25
|
+
spreadsheetUrl: z.ZodString;
|
|
26
|
+
sheetTitle: z.ZodString;
|
|
27
|
+
sheetUrl: z.ZodString;
|
|
28
|
+
updatedRows: z.ZodNumber;
|
|
29
|
+
insertedKeys: z.ZodArray<z.ZodString>;
|
|
30
|
+
rowsSkipped: z.ZodNumber;
|
|
31
|
+
headersAdded: z.ZodArray<z.ZodString>;
|
|
32
|
+
errors: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
33
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
34
|
+
type: z.ZodLiteral<"auth_required">;
|
|
35
|
+
provider: z.ZodString;
|
|
36
|
+
message: z.ZodString;
|
|
37
|
+
url: z.ZodOptional<z.ZodString>;
|
|
38
|
+
}, z.core.$strip>], "type">;
|
|
39
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
40
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
41
|
+
declare function handler({ id, gid, rows, headers, updateBy, behavior, valueInputOption }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
42
|
+
export default function createTool(): {
|
|
43
|
+
name: string;
|
|
44
|
+
config: {
|
|
45
|
+
readonly description: "Update spreadsheet data by column headers with intelligent upsert logic. Supports adding missing columns, flexible update behaviors, and robust error handling. Uses column names as keys for matching existing rows, enabling context-aware data synchronization workflows.";
|
|
46
|
+
readonly inputSchema: z.ZodObject<{
|
|
47
|
+
id: z.ZodString;
|
|
48
|
+
gid: z.ZodCoercedString<unknown>;
|
|
49
|
+
rows: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
50
|
+
headers: z.ZodArray<z.ZodString>;
|
|
51
|
+
updateBy: z.ZodArray<z.ZodString>;
|
|
52
|
+
behavior: z.ZodDefault<z.ZodEnum<{
|
|
53
|
+
"add-or-update": "add-or-update";
|
|
54
|
+
"update-only": "update-only";
|
|
55
|
+
"add-only": "add-only";
|
|
56
|
+
}>>;
|
|
57
|
+
valueInputOption: z.ZodDefault<z.ZodEnum<{
|
|
58
|
+
RAW: "RAW";
|
|
59
|
+
USER_ENTERED: "USER_ENTERED";
|
|
60
|
+
}>>;
|
|
61
|
+
}, z.core.$strip>;
|
|
62
|
+
readonly outputSchema: z.ZodObject<{
|
|
63
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
64
|
+
type: z.ZodLiteral<"success">;
|
|
65
|
+
id: z.ZodString;
|
|
66
|
+
gid: z.ZodString;
|
|
67
|
+
spreadsheetTitle: z.ZodString;
|
|
68
|
+
spreadsheetUrl: z.ZodString;
|
|
69
|
+
sheetTitle: z.ZodString;
|
|
70
|
+
sheetUrl: z.ZodString;
|
|
71
|
+
updatedRows: z.ZodNumber;
|
|
72
|
+
insertedKeys: z.ZodArray<z.ZodString>;
|
|
73
|
+
rowsSkipped: z.ZodNumber;
|
|
74
|
+
headersAdded: z.ZodArray<z.ZodString>;
|
|
75
|
+
errors: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
76
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
77
|
+
type: z.ZodLiteral<"auth_required">;
|
|
78
|
+
provider: z.ZodString;
|
|
79
|
+
message: z.ZodString;
|
|
80
|
+
url: z.ZodOptional<z.ZodString>;
|
|
81
|
+
}, z.core.$strip>], "type">;
|
|
82
|
+
}, z.core.$strip>;
|
|
83
|
+
};
|
|
84
|
+
handler: typeof handler;
|
|
85
|
+
};
|
|
86
|
+
export {};
|