@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,564 @@
|
|
|
1
|
+
"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
|
+
var _rangeoperations = require("../../spreadsheet/range-operations.js");
|
|
17
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
18
|
+
try {
|
|
19
|
+
var info = gen[key](arg);
|
|
20
|
+
var value = info.value;
|
|
21
|
+
} catch (error) {
|
|
22
|
+
reject(error);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
if (info.done) {
|
|
26
|
+
resolve(value);
|
|
27
|
+
} else {
|
|
28
|
+
Promise.resolve(value).then(_next, _throw);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
function _async_to_generator(fn) {
|
|
32
|
+
return function() {
|
|
33
|
+
var self = this, args = arguments;
|
|
34
|
+
return new Promise(function(resolve, reject) {
|
|
35
|
+
var gen = fn.apply(self, args);
|
|
36
|
+
function _next(value) {
|
|
37
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
38
|
+
}
|
|
39
|
+
function _throw(err) {
|
|
40
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
41
|
+
}
|
|
42
|
+
_next(undefined);
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
function _instanceof(left, right) {
|
|
47
|
+
if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
|
|
48
|
+
return !!right[Symbol.hasInstance](left);
|
|
49
|
+
} else {
|
|
50
|
+
return left instanceof right;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
function _ts_generator(thisArg, body) {
|
|
54
|
+
var f, y, t, _ = {
|
|
55
|
+
label: 0,
|
|
56
|
+
sent: function() {
|
|
57
|
+
if (t[0] & 1) throw t[1];
|
|
58
|
+
return t[1];
|
|
59
|
+
},
|
|
60
|
+
trys: [],
|
|
61
|
+
ops: []
|
|
62
|
+
}, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype), d = Object.defineProperty;
|
|
63
|
+
return d(g, "next", {
|
|
64
|
+
value: verb(0)
|
|
65
|
+
}), d(g, "throw", {
|
|
66
|
+
value: verb(1)
|
|
67
|
+
}), d(g, "return", {
|
|
68
|
+
value: verb(2)
|
|
69
|
+
}), typeof Symbol === "function" && d(g, Symbol.iterator, {
|
|
70
|
+
value: function() {
|
|
71
|
+
return this;
|
|
72
|
+
}
|
|
73
|
+
}), g;
|
|
74
|
+
function verb(n) {
|
|
75
|
+
return function(v) {
|
|
76
|
+
return step([
|
|
77
|
+
n,
|
|
78
|
+
v
|
|
79
|
+
]);
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
function step(op) {
|
|
83
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
84
|
+
while(g && (g = 0, op[0] && (_ = 0)), _)try {
|
|
85
|
+
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;
|
|
86
|
+
if (y = 0, t) op = [
|
|
87
|
+
op[0] & 2,
|
|
88
|
+
t.value
|
|
89
|
+
];
|
|
90
|
+
switch(op[0]){
|
|
91
|
+
case 0:
|
|
92
|
+
case 1:
|
|
93
|
+
t = op;
|
|
94
|
+
break;
|
|
95
|
+
case 4:
|
|
96
|
+
_.label++;
|
|
97
|
+
return {
|
|
98
|
+
value: op[1],
|
|
99
|
+
done: false
|
|
100
|
+
};
|
|
101
|
+
case 5:
|
|
102
|
+
_.label++;
|
|
103
|
+
y = op[1];
|
|
104
|
+
op = [
|
|
105
|
+
0
|
|
106
|
+
];
|
|
107
|
+
continue;
|
|
108
|
+
case 7:
|
|
109
|
+
op = _.ops.pop();
|
|
110
|
+
_.trys.pop();
|
|
111
|
+
continue;
|
|
112
|
+
default:
|
|
113
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
114
|
+
_ = 0;
|
|
115
|
+
continue;
|
|
116
|
+
}
|
|
117
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
118
|
+
_.label = op[1];
|
|
119
|
+
break;
|
|
120
|
+
}
|
|
121
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
122
|
+
_.label = t[1];
|
|
123
|
+
t = op;
|
|
124
|
+
break;
|
|
125
|
+
}
|
|
126
|
+
if (t && _.label < t[2]) {
|
|
127
|
+
_.label = t[2];
|
|
128
|
+
_.ops.push(op);
|
|
129
|
+
break;
|
|
130
|
+
}
|
|
131
|
+
if (t[2]) _.ops.pop();
|
|
132
|
+
_.trys.pop();
|
|
133
|
+
continue;
|
|
134
|
+
}
|
|
135
|
+
op = body.call(thisArg, _);
|
|
136
|
+
} catch (e) {
|
|
137
|
+
op = [
|
|
138
|
+
6,
|
|
139
|
+
e
|
|
140
|
+
];
|
|
141
|
+
y = 0;
|
|
142
|
+
} finally{
|
|
143
|
+
f = t = 0;
|
|
144
|
+
}
|
|
145
|
+
if (op[0] & 5) throw op[1];
|
|
146
|
+
return {
|
|
147
|
+
value: op[0] ? op[1] : void 0,
|
|
148
|
+
done: true
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
153
|
+
// Discriminated union for validation rule types
|
|
154
|
+
var ValidationRuleSchema = _zod.z.discriminatedUnion('conditionType', [
|
|
155
|
+
// Dropdown with hardcoded list
|
|
156
|
+
_zod.z.object({
|
|
157
|
+
conditionType: _zod.z.literal('ONE_OF_LIST'),
|
|
158
|
+
values: _zod.z.array(_zod.z.string()).min(1).describe('Hardcoded dropdown options'),
|
|
159
|
+
showDropdown: _zod.z.boolean().default(true).describe('Show dropdown UI in cells'),
|
|
160
|
+
strict: _zod.z.boolean().default(true).describe('Reject invalid entries')
|
|
161
|
+
}),
|
|
162
|
+
// Dropdown from range
|
|
163
|
+
_zod.z.object({
|
|
164
|
+
conditionType: _zod.z.literal('ONE_OF_RANGE'),
|
|
165
|
+
sourceRange: _zod.z.string().min(1).describe('A1 notation range containing dropdown options (e.g., "Options!A1:A10")'),
|
|
166
|
+
showDropdown: _zod.z.boolean().default(true).describe('Show dropdown UI in cells'),
|
|
167
|
+
strict: _zod.z.boolean().default(true).describe('Reject invalid entries')
|
|
168
|
+
}),
|
|
169
|
+
// Numeric constraints
|
|
170
|
+
_zod.z.object({
|
|
171
|
+
conditionType: _zod.z.enum([
|
|
172
|
+
'NUMBER_GREATER',
|
|
173
|
+
'NUMBER_LESS',
|
|
174
|
+
'NUMBER_BETWEEN'
|
|
175
|
+
]),
|
|
176
|
+
values: _zod.z.array(_zod.z.number()).min(1).max(2).describe('1 value for GREATER/LESS, 2 values for BETWEEN'),
|
|
177
|
+
strict: _zod.z.boolean().default(true).describe('Reject invalid entries')
|
|
178
|
+
}),
|
|
179
|
+
// Text constraints
|
|
180
|
+
_zod.z.object({
|
|
181
|
+
conditionType: _zod.z.enum([
|
|
182
|
+
'TEXT_CONTAINS',
|
|
183
|
+
'TEXT_IS_EMAIL',
|
|
184
|
+
'TEXT_IS_URL'
|
|
185
|
+
]),
|
|
186
|
+
values: _zod.z.array(_zod.z.string()).optional().describe('Text to match (for TEXT_CONTAINS only)'),
|
|
187
|
+
strict: _zod.z.boolean().default(true).describe('Reject invalid entries')
|
|
188
|
+
}),
|
|
189
|
+
// Date constraints
|
|
190
|
+
_zod.z.object({
|
|
191
|
+
conditionType: _zod.z.enum([
|
|
192
|
+
'DATE_AFTER',
|
|
193
|
+
'DATE_BEFORE',
|
|
194
|
+
'DATE_BETWEEN'
|
|
195
|
+
]),
|
|
196
|
+
values: _zod.z.array(_zod.z.string()).min(1).max(2).describe('ISO date strings (YYYY-MM-DD)'),
|
|
197
|
+
strict: _zod.z.boolean().default(true).describe('Reject invalid entries')
|
|
198
|
+
}),
|
|
199
|
+
// Custom formula
|
|
200
|
+
_zod.z.object({
|
|
201
|
+
conditionType: _zod.z.literal('CUSTOM_FORMULA'),
|
|
202
|
+
formula: _zod.z.string().min(1).describe('Custom validation formula (e.g., "=A1>0")'),
|
|
203
|
+
strict: _zod.z.boolean().default(true).describe('Reject invalid entries')
|
|
204
|
+
})
|
|
205
|
+
]);
|
|
206
|
+
// Input schema for validation requests
|
|
207
|
+
var ValidationRequestSchema = _zod.z.object({
|
|
208
|
+
range: _zod.z.string().min(1).describe('A1 notation range for validation (e.g., "B2:B100")'),
|
|
209
|
+
rule: ValidationRuleSchema,
|
|
210
|
+
inputMessage: _zod.z.string().optional().describe('Help text shown when cell is selected')
|
|
211
|
+
});
|
|
212
|
+
var inputSchema = _zod.z.object({
|
|
213
|
+
id: _index.SpreadsheetIdSchema,
|
|
214
|
+
gid: _index.SheetGidSchema,
|
|
215
|
+
requests: _zod.z.array(ValidationRequestSchema).min(1).max(50).describe('Array of validation rules. Batch multiple ranges for efficiency.')
|
|
216
|
+
});
|
|
217
|
+
var successBranchSchema = _zod.z.object({
|
|
218
|
+
type: _zod.z.literal('success'),
|
|
219
|
+
id: _index.SpreadsheetIdOutput,
|
|
220
|
+
gid: _index.SheetGidOutput,
|
|
221
|
+
sheetTitle: _zod.z.string().describe('Title of the sheet with validation'),
|
|
222
|
+
sheetUrl: _zod.z.string().describe('URL of the sheet with validation'),
|
|
223
|
+
successCount: _zod.z.number().int().nonnegative().describe('Number of validation rules successfully applied'),
|
|
224
|
+
failedRanges: _zod.z.array(_zod.z.object({
|
|
225
|
+
range: _zod.z.string().describe('A1 notation of range that failed validation setup'),
|
|
226
|
+
error: _zod.z.string().describe('Why validation failed for this range')
|
|
227
|
+
})).optional().describe('Only populated if some validation rules failed')
|
|
228
|
+
});
|
|
229
|
+
var outputSchema = _zod.z.discriminatedUnion('type', [
|
|
230
|
+
successBranchSchema,
|
|
231
|
+
AuthRequiredBranchSchema
|
|
232
|
+
]);
|
|
233
|
+
var config = {
|
|
234
|
+
description: 'Add data validation rules including dropdowns, numeric constraints, text patterns, date ranges, custom formulas. Supports batch operations for efficiency. Use discriminated conditionType to specify rule type. Best for enforcing data integrity and providing user-friendly input controls.',
|
|
235
|
+
inputSchema: inputSchema,
|
|
236
|
+
outputSchema: _zod.z.object({
|
|
237
|
+
result: outputSchema
|
|
238
|
+
})
|
|
239
|
+
};
|
|
240
|
+
// Map condition types to Google Sheets API format
|
|
241
|
+
function buildCondition(rule) {
|
|
242
|
+
switch(rule.conditionType){
|
|
243
|
+
case 'ONE_OF_LIST':
|
|
244
|
+
return {
|
|
245
|
+
type: 'ONE_OF_LIST',
|
|
246
|
+
values: rule.values.map(function(value) {
|
|
247
|
+
return {
|
|
248
|
+
userEnteredValue: value
|
|
249
|
+
};
|
|
250
|
+
})
|
|
251
|
+
};
|
|
252
|
+
case 'ONE_OF_RANGE':
|
|
253
|
+
return {
|
|
254
|
+
type: 'ONE_OF_RANGE',
|
|
255
|
+
values: [
|
|
256
|
+
{
|
|
257
|
+
userEnteredValue: "=".concat(rule.sourceRange)
|
|
258
|
+
}
|
|
259
|
+
]
|
|
260
|
+
};
|
|
261
|
+
case 'NUMBER_GREATER':
|
|
262
|
+
return {
|
|
263
|
+
type: 'NUMBER_GREATER',
|
|
264
|
+
values: [
|
|
265
|
+
{
|
|
266
|
+
userEnteredValue: String(rule.values[0])
|
|
267
|
+
}
|
|
268
|
+
]
|
|
269
|
+
};
|
|
270
|
+
case 'NUMBER_LESS':
|
|
271
|
+
return {
|
|
272
|
+
type: 'NUMBER_LESS',
|
|
273
|
+
values: [
|
|
274
|
+
{
|
|
275
|
+
userEnteredValue: String(rule.values[0])
|
|
276
|
+
}
|
|
277
|
+
]
|
|
278
|
+
};
|
|
279
|
+
case 'NUMBER_BETWEEN':
|
|
280
|
+
return {
|
|
281
|
+
type: 'NUMBER_BETWEEN',
|
|
282
|
+
values: [
|
|
283
|
+
{
|
|
284
|
+
userEnteredValue: String(rule.values[0])
|
|
285
|
+
},
|
|
286
|
+
{
|
|
287
|
+
userEnteredValue: String(rule.values[1])
|
|
288
|
+
}
|
|
289
|
+
]
|
|
290
|
+
};
|
|
291
|
+
case 'TEXT_CONTAINS':
|
|
292
|
+
return {
|
|
293
|
+
type: 'TEXT_CONTAINS',
|
|
294
|
+
values: rule.values ? [
|
|
295
|
+
{
|
|
296
|
+
userEnteredValue: rule.values[0]
|
|
297
|
+
}
|
|
298
|
+
] : []
|
|
299
|
+
};
|
|
300
|
+
case 'TEXT_IS_EMAIL':
|
|
301
|
+
return {
|
|
302
|
+
type: 'TEXT_IS_EMAIL',
|
|
303
|
+
values: []
|
|
304
|
+
};
|
|
305
|
+
case 'TEXT_IS_URL':
|
|
306
|
+
return {
|
|
307
|
+
type: 'TEXT_IS_URL',
|
|
308
|
+
values: []
|
|
309
|
+
};
|
|
310
|
+
case 'DATE_AFTER':
|
|
311
|
+
return {
|
|
312
|
+
type: 'DATE_AFTER',
|
|
313
|
+
values: [
|
|
314
|
+
{
|
|
315
|
+
userEnteredValue: rule.values[0]
|
|
316
|
+
}
|
|
317
|
+
]
|
|
318
|
+
};
|
|
319
|
+
case 'DATE_BEFORE':
|
|
320
|
+
return {
|
|
321
|
+
type: 'DATE_BEFORE',
|
|
322
|
+
values: [
|
|
323
|
+
{
|
|
324
|
+
userEnteredValue: rule.values[0]
|
|
325
|
+
}
|
|
326
|
+
]
|
|
327
|
+
};
|
|
328
|
+
case 'DATE_BETWEEN':
|
|
329
|
+
return {
|
|
330
|
+
type: 'DATE_BETWEEN',
|
|
331
|
+
values: [
|
|
332
|
+
{
|
|
333
|
+
userEnteredValue: rule.values[0]
|
|
334
|
+
},
|
|
335
|
+
{
|
|
336
|
+
userEnteredValue: rule.values[1]
|
|
337
|
+
}
|
|
338
|
+
]
|
|
339
|
+
};
|
|
340
|
+
case 'CUSTOM_FORMULA':
|
|
341
|
+
return {
|
|
342
|
+
type: 'CUSTOM_FORMULA',
|
|
343
|
+
values: [
|
|
344
|
+
{
|
|
345
|
+
userEnteredValue: rule.formula.startsWith('=') ? rule.formula : "=".concat(rule.formula)
|
|
346
|
+
}
|
|
347
|
+
]
|
|
348
|
+
};
|
|
349
|
+
default:
|
|
350
|
+
// Exhaustive check - all valid conditionType values should be handled above
|
|
351
|
+
throw new Error("Unknown condition type: ".concat(rule.conditionType));
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
function handler(_0, _1) {
|
|
355
|
+
return _async_to_generator(function(param, extra) {
|
|
356
|
+
var id, gid, requests, logger, _sheet_properties_title, _spreadsheetResponse_data_sheets, sheets, spreadsheetResponse, sheet, sheetTitle, sheetId, sheetUrl, batchRequests, failedRanges, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, request, rangeRef, gridRange, condition, dataValidationRule, message, result, result1, error, message1;
|
|
357
|
+
return _ts_generator(this, function(_state) {
|
|
358
|
+
switch(_state.label){
|
|
359
|
+
case 0:
|
|
360
|
+
id = param.id, gid = param.gid, requests = param.requests;
|
|
361
|
+
logger = extra.logger;
|
|
362
|
+
logger.info('sheets.validation.set called', {
|
|
363
|
+
id: id,
|
|
364
|
+
gid: gid,
|
|
365
|
+
requestCount: requests.length
|
|
366
|
+
});
|
|
367
|
+
_state.label = 1;
|
|
368
|
+
case 1:
|
|
369
|
+
_state.trys.push([
|
|
370
|
+
1,
|
|
371
|
+
4,
|
|
372
|
+
,
|
|
373
|
+
5
|
|
374
|
+
]);
|
|
375
|
+
sheets = _googleapis.google.sheets({
|
|
376
|
+
version: 'v4',
|
|
377
|
+
auth: extra.authContext.auth
|
|
378
|
+
});
|
|
379
|
+
return [
|
|
380
|
+
4,
|
|
381
|
+
sheets.spreadsheets.get({
|
|
382
|
+
spreadsheetId: id,
|
|
383
|
+
fields: 'sheets.properties.sheetId,sheets.properties.title'
|
|
384
|
+
})
|
|
385
|
+
];
|
|
386
|
+
case 2:
|
|
387
|
+
spreadsheetResponse = _state.sent();
|
|
388
|
+
// Find sheet by gid
|
|
389
|
+
sheet = (_spreadsheetResponse_data_sheets = spreadsheetResponse.data.sheets) === null || _spreadsheetResponse_data_sheets === void 0 ? void 0 : _spreadsheetResponse_data_sheets.find(function(s) {
|
|
390
|
+
var _s_properties;
|
|
391
|
+
return String((_s_properties = s.properties) === null || _s_properties === void 0 ? void 0 : _s_properties.sheetId) === gid;
|
|
392
|
+
});
|
|
393
|
+
if (!(sheet === null || sheet === void 0 ? void 0 : sheet.properties)) {
|
|
394
|
+
logger.info('Sheet not found for validation set', {
|
|
395
|
+
id: id,
|
|
396
|
+
gid: gid,
|
|
397
|
+
requestCount: requests.length
|
|
398
|
+
});
|
|
399
|
+
throw new _types.McpError(_types.ErrorCode.InvalidParams, "Sheet not found: ".concat(gid));
|
|
400
|
+
}
|
|
401
|
+
sheetTitle = (_sheet_properties_title = sheet.properties.title) !== null && _sheet_properties_title !== void 0 ? _sheet_properties_title : gid;
|
|
402
|
+
sheetId = sheet.properties.sheetId;
|
|
403
|
+
sheetUrl = "https://docs.google.com/spreadsheets/d/".concat(id, "/edit#gid=").concat(sheetId);
|
|
404
|
+
// Validate sheetId exists
|
|
405
|
+
if (sheetId === undefined || sheetId === null) {
|
|
406
|
+
logger.error('Sheet ID not available for validation set', {
|
|
407
|
+
id: id,
|
|
408
|
+
gid: gid,
|
|
409
|
+
sheetTitle: sheetTitle
|
|
410
|
+
});
|
|
411
|
+
throw new _types.McpError(_types.ErrorCode.InternalError, "Sheet ID not available for ".concat(gid, ". Cannot perform validation operations without valid sheet ID."));
|
|
412
|
+
}
|
|
413
|
+
// Build batch update requests
|
|
414
|
+
batchRequests = [];
|
|
415
|
+
failedRanges = [];
|
|
416
|
+
_iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
417
|
+
try {
|
|
418
|
+
for(_iterator = requests[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
|
|
419
|
+
request = _step.value;
|
|
420
|
+
try {
|
|
421
|
+
// Parse A1 notation to range reference
|
|
422
|
+
rangeRef = (0, _rangeoperations.parseA1Notation)(request.range);
|
|
423
|
+
// Build grid range from range reference using helper function
|
|
424
|
+
gridRange = (0, _rangeoperations.rangeReferenceToGridRange)(rangeRef, sheetId);
|
|
425
|
+
// Build validation rule
|
|
426
|
+
condition = buildCondition(request.rule);
|
|
427
|
+
// Build data validation rule - structure matches Schema$DataValidationRule
|
|
428
|
+
dataValidationRule = {
|
|
429
|
+
condition: condition,
|
|
430
|
+
strict: request.rule.strict,
|
|
431
|
+
showCustomUi: 'showDropdown' in request.rule ? request.rule.showDropdown : undefined,
|
|
432
|
+
inputMessage: request.inputMessage
|
|
433
|
+
};
|
|
434
|
+
// Add setDataValidation request
|
|
435
|
+
batchRequests.push({
|
|
436
|
+
setDataValidation: {
|
|
437
|
+
range: gridRange,
|
|
438
|
+
rule: dataValidationRule
|
|
439
|
+
}
|
|
440
|
+
});
|
|
441
|
+
} catch (error) {
|
|
442
|
+
message = _instanceof(error, Error) ? error.message : String(error);
|
|
443
|
+
logger.info('Failed to build validation rule', {
|
|
444
|
+
range: request.range,
|
|
445
|
+
error: message
|
|
446
|
+
});
|
|
447
|
+
failedRanges.push({
|
|
448
|
+
range: request.range,
|
|
449
|
+
error: "Failed to build validation rule: ".concat(message)
|
|
450
|
+
});
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
} catch (err) {
|
|
454
|
+
_didIteratorError = true;
|
|
455
|
+
_iteratorError = err;
|
|
456
|
+
} finally{
|
|
457
|
+
try {
|
|
458
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
459
|
+
_iterator.return();
|
|
460
|
+
}
|
|
461
|
+
} finally{
|
|
462
|
+
if (_didIteratorError) {
|
|
463
|
+
throw _iteratorError;
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
}
|
|
467
|
+
// Early return if all ranges failed
|
|
468
|
+
if (batchRequests.length === 0) {
|
|
469
|
+
result = {
|
|
470
|
+
type: 'success',
|
|
471
|
+
id: id,
|
|
472
|
+
gid: String(sheetId),
|
|
473
|
+
sheetTitle: sheetTitle,
|
|
474
|
+
sheetUrl: sheetUrl,
|
|
475
|
+
successCount: 0,
|
|
476
|
+
failedRanges: failedRanges.length > 0 ? failedRanges : undefined
|
|
477
|
+
};
|
|
478
|
+
return [
|
|
479
|
+
2,
|
|
480
|
+
{
|
|
481
|
+
content: [
|
|
482
|
+
{
|
|
483
|
+
type: 'text',
|
|
484
|
+
text: JSON.stringify(result)
|
|
485
|
+
}
|
|
486
|
+
],
|
|
487
|
+
structuredContent: {
|
|
488
|
+
result: result
|
|
489
|
+
}
|
|
490
|
+
}
|
|
491
|
+
];
|
|
492
|
+
}
|
|
493
|
+
logger.info('sheets.validation.set executing batch request', {
|
|
494
|
+
spreadsheetId: id,
|
|
495
|
+
sheetTitle: sheetTitle,
|
|
496
|
+
batchRequestsCount: batchRequests.length
|
|
497
|
+
});
|
|
498
|
+
// Execute the batch update
|
|
499
|
+
return [
|
|
500
|
+
4,
|
|
501
|
+
sheets.spreadsheets.batchUpdate({
|
|
502
|
+
spreadsheetId: id,
|
|
503
|
+
requestBody: {
|
|
504
|
+
requests: batchRequests
|
|
505
|
+
}
|
|
506
|
+
})
|
|
507
|
+
];
|
|
508
|
+
case 3:
|
|
509
|
+
_state.sent();
|
|
510
|
+
logger.info('sheets.validation.set completed successfully', {
|
|
511
|
+
successCount: requests.length - failedRanges.length,
|
|
512
|
+
failedCount: failedRanges.length
|
|
513
|
+
});
|
|
514
|
+
result1 = {
|
|
515
|
+
type: 'success',
|
|
516
|
+
id: id,
|
|
517
|
+
gid: String(sheetId),
|
|
518
|
+
sheetTitle: sheetTitle,
|
|
519
|
+
sheetUrl: sheetUrl,
|
|
520
|
+
successCount: requests.length - failedRanges.length,
|
|
521
|
+
failedRanges: failedRanges.length > 0 ? failedRanges : undefined
|
|
522
|
+
};
|
|
523
|
+
return [
|
|
524
|
+
2,
|
|
525
|
+
{
|
|
526
|
+
content: [
|
|
527
|
+
{
|
|
528
|
+
type: 'text',
|
|
529
|
+
text: JSON.stringify(result1)
|
|
530
|
+
}
|
|
531
|
+
],
|
|
532
|
+
structuredContent: {
|
|
533
|
+
result: result1
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
];
|
|
537
|
+
case 4:
|
|
538
|
+
error = _state.sent();
|
|
539
|
+
message1 = _instanceof(error, Error) ? error.message : String(error);
|
|
540
|
+
logger.error('Validation set operation failed', {
|
|
541
|
+
id: id,
|
|
542
|
+
gid: gid,
|
|
543
|
+
requestCount: requests.length,
|
|
544
|
+
error: message1
|
|
545
|
+
});
|
|
546
|
+
throw new _types.McpError(_types.ErrorCode.InternalError, "Error setting validation: ".concat(message1), {
|
|
547
|
+
stack: _instanceof(error, Error) ? error.stack : undefined
|
|
548
|
+
});
|
|
549
|
+
case 5:
|
|
550
|
+
return [
|
|
551
|
+
2
|
|
552
|
+
];
|
|
553
|
+
}
|
|
554
|
+
});
|
|
555
|
+
}).apply(this, arguments);
|
|
556
|
+
}
|
|
557
|
+
function createTool() {
|
|
558
|
+
return {
|
|
559
|
+
name: 'validation-set',
|
|
560
|
+
config: config,
|
|
561
|
+
handler: handler
|
|
562
|
+
};
|
|
563
|
+
}
|
|
564
|
+
/* 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/validation-set.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// Discriminated union for validation rule types\nconst ValidationRuleSchema = z.discriminatedUnion('conditionType', [\n // Dropdown with hardcoded list\n z.object({\n conditionType: z.literal('ONE_OF_LIST'),\n values: z.array(z.string()).min(1).describe('Hardcoded dropdown options'),\n showDropdown: z.boolean().default(true).describe('Show dropdown UI in cells'),\n strict: z.boolean().default(true).describe('Reject invalid entries'),\n }),\n // Dropdown from range\n z.object({\n conditionType: z.literal('ONE_OF_RANGE'),\n sourceRange: z.string().min(1).describe('A1 notation range containing dropdown options (e.g., \"Options!A1:A10\")'),\n showDropdown: z.boolean().default(true).describe('Show dropdown UI in cells'),\n strict: z.boolean().default(true).describe('Reject invalid entries'),\n }),\n // Numeric constraints\n z.object({\n conditionType: z.enum(['NUMBER_GREATER', 'NUMBER_LESS', 'NUMBER_BETWEEN']),\n values: z.array(z.number()).min(1).max(2).describe('1 value for GREATER/LESS, 2 values for BETWEEN'),\n strict: z.boolean().default(true).describe('Reject invalid entries'),\n }),\n // Text constraints\n z.object({\n conditionType: z.enum(['TEXT_CONTAINS', 'TEXT_IS_EMAIL', 'TEXT_IS_URL']),\n values: z.array(z.string()).optional().describe('Text to match (for TEXT_CONTAINS only)'),\n strict: z.boolean().default(true).describe('Reject invalid entries'),\n }),\n // Date constraints\n z.object({\n conditionType: z.enum(['DATE_AFTER', 'DATE_BEFORE', 'DATE_BETWEEN']),\n values: z.array(z.string()).min(1).max(2).describe('ISO date strings (YYYY-MM-DD)'),\n strict: z.boolean().default(true).describe('Reject invalid entries'),\n }),\n // Custom formula\n z.object({\n conditionType: z.literal('CUSTOM_FORMULA'),\n formula: z.string().min(1).describe('Custom validation formula (e.g., \"=A1>0\")'),\n strict: z.boolean().default(true).describe('Reject invalid entries'),\n }),\n]);\n\n// Input schema for validation requests\nconst ValidationRequestSchema = z.object({\n range: z.string().min(1).describe('A1 notation range for validation (e.g., \"B2:B100\")'),\n rule: ValidationRuleSchema,\n inputMessage: z.string().optional().describe('Help text shown when cell is selected'),\n});\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n requests: z.array(ValidationRequestSchema).min(1).max(50).describe('Array of validation rules. Batch multiple ranges for efficiency.'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n sheetTitle: z.string().describe('Title of the sheet with validation'),\n sheetUrl: z.string().describe('URL of the sheet with validation'),\n successCount: z.number().int().nonnegative().describe('Number of validation rules successfully applied'),\n failedRanges: z\n .array(\n z.object({\n range: z.string().describe('A1 notation of range that failed validation setup'),\n error: z.string().describe('Why validation failed for this range'),\n })\n )\n .optional()\n .describe('Only populated if some validation rules failed'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Add data validation rules including dropdowns, numeric constraints, text patterns, date ranges, custom formulas. Supports batch operations for efficiency. Use discriminated conditionType to specify rule type. Best for enforcing data integrity and providing user-friendly input controls.',\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// Map condition types to Google Sheets API format\nfunction buildCondition(rule: z.infer<typeof ValidationRuleSchema>) {\n switch (rule.conditionType) {\n case 'ONE_OF_LIST':\n return {\n type: 'ONE_OF_LIST',\n values: rule.values.map((value) => ({ userEnteredValue: value })),\n };\n case 'ONE_OF_RANGE':\n return {\n type: 'ONE_OF_RANGE',\n values: [{ userEnteredValue: `=${rule.sourceRange}` }],\n };\n case 'NUMBER_GREATER':\n return {\n type: 'NUMBER_GREATER',\n values: [{ userEnteredValue: String(rule.values[0]) }],\n };\n case 'NUMBER_LESS':\n return {\n type: 'NUMBER_LESS',\n values: [{ userEnteredValue: String(rule.values[0]) }],\n };\n case 'NUMBER_BETWEEN':\n return {\n type: 'NUMBER_BETWEEN',\n values: [{ userEnteredValue: String(rule.values[0]) }, { userEnteredValue: String(rule.values[1]) }],\n };\n case 'TEXT_CONTAINS':\n return {\n type: 'TEXT_CONTAINS',\n values: rule.values ? [{ userEnteredValue: rule.values[0] }] : [],\n };\n case 'TEXT_IS_EMAIL':\n return {\n type: 'TEXT_IS_EMAIL',\n values: [],\n };\n case 'TEXT_IS_URL':\n return {\n type: 'TEXT_IS_URL',\n values: [],\n };\n case 'DATE_AFTER':\n return {\n type: 'DATE_AFTER',\n values: [{ userEnteredValue: rule.values[0] }],\n };\n case 'DATE_BEFORE':\n return {\n type: 'DATE_BEFORE',\n values: [{ userEnteredValue: rule.values[0] }],\n };\n case 'DATE_BETWEEN':\n return {\n type: 'DATE_BETWEEN',\n values: [{ userEnteredValue: rule.values[0] }, { userEnteredValue: rule.values[1] }],\n };\n case 'CUSTOM_FORMULA':\n return {\n type: 'CUSTOM_FORMULA',\n values: [{ userEnteredValue: rule.formula.startsWith('=') ? rule.formula : `=${rule.formula}` }],\n };\n default:\n // Exhaustive check - all valid conditionType values should be handled above\n throw new Error(`Unknown condition type: ${(rule as { conditionType: string }).conditionType}`);\n }\n}\n\nasync function handler({ id, gid, requests }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.validation.set called', {\n id,\n gid,\n requestCount: requests.length,\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 validation set', { id, gid, requestCount: requests.length });\n throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);\n }\n\n const sheetTitle = sheet.properties.title ?? gid;\n const sheetId = sheet.properties.sheetId;\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetId}`;\n\n // Validate sheetId exists\n if (sheetId === undefined || sheetId === null) {\n logger.error('Sheet ID not available for validation set', { id, gid, sheetTitle });\n throw new McpError(ErrorCode.InternalError, `Sheet ID not available for ${gid}. Cannot perform validation operations without valid sheet ID.`);\n }\n\n // Build batch update requests\n const batchRequests: sheets_v4.Schema$Request[] = [];\n const failedRanges: Array<{ range: string; error: string }> = [];\n\n for (const request of requests) {\n try {\n // Parse A1 notation to range reference\n const rangeRef = parseA1Notation(request.range);\n\n // Build grid range from range reference using helper function\n const gridRange = rangeReferenceToGridRange(rangeRef, sheetId);\n\n // Build validation rule\n const condition = buildCondition(request.rule);\n\n // Build data validation rule - structure matches Schema$DataValidationRule\n const dataValidationRule = {\n condition,\n strict: request.rule.strict,\n showCustomUi: 'showDropdown' in request.rule ? request.rule.showDropdown : undefined,\n inputMessage: request.inputMessage,\n } as sheets_v4.Schema$DataValidationRule;\n\n // Add setDataValidation request\n batchRequests.push({\n setDataValidation: {\n range: gridRange,\n rule: dataValidationRule,\n },\n });\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.info('Failed to build validation rule', {\n range: request.range,\n error: message,\n });\n failedRanges.push({\n range: request.range,\n error: `Failed to build validation rule: ${message}`,\n });\n }\n }\n\n // Early return if all ranges failed\n if (batchRequests.length === 0) {\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetId),\n sheetTitle,\n sheetUrl,\n successCount: 0,\n failedRanges: failedRanges.length > 0 ? failedRanges : undefined,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n }\n\n logger.info('sheets.validation.set executing batch request', {\n spreadsheetId: id,\n sheetTitle,\n batchRequestsCount: batchRequests.length,\n });\n\n // Execute the batch update\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: batchRequests,\n },\n });\n\n logger.info('sheets.validation.set completed successfully', {\n successCount: requests.length - failedRanges.length,\n failedCount: failedRanges.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetId),\n sheetTitle,\n sheetUrl,\n successCount: requests.length - failedRanges.length,\n failedRanges: failedRanges.length > 0 ? failedRanges : undefined,\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('Validation set operation failed', {\n id,\n gid,\n requestCount: requests.length,\n error: message,\n });\n\n throw new McpError(ErrorCode.InternalError, `Error setting validation: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'validation-set',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","ValidationRuleSchema","z","discriminatedUnion","object","conditionType","literal","values","array","string","min","describe","showDropdown","boolean","default","strict","sourceRange","enum","number","max","optional","formula","ValidationRequestSchema","range","rule","inputMessage","inputSchema","id","SpreadsheetIdSchema","gid","SheetGidSchema","requests","successBranchSchema","type","SpreadsheetIdOutput","SheetGidOutput","sheetTitle","sheetUrl","successCount","int","nonnegative","failedRanges","error","outputSchema","config","description","result","buildCondition","map","value","userEnteredValue","String","startsWith","Error","handler","extra","logger","sheet","spreadsheetResponse","sheets","sheetId","batchRequests","request","rangeRef","gridRange","condition","dataValidationRule","message","info","requestCount","length","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","properties","McpError","ErrorCode","InvalidParams","title","undefined","InternalError","parseA1Notation","rangeReferenceToGridRange","showCustomUi","push","setDataValidation","content","text","JSON","stringify","structuredContent","batchRequestsCount","batchUpdate","requestBody","failedCount","stack","name"],"mappings":"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"}
|