@mcp-z/mcp-sheets 1.0.0 → 1.0.1
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/README.md +32 -3
- package/bin/server.js +1 -1
- package/dist/cjs/constants.js.map +1 -1
- package/dist/cjs/index.js +13 -13
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/lib/create-store.js.map +1 -1
- package/dist/cjs/mcp/index.js +6 -6
- package/dist/cjs/mcp/index.js.map +1 -1
- package/dist/cjs/mcp/prompts/a1-notation.js.map +1 -1
- package/dist/cjs/mcp/prompts/index.js +2 -2
- package/dist/cjs/mcp/prompts/index.js.map +1 -1
- package/dist/cjs/mcp/resources/index.js +2 -2
- package/dist/cjs/mcp/resources/index.js.map +1 -1
- package/dist/cjs/mcp/resources/spreadsheet.js.map +1 -1
- package/dist/cjs/mcp/tools/cells-format.js +8 -8
- package/dist/cjs/mcp/tools/cells-format.js.map +1 -1
- package/dist/cjs/mcp/tools/chart-create.js +8 -8
- package/dist/cjs/mcp/tools/chart-create.js.map +1 -1
- package/dist/cjs/mcp/tools/columns-get.js +3 -3
- package/dist/cjs/mcp/tools/columns-get.js.map +1 -1
- package/dist/cjs/mcp/tools/columns-update.js +10 -10
- package/dist/cjs/mcp/tools/columns-update.js.map +1 -1
- package/dist/cjs/mcp/tools/csv-get-columns.js +2 -2
- package/dist/cjs/mcp/tools/csv-get-columns.js.map +1 -1
- package/dist/cjs/mcp/tools/dimensions-batch-update.js +16 -16
- package/dist/cjs/mcp/tools/dimensions-batch-update.js.map +1 -1
- package/dist/cjs/mcp/tools/dimensions-move.js +5 -5
- package/dist/cjs/mcp/tools/dimensions-move.js.map +1 -1
- package/dist/cjs/mcp/tools/index.js +52 -52
- package/dist/cjs/mcp/tools/index.js.map +1 -1
- package/dist/cjs/mcp/tools/lib/dimension-operations.js.map +1 -1
- package/dist/cjs/mcp/tools/rows-append.js +10 -10
- package/dist/cjs/mcp/tools/rows-append.js.map +1 -1
- package/dist/cjs/mcp/tools/rows-csv-append.js +13 -13
- package/dist/cjs/mcp/tools/rows-csv-append.js.map +1 -1
- package/dist/cjs/mcp/tools/rows-get.js +4 -4
- package/dist/cjs/mcp/tools/rows-get.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-copy-to.js +4 -4
- package/dist/cjs/mcp/tools/sheet-copy-to.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-copy.js +5 -5
- package/dist/cjs/mcp/tools/sheet-copy.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-create.js +4 -4
- package/dist/cjs/mcp/tools/sheet-create.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-delete.js +4 -4
- package/dist/cjs/mcp/tools/sheet-delete.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-find.js +7 -7
- package/dist/cjs/mcp/tools/sheet-find.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-rename.js +5 -5
- package/dist/cjs/mcp/tools/sheet-rename.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-copy.js +2 -2
- package/dist/cjs/mcp/tools/spreadsheet-copy.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-create.js +2 -2
- package/dist/cjs/mcp/tools/spreadsheet-create.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-find.js +6 -6
- package/dist/cjs/mcp/tools/spreadsheet-find.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-rename.js +3 -3
- package/dist/cjs/mcp/tools/spreadsheet-rename.js.map +1 -1
- package/dist/cjs/mcp/tools/validation-set.js +8 -8
- package/dist/cjs/mcp/tools/validation-set.js.map +1 -1
- package/dist/cjs/mcp/tools/values-batch-update.js +8 -8
- package/dist/cjs/mcp/tools/values-batch-update.js.map +1 -1
- package/dist/cjs/mcp/tools/values-clear.js +6 -6
- package/dist/cjs/mcp/tools/values-clear.js.map +1 -1
- package/dist/cjs/mcp/tools/values-csv-update.js +8 -8
- package/dist/cjs/mcp/tools/values-csv-update.js.map +1 -1
- package/dist/cjs/mcp/tools/values-replace.js +8 -8
- package/dist/cjs/mcp/tools/values-replace.js.map +1 -1
- package/dist/cjs/mcp/tools/values-search.js +5 -5
- package/dist/cjs/mcp/tools/values-search.js.map +1 -1
- package/dist/cjs/schemas/index.js.map +1 -1
- package/dist/cjs/setup/config.js +11 -1
- package/dist/cjs/setup/config.js.map +1 -1
- package/dist/cjs/setup/http.js +6 -2
- package/dist/cjs/setup/http.js.map +1 -1
- package/dist/cjs/setup/index.js +9 -9
- package/dist/cjs/setup/index.js.map +1 -1
- package/dist/cjs/setup/oauth-google.d.cts +3 -2
- package/dist/cjs/setup/oauth-google.d.ts +3 -2
- package/dist/cjs/setup/oauth-google.js +15 -12
- package/dist/cjs/setup/oauth-google.js.map +1 -1
- package/dist/cjs/setup/runtime.js +9 -9
- package/dist/cjs/setup/runtime.js.map +1 -1
- package/dist/cjs/setup/stdio.js +2 -2
- package/dist/cjs/setup/stdio.js.map +1 -1
- package/dist/cjs/spreadsheet/column-utilities.js.map +1 -1
- package/dist/cjs/spreadsheet/csv-streaming.js.map +1 -1
- package/dist/cjs/spreadsheet/data-operations.js +9 -9
- package/dist/cjs/spreadsheet/data-operations.js.map +1 -1
- package/dist/cjs/spreadsheet/deduplication-utils.js.map +1 -1
- package/dist/cjs/spreadsheet/range-operations.js +2 -2
- package/dist/cjs/spreadsheet/range-operations.js.map +1 -1
- package/dist/cjs/spreadsheet/sheet-operations.js +3 -3
- package/dist/cjs/spreadsheet/sheet-operations.js.map +1 -1
- package/dist/cjs/spreadsheet/spreadsheet-management.js.map +1 -1
- package/dist/esm/constants.js.map +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/create-store.js.map +1 -1
- package/dist/esm/mcp/index.js.map +1 -1
- package/dist/esm/mcp/prompts/a1-notation.js.map +1 -1
- package/dist/esm/mcp/prompts/index.js.map +1 -1
- package/dist/esm/mcp/resources/index.js.map +1 -1
- package/dist/esm/mcp/resources/spreadsheet.js.map +1 -1
- package/dist/esm/mcp/tools/cells-format.js.map +1 -1
- package/dist/esm/mcp/tools/chart-create.js.map +1 -1
- package/dist/esm/mcp/tools/columns-get.js.map +1 -1
- package/dist/esm/mcp/tools/columns-update.js.map +1 -1
- package/dist/esm/mcp/tools/csv-get-columns.js.map +1 -1
- package/dist/esm/mcp/tools/dimensions-batch-update.js.map +1 -1
- package/dist/esm/mcp/tools/dimensions-move.js.map +1 -1
- package/dist/esm/mcp/tools/index.js.map +1 -1
- package/dist/esm/mcp/tools/lib/dimension-operations.js.map +1 -1
- package/dist/esm/mcp/tools/rows-append.js.map +1 -1
- package/dist/esm/mcp/tools/rows-csv-append.js.map +1 -1
- package/dist/esm/mcp/tools/rows-get.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-copy-to.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-copy.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-create.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-delete.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-find.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-rename.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-copy.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-create.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-find.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-rename.js.map +1 -1
- package/dist/esm/mcp/tools/validation-set.js.map +1 -1
- package/dist/esm/mcp/tools/values-batch-update.js.map +1 -1
- package/dist/esm/mcp/tools/values-clear.js.map +1 -1
- package/dist/esm/mcp/tools/values-csv-update.js.map +1 -1
- package/dist/esm/mcp/tools/values-replace.js.map +1 -1
- package/dist/esm/mcp/tools/values-search.js.map +1 -1
- package/dist/esm/schemas/index.js.map +1 -1
- package/dist/esm/setup/config.js +12 -2
- package/dist/esm/setup/config.js.map +1 -1
- package/dist/esm/setup/http.js +4 -0
- package/dist/esm/setup/http.js.map +1 -1
- package/dist/esm/setup/index.js.map +1 -1
- package/dist/esm/setup/oauth-google.d.ts +3 -2
- package/dist/esm/setup/oauth-google.js +8 -11
- package/dist/esm/setup/oauth-google.js.map +1 -1
- package/dist/esm/setup/runtime.js.map +1 -1
- package/dist/esm/setup/stdio.js.map +1 -1
- package/dist/esm/spreadsheet/column-utilities.js.map +1 -1
- package/dist/esm/spreadsheet/csv-streaming.js.map +1 -1
- package/dist/esm/spreadsheet/data-operations.js.map +1 -1
- package/dist/esm/spreadsheet/deduplication-utils.js.map +1 -1
- package/dist/esm/spreadsheet/range-operations.js.map +1 -1
- package/dist/esm/spreadsheet/sheet-operations.js.map +1 -1
- package/dist/esm/spreadsheet/spreadsheet-management.js.map +1 -1
- package/dist/esm/types.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/sheet-delete.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 { SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\n\nconst MAX_BATCH_SIZE = 1000;\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gids: z.array(SheetGidSchema).min(1).max(MAX_BATCH_SIZE).describe('Sheet grid IDs to permanently delete'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Human-readable summary of the operation'),\n itemsProcessed: z.number().describe('Total sheets attempted to delete'),\n itemsChanged: z.number().describe('Number of sheets successfully deleted'),\n completedAt: z.string().describe('ISO timestamp when operation completed'),\n recoverable: z.literal(false).describe('Whether deletion can be undone (always false)'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().optional().describe('URL to view the spreadsheet'),\n failures: z\n .array(\n z.object({\n gid: z.string().describe('Grid ID of sheet that failed to delete'),\n error: z.string().describe('Error message explaining the failure'),\n })\n )\n .optional()\n .describe('Details of any sheets that failed to delete'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Permanently delete sheets from a spreadsheet. Cannot delete the last remaining sheet.',\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, gids }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.delete called', { id, count: gids.length });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n const results = await Promise.allSettled(\n gids.map(async (gid) => {\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [{ deleteSheet: { sheetId: Number(gid) } }],\n },\n });\n return gid;\n })\n );\n\n // Separate successes and failures\n const failures: Array<{ gid: string; error: string }> = [];\n\n results.forEach((result, index) => {\n const gid = gids[index];\n if (!gid) return;\n\n if (result.status === 'rejected') {\n const errorMessage = result.reason instanceof Error ? result.reason.message : String(result.reason);\n failures.push({ gid, error: errorMessage });\n }\n });\n\n const successCount = gids.length - failures.length;\n const failureCount = failures.length;\n const totalCount = gids.length;\n\n const summary = failureCount === 0 ? `Permanently deleted ${successCount} sheet${successCount === 1 ? '' : 's'}` : `Deleted ${successCount} of ${totalCount} sheet${totalCount === 1 ? '' : 's'} (${failureCount} failed)`;\n\n logger.info('sheets.sheet.delete completed', {\n totalCount,\n successCount,\n failureCount,\n });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: summary,\n itemsProcessed: totalCount,\n itemsChanged: successCount,\n completedAt: new Date().toISOString(),\n recoverable: false as const,\n id,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${id}`,\n ...(failures.length > 0 && { failures }),\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.delete error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error deleting sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-delete',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","MAX_BATCH_SIZE","inputSchema","z","object","id","SpreadsheetIdSchema","gids","array","SheetGidSchema","min","max","describe","successBranchSchema","type","literal","operationSummary","string","itemsProcessed","number","itemsChanged","completedAt","recoverable","SpreadsheetIdOutput","spreadsheetUrl","optional","failures","gid","error","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sheets","results","successCount","failureCount","totalCount","summary","message","info","count","length","google","version","auth","authContext","Promise","allSettled","map","spreadsheets","batchUpdate","spreadsheetId","requestBody","requests","deleteSheet","sheetId","Number","forEach","index","status","errorMessage","reason","Error","String","push","Date","toISOString","content","text","JSON","stringify","structuredContent","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
|
|
@@ -12,8 +12,8 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
16
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
|
+
var _sheetoperationsts = require("../../spreadsheet/sheet-operations.js");
|
|
17
17
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
18
18
|
try {
|
|
19
19
|
var info = gen[key](arg);
|
|
@@ -151,13 +151,13 @@ function _ts_generator(thisArg, body) {
|
|
|
151
151
|
}
|
|
152
152
|
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
153
153
|
var inputSchema = _zod.z.object({
|
|
154
|
-
id:
|
|
155
|
-
sheetRef:
|
|
154
|
+
id: _indexts.SpreadsheetIdSchema,
|
|
155
|
+
sheetRef: _indexts.SheetRefSchema
|
|
156
156
|
});
|
|
157
157
|
var successBranchSchema = _zod.z.object({
|
|
158
158
|
type: _zod.z.literal('success'),
|
|
159
|
-
id:
|
|
160
|
-
gid:
|
|
159
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
160
|
+
gid: _indexts.SheetGidOutput,
|
|
161
161
|
title: _zod.z.string().describe('Sheet tab name'),
|
|
162
162
|
sheetUrl: _zod.z.string().optional().describe('URL to view the sheet')
|
|
163
163
|
});
|
|
@@ -198,7 +198,7 @@ function handler(_0, _1) {
|
|
|
198
198
|
});
|
|
199
199
|
return [
|
|
200
200
|
4,
|
|
201
|
-
(0,
|
|
201
|
+
(0, _sheetoperationsts.findSheetByRef)(sheets, id, sheetRef, logger)
|
|
202
202
|
];
|
|
203
203
|
case 2:
|
|
204
204
|
sheet = _state.sent();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/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.ts';\nimport { findSheetByRef } from '../../spreadsheet/sheet-operations.ts';\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":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","sheetRef","SheetRefSchema","successBranchSchema","type","literal","SpreadsheetIdOutput","gid","SheetGidOutput","title","string","describe","sheetUrl","optional","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sheet","sheets","error","message","info","google","version","auth","authContext","findSheetByRef","McpError","ErrorCode","InvalidParams","properties","String","sheetId","content","text","JSON","stringify","structuredContent","Error","InternalError","stack","undefined","name"],"mappings":"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"}
|
|
@@ -12,7 +12,7 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
16
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
17
17
|
try {
|
|
18
18
|
var info = gen[key](arg);
|
|
@@ -150,8 +150,8 @@ function _ts_generator(thisArg, body) {
|
|
|
150
150
|
}
|
|
151
151
|
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
152
152
|
var inputSchema = _zod.z.object({
|
|
153
|
-
id:
|
|
154
|
-
gid:
|
|
153
|
+
id: _indexts.SpreadsheetIdSchema,
|
|
154
|
+
gid: _indexts.SheetGidSchema,
|
|
155
155
|
newTitle: _zod.z.coerce.string().trim().min(1).describe('New name for the sheet tab')
|
|
156
156
|
});
|
|
157
157
|
// Success branch schema
|
|
@@ -161,8 +161,8 @@ var successBranchSchema = _zod.z.object({
|
|
|
161
161
|
itemsProcessed: _zod.z.number().describe('Total items attempted (always 1 for single sheet)'),
|
|
162
162
|
itemsChanged: _zod.z.number().describe('Successfully renamed sheets (always 1 on success)'),
|
|
163
163
|
completedAt: _zod.z.string().describe('ISO datetime when operation completed'),
|
|
164
|
-
id:
|
|
165
|
-
gid:
|
|
164
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
165
|
+
gid: _indexts.SheetGidOutput,
|
|
166
166
|
sheetUrl: _zod.z.string().describe('URL of the renamed sheet'),
|
|
167
167
|
oldTitle: _zod.z.string().describe('Previous title of the sheet'),
|
|
168
168
|
newTitle: _zod.z.string().describe('New title of the sheet')
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/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.ts';\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":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","newTitle","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","SpreadsheetIdOutput","SheetGidOutput","sheetUrl","oldTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetInfo","sheets","sheetInfo","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","String","properties","sheetId","McpError","ErrorCode","InvalidParams","title","batchUpdate","requestBody","requests","updateSheetProperties","Number","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","InternalError","stack","undefined","name"],"mappings":"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"}
|
|
@@ -12,7 +12,7 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
16
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
17
17
|
try {
|
|
18
18
|
var info = gen[key](arg);
|
|
@@ -179,7 +179,7 @@ function _ts_generator(thisArg, body) {
|
|
|
179
179
|
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
180
180
|
// Note: Using contextual descriptions for sourceId/newId since they describe different spreadsheets
|
|
181
181
|
var inputSchema = _zod.z.object({
|
|
182
|
-
id:
|
|
182
|
+
id: _indexts.SpreadsheetIdSchema,
|
|
183
183
|
newTitle: _zod.z.coerce.string().trim().min(1).optional().describe('Name for the copy (optional, defaults to "Copy of [original]")')
|
|
184
184
|
});
|
|
185
185
|
// Success branch schema
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/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.ts';\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":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","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","sourceInfo","drive","sheets","copyResponse","resultTitle","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","files","copy","fileId","requestBody","name","Error","Date","toISOString","content","text","JSON","stringify","structuredContent","String","McpError","ErrorCode","InternalError","stack","undefined"],"mappings":"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"}
|
|
@@ -12,7 +12,7 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
16
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
17
17
|
try {
|
|
18
18
|
var info = gen[key](arg);
|
|
@@ -159,7 +159,7 @@ var successBranchSchema = _zod.z.object({
|
|
|
159
159
|
itemsProcessed: _zod.z.number().describe('Total items attempted (always 1 for single spreadsheet)'),
|
|
160
160
|
itemsChanged: _zod.z.number().describe('Successfully created spreadsheets (always 1 on success)'),
|
|
161
161
|
completedAt: _zod.z.string().describe('ISO datetime when operation completed'),
|
|
162
|
-
id:
|
|
162
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
163
163
|
spreadsheetUrl: _zod.z.string().describe('URL of the created spreadsheet'),
|
|
164
164
|
title: _zod.z.string().describe('Title of the created spreadsheet')
|
|
165
165
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/spreadsheet-create.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport type { ToolModule } from '@mcp-z/server';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { SpreadsheetIdOutput } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n title: z.coerce.string().trim().min(1).describe('Title for the new spreadsheet'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the spreadsheet creation operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single spreadsheet)'),\n itemsChanged: z.number().describe('Successfully created spreadsheets (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().describe('URL of the created spreadsheet'),\n title: z.string().describe('Title of the created spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Create a new 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({ title }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.create called', { title });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n const response = await sheets.spreadsheets.create({\n requestBody: {\n properties: {\n title: title,\n },\n },\n });\n const res = response.data;\n const id = res.spreadsheetId ?? '';\n const url = res.spreadsheetUrl ?? '';\n\n logger.info('sheets.spreadsheet.create success', { id, title, url });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Created spreadsheet \"${title}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n spreadsheetUrl: url,\n title,\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.create error', { error: message });\n\n // Throw McpError for proper MCP error handling\n throw new McpError(ErrorCode.InternalError, `Error creating spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-create',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","title","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","id","SpreadsheetIdOutput","spreadsheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","res","sheets","response","url","error","message","info","google","version","auth","authContext","spreadsheets","create","requestBody","properties","data","spreadsheetId","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":";;;;+BA4FA;;;eAAwBA;;;2BA3FA;qBAMY;0BACb;mBACL;uBACkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAPpC,IAAM,AAAEC,2BAA6BC,oBAAO,CAApCD;AASR,IAAME,cAAcC,MAAC,CAACC,MAAM,CAAC;IAC3BC,OAAOF,MAAC,CAACG,MAAM,CAACC,MAAM,GAAGC,IAAI,GAAGC,GAAG,CAAC,GAAGC,QAAQ,CAAC;AAClD;AAEA,wBAAwB;AACxB,IAAMC,sBAAsBR,MAAC,CAACC,MAAM,CAAC;IACnCQ,MAAMT,MAAC,CAACU,OAAO,CAAC;IAChBC,kBAAkBX,MAAC,CAACI,MAAM,GAAGG,QAAQ,CAAC;IACtCK,gBAAgBZ,MAAC,CAACa,MAAM,GAAGN,QAAQ,CAAC;IACpCO,cAAcd,MAAC,CAACa,MAAM,GAAGN,QAAQ,CAAC;IAClCQ,aAAaf,MAAC,CAACI,MAAM,GAAGG,QAAQ,CAAC;IACjCS,IAAIC,4BAAmB;IACvBC,gBAAgBlB,MAAC,CAACI,MAAM,GAAGG,QAAQ,CAAC;IACpCL,OAAOF,MAAC,CAACI,MAAM,GAAGG,QAAQ,CAAC;AAC7B;AAEA,2CAA2C;AAC3C,IAAMY,eAAenB,MAAC,CAACoB,kBAAkB,CAAC,QAAQ;IAACZ;IAAqBX;CAAyB;AAEjG,IAAMwB,SAAS;IACbC,aAAa;IACbvB,aAAAA;IACAoB,cAAcnB,MAAC,CAACC,MAAM,CAAC;QACrBsB,QAAQJ;IACV;AACF;AAKA,SAAeK;wCAAQ,KAAgB,EAAEC,KAAoB;YAApCvB,OACjBwB,QAaOC,oBACCA,qBAVNC,QACAC,UAOAF,KACAX,IACAc,KAIAP,QAoBCQ,OACDC;;;;oBAxCe9B,QAAF,MAAEA;oBACjBwB,SAASD,MAAMC,MAAM;oBAC3BA,OAAOO,IAAI,CAAC,oCAAoC;wBAAE/B,OAAAA;oBAAM;;;;;;;;;oBAGhD0B,SAASM,kBAAM,CAACN,MAAM,CAAC;wBAAEO,SAAS;wBAAMC,MAAMX,MAAMY,WAAW,CAACD,IAAI;oBAAC;oBAC1D;;wBAAMR,OAAOU,YAAY,CAACC,MAAM,CAAC;4BAChDC,aAAa;gCACXC,YAAY;oCACVvC,OAAOA;gCACT;4BACF;wBACF;;;oBANM2B,WAAW;oBAOXF,MAAME,SAASa,IAAI;oBACnB1B,MAAKW,qBAAAA,IAAIgB,aAAa,cAAjBhB,gCAAAA,qBAAqB;oBAC1BG,OAAMH,sBAAAA,IAAIT,cAAc,cAAlBS,iCAAAA,sBAAsB;oBAElCD,OAAOO,IAAI,CAAC,qCAAqC;wBAAEjB,IAAAA;wBAAId,OAAAA;wBAAO4B,KAAAA;oBAAI;oBAE5DP,SAAiB;wBACrBd,MAAM;wBACNE,kBAAkB,AAAC,wBAA6B,OAANT,OAAM;wBAChDU,gBAAgB;wBAChBE,cAAc;wBACdC,aAAa,IAAI6B,OAAOC,WAAW;wBACnC7B,IAAAA;wBACAE,gBAAgBY;wBAChB5B,OAAAA;oBACF;oBAEA;;wBAAO;4BACL4C,OAAO;gCACL;oCACErC,MAAM;oCACNsC,MAAMC,KAAKC,SAAS,CAAC1B;gCACvB;;4BAEF2B,mBAAmB;gCAAE3B,QAAAA;4BAAO;wBAC9B;;;oBACOQ;oBACDC,UAAUD,AAAK,YAALA,OAAiBoB,SAAQpB,MAAMC,OAAO,GAAGoB,OAAOrB;oBAChEL,OAAOK,KAAK,CAAC,mCAAmC;wBAAEA,OAAOC;oBAAQ;oBAEjE,+CAA+C;oBAC/C,MAAM,IAAIqB,eAAQ,CAACC,gBAAS,CAACC,aAAa,EAAE,AAAC,+BAAsC,OAARvB,UAAW;wBACpFwB,OAAOzB,AAAK,YAALA,OAAiBoB,SAAQpB,MAAMyB,KAAK,GAAGC;oBAChD;;;;;;;IAEJ;;AAEe,SAAS7D;IACtB,OAAO;QACL8D,MAAM;QACNrC,QAAAA;QACAG,SAAAA;IACF;AACF"}
|
|
@@ -12,8 +12,8 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
16
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
|
+
var _spreadsheetmanagementts = require("../../spreadsheet/spreadsheet-management.js");
|
|
17
17
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
18
18
|
try {
|
|
19
19
|
var info = gen[key](arg);
|
|
@@ -179,17 +179,17 @@ function _ts_generator(thisArg, body) {
|
|
|
179
179
|
}
|
|
180
180
|
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
181
181
|
var inputSchema = _zod.z.object({
|
|
182
|
-
spreadsheetRef:
|
|
182
|
+
spreadsheetRef: _indexts.SpreadsheetRefSchema
|
|
183
183
|
});
|
|
184
184
|
var successBranchSchema = _zod.z.object({
|
|
185
185
|
type: _zod.z.literal('success'),
|
|
186
186
|
items: _zod.z.array(_zod.z.object({
|
|
187
|
-
id:
|
|
187
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
188
188
|
spreadsheetTitle: _zod.z.string().describe('Name of the spreadsheet'),
|
|
189
189
|
spreadsheetUrl: _zod.z.string().optional().describe('URL to view the spreadsheet'),
|
|
190
190
|
modifiedTime: _zod.z.string().optional().describe('Last modified timestamp (ISO format)'),
|
|
191
191
|
sheets: _zod.z.array(_zod.z.object({
|
|
192
|
-
gid:
|
|
192
|
+
gid: _indexts.SheetGidOutput,
|
|
193
193
|
sheetTitle: _zod.z.string().describe('Sheet tab name')
|
|
194
194
|
})).describe('All sheets/tabs in this spreadsheet')
|
|
195
195
|
})).describe('Matching spreadsheets sorted by modification time')
|
|
@@ -234,7 +234,7 @@ function handler(_0, _1) {
|
|
|
234
234
|
});
|
|
235
235
|
return [
|
|
236
236
|
4,
|
|
237
|
-
(0,
|
|
237
|
+
(0, _spreadsheetmanagementts.findSpreadsheetsByRef)(sheets, drive, spreadsheetRef)
|
|
238
238
|
];
|
|
239
239
|
case 2:
|
|
240
240
|
matches = _state.sent();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/spreadsheet-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, SpreadsheetIdOutput, SpreadsheetRefSchema } from '../../schemas/index.ts';\nimport { findSpreadsheetsByRef } from '../../spreadsheet/spreadsheet-management.ts';\n\n/** Spreadsheet match result from findSpreadsheetsByRef */\ninterface SpreadsheetMatch {\n id: string;\n spreadsheetTitle: string | undefined;\n url: string | undefined;\n modifiedTime: string | null | undefined;\n}\n\nconst inputSchema = z.object({\n spreadsheetRef: SpreadsheetRefSchema,\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n items: z\n .array(\n z.object({\n id: SpreadsheetIdOutput,\n spreadsheetTitle: z.string().describe('Name of the spreadsheet'),\n spreadsheetUrl: z.string().optional().describe('URL to view the spreadsheet'),\n modifiedTime: z.string().optional().describe('Last modified timestamp (ISO format)'),\n sheets: z\n .array(\n z.object({\n gid: SheetGidOutput,\n sheetTitle: z.string().describe('Sheet tab name'),\n })\n )\n .describe('All sheets/tabs in this spreadsheet'),\n })\n )\n .describe('Matching spreadsheets sorted by modification time'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Find spreadsheet by ID, URL, or name. Returns all sheets/tabs in response.',\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({ spreadsheetRef }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.find called', { spreadsheetRef });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const matches = (await findSpreadsheetsByRef(sheets, drive, spreadsheetRef)) as SpreadsheetMatch[];\n\n const sorted = (matches || []).slice().sort((a: SpreadsheetMatch, b: SpreadsheetMatch) => (b.modifiedTime ? new Date(b.modifiedTime).getTime() : 0) - (a.modifiedTime ? new Date(a.modifiedTime).getTime() : 0));\n\n const items = await Promise.all(\n sorted.map(async (m: SpreadsheetMatch) => {\n // Fetch sheet metadata for each spreadsheet\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: m.id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheetsData = (spreadsheetResponse.data.sheets || []).map((sheet) => {\n const gid = String(sheet.properties?.sheetId ?? '');\n return {\n gid,\n sheetTitle: sheet.properties?.title ?? '',\n };\n });\n\n return {\n id: m.id,\n spreadsheetTitle: m.spreadsheetTitle ?? '',\n sheets: sheetsData,\n ...(m.url && { spreadsheetUrl: m.url }),\n ...(m.modifiedTime && { modifiedTime: m.modifiedTime }),\n };\n })\n );\n\n logger.info('sheets.spreadsheet.find success', { count: items.length });\n\n const result: Output = {\n type: 'success' as const,\n items,\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.spreadsheet.find error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error finding spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-find',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","spreadsheetRef","SpreadsheetRefSchema","successBranchSchema","type","literal","items","array","id","SpreadsheetIdOutput","spreadsheetTitle","string","describe","spreadsheetUrl","optional","modifiedTime","sheets","gid","SheetGidOutput","sheetTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","drive","matches","sorted","error","message","info","google","version","auth","authContext","findSpreadsheetsByRef","slice","sort","a","b","Date","getTime","Promise","all","map","m","spreadsheetResponse","sheetsData","spreadsheets","get","spreadsheetId","fields","data","sheet","String","properties","sheetId","title","url","count","length","content","text","JSON","stringify","structuredContent","Error","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
|
|
@@ -12,7 +12,7 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
16
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
17
17
|
try {
|
|
18
18
|
var info = gen[key](arg);
|
|
@@ -150,7 +150,7 @@ function _ts_generator(thisArg, body) {
|
|
|
150
150
|
}
|
|
151
151
|
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
152
152
|
var inputSchema = _zod.z.object({
|
|
153
|
-
id:
|
|
153
|
+
id: _indexts.SpreadsheetIdSchema,
|
|
154
154
|
newTitle: _zod.z.coerce.string().trim().min(1).describe('New name for the spreadsheet')
|
|
155
155
|
});
|
|
156
156
|
// Success branch schema
|
|
@@ -160,7 +160,7 @@ var successBranchSchema = _zod.z.object({
|
|
|
160
160
|
itemsProcessed: _zod.z.number().describe('Total items attempted (always 1)'),
|
|
161
161
|
itemsChanged: _zod.z.number().describe('Successfully renamed (always 1 on success)'),
|
|
162
162
|
completedAt: _zod.z.string().describe('ISO datetime when operation completed'),
|
|
163
|
-
id:
|
|
163
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
164
164
|
spreadsheetUrl: _zod.z.string().describe('URL of the renamed spreadsheet'),
|
|
165
165
|
oldTitle: _zod.z.string().describe('Previous title of the spreadsheet'),
|
|
166
166
|
newTitle: _zod.z.string().describe('New title of the spreadsheet')
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/spreadsheet-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 { SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n newTitle: z.coerce.string().trim().min(1).describe('New name for the spreadsheet'),\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)'),\n itemsChanged: z.number().describe('Successfully renamed (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().describe('URL of the renamed spreadsheet'),\n oldTitle: z.string().describe('Previous title of the spreadsheet'),\n newTitle: z.string().describe('New title of the spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Rename a spreadsheet/workbook (the entire document, not individual sheets/tabs)',\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.rename called', { id, newTitle });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // First, get the current spreadsheet title\n const spreadsheetInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title',\n });\n\n const oldTitle = spreadsheetInfo.data.properties?.title || '';\n\n // Rename the spreadsheet\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n updateSpreadsheetProperties: {\n properties: { title: newTitle },\n fields: 'title',\n },\n },\n ],\n },\n });\n\n logger.info('sheets.spreadsheet.rename success', { id, oldTitle, newTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Renamed spreadsheet \"${oldTitle}\" to \"${newTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${id}`,\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 const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.rename error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error renaming spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-rename',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","newTitle","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","SpreadsheetIdOutput","spreadsheetUrl","oldTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetInfo","sheets","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","batchUpdate","requestBody","requests","updateSpreadsheetProperties","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
|
|
@@ -12,8 +12,8 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
16
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
|
+
var _rangeoperationsts = require("../../spreadsheet/range-operations.js");
|
|
17
17
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
18
18
|
try {
|
|
19
19
|
var info = gen[key](arg);
|
|
@@ -210,14 +210,14 @@ var ValidationRequestSchema = _zod.z.object({
|
|
|
210
210
|
inputMessage: _zod.z.string().optional().describe('Help text shown when cell is selected')
|
|
211
211
|
});
|
|
212
212
|
var inputSchema = _zod.z.object({
|
|
213
|
-
id:
|
|
214
|
-
gid:
|
|
213
|
+
id: _indexts.SpreadsheetIdSchema,
|
|
214
|
+
gid: _indexts.SheetGidSchema,
|
|
215
215
|
requests: _zod.z.array(ValidationRequestSchema).min(1).max(50).describe('Array of validation rules. Batch multiple ranges for efficiency.')
|
|
216
216
|
});
|
|
217
217
|
var successBranchSchema = _zod.z.object({
|
|
218
218
|
type: _zod.z.literal('success'),
|
|
219
|
-
id:
|
|
220
|
-
gid:
|
|
219
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
220
|
+
gid: _indexts.SheetGidOutput,
|
|
221
221
|
sheetTitle: _zod.z.string().describe('Title of the sheet with validation'),
|
|
222
222
|
sheetUrl: _zod.z.string().describe('URL of the sheet with validation'),
|
|
223
223
|
successCount: _zod.z.number().int().nonnegative().describe('Number of validation rules successfully applied'),
|
|
@@ -419,9 +419,9 @@ function handler(_0, _1) {
|
|
|
419
419
|
request = _step.value;
|
|
420
420
|
try {
|
|
421
421
|
// Parse A1 notation to range reference
|
|
422
|
-
rangeRef = (0,
|
|
422
|
+
rangeRef = (0, _rangeoperationsts.parseA1Notation)(request.range);
|
|
423
423
|
// Build grid range from range reference using helper function
|
|
424
|
-
gridRange = (0,
|
|
424
|
+
gridRange = (0, _rangeoperationsts.rangeReferenceToGridRange)(rangeRef, sheetId);
|
|
425
425
|
// Build validation rule
|
|
426
426
|
condition = buildCondition(request.rule);
|
|
427
427
|
// Build data validation rule - structure matches Schema$DataValidationRule
|