@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,90 @@
|
|
|
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 { SheetGidOutput, SheetRefSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';
|
|
7
|
+
import { findSheetByRef } from '../../spreadsheet/sheet-operations.js';
|
|
8
|
+
const inputSchema = z.object({
|
|
9
|
+
id: SpreadsheetIdSchema,
|
|
10
|
+
sheetRef: SheetRefSchema
|
|
11
|
+
});
|
|
12
|
+
const successBranchSchema = z.object({
|
|
13
|
+
type: z.literal('success'),
|
|
14
|
+
id: SpreadsheetIdOutput,
|
|
15
|
+
gid: SheetGidOutput,
|
|
16
|
+
title: z.string().describe('Sheet tab name'),
|
|
17
|
+
sheetUrl: z.string().optional().describe('URL to view the sheet')
|
|
18
|
+
});
|
|
19
|
+
const outputSchema = z.discriminatedUnion('type', [
|
|
20
|
+
successBranchSchema,
|
|
21
|
+
AuthRequiredBranchSchema
|
|
22
|
+
]);
|
|
23
|
+
const config = {
|
|
24
|
+
description: 'Find an existing sheet/tab within a known spreadsheet by title or GUID',
|
|
25
|
+
inputSchema,
|
|
26
|
+
outputSchema: z.object({
|
|
27
|
+
result: outputSchema
|
|
28
|
+
})
|
|
29
|
+
};
|
|
30
|
+
async function handler({ id, sheetRef }, extra) {
|
|
31
|
+
const logger = extra.logger;
|
|
32
|
+
logger.info('sheets.sheet.find called', {
|
|
33
|
+
id,
|
|
34
|
+
sheetRef
|
|
35
|
+
});
|
|
36
|
+
try {
|
|
37
|
+
var _ref;
|
|
38
|
+
var _sheet_properties, _sheet_properties1;
|
|
39
|
+
const sheets = google.sheets({
|
|
40
|
+
version: 'v4',
|
|
41
|
+
auth: extra.authContext.auth
|
|
42
|
+
});
|
|
43
|
+
// Find sheet within the known spreadsheet
|
|
44
|
+
const sheet = await findSheetByRef(sheets, id, sheetRef, logger);
|
|
45
|
+
if (!sheet) {
|
|
46
|
+
throw new McpError(ErrorCode.InvalidParams, 'Sheet not found');
|
|
47
|
+
}
|
|
48
|
+
const title = (_ref = sheet === null || sheet === void 0 ? void 0 : (_sheet_properties = sheet.properties) === null || _sheet_properties === void 0 ? void 0 : _sheet_properties.title) !== null && _ref !== void 0 ? _ref : String(sheetRef);
|
|
49
|
+
const gid = (sheet === null || sheet === void 0 ? void 0 : (_sheet_properties1 = sheet.properties) === null || _sheet_properties1 === void 0 ? void 0 : _sheet_properties1.sheetId) != null ? String(sheet.properties.sheetId) : '';
|
|
50
|
+
const sheetUrl = gid ? `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}` : `https://docs.google.com/spreadsheets/d/${id}`;
|
|
51
|
+
logger.info('sheets.sheet.find success', {
|
|
52
|
+
id,
|
|
53
|
+
gid,
|
|
54
|
+
title
|
|
55
|
+
});
|
|
56
|
+
const result = {
|
|
57
|
+
type: 'success',
|
|
58
|
+
id,
|
|
59
|
+
gid,
|
|
60
|
+
title,
|
|
61
|
+
sheetUrl
|
|
62
|
+
};
|
|
63
|
+
return {
|
|
64
|
+
content: [
|
|
65
|
+
{
|
|
66
|
+
type: 'text',
|
|
67
|
+
text: JSON.stringify(result)
|
|
68
|
+
}
|
|
69
|
+
],
|
|
70
|
+
structuredContent: {
|
|
71
|
+
result
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
} catch (error) {
|
|
75
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
76
|
+
logger.error('sheets.sheet.find error', {
|
|
77
|
+
error: message
|
|
78
|
+
});
|
|
79
|
+
throw new McpError(ErrorCode.InternalError, `Error finding sheet: ${message}`, {
|
|
80
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
export default function createTool() {
|
|
85
|
+
return {
|
|
86
|
+
name: 'sheet-find',
|
|
87
|
+
config,
|
|
88
|
+
handler
|
|
89
|
+
};
|
|
90
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/sheet-find.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 { SheetGidOutput, SheetRefSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\nimport { findSheetByRef } from '../../spreadsheet/sheet-operations.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n sheetRef: SheetRefSchema,\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n title: z.string().describe('Sheet tab name'),\n sheetUrl: z.string().optional().describe('URL to view the sheet'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Find an existing sheet/tab within a known spreadsheet by title or GUID',\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, sheetRef }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.find called', { id, sheetRef });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Find sheet within the known spreadsheet\n const sheet = await findSheetByRef(sheets, id, sheetRef, logger);\n if (!sheet) {\n throw new McpError(ErrorCode.InvalidParams, 'Sheet not found');\n }\n\n const title = sheet?.properties?.title ?? String(sheetRef);\n const gid = sheet?.properties?.sheetId != null ? String(sheet.properties.sheetId) : '';\n const sheetUrl = gid ? `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}` : `https://docs.google.com/spreadsheets/d/${id}`;\n\n logger.info('sheets.sheet.find success', { id, gid, title });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid,\n title,\n sheetUrl,\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('sheets.sheet.find error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error finding sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-find',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["schemas","AuthRequiredBranchSchema","ErrorCode","McpError","google","z","SheetGidOutput","SheetRefSchema","SpreadsheetIdOutput","SpreadsheetIdSchema","findSheetByRef","inputSchema","object","id","sheetRef","successBranchSchema","type","literal","gid","title","string","describe","sheetUrl","optional","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","info","sheet","sheets","version","auth","authContext","InvalidParams","properties","String","sheetId","content","text","JSON","stringify","structuredContent","error","message","Error","InternalError","stack","undefined","createTool","name"],"mappings":"AACA,SAASA,OAAO,QAAQ,sBAAsB;AAE9C,MAAM,EAAEC,wBAAwB,EAAE,GAAGD;AAIrC,SAASE,SAAS,EAAEC,QAAQ,QAAQ,qCAAqC;AACzE,SAASC,MAAM,QAAQ,aAAa;AACpC,SAASC,CAAC,QAAQ,MAAM;AACxB,SAASC,cAAc,EAAEC,cAAc,EAAEC,mBAAmB,EAAEC,mBAAmB,QAAQ,yBAAyB;AAClH,SAASC,cAAc,QAAQ,wCAAwC;AAEvE,MAAMC,cAAcN,EAAEO,MAAM,CAAC;IAC3BC,IAAIJ;IACJK,UAAUP;AACZ;AAEA,MAAMQ,sBAAsBV,EAAEO,MAAM,CAAC;IACnCI,MAAMX,EAAEY,OAAO,CAAC;IAChBJ,IAAIL;IACJU,KAAKZ;IACLa,OAAOd,EAAEe,MAAM,GAAGC,QAAQ,CAAC;IAC3BC,UAAUjB,EAAEe,MAAM,GAAGG,QAAQ,GAAGF,QAAQ,CAAC;AAC3C;AAEA,MAAMG,eAAenB,EAAEoB,kBAAkB,CAAC,QAAQ;IAACV;IAAqBd;CAAyB;AAEjG,MAAMyB,SAAS;IACbC,aAAa;IACbhB;IACAa,cAAcnB,EAAEO,MAAM,CAAC;QACrBgB,QAAQJ;IACV;AACF;AAKA,eAAeK,QAAQ,EAAEhB,EAAE,EAAEC,QAAQ,EAAS,EAAEgB,KAAoB;IAClE,MAAMC,SAASD,MAAMC,MAAM;IAC3BA,OAAOC,IAAI,CAAC,4BAA4B;QAAEnB;QAAIC;IAAS;IAEvD,IAAI;;YASYmB,mBACFA;QATZ,MAAMC,SAAS9B,OAAO8B,MAAM,CAAC;YAAEC,SAAS;YAAMC,MAAMN,MAAMO,WAAW,CAACD,IAAI;QAAC;QAE3E,0CAA0C;QAC1C,MAAMH,QAAQ,MAAMvB,eAAewB,QAAQrB,IAAIC,UAAUiB;QACzD,IAAI,CAACE,OAAO;YACV,MAAM,IAAI9B,SAASD,UAAUoC,aAAa,EAAE;QAC9C;QAEA,MAAMnB,gBAAQc,kBAAAA,6BAAAA,oBAAAA,MAAOM,UAAU,cAAjBN,wCAAAA,kBAAmBd,KAAK,uCAAIqB,OAAO1B;QACjD,MAAMI,MAAMe,CAAAA,kBAAAA,6BAAAA,qBAAAA,MAAOM,UAAU,cAAjBN,yCAAAA,mBAAmBQ,OAAO,KAAI,OAAOD,OAAOP,MAAMM,UAAU,CAACE,OAAO,IAAI;QACpF,MAAMnB,WAAWJ,MAAM,CAAC,uCAAuC,EAAEL,GAAG,UAAU,EAAEK,KAAK,GAAG,CAAC,uCAAuC,EAAEL,IAAI;QAEtIkB,OAAOC,IAAI,CAAC,6BAA6B;YAAEnB;YAAIK;YAAKC;QAAM;QAE1D,MAAMS,SAAiB;YACrBZ,MAAM;YACNH;YACAK;YACAC;YACAG;QACF;QAEA,OAAO;YACLoB,SAAS;gBAAC;oBAAE1B,MAAM;oBAAiB2B,MAAMC,KAAKC,SAAS,CAACjB;gBAAQ;aAAE;YAClEkB,mBAAmB;gBAAElB;YAAO;QAC9B;IACF,EAAE,OAAOmB,OAAO;QACd,MAAMC,UAAUD,iBAAiBE,QAAQF,MAAMC,OAAO,GAAGR,OAAOO;QAChEhB,OAAOgB,KAAK,CAAC,2BAA2B;YAAEA,OAAOC;QAAQ;QAEzD,MAAM,IAAI7C,SAASD,UAAUgD,aAAa,EAAE,CAAC,qBAAqB,EAAEF,SAAS,EAAE;YAC7EG,OAAOJ,iBAAiBE,QAAQF,MAAMI,KAAK,GAAGC;QAChD;IACF;AACF;AAEA,eAAe,SAASC;IACtB,OAAO;QACLC,MAAM;QACN5B;QACAG;IACF;AACF"}
|
|
@@ -0,0 +1,60 @@
|
|
|
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
|
+
newTitle: z.ZodCoercedString<unknown>;
|
|
8
|
+
}, z.core.$strip>;
|
|
9
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
10
|
+
type: z.ZodLiteral<"success">;
|
|
11
|
+
operationSummary: z.ZodString;
|
|
12
|
+
itemsProcessed: z.ZodNumber;
|
|
13
|
+
itemsChanged: z.ZodNumber;
|
|
14
|
+
completedAt: z.ZodString;
|
|
15
|
+
id: z.ZodString;
|
|
16
|
+
gid: z.ZodString;
|
|
17
|
+
sheetUrl: z.ZodString;
|
|
18
|
+
oldTitle: z.ZodString;
|
|
19
|
+
newTitle: z.ZodString;
|
|
20
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
21
|
+
type: z.ZodLiteral<"auth_required">;
|
|
22
|
+
provider: z.ZodString;
|
|
23
|
+
message: z.ZodString;
|
|
24
|
+
url: z.ZodOptional<z.ZodString>;
|
|
25
|
+
}, z.core.$strip>], "type">;
|
|
26
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
27
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
28
|
+
declare function handler({ id, gid, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
29
|
+
export default function createTool(): {
|
|
30
|
+
name: string;
|
|
31
|
+
config: {
|
|
32
|
+
readonly description: "Rename a sheet within a spreadsheet.";
|
|
33
|
+
readonly inputSchema: z.ZodObject<{
|
|
34
|
+
id: z.ZodString;
|
|
35
|
+
gid: z.ZodCoercedString<unknown>;
|
|
36
|
+
newTitle: z.ZodCoercedString<unknown>;
|
|
37
|
+
}, z.core.$strip>;
|
|
38
|
+
readonly outputSchema: z.ZodObject<{
|
|
39
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
40
|
+
type: z.ZodLiteral<"success">;
|
|
41
|
+
operationSummary: z.ZodString;
|
|
42
|
+
itemsProcessed: z.ZodNumber;
|
|
43
|
+
itemsChanged: z.ZodNumber;
|
|
44
|
+
completedAt: z.ZodString;
|
|
45
|
+
id: z.ZodString;
|
|
46
|
+
gid: z.ZodString;
|
|
47
|
+
sheetUrl: z.ZodString;
|
|
48
|
+
oldTitle: z.ZodString;
|
|
49
|
+
newTitle: z.ZodString;
|
|
50
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
51
|
+
type: z.ZodLiteral<"auth_required">;
|
|
52
|
+
provider: z.ZodString;
|
|
53
|
+
message: z.ZodString;
|
|
54
|
+
url: z.ZodOptional<z.ZodString>;
|
|
55
|
+
}, z.core.$strip>], "type">;
|
|
56
|
+
}, z.core.$strip>;
|
|
57
|
+
};
|
|
58
|
+
handler: typeof handler;
|
|
59
|
+
};
|
|
60
|
+
export {};
|
|
@@ -0,0 +1,128 @@
|
|
|
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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';
|
|
7
|
+
const inputSchema = z.object({
|
|
8
|
+
id: SpreadsheetIdSchema,
|
|
9
|
+
gid: SheetGidSchema,
|
|
10
|
+
newTitle: z.coerce.string().trim().min(1).describe('New name for the sheet tab')
|
|
11
|
+
});
|
|
12
|
+
// Success branch schema
|
|
13
|
+
const successBranchSchema = z.object({
|
|
14
|
+
type: z.literal('success'),
|
|
15
|
+
operationSummary: z.string().describe('Summary of the rename operation'),
|
|
16
|
+
itemsProcessed: z.number().describe('Total items attempted (always 1 for single sheet)'),
|
|
17
|
+
itemsChanged: z.number().describe('Successfully renamed sheets (always 1 on success)'),
|
|
18
|
+
completedAt: z.string().describe('ISO datetime when operation completed'),
|
|
19
|
+
id: SpreadsheetIdOutput,
|
|
20
|
+
gid: SheetGidOutput,
|
|
21
|
+
sheetUrl: z.string().describe('URL of the renamed sheet'),
|
|
22
|
+
oldTitle: z.string().describe('Previous title of the sheet'),
|
|
23
|
+
newTitle: z.string().describe('New title of the sheet')
|
|
24
|
+
});
|
|
25
|
+
// Output schema with auth_required support
|
|
26
|
+
const outputSchema = z.discriminatedUnion('type', [
|
|
27
|
+
successBranchSchema,
|
|
28
|
+
AuthRequiredBranchSchema
|
|
29
|
+
]);
|
|
30
|
+
const config = {
|
|
31
|
+
description: 'Rename a sheet within a spreadsheet.',
|
|
32
|
+
inputSchema,
|
|
33
|
+
outputSchema: z.object({
|
|
34
|
+
result: outputSchema
|
|
35
|
+
})
|
|
36
|
+
};
|
|
37
|
+
async function handler({ id, gid, newTitle }, extra) {
|
|
38
|
+
const logger = extra.logger;
|
|
39
|
+
logger.info('sheets.sheet.rename called', {
|
|
40
|
+
id,
|
|
41
|
+
gid,
|
|
42
|
+
newTitle
|
|
43
|
+
});
|
|
44
|
+
try {
|
|
45
|
+
var _spreadsheetInfo_data_sheets;
|
|
46
|
+
const sheets = google.sheets({
|
|
47
|
+
version: 'v4',
|
|
48
|
+
auth: extra.authContext.auth
|
|
49
|
+
});
|
|
50
|
+
// First, get the current sheet title
|
|
51
|
+
const spreadsheetInfo = await sheets.spreadsheets.get({
|
|
52
|
+
spreadsheetId: id,
|
|
53
|
+
fields: 'sheets.properties.sheetId,sheets.properties.title'
|
|
54
|
+
});
|
|
55
|
+
const sheetInfo = (_spreadsheetInfo_data_sheets = spreadsheetInfo.data.sheets) === null || _spreadsheetInfo_data_sheets === void 0 ? void 0 : _spreadsheetInfo_data_sheets.find((s)=>{
|
|
56
|
+
var _s_properties;
|
|
57
|
+
return String((_s_properties = s.properties) === null || _s_properties === void 0 ? void 0 : _s_properties.sheetId) === gid;
|
|
58
|
+
});
|
|
59
|
+
if (!(sheetInfo === null || sheetInfo === void 0 ? void 0 : sheetInfo.properties)) {
|
|
60
|
+
throw new McpError(ErrorCode.InvalidParams, `Sheet with gid "${gid}" not found in spreadsheet`);
|
|
61
|
+
}
|
|
62
|
+
const oldTitle = sheetInfo.properties.title || '';
|
|
63
|
+
// Rename the sheet
|
|
64
|
+
await sheets.spreadsheets.batchUpdate({
|
|
65
|
+
spreadsheetId: id,
|
|
66
|
+
requestBody: {
|
|
67
|
+
requests: [
|
|
68
|
+
{
|
|
69
|
+
updateSheetProperties: {
|
|
70
|
+
properties: {
|
|
71
|
+
sheetId: Number(gid),
|
|
72
|
+
title: newTitle
|
|
73
|
+
},
|
|
74
|
+
fields: 'title'
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
]
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
logger.info('sheets.sheet.rename success', {
|
|
81
|
+
id,
|
|
82
|
+
gid,
|
|
83
|
+
oldTitle,
|
|
84
|
+
newTitle
|
|
85
|
+
});
|
|
86
|
+
const result = {
|
|
87
|
+
type: 'success',
|
|
88
|
+
operationSummary: `Renamed sheet "${oldTitle}" to "${newTitle}"`,
|
|
89
|
+
itemsProcessed: 1,
|
|
90
|
+
itemsChanged: 1,
|
|
91
|
+
completedAt: new Date().toISOString(),
|
|
92
|
+
id,
|
|
93
|
+
gid,
|
|
94
|
+
sheetUrl: `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}`,
|
|
95
|
+
oldTitle,
|
|
96
|
+
newTitle
|
|
97
|
+
};
|
|
98
|
+
return {
|
|
99
|
+
content: [
|
|
100
|
+
{
|
|
101
|
+
type: 'text',
|
|
102
|
+
text: JSON.stringify(result)
|
|
103
|
+
}
|
|
104
|
+
],
|
|
105
|
+
structuredContent: {
|
|
106
|
+
result
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
} catch (error) {
|
|
110
|
+
if (error instanceof McpError) {
|
|
111
|
+
throw error;
|
|
112
|
+
}
|
|
113
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
114
|
+
logger.error('sheets.sheet.rename error', {
|
|
115
|
+
error: message
|
|
116
|
+
});
|
|
117
|
+
throw new McpError(ErrorCode.InternalError, `Error renaming sheet: ${message}`, {
|
|
118
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
export default function createTool() {
|
|
123
|
+
return {
|
|
124
|
+
name: 'sheet-rename',
|
|
125
|
+
config,
|
|
126
|
+
handler
|
|
127
|
+
};
|
|
128
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/sheet-rename.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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n newTitle: z.coerce.string().trim().min(1).describe('New name for the sheet tab'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the rename operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single sheet)'),\n itemsChanged: z.number().describe('Successfully renamed sheets (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n sheetUrl: z.string().describe('URL of the renamed sheet'),\n oldTitle: z.string().describe('Previous title of the sheet'),\n newTitle: z.string().describe('New title of the sheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Rename a sheet within a spreadsheet.',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.rename called', { id, gid, newTitle });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // First, get the current sheet title\n const spreadsheetInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheetInfo = spreadsheetInfo.data.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheetInfo?.properties) {\n throw new McpError(ErrorCode.InvalidParams, `Sheet with gid \"${gid}\" not found in spreadsheet`);\n }\n\n const oldTitle = sheetInfo.properties.title || '';\n\n // Rename the sheet\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n updateSheetProperties: {\n properties: { sheetId: Number(gid), title: newTitle },\n fields: 'title',\n },\n },\n ],\n },\n });\n\n logger.info('sheets.sheet.rename success', { id, gid, oldTitle, newTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Renamed sheet \"${oldTitle}\" to \"${newTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n gid,\n sheetUrl: `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}`,\n oldTitle,\n newTitle,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n if (error instanceof McpError) {\n throw error;\n }\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.sheet.rename error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error renaming sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-rename',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["schemas","AuthRequiredBranchSchema","ErrorCode","McpError","google","z","SheetGidOutput","SheetGidSchema","SpreadsheetIdOutput","SpreadsheetIdSchema","inputSchema","object","id","gid","newTitle","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","sheetUrl","oldTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","info","spreadsheetInfo","sheets","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","sheetInfo","data","find","s","String","properties","sheetId","InvalidParams","title","batchUpdate","requestBody","requests","updateSheetProperties","Number","Date","toISOString","content","text","JSON","stringify","structuredContent","error","message","Error","InternalError","stack","undefined","createTool","name"],"mappings":"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"}
|
|
@@ -0,0 +1,58 @@
|
|
|
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
|
+
newTitle: z.ZodOptional<z.ZodCoercedString<unknown>>;
|
|
7
|
+
}, z.core.$strip>;
|
|
8
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
9
|
+
type: z.ZodLiteral<"success">;
|
|
10
|
+
operationSummary: z.ZodString;
|
|
11
|
+
itemsProcessed: z.ZodNumber;
|
|
12
|
+
itemsChanged: z.ZodNumber;
|
|
13
|
+
completedAt: z.ZodString;
|
|
14
|
+
sourceId: z.ZodString;
|
|
15
|
+
sourceTitle: z.ZodString;
|
|
16
|
+
newId: z.ZodString;
|
|
17
|
+
newTitle: z.ZodString;
|
|
18
|
+
spreadsheetUrl: z.ZodString;
|
|
19
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
20
|
+
type: z.ZodLiteral<"auth_required">;
|
|
21
|
+
provider: z.ZodString;
|
|
22
|
+
message: z.ZodString;
|
|
23
|
+
url: z.ZodOptional<z.ZodString>;
|
|
24
|
+
}, z.core.$strip>], "type">;
|
|
25
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
26
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
27
|
+
declare function handler({ id, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
28
|
+
export default function createTool(): {
|
|
29
|
+
name: string;
|
|
30
|
+
config: {
|
|
31
|
+
readonly description: "Copy an entire spreadsheet/workbook (all sheets, formatting, charts, named ranges, etc.). Creates in the same folder as the original. Uses Google Drive API.";
|
|
32
|
+
readonly inputSchema: z.ZodObject<{
|
|
33
|
+
id: z.ZodString;
|
|
34
|
+
newTitle: z.ZodOptional<z.ZodCoercedString<unknown>>;
|
|
35
|
+
}, z.core.$strip>;
|
|
36
|
+
readonly outputSchema: z.ZodObject<{
|
|
37
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
38
|
+
type: z.ZodLiteral<"success">;
|
|
39
|
+
operationSummary: z.ZodString;
|
|
40
|
+
itemsProcessed: z.ZodNumber;
|
|
41
|
+
itemsChanged: z.ZodNumber;
|
|
42
|
+
completedAt: z.ZodString;
|
|
43
|
+
sourceId: z.ZodString;
|
|
44
|
+
sourceTitle: z.ZodString;
|
|
45
|
+
newId: z.ZodString;
|
|
46
|
+
newTitle: z.ZodString;
|
|
47
|
+
spreadsheetUrl: z.ZodString;
|
|
48
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
49
|
+
type: z.ZodLiteral<"auth_required">;
|
|
50
|
+
provider: z.ZodString;
|
|
51
|
+
message: z.ZodString;
|
|
52
|
+
url: z.ZodOptional<z.ZodString>;
|
|
53
|
+
}, z.core.$strip>], "type">;
|
|
54
|
+
}, z.core.$strip>;
|
|
55
|
+
};
|
|
56
|
+
handler: typeof handler;
|
|
57
|
+
};
|
|
58
|
+
export {};
|
|
@@ -0,0 +1,117 @@
|
|
|
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 { SpreadsheetIdSchema } from '../../schemas/index.js';
|
|
7
|
+
// Note: Using contextual descriptions for sourceId/newId since they describe different spreadsheets
|
|
8
|
+
const inputSchema = z.object({
|
|
9
|
+
id: SpreadsheetIdSchema,
|
|
10
|
+
newTitle: z.coerce.string().trim().min(1).optional().describe('Name for the copy (optional, defaults to "Copy of [original]")')
|
|
11
|
+
});
|
|
12
|
+
// Success branch schema
|
|
13
|
+
const successBranchSchema = z.object({
|
|
14
|
+
type: z.literal('success'),
|
|
15
|
+
operationSummary: z.string().describe('Summary of the copy operation'),
|
|
16
|
+
itemsProcessed: z.number().describe('Total items attempted (always 1)'),
|
|
17
|
+
itemsChanged: z.number().describe('Successfully copied (always 1 on success)'),
|
|
18
|
+
completedAt: z.string().describe('ISO datetime when operation completed'),
|
|
19
|
+
sourceId: z.string().describe('Source spreadsheet ID'),
|
|
20
|
+
sourceTitle: z.string().describe('Source spreadsheet title'),
|
|
21
|
+
newId: z.string().describe('Copied spreadsheet ID'),
|
|
22
|
+
newTitle: z.string().describe('Title of the copied spreadsheet'),
|
|
23
|
+
spreadsheetUrl: z.string().describe('URL of the copied spreadsheet')
|
|
24
|
+
});
|
|
25
|
+
// Output schema with auth_required support
|
|
26
|
+
const outputSchema = z.discriminatedUnion('type', [
|
|
27
|
+
successBranchSchema,
|
|
28
|
+
AuthRequiredBranchSchema
|
|
29
|
+
]);
|
|
30
|
+
const config = {
|
|
31
|
+
description: 'Copy an entire spreadsheet/workbook (all sheets, formatting, charts, named ranges, etc.). Creates in the same folder as the original. Uses Google Drive API.',
|
|
32
|
+
inputSchema,
|
|
33
|
+
outputSchema: z.object({
|
|
34
|
+
result: outputSchema
|
|
35
|
+
})
|
|
36
|
+
};
|
|
37
|
+
async function handler({ id, newTitle }, extra) {
|
|
38
|
+
const logger = extra.logger;
|
|
39
|
+
logger.info('sheets.spreadsheet.copy called', {
|
|
40
|
+
id,
|
|
41
|
+
newTitle
|
|
42
|
+
});
|
|
43
|
+
try {
|
|
44
|
+
var _sourceInfo_data_properties;
|
|
45
|
+
const drive = google.drive({
|
|
46
|
+
version: 'v3',
|
|
47
|
+
auth: extra.authContext.auth
|
|
48
|
+
});
|
|
49
|
+
const sheets = google.sheets({
|
|
50
|
+
version: 'v4',
|
|
51
|
+
auth: extra.authContext.auth
|
|
52
|
+
});
|
|
53
|
+
// Get the original spreadsheet title
|
|
54
|
+
const sourceInfo = await sheets.spreadsheets.get({
|
|
55
|
+
spreadsheetId: id,
|
|
56
|
+
fields: 'properties.title'
|
|
57
|
+
});
|
|
58
|
+
const sourceTitle = ((_sourceInfo_data_properties = sourceInfo.data.properties) === null || _sourceInfo_data_properties === void 0 ? void 0 : _sourceInfo_data_properties.title) || '';
|
|
59
|
+
// Copy the spreadsheet using Drive API
|
|
60
|
+
const copyResponse = await drive.files.copy({
|
|
61
|
+
fileId: id,
|
|
62
|
+
requestBody: {
|
|
63
|
+
...newTitle && {
|
|
64
|
+
name: newTitle
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
const newId = copyResponse.data.id;
|
|
69
|
+
const resultTitle = copyResponse.data.name || '';
|
|
70
|
+
if (!newId) {
|
|
71
|
+
throw new Error('Failed to retrieve new spreadsheet ID from API response');
|
|
72
|
+
}
|
|
73
|
+
logger.info('sheets.spreadsheet.copy success', {
|
|
74
|
+
sourceId: id,
|
|
75
|
+
newId,
|
|
76
|
+
newTitle: resultTitle
|
|
77
|
+
});
|
|
78
|
+
const result = {
|
|
79
|
+
type: 'success',
|
|
80
|
+
operationSummary: `Copied spreadsheet "${sourceTitle}" to "${resultTitle}"`,
|
|
81
|
+
itemsProcessed: 1,
|
|
82
|
+
itemsChanged: 1,
|
|
83
|
+
completedAt: new Date().toISOString(),
|
|
84
|
+
sourceId: id,
|
|
85
|
+
sourceTitle,
|
|
86
|
+
newId,
|
|
87
|
+
newTitle: resultTitle,
|
|
88
|
+
spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${newId}`
|
|
89
|
+
};
|
|
90
|
+
return {
|
|
91
|
+
content: [
|
|
92
|
+
{
|
|
93
|
+
type: 'text',
|
|
94
|
+
text: JSON.stringify(result)
|
|
95
|
+
}
|
|
96
|
+
],
|
|
97
|
+
structuredContent: {
|
|
98
|
+
result
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
} catch (error) {
|
|
102
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
103
|
+
logger.error('sheets.spreadsheet.copy error', {
|
|
104
|
+
error: message
|
|
105
|
+
});
|
|
106
|
+
throw new McpError(ErrorCode.InternalError, `Error copying spreadsheet: ${message}`, {
|
|
107
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
export default function createTool() {
|
|
112
|
+
return {
|
|
113
|
+
name: 'spreadsheet-copy',
|
|
114
|
+
config,
|
|
115
|
+
handler
|
|
116
|
+
};
|
|
117
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/spreadsheet-copy.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 { SpreadsheetIdSchema } from '../../schemas/index.js';\n\n// Note: Using contextual descriptions for sourceId/newId since they describe different spreadsheets\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n newTitle: z.coerce.string().trim().min(1).optional().describe('Name for the copy (optional, defaults to \"Copy of [original]\")'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the copy operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1)'),\n itemsChanged: z.number().describe('Successfully copied (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n sourceId: z.string().describe('Source spreadsheet ID'),\n sourceTitle: z.string().describe('Source spreadsheet title'),\n newId: z.string().describe('Copied spreadsheet ID'),\n newTitle: z.string().describe('Title of the copied spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the copied spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Copy an entire spreadsheet/workbook (all sheets, formatting, charts, named ranges, etc.). Creates in the same folder as the original. Uses Google Drive API.',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.copy called', { id, newTitle });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get the original spreadsheet title\n const sourceInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title',\n });\n\n const sourceTitle = sourceInfo.data.properties?.title || '';\n\n // Copy the spreadsheet using Drive API\n const copyResponse = await drive.files.copy({\n fileId: id,\n requestBody: {\n ...(newTitle && { name: newTitle }),\n },\n });\n\n const newId = copyResponse.data.id;\n const resultTitle = copyResponse.data.name || '';\n\n if (!newId) {\n throw new Error('Failed to retrieve new spreadsheet ID from API response');\n }\n\n logger.info('sheets.spreadsheet.copy success', { sourceId: id, newId, newTitle: resultTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Copied spreadsheet \"${sourceTitle}\" to \"${resultTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n sourceId: id,\n sourceTitle,\n newId,\n newTitle: resultTitle,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${newId}`,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.copy error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error copying spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-copy',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["schemas","AuthRequiredBranchSchema","ErrorCode","McpError","google","z","SpreadsheetIdSchema","inputSchema","object","id","newTitle","coerce","string","trim","min","optional","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","sourceId","sourceTitle","newId","spreadsheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","info","sourceInfo","drive","version","auth","authContext","sheets","spreadsheets","get","spreadsheetId","fields","data","properties","title","copyResponse","files","copy","fileId","requestBody","name","resultTitle","Error","Date","toISOString","content","text","JSON","stringify","structuredContent","error","message","String","InternalError","stack","undefined","createTool"],"mappings":"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"}
|
|
@@ -0,0 +1,52 @@
|
|
|
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
|
+
title: z.ZodCoercedString<unknown>;
|
|
6
|
+
}, z.core.$strip>;
|
|
7
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
8
|
+
type: z.ZodLiteral<"success">;
|
|
9
|
+
operationSummary: z.ZodString;
|
|
10
|
+
itemsProcessed: z.ZodNumber;
|
|
11
|
+
itemsChanged: z.ZodNumber;
|
|
12
|
+
completedAt: z.ZodString;
|
|
13
|
+
id: z.ZodString;
|
|
14
|
+
spreadsheetUrl: z.ZodString;
|
|
15
|
+
title: z.ZodString;
|
|
16
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
17
|
+
type: z.ZodLiteral<"auth_required">;
|
|
18
|
+
provider: z.ZodString;
|
|
19
|
+
message: z.ZodString;
|
|
20
|
+
url: z.ZodOptional<z.ZodString>;
|
|
21
|
+
}, z.core.$strip>], "type">;
|
|
22
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
23
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
24
|
+
declare function handler({ title }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
25
|
+
export default function createTool(): {
|
|
26
|
+
name: string;
|
|
27
|
+
config: {
|
|
28
|
+
readonly description: "Create a new spreadsheet";
|
|
29
|
+
readonly inputSchema: z.ZodObject<{
|
|
30
|
+
title: z.ZodCoercedString<unknown>;
|
|
31
|
+
}, z.core.$strip>;
|
|
32
|
+
readonly outputSchema: z.ZodObject<{
|
|
33
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
34
|
+
type: z.ZodLiteral<"success">;
|
|
35
|
+
operationSummary: z.ZodString;
|
|
36
|
+
itemsProcessed: z.ZodNumber;
|
|
37
|
+
itemsChanged: z.ZodNumber;
|
|
38
|
+
completedAt: z.ZodString;
|
|
39
|
+
id: z.ZodString;
|
|
40
|
+
spreadsheetUrl: z.ZodString;
|
|
41
|
+
title: z.ZodString;
|
|
42
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
43
|
+
type: z.ZodLiteral<"auth_required">;
|
|
44
|
+
provider: z.ZodString;
|
|
45
|
+
message: z.ZodString;
|
|
46
|
+
url: z.ZodOptional<z.ZodString>;
|
|
47
|
+
}, z.core.$strip>], "type">;
|
|
48
|
+
}, z.core.$strip>;
|
|
49
|
+
};
|
|
50
|
+
handler: typeof handler;
|
|
51
|
+
};
|
|
52
|
+
export {};
|
|
@@ -0,0 +1,97 @@
|
|
|
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 { SpreadsheetIdOutput } from '../../schemas/index.js';
|
|
7
|
+
const inputSchema = z.object({
|
|
8
|
+
title: z.coerce.string().trim().min(1).describe('Title for the new spreadsheet')
|
|
9
|
+
});
|
|
10
|
+
// Success branch schema
|
|
11
|
+
const successBranchSchema = z.object({
|
|
12
|
+
type: z.literal('success'),
|
|
13
|
+
operationSummary: z.string().describe('Summary of the spreadsheet creation operation'),
|
|
14
|
+
itemsProcessed: z.number().describe('Total items attempted (always 1 for single spreadsheet)'),
|
|
15
|
+
itemsChanged: z.number().describe('Successfully created spreadsheets (always 1 on success)'),
|
|
16
|
+
completedAt: z.string().describe('ISO datetime when operation completed'),
|
|
17
|
+
id: SpreadsheetIdOutput,
|
|
18
|
+
spreadsheetUrl: z.string().describe('URL of the created spreadsheet'),
|
|
19
|
+
title: z.string().describe('Title of the created spreadsheet')
|
|
20
|
+
});
|
|
21
|
+
// Output schema with auth_required support
|
|
22
|
+
const outputSchema = z.discriminatedUnion('type', [
|
|
23
|
+
successBranchSchema,
|
|
24
|
+
AuthRequiredBranchSchema
|
|
25
|
+
]);
|
|
26
|
+
const config = {
|
|
27
|
+
description: 'Create a new spreadsheet',
|
|
28
|
+
inputSchema,
|
|
29
|
+
outputSchema: z.object({
|
|
30
|
+
result: outputSchema
|
|
31
|
+
})
|
|
32
|
+
};
|
|
33
|
+
async function handler({ title }, extra) {
|
|
34
|
+
const logger = extra.logger;
|
|
35
|
+
logger.info('sheets.spreadsheet.create called', {
|
|
36
|
+
title
|
|
37
|
+
});
|
|
38
|
+
try {
|
|
39
|
+
var _res_spreadsheetId, _res_spreadsheetUrl;
|
|
40
|
+
const sheets = google.sheets({
|
|
41
|
+
version: 'v4',
|
|
42
|
+
auth: extra.authContext.auth
|
|
43
|
+
});
|
|
44
|
+
const response = await sheets.spreadsheets.create({
|
|
45
|
+
requestBody: {
|
|
46
|
+
properties: {
|
|
47
|
+
title: title
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
const res = response.data;
|
|
52
|
+
const id = (_res_spreadsheetId = res.spreadsheetId) !== null && _res_spreadsheetId !== void 0 ? _res_spreadsheetId : '';
|
|
53
|
+
const url = (_res_spreadsheetUrl = res.spreadsheetUrl) !== null && _res_spreadsheetUrl !== void 0 ? _res_spreadsheetUrl : '';
|
|
54
|
+
logger.info('sheets.spreadsheet.create success', {
|
|
55
|
+
id,
|
|
56
|
+
title,
|
|
57
|
+
url
|
|
58
|
+
});
|
|
59
|
+
const result = {
|
|
60
|
+
type: 'success',
|
|
61
|
+
operationSummary: `Created spreadsheet "${title}"`,
|
|
62
|
+
itemsProcessed: 1,
|
|
63
|
+
itemsChanged: 1,
|
|
64
|
+
completedAt: new Date().toISOString(),
|
|
65
|
+
id,
|
|
66
|
+
spreadsheetUrl: url,
|
|
67
|
+
title
|
|
68
|
+
};
|
|
69
|
+
return {
|
|
70
|
+
content: [
|
|
71
|
+
{
|
|
72
|
+
type: 'text',
|
|
73
|
+
text: JSON.stringify(result)
|
|
74
|
+
}
|
|
75
|
+
],
|
|
76
|
+
structuredContent: {
|
|
77
|
+
result
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
} catch (error) {
|
|
81
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
82
|
+
logger.error('sheets.spreadsheet.create error', {
|
|
83
|
+
error: message
|
|
84
|
+
});
|
|
85
|
+
// Throw McpError for proper MCP error handling
|
|
86
|
+
throw new McpError(ErrorCode.InternalError, `Error creating spreadsheet: ${message}`, {
|
|
87
|
+
stack: error instanceof Error ? error.stack : undefined
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
export default function createTool() {
|
|
92
|
+
return {
|
|
93
|
+
name: 'spreadsheet-create',
|
|
94
|
+
config,
|
|
95
|
+
handler
|
|
96
|
+
};
|
|
97
|
+
}
|