@mcp-z/mcp-drive 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.
Files changed (78) hide show
  1. package/README.md +32 -3
  2. package/bin/server.js +1 -1
  3. package/dist/cjs/constants.js.map +1 -1
  4. package/dist/cjs/index.js +13 -13
  5. package/dist/cjs/index.js.map +1 -1
  6. package/dist/cjs/lib/create-store.js.map +1 -1
  7. package/dist/cjs/lib/query-builder.js.map +1 -1
  8. package/dist/cjs/mcp/index.js +6 -6
  9. package/dist/cjs/mcp/index.js.map +1 -1
  10. package/dist/cjs/mcp/prompts/index.js +4 -4
  11. package/dist/cjs/mcp/prompts/index.js.map +1 -1
  12. package/dist/cjs/mcp/prompts/organize-files.js.map +1 -1
  13. package/dist/cjs/mcp/prompts/query-syntax.js.map +1 -1
  14. package/dist/cjs/mcp/resources/file.js.map +1 -1
  15. package/dist/cjs/mcp/resources/index.js +2 -2
  16. package/dist/cjs/mcp/resources/index.js.map +1 -1
  17. package/dist/cjs/mcp/tools/file-move-to-trash.js.map +1 -1
  18. package/dist/cjs/mcp/tools/file-move.js.map +1 -1
  19. package/dist/cjs/mcp/tools/files-search.js +10 -10
  20. package/dist/cjs/mcp/tools/files-search.js.map +1 -1
  21. package/dist/cjs/mcp/tools/folder-contents.js +7 -7
  22. package/dist/cjs/mcp/tools/folder-contents.js.map +1 -1
  23. package/dist/cjs/mcp/tools/folder-create.js.map +1 -1
  24. package/dist/cjs/mcp/tools/folder-path.js.map +1 -1
  25. package/dist/cjs/mcp/tools/folder-search.js +10 -10
  26. package/dist/cjs/mcp/tools/folder-search.js.map +1 -1
  27. package/dist/cjs/mcp/tools/index.js +14 -14
  28. package/dist/cjs/mcp/tools/index.js.map +1 -1
  29. package/dist/cjs/schemas/drive-query-schema.js.map +1 -1
  30. package/dist/cjs/schemas/drive-validation.js.map +1 -1
  31. package/dist/cjs/schemas/index.js.map +1 -1
  32. package/dist/cjs/setup/config.js +11 -1
  33. package/dist/cjs/setup/config.js.map +1 -1
  34. package/dist/cjs/setup/http.js +6 -2
  35. package/dist/cjs/setup/http.js.map +1 -1
  36. package/dist/cjs/setup/index.js +9 -9
  37. package/dist/cjs/setup/index.js.map +1 -1
  38. package/dist/cjs/setup/oauth-google.d.cts +3 -2
  39. package/dist/cjs/setup/oauth-google.d.ts +3 -2
  40. package/dist/cjs/setup/oauth-google.js +15 -12
  41. package/dist/cjs/setup/oauth-google.js.map +1 -1
  42. package/dist/cjs/setup/runtime.js +9 -9
  43. package/dist/cjs/setup/runtime.js.map +1 -1
  44. package/dist/cjs/setup/stdio.js +2 -2
  45. package/dist/cjs/setup/stdio.js.map +1 -1
  46. package/dist/esm/constants.js.map +1 -1
  47. package/dist/esm/index.js.map +1 -1
  48. package/dist/esm/lib/create-store.js.map +1 -1
  49. package/dist/esm/lib/query-builder.js.map +1 -1
  50. package/dist/esm/mcp/index.js.map +1 -1
  51. package/dist/esm/mcp/prompts/index.js.map +1 -1
  52. package/dist/esm/mcp/prompts/organize-files.js.map +1 -1
  53. package/dist/esm/mcp/prompts/query-syntax.js.map +1 -1
  54. package/dist/esm/mcp/resources/file.js.map +1 -1
  55. package/dist/esm/mcp/resources/index.js.map +1 -1
  56. package/dist/esm/mcp/tools/file-move-to-trash.js.map +1 -1
  57. package/dist/esm/mcp/tools/file-move.js.map +1 -1
  58. package/dist/esm/mcp/tools/files-search.js.map +1 -1
  59. package/dist/esm/mcp/tools/folder-contents.js.map +1 -1
  60. package/dist/esm/mcp/tools/folder-create.js.map +1 -1
  61. package/dist/esm/mcp/tools/folder-path.js.map +1 -1
  62. package/dist/esm/mcp/tools/folder-search.js.map +1 -1
  63. package/dist/esm/mcp/tools/index.js.map +1 -1
  64. package/dist/esm/schemas/drive-query-schema.js.map +1 -1
  65. package/dist/esm/schemas/drive-validation.js.map +1 -1
  66. package/dist/esm/schemas/index.js.map +1 -1
  67. package/dist/esm/setup/config.js +12 -2
  68. package/dist/esm/setup/config.js.map +1 -1
  69. package/dist/esm/setup/http.js +4 -0
  70. package/dist/esm/setup/http.js.map +1 -1
  71. package/dist/esm/setup/index.js.map +1 -1
  72. package/dist/esm/setup/oauth-google.d.ts +3 -2
  73. package/dist/esm/setup/oauth-google.js +8 -11
  74. package/dist/esm/setup/oauth-google.js.map +1 -1
  75. package/dist/esm/setup/runtime.js.map +1 -1
  76. package/dist/esm/setup/stdio.js.map +1 -1
  77. package/dist/esm/types.js.map +1 -1
  78. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-drive/src/mcp/tools/files-search.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { createFieldsSchema, createPaginationSchema, createShapeSchema, filterFields, parseFields, toColumnarFormat } from '@mcp-z/server';\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { type drive_v3, google } from 'googleapis';\nimport { z } from 'zod';\nimport { toDriveQuery } from '../../lib/query-builder.js';\nimport { DRIVE_FILE_COMMON_PATTERNS, DRIVE_FILE_FIELD_DESCRIPTIONS, DRIVE_FILE_FIELDS, type DriveFile, DriveFileSchema, DriveQuerySchema } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n query: DriveQuerySchema.describe('Drive query object with structured search fields. See DriveQuerySchema for detailed query syntax and examples.'),\n fields: createFieldsSchema({\n availableFields: DRIVE_FILE_FIELDS,\n fieldDescriptions: DRIVE_FILE_FIELD_DESCRIPTIONS,\n commonPatterns: DRIVE_FILE_COMMON_PATTERNS,\n resourceName: 'Drive file',\n }),\n ...createPaginationSchema({\n defaultPageSize: 50,\n maxPageSize: 1000,\n provider: 'drive',\n }).shape,\n shape: createShapeSchema(),\n});\n\n// Success branch schemas for different shapes\nconst successObjectsBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('objects'),\n items: z.array(DriveFileSchema).describe('Matching Drive files'),\n count: z.number().describe('Number of files in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\nconst successArraysBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('arrays'),\n columns: z.array(z.string()).describe('Column names in canonical order'),\n rows: z.array(z.array(z.unknown())).describe('Row data matching column order'),\n count: z.number().describe('Number of files in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\n// Output schema with auth_required support\n// Using z.union instead of discriminatedUnion since we have two success branches with different shapes\nconst outputSchema = z.union([successObjectsBranchSchema, successArraysBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Search Drive Files',\n description: 'Search Google Drive files with flexible field selection for optimal performance.',\n inputSchema: 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// Type for the raw Google Drive API response\ntype driveFile = drive_v3.Schema$File;\n\ntype driveResponse = drive_v3.Schema$FileList;\n\nasync function handler({ query, pageSize = 50, pageToken, fields, shape = 'arrays' }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n\n const requestedFields = parseFields(fields, DRIVE_FILE_FIELDS);\n\n // Validate and clamp pageSize to Google Drive API limits (1-1000)\n const validPageSize = Math.max(1, Math.min(1000, Math.floor(pageSize || 50)));\n\n logger.info('drive.files-search called', {\n query,\n pageSize: validPageSize,\n pageToken: pageToken ? '[provided]' : undefined,\n fields: fields || 'all',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n // Handle query parameter\n let qStr: string;\n if (typeof query === 'string') {\n // String query - treat as raw Drive query\n qStr = `(${query}) and trashed = false`;\n } else if (query && typeof query === 'object' && 'rawDriveQuery' in query && query.rawDriveQuery) {\n // Object with rawDriveQuery field - use it directly\n qStr = `(${query.rawDriveQuery}) and trashed = false`;\n } else {\n // Structured query object - convert to Drive query string\n const { q } = toDriveQuery(query);\n qStr = q ? `(${q}) and trashed = false` : 'trashed = false';\n }\n\n const listOptions: {\n q: string;\n pageSize: number;\n fields: string;\n orderBy: string;\n pageToken?: string;\n } = {\n q: qStr,\n pageSize: validPageSize,\n fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',\n orderBy: 'modifiedTime desc',\n };\n if (pageToken && pageToken.trim().length > 0) {\n listOptions.pageToken = pageToken;\n }\n\n const response = await drive.files.list(listOptions);\n const res = response.data as driveResponse;\n const files = Array.isArray(res?.files) ? res.files : [];\n\n const parentIds = new Set<string>();\n for (const f of files) {\n if (f?.parents && f.parents.length > 0) {\n for (const parentId of f.parents) {\n if (parentId && parentId !== 'root') {\n parentIds.add(parentId);\n }\n }\n }\n }\n\n const parentNameMap = new Map<string, string>();\n if (parentIds.size > 0) {\n logger.info('Fetching parent names', { count: parentIds.size });\n const parentFetches = Array.from(parentIds).map(async (parentId) => {\n try {\n const parentRes = await drive.files.get({\n fileId: parentId,\n fields: 'id,name',\n });\n const parentName = (parentRes.data.name as string | undefined) || parentId;\n parentNameMap.set(parentId, parentName);\n } catch (e) {\n logger.info('Failed to fetch parent name', { parentId, error: e });\n parentNameMap.set(parentId, parentId); // Fallback to ID\n }\n });\n await Promise.all(parentFetches);\n }\n\n const items: DriveFile[] = files.map((f: driveFile) => {\n const id = f?.id ? String(f.id) : 'unknown';\n const name = f?.name || id;\n const result: DriveFile = { id, name };\n\n // Only include properties that have actual values\n if (f?.mimeType) result.mimeType = f.mimeType;\n if (f?.webViewLink) result.webViewLink = f.webViewLink;\n if (f?.modifiedTime) result.modifiedTime = f.modifiedTime;\n\n if (f?.parents && f.parents.length > 0) {\n result.parents = f.parents.map((parentId) => {\n if (parentId === 'root') {\n return { id: 'root', name: 'My Drive' };\n }\n const parentName = parentNameMap.get(parentId) || parentId;\n return { id: parentId, name: parentName };\n });\n }\n\n if (f?.shared != null) result.shared = f.shared;\n if (f?.starred != null) result.starred = f.starred;\n\n if (f?.owners && f.owners.length > 0) {\n result.owners = f.owners.map((o) => {\n const owner: NonNullable<DriveFile['owners']>[number] = {};\n if (o?.displayName) owner.displayName = o.displayName;\n if (o?.emailAddress) owner.emailAddress = o.emailAddress;\n if (o?.kind) owner.kind = o.kind;\n if (o?.me != null) owner.me = o.me;\n if (o?.permissionId) owner.permissionId = o.permissionId;\n if (o?.photoLink) owner.photoLink = o.photoLink;\n return owner;\n });\n }\n\n return result;\n });\n\n const filteredItems = items.map((item) => filterFields(item, requestedFields));\n\n logger.info('drive.files-search returning', {\n query,\n pageSize,\n resultCount: filteredItems.length,\n fields: fields || 'all',\n });\n\n const nextPageToken = res.nextPageToken && res.nextPageToken.trim().length > 0 ? res.nextPageToken : undefined;\n\n // Build result based on shape\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n ...toColumnarFormat(filteredItems, requestedFields, DRIVE_FILE_FIELDS),\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: filteredItems,\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\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('drive.files-search error', { error: message });\n\n // Check if this is a Drive API validation error (invalid query, invalid pageToken, etc.)\n // These should return empty results rather than throw\n const isDriveValidationError = message.includes('Invalid Value') || message.includes('Invalid value') || message.includes('File not found') || message.includes('Bad Request');\n\n if (isDriveValidationError) {\n // Return empty result set for validation errors\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n columns: [],\n rows: [],\n count: 0,\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: [],\n count: 0,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n }\n\n // Throw McpError for other errors\n throw new McpError(ErrorCode.InternalError, `Error searching files: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'files-search' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","query","DriveQuerySchema","describe","fields","createFieldsSchema","availableFields","DRIVE_FILE_FIELDS","fieldDescriptions","DRIVE_FILE_FIELD_DESCRIPTIONS","commonPatterns","DRIVE_FILE_COMMON_PATTERNS","resourceName","createPaginationSchema","defaultPageSize","maxPageSize","provider","shape","createShapeSchema","successObjectsBranchSchema","type","literal","items","array","DriveFileSchema","count","number","nextPageToken","string","optional","successArraysBranchSchema","columns","rows","unknown","outputSchema","union","config","title","description","result","handler","extra","pageSize","pageToken","logger","requestedFields","validPageSize","drive","qStr","q","listOptions","response","res","files","parentIds","f","parentId","parentNameMap","parentFetches","filteredItems","error","message","isDriveValidationError","parseFields","Math","max","min","floor","info","undefined","google","version","auth","authContext","rawDriveQuery","toDriveQuery","orderBy","trim","length","list","data","Array","isArray","Set","parents","add","Map","size","from","map","parentRes","parentName","e","get","fileId","name","set","Promise","all","id","String","mimeType","webViewLink","modifiedTime","shared","starred","owners","o","owner","displayName","emailAddress","kind","me","permissionId","photoLink","item","filterFields","resultCount","toColumnarFormat","content","text","JSON","stringify","structuredContent","Error","includes","McpError","ErrorCode","InternalError","stack"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/mcp/tools/files-search.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { createFieldsSchema, createPaginationSchema, createShapeSchema, filterFields, parseFields, toColumnarFormat } from '@mcp-z/server';\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { type drive_v3, google } from 'googleapis';\nimport { z } from 'zod';\nimport { toDriveQuery } from '../../lib/query-builder.ts';\nimport { DRIVE_FILE_COMMON_PATTERNS, DRIVE_FILE_FIELD_DESCRIPTIONS, DRIVE_FILE_FIELDS, type DriveFile, DriveFileSchema, DriveQuerySchema } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n query: DriveQuerySchema.describe('Drive query object with structured search fields. See DriveQuerySchema for detailed query syntax and examples.'),\n fields: createFieldsSchema({\n availableFields: DRIVE_FILE_FIELDS,\n fieldDescriptions: DRIVE_FILE_FIELD_DESCRIPTIONS,\n commonPatterns: DRIVE_FILE_COMMON_PATTERNS,\n resourceName: 'Drive file',\n }),\n ...createPaginationSchema({\n defaultPageSize: 50,\n maxPageSize: 1000,\n provider: 'drive',\n }).shape,\n shape: createShapeSchema(),\n});\n\n// Success branch schemas for different shapes\nconst successObjectsBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('objects'),\n items: z.array(DriveFileSchema).describe('Matching Drive files'),\n count: z.number().describe('Number of files in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\nconst successArraysBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('arrays'),\n columns: z.array(z.string()).describe('Column names in canonical order'),\n rows: z.array(z.array(z.unknown())).describe('Row data matching column order'),\n count: z.number().describe('Number of files in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\n// Output schema with auth_required support\n// Using z.union instead of discriminatedUnion since we have two success branches with different shapes\nconst outputSchema = z.union([successObjectsBranchSchema, successArraysBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Search Drive Files',\n description: 'Search Google Drive files with flexible field selection for optimal performance.',\n inputSchema: 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// Type for the raw Google Drive API response\ntype driveFile = drive_v3.Schema$File;\n\ntype driveResponse = drive_v3.Schema$FileList;\n\nasync function handler({ query, pageSize = 50, pageToken, fields, shape = 'arrays' }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n\n const requestedFields = parseFields(fields, DRIVE_FILE_FIELDS);\n\n // Validate and clamp pageSize to Google Drive API limits (1-1000)\n const validPageSize = Math.max(1, Math.min(1000, Math.floor(pageSize || 50)));\n\n logger.info('drive.files-search called', {\n query,\n pageSize: validPageSize,\n pageToken: pageToken ? '[provided]' : undefined,\n fields: fields || 'all',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n // Handle query parameter\n let qStr: string;\n if (typeof query === 'string') {\n // String query - treat as raw Drive query\n qStr = `(${query}) and trashed = false`;\n } else if (query && typeof query === 'object' && 'rawDriveQuery' in query && query.rawDriveQuery) {\n // Object with rawDriveQuery field - use it directly\n qStr = `(${query.rawDriveQuery}) and trashed = false`;\n } else {\n // Structured query object - convert to Drive query string\n const { q } = toDriveQuery(query);\n qStr = q ? `(${q}) and trashed = false` : 'trashed = false';\n }\n\n const listOptions: {\n q: string;\n pageSize: number;\n fields: string;\n orderBy: string;\n pageToken?: string;\n } = {\n q: qStr,\n pageSize: validPageSize,\n fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',\n orderBy: 'modifiedTime desc',\n };\n if (pageToken && pageToken.trim().length > 0) {\n listOptions.pageToken = pageToken;\n }\n\n const response = await drive.files.list(listOptions);\n const res = response.data as driveResponse;\n const files = Array.isArray(res?.files) ? res.files : [];\n\n const parentIds = new Set<string>();\n for (const f of files) {\n if (f?.parents && f.parents.length > 0) {\n for (const parentId of f.parents) {\n if (parentId && parentId !== 'root') {\n parentIds.add(parentId);\n }\n }\n }\n }\n\n const parentNameMap = new Map<string, string>();\n if (parentIds.size > 0) {\n logger.info('Fetching parent names', { count: parentIds.size });\n const parentFetches = Array.from(parentIds).map(async (parentId) => {\n try {\n const parentRes = await drive.files.get({\n fileId: parentId,\n fields: 'id,name',\n });\n const parentName = (parentRes.data.name as string | undefined) || parentId;\n parentNameMap.set(parentId, parentName);\n } catch (e) {\n logger.info('Failed to fetch parent name', { parentId, error: e });\n parentNameMap.set(parentId, parentId); // Fallback to ID\n }\n });\n await Promise.all(parentFetches);\n }\n\n const items: DriveFile[] = files.map((f: driveFile) => {\n const id = f?.id ? String(f.id) : 'unknown';\n const name = f?.name || id;\n const result: DriveFile = { id, name };\n\n // Only include properties that have actual values\n if (f?.mimeType) result.mimeType = f.mimeType;\n if (f?.webViewLink) result.webViewLink = f.webViewLink;\n if (f?.modifiedTime) result.modifiedTime = f.modifiedTime;\n\n if (f?.parents && f.parents.length > 0) {\n result.parents = f.parents.map((parentId) => {\n if (parentId === 'root') {\n return { id: 'root', name: 'My Drive' };\n }\n const parentName = parentNameMap.get(parentId) || parentId;\n return { id: parentId, name: parentName };\n });\n }\n\n if (f?.shared != null) result.shared = f.shared;\n if (f?.starred != null) result.starred = f.starred;\n\n if (f?.owners && f.owners.length > 0) {\n result.owners = f.owners.map((o) => {\n const owner: NonNullable<DriveFile['owners']>[number] = {};\n if (o?.displayName) owner.displayName = o.displayName;\n if (o?.emailAddress) owner.emailAddress = o.emailAddress;\n if (o?.kind) owner.kind = o.kind;\n if (o?.me != null) owner.me = o.me;\n if (o?.permissionId) owner.permissionId = o.permissionId;\n if (o?.photoLink) owner.photoLink = o.photoLink;\n return owner;\n });\n }\n\n return result;\n });\n\n const filteredItems = items.map((item) => filterFields(item, requestedFields));\n\n logger.info('drive.files-search returning', {\n query,\n pageSize,\n resultCount: filteredItems.length,\n fields: fields || 'all',\n });\n\n const nextPageToken = res.nextPageToken && res.nextPageToken.trim().length > 0 ? res.nextPageToken : undefined;\n\n // Build result based on shape\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n ...toColumnarFormat(filteredItems, requestedFields, DRIVE_FILE_FIELDS),\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: filteredItems,\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\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('drive.files-search error', { error: message });\n\n // Check if this is a Drive API validation error (invalid query, invalid pageToken, etc.)\n // These should return empty results rather than throw\n const isDriveValidationError = message.includes('Invalid Value') || message.includes('Invalid value') || message.includes('File not found') || message.includes('Bad Request');\n\n if (isDriveValidationError) {\n // Return empty result set for validation errors\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n columns: [],\n rows: [],\n count: 0,\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: [],\n count: 0,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n }\n\n // Throw McpError for other errors\n throw new McpError(ErrorCode.InternalError, `Error searching files: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'files-search' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","query","DriveQuerySchema","describe","fields","createFieldsSchema","availableFields","DRIVE_FILE_FIELDS","fieldDescriptions","DRIVE_FILE_FIELD_DESCRIPTIONS","commonPatterns","DRIVE_FILE_COMMON_PATTERNS","resourceName","createPaginationSchema","defaultPageSize","maxPageSize","provider","shape","createShapeSchema","successObjectsBranchSchema","type","literal","items","array","DriveFileSchema","count","number","nextPageToken","string","optional","successArraysBranchSchema","columns","rows","unknown","outputSchema","union","config","title","description","result","handler","extra","pageSize","pageToken","logger","requestedFields","validPageSize","drive","qStr","q","listOptions","response","res","files","parentIds","f","parentId","parentNameMap","parentFetches","filteredItems","error","message","isDriveValidationError","parseFields","Math","max","min","floor","info","undefined","google","version","auth","authContext","rawDriveQuery","toDriveQuery","orderBy","trim","length","list","data","Array","isArray","Set","parents","add","Map","size","from","map","parentRes","parentName","e","get","fileId","name","set","Promise","all","id","String","mimeType","webViewLink","modifiedTime","shared","starred","owners","o","owner","displayName","emailAddress","kind","me","permissionId","photoLink","item","filterFields","resultCount","toColumnarFormat","content","text","JSON","stringify","structuredContent","Error","includes","McpError","ErrorCode","InternalError","stack"],"mappings":"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"}
@@ -13,7 +13,7 @@ var _server = require("@mcp-z/server");
13
13
  var _types = require("@modelcontextprotocol/sdk/types.js");
14
14
  var _googleapis = require("googleapis");
15
15
  var _zod = require("zod");
16
- var _index = require("../../schemas/index.js");
16
+ var _indexts = require("../../schemas/index.js");
17
17
  function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
18
18
  try {
19
19
  var info = gen[key](arg);
@@ -205,9 +205,9 @@ var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
205
205
  var inputSchema = _zod.z.object(_object_spread_props(_object_spread({
206
206
  folderId: _zod.z.string().min(1).describe('Folder ID to list contents (use "root" for Drive root)'),
207
207
  fields: (0, _server.createFieldsSchema)({
208
- availableFields: _index.DRIVE_FILE_FIELDS,
209
- fieldDescriptions: _index.DRIVE_FILE_FIELD_DESCRIPTIONS,
210
- commonPatterns: _index.DRIVE_FILE_COMMON_PATTERNS,
208
+ availableFields: _indexts.DRIVE_FILE_FIELDS,
209
+ fieldDescriptions: _indexts.DRIVE_FILE_FIELD_DESCRIPTIONS,
210
+ commonPatterns: _indexts.DRIVE_FILE_COMMON_PATTERNS,
211
211
  resourceName: 'Drive item'
212
212
  })
213
213
  }, (0, _server.createPaginationSchema)({
@@ -221,7 +221,7 @@ var inputSchema = _zod.z.object(_object_spread_props(_object_spread({
221
221
  var successObjectsBranchSchema = _zod.z.object({
222
222
  type: _zod.z.literal('success'),
223
223
  shape: _zod.z.literal('objects'),
224
- items: _zod.z.array(_index.DriveFileSchema).describe('Files and folders in the specified folder'),
224
+ items: _zod.z.array(_indexts.DriveFileSchema).describe('Files and folders in the specified folder'),
225
225
  count: _zod.z.number().describe('Number of items in this page'),
226
226
  folderId: _zod.z.string().describe('ID of the folder that was listed'),
227
227
  nextPageToken: _zod.z.string().optional().describe('Token for fetching next page of results')
@@ -258,7 +258,7 @@ function handler(_0, _1) {
258
258
  case 0:
259
259
  folderId = param.folderId, _param_pageSize = param.pageSize, pageSize = _param_pageSize === void 0 ? 50 : _param_pageSize, pageToken = param.pageToken, fields = param.fields, _param_shape = param.shape, shape = _param_shape === void 0 ? 'arrays' : _param_shape;
260
260
  logger = extra.logger;
261
- requestedFields = (0, _server.parseFields)(fields, _index.DRIVE_FILE_FIELDS);
261
+ requestedFields = (0, _server.parseFields)(fields, _indexts.DRIVE_FILE_FIELDS);
262
262
  logger.info('drive.folder.contents called', {
263
263
  folderId: folderId,
264
264
  pageSize: pageSize,
@@ -457,7 +457,7 @@ function handler(_0, _1) {
457
457
  result = shape === 'arrays' ? _object_spread(_object_spread_props(_object_spread({
458
458
  type: 'success',
459
459
  shape: 'arrays'
460
- }, (0, _server.toColumnarFormat)(filteredItems, requestedFields, _index.DRIVE_FILE_FIELDS)), {
460
+ }, (0, _server.toColumnarFormat)(filteredItems, requestedFields, _indexts.DRIVE_FILE_FIELDS)), {
461
461
  count: filteredItems.length,
462
462
  folderId: folderId
463
463
  }), nextPageToken && {
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-drive/src/mcp/tools/folder-contents.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { createFieldsSchema, createPaginationSchema, createShapeSchema, filterFields, parseFields, toColumnarFormat } from '@mcp-z/server';\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { DRIVE_FILE_COMMON_PATTERNS, DRIVE_FILE_FIELD_DESCRIPTIONS, DRIVE_FILE_FIELDS, type DriveFile, DriveFileSchema } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n folderId: z.string().min(1).describe('Folder ID to list contents (use \"root\" for Drive root)'),\n fields: createFieldsSchema({\n availableFields: DRIVE_FILE_FIELDS,\n fieldDescriptions: DRIVE_FILE_FIELD_DESCRIPTIONS,\n commonPatterns: DRIVE_FILE_COMMON_PATTERNS,\n resourceName: 'Drive item',\n }),\n ...createPaginationSchema({\n defaultPageSize: 50,\n maxPageSize: 1000,\n provider: 'drive',\n }).shape,\n shape: createShapeSchema(),\n});\n\n// Success branch schemas for different shapes\nconst successObjectsBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('objects'),\n items: z.array(DriveFileSchema).describe('Files and folders in the specified folder'),\n count: z.number().describe('Number of items in this page'),\n folderId: z.string().describe('ID of the folder that was listed'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\nconst successArraysBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('arrays'),\n columns: z.array(z.string()).describe('Column names in canonical order'),\n rows: z.array(z.array(z.unknown())).describe('Row data matching column order'),\n count: z.number().describe('Number of items in this page'),\n folderId: z.string().describe('ID of the folder that was listed'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\n// Output schema with auth_required support\n// Using z.union instead of discriminatedUnion since we have two success branches with different shapes\nconst outputSchema = z.union([successObjectsBranchSchema, successArraysBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'List Folder Contents',\n description: 'List files and folders in a specific folder with field selection.',\n inputSchema: 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// Type for the raw Google Drive API response\ntype DriveItem = {\n id?: string;\n name?: string;\n mimeType?: string;\n webViewLink?: string;\n modifiedTime?: string;\n parents?: string[];\n shared?: boolean;\n starred?: boolean;\n owners?: Array<{\n displayName?: string;\n emailAddress?: string;\n kind?: string;\n me?: boolean;\n permissionId?: string;\n photoLink?: string;\n }>;\n};\n\ntype DriveResponse = {\n files?: DriveItem[];\n nextPageToken?: string;\n};\n\nasync function handler({ folderId, pageSize = 50, pageToken, fields, shape = 'arrays' }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n\n const requestedFields = parseFields(fields, DRIVE_FILE_FIELDS);\n\n logger.info('drive.folder.contents called', {\n folderId,\n pageSize,\n pageToken: pageToken ? '[provided]' : undefined,\n fields: fields || 'all',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const qStr = `'${folderId}' in parents and trashed = false`;\n\n const listOptions: {\n q: string;\n pageSize: number;\n fields: string;\n orderBy: string;\n pageToken?: string;\n } = {\n q: qStr,\n pageSize: Math.min(1000, pageSize),\n fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',\n orderBy: 'folder,name', // Folders first, then by name\n };\n if (pageToken && pageToken.trim().length > 0) {\n listOptions.pageToken = pageToken;\n }\n\n const response = await drive.files.list(listOptions);\n\n const res = response.data as DriveResponse;\n const items = Array.isArray(res?.files) ? res.files : [];\n\n const parentIds = new Set<string>();\n for (const f of items) {\n if (f?.parents && f.parents.length > 0) {\n for (const parentId of f.parents) {\n if (parentId && parentId !== 'root') {\n parentIds.add(parentId);\n }\n }\n }\n }\n\n const parentNameMap = new Map<string, string>();\n if (parentIds.size > 0) {\n logger.info('Fetching parent names', { count: parentIds.size });\n const parentFetches = Array.from(parentIds).map(async (parentId) => {\n try {\n const parentRes = await drive.files.get({\n fileId: parentId,\n fields: 'id,name',\n });\n const parentName = (parentRes.data.name as string | undefined) || parentId;\n parentNameMap.set(parentId, parentName);\n } catch (e) {\n logger.info('Failed to fetch parent name', { parentId, error: e });\n parentNameMap.set(parentId, parentId); // Fallback to ID\n }\n });\n await Promise.all(parentFetches);\n }\n\n const driveFiles: DriveFile[] = items.map((f: DriveItem) => {\n const id = f?.id ? String(f.id) : 'unknown';\n const name = f?.name || id;\n const result: DriveFile = { id, name };\n\n // Only include properties that have actual values\n if (f?.mimeType) result.mimeType = f.mimeType;\n if (f?.webViewLink) result.webViewLink = f.webViewLink;\n if (f?.modifiedTime) result.modifiedTime = f.modifiedTime;\n\n // Build parent objects with names\n if (f?.parents && f.parents.length > 0) {\n result.parents = f.parents.map((parentId) => {\n if (parentId === 'root') {\n return { id: 'root', name: 'My Drive' };\n }\n const parentName = parentNameMap.get(parentId) || parentId;\n return { id: parentId, name: parentName };\n });\n }\n\n if (f?.shared !== undefined) result.shared = f.shared;\n if (f?.starred !== undefined) result.starred = f.starred;\n\n if (f?.owners && f.owners.length > 0) {\n result.owners = f.owners.map((o) => {\n const owner: NonNullable<DriveFile['owners']>[number] = {};\n if (o?.displayName) owner.displayName = o.displayName;\n if (o?.emailAddress) owner.emailAddress = o.emailAddress;\n if (o?.kind) owner.kind = o.kind;\n if (o?.me !== undefined) owner.me = o.me;\n if (o?.permissionId) owner.permissionId = o.permissionId;\n if (o?.photoLink) owner.photoLink = o.photoLink;\n return owner;\n });\n }\n\n return result;\n });\n\n const filteredItems = driveFiles.map((item) => filterFields(item, requestedFields));\n\n logger.info('drive.folder.contents returning', {\n folderId,\n resultCount: filteredItems.length,\n fields: fields || 'all',\n });\n\n const nextPageToken = res.nextPageToken && res.nextPageToken.trim().length > 0 ? res.nextPageToken : undefined;\n\n // Build result based on shape\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n ...toColumnarFormat(filteredItems, requestedFields, DRIVE_FILE_FIELDS),\n count: filteredItems.length,\n folderId,\n ...(nextPageToken && { nextPageToken }),\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: filteredItems,\n count: filteredItems.length,\n folderId,\n ...(nextPageToken && { nextPageToken }),\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('drive.folder.contents error', { error: message });\n\n // Throw McpError\n throw new McpError(ErrorCode.InternalError, `Error listing folder contents: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-contents' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","folderId","string","min","describe","fields","createFieldsSchema","availableFields","DRIVE_FILE_FIELDS","fieldDescriptions","DRIVE_FILE_FIELD_DESCRIPTIONS","commonPatterns","DRIVE_FILE_COMMON_PATTERNS","resourceName","createPaginationSchema","defaultPageSize","maxPageSize","provider","shape","createShapeSchema","successObjectsBranchSchema","type","literal","items","array","DriveFileSchema","count","number","nextPageToken","optional","successArraysBranchSchema","columns","rows","unknown","outputSchema","union","config","title","description","result","handler","extra","pageSize","pageToken","logger","requestedFields","drive","qStr","listOptions","response","res","parentIds","f","parentId","parentNameMap","parentFetches","driveFiles","filteredItems","error","message","parseFields","info","undefined","google","version","auth","authContext","q","Math","orderBy","trim","length","files","list","data","Array","isArray","Set","parents","add","Map","size","from","map","parentRes","parentName","e","get","fileId","name","set","Promise","all","id","String","mimeType","webViewLink","modifiedTime","shared","starred","owners","o","owner","displayName","emailAddress","kind","me","permissionId","photoLink","item","filterFields","resultCount","toColumnarFormat","content","text","JSON","stringify","structuredContent","Error","McpError","ErrorCode","InternalError","stack"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/mcp/tools/folder-contents.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { createFieldsSchema, createPaginationSchema, createShapeSchema, filterFields, parseFields, toColumnarFormat } from '@mcp-z/server';\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { DRIVE_FILE_COMMON_PATTERNS, DRIVE_FILE_FIELD_DESCRIPTIONS, DRIVE_FILE_FIELDS, type DriveFile, DriveFileSchema } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n folderId: z.string().min(1).describe('Folder ID to list contents (use \"root\" for Drive root)'),\n fields: createFieldsSchema({\n availableFields: DRIVE_FILE_FIELDS,\n fieldDescriptions: DRIVE_FILE_FIELD_DESCRIPTIONS,\n commonPatterns: DRIVE_FILE_COMMON_PATTERNS,\n resourceName: 'Drive item',\n }),\n ...createPaginationSchema({\n defaultPageSize: 50,\n maxPageSize: 1000,\n provider: 'drive',\n }).shape,\n shape: createShapeSchema(),\n});\n\n// Success branch schemas for different shapes\nconst successObjectsBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('objects'),\n items: z.array(DriveFileSchema).describe('Files and folders in the specified folder'),\n count: z.number().describe('Number of items in this page'),\n folderId: z.string().describe('ID of the folder that was listed'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\nconst successArraysBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('arrays'),\n columns: z.array(z.string()).describe('Column names in canonical order'),\n rows: z.array(z.array(z.unknown())).describe('Row data matching column order'),\n count: z.number().describe('Number of items in this page'),\n folderId: z.string().describe('ID of the folder that was listed'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\n// Output schema with auth_required support\n// Using z.union instead of discriminatedUnion since we have two success branches with different shapes\nconst outputSchema = z.union([successObjectsBranchSchema, successArraysBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'List Folder Contents',\n description: 'List files and folders in a specific folder with field selection.',\n inputSchema: 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// Type for the raw Google Drive API response\ntype DriveItem = {\n id?: string;\n name?: string;\n mimeType?: string;\n webViewLink?: string;\n modifiedTime?: string;\n parents?: string[];\n shared?: boolean;\n starred?: boolean;\n owners?: Array<{\n displayName?: string;\n emailAddress?: string;\n kind?: string;\n me?: boolean;\n permissionId?: string;\n photoLink?: string;\n }>;\n};\n\ntype DriveResponse = {\n files?: DriveItem[];\n nextPageToken?: string;\n};\n\nasync function handler({ folderId, pageSize = 50, pageToken, fields, shape = 'arrays' }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n\n const requestedFields = parseFields(fields, DRIVE_FILE_FIELDS);\n\n logger.info('drive.folder.contents called', {\n folderId,\n pageSize,\n pageToken: pageToken ? '[provided]' : undefined,\n fields: fields || 'all',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const qStr = `'${folderId}' in parents and trashed = false`;\n\n const listOptions: {\n q: string;\n pageSize: number;\n fields: string;\n orderBy: string;\n pageToken?: string;\n } = {\n q: qStr,\n pageSize: Math.min(1000, pageSize),\n fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',\n orderBy: 'folder,name', // Folders first, then by name\n };\n if (pageToken && pageToken.trim().length > 0) {\n listOptions.pageToken = pageToken;\n }\n\n const response = await drive.files.list(listOptions);\n\n const res = response.data as DriveResponse;\n const items = Array.isArray(res?.files) ? res.files : [];\n\n const parentIds = new Set<string>();\n for (const f of items) {\n if (f?.parents && f.parents.length > 0) {\n for (const parentId of f.parents) {\n if (parentId && parentId !== 'root') {\n parentIds.add(parentId);\n }\n }\n }\n }\n\n const parentNameMap = new Map<string, string>();\n if (parentIds.size > 0) {\n logger.info('Fetching parent names', { count: parentIds.size });\n const parentFetches = Array.from(parentIds).map(async (parentId) => {\n try {\n const parentRes = await drive.files.get({\n fileId: parentId,\n fields: 'id,name',\n });\n const parentName = (parentRes.data.name as string | undefined) || parentId;\n parentNameMap.set(parentId, parentName);\n } catch (e) {\n logger.info('Failed to fetch parent name', { parentId, error: e });\n parentNameMap.set(parentId, parentId); // Fallback to ID\n }\n });\n await Promise.all(parentFetches);\n }\n\n const driveFiles: DriveFile[] = items.map((f: DriveItem) => {\n const id = f?.id ? String(f.id) : 'unknown';\n const name = f?.name || id;\n const result: DriveFile = { id, name };\n\n // Only include properties that have actual values\n if (f?.mimeType) result.mimeType = f.mimeType;\n if (f?.webViewLink) result.webViewLink = f.webViewLink;\n if (f?.modifiedTime) result.modifiedTime = f.modifiedTime;\n\n // Build parent objects with names\n if (f?.parents && f.parents.length > 0) {\n result.parents = f.parents.map((parentId) => {\n if (parentId === 'root') {\n return { id: 'root', name: 'My Drive' };\n }\n const parentName = parentNameMap.get(parentId) || parentId;\n return { id: parentId, name: parentName };\n });\n }\n\n if (f?.shared !== undefined) result.shared = f.shared;\n if (f?.starred !== undefined) result.starred = f.starred;\n\n if (f?.owners && f.owners.length > 0) {\n result.owners = f.owners.map((o) => {\n const owner: NonNullable<DriveFile['owners']>[number] = {};\n if (o?.displayName) owner.displayName = o.displayName;\n if (o?.emailAddress) owner.emailAddress = o.emailAddress;\n if (o?.kind) owner.kind = o.kind;\n if (o?.me !== undefined) owner.me = o.me;\n if (o?.permissionId) owner.permissionId = o.permissionId;\n if (o?.photoLink) owner.photoLink = o.photoLink;\n return owner;\n });\n }\n\n return result;\n });\n\n const filteredItems = driveFiles.map((item) => filterFields(item, requestedFields));\n\n logger.info('drive.folder.contents returning', {\n folderId,\n resultCount: filteredItems.length,\n fields: fields || 'all',\n });\n\n const nextPageToken = res.nextPageToken && res.nextPageToken.trim().length > 0 ? res.nextPageToken : undefined;\n\n // Build result based on shape\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n ...toColumnarFormat(filteredItems, requestedFields, DRIVE_FILE_FIELDS),\n count: filteredItems.length,\n folderId,\n ...(nextPageToken && { nextPageToken }),\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: filteredItems,\n count: filteredItems.length,\n folderId,\n ...(nextPageToken && { nextPageToken }),\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('drive.folder.contents error', { error: message });\n\n // Throw McpError\n throw new McpError(ErrorCode.InternalError, `Error listing folder contents: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-contents' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","folderId","string","min","describe","fields","createFieldsSchema","availableFields","DRIVE_FILE_FIELDS","fieldDescriptions","DRIVE_FILE_FIELD_DESCRIPTIONS","commonPatterns","DRIVE_FILE_COMMON_PATTERNS","resourceName","createPaginationSchema","defaultPageSize","maxPageSize","provider","shape","createShapeSchema","successObjectsBranchSchema","type","literal","items","array","DriveFileSchema","count","number","nextPageToken","optional","successArraysBranchSchema","columns","rows","unknown","outputSchema","union","config","title","description","result","handler","extra","pageSize","pageToken","logger","requestedFields","drive","qStr","listOptions","response","res","parentIds","f","parentId","parentNameMap","parentFetches","driveFiles","filteredItems","error","message","parseFields","info","undefined","google","version","auth","authContext","q","Math","orderBy","trim","length","files","list","data","Array","isArray","Set","parents","add","Map","size","from","map","parentRes","parentName","e","get","fileId","name","set","Promise","all","id","String","mimeType","webViewLink","modifiedTime","shared","starred","owners","o","owner","displayName","emailAddress","kind","me","permissionId","photoLink","item","filterFields","resultCount","toColumnarFormat","content","text","JSON","stringify","structuredContent","Error","McpError","ErrorCode","InternalError","stack"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-drive/src/mcp/tools/folder-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 { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\n\nconst inputSchema = z.object({\n name: z.string().trim().min(1).describe('Name for the new folder'),\n parentId: z.string().optional().describe('Parent folder ID (omit to create in My Drive root)'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the folder creation operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single folder)'),\n itemsChanged: z.number().describe('Successfully created folders (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: z.string().describe('ID of the created folder'),\n name: z.string().describe('Name of the created folder'),\n webViewLink: z.string().describe('URL to view the folder in Drive'),\n parentId: z.string().optional().describe('ID of the parent folder'),\n parentName: z.string().optional().describe('Name of the parent folder'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Create Folder',\n description: 'Create a new folder in Google Drive. Returns folder ID for use in other operations.',\n inputSchema,\n outputSchema: z.object({\n result: outputSchema,\n }),\n} as const;\n\n// Export types for strong typing in tests\nexport type Input = z.infer<typeof inputSchema>;\nexport type Output = z.infer<typeof outputSchema>;\n\nasync function handler({ name: folderName, parentId }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('drive.folder.create called', {\n name: folderName,\n parentId: parentId || 'root',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n // Folder MIME type constant (consistent with folder-search.ts)\n const folderMimeType = 'application/vnd.google-apps.folder';\n\n // Create the folder\n const response = await drive.files.create({\n requestBody: {\n name: folderName,\n mimeType: folderMimeType,\n parents: parentId ? [parentId] : null,\n },\n fields: 'id,name,webViewLink,parents',\n });\n\n const res = response.data;\n const id = res.id ?? '';\n const name = res.name ?? folderName;\n const webViewLink = res.webViewLink ?? '';\n const parents = (res.parents as string[] | undefined) || [];\n\n // Fetch parent name if parentId was provided\n let parentName: string | undefined;\n let actualParentId: string | undefined;\n\n if (parents.length > 0) {\n actualParentId = parents[0];\n\n if (actualParentId === 'root') {\n parentName = 'My Drive';\n } else if (actualParentId) {\n try {\n const parentResponse = await drive.files.get({\n fileId: actualParentId,\n fields: 'name',\n });\n parentName = (parentResponse.data.name as string | undefined) || actualParentId;\n } catch (e) {\n logger.info('Failed to fetch parent name', {\n parentId: actualParentId,\n error: e,\n });\n parentName = actualParentId; // Fallback to ID\n }\n }\n }\n\n const locationSummary = parentName ? ` in \"${parentName}\"` : ' in My Drive';\n\n logger.info('drive.folder.create success', {\n id,\n name,\n parentId: actualParentId,\n });\n\n // Build result object with operation metadata\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Created folder \"${name}\"${locationSummary}`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n name,\n webViewLink,\n ...(actualParentId && { parentId: actualParentId }),\n ...(parentName && { parentName }),\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('drive.folder.create error', { error: message });\n\n // Throw McpError for proper MCP error handling\n throw new McpError(ErrorCode.InternalError, `Error creating folder: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-create' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","name","string","trim","min","describe","parentId","optional","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","id","webViewLink","parentName","outputSchema","discriminatedUnion","config","title","description","result","handler","extra","folderName","logger","res","drive","folderMimeType","response","parents","actualParentId","parentResponse","e","locationSummary","error","message","info","google","version","auth","authContext","files","create","requestBody","mimeType","fields","data","length","get","fileId","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/mcp/tools/folder-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 { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\n\nconst inputSchema = z.object({\n name: z.string().trim().min(1).describe('Name for the new folder'),\n parentId: z.string().optional().describe('Parent folder ID (omit to create in My Drive root)'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the folder creation operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single folder)'),\n itemsChanged: z.number().describe('Successfully created folders (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: z.string().describe('ID of the created folder'),\n name: z.string().describe('Name of the created folder'),\n webViewLink: z.string().describe('URL to view the folder in Drive'),\n parentId: z.string().optional().describe('ID of the parent folder'),\n parentName: z.string().optional().describe('Name of the parent folder'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Create Folder',\n description: 'Create a new folder in Google Drive. Returns folder ID for use in other operations.',\n inputSchema,\n outputSchema: z.object({\n result: outputSchema,\n }),\n} as const;\n\n// Export types for strong typing in tests\nexport type Input = z.infer<typeof inputSchema>;\nexport type Output = z.infer<typeof outputSchema>;\n\nasync function handler({ name: folderName, parentId }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('drive.folder.create called', {\n name: folderName,\n parentId: parentId || 'root',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n // Folder MIME type constant (consistent with folder-search.ts)\n const folderMimeType = 'application/vnd.google-apps.folder';\n\n // Create the folder\n const response = await drive.files.create({\n requestBody: {\n name: folderName,\n mimeType: folderMimeType,\n parents: parentId ? [parentId] : null,\n },\n fields: 'id,name,webViewLink,parents',\n });\n\n const res = response.data;\n const id = res.id ?? '';\n const name = res.name ?? folderName;\n const webViewLink = res.webViewLink ?? '';\n const parents = (res.parents as string[] | undefined) || [];\n\n // Fetch parent name if parentId was provided\n let parentName: string | undefined;\n let actualParentId: string | undefined;\n\n if (parents.length > 0) {\n actualParentId = parents[0];\n\n if (actualParentId === 'root') {\n parentName = 'My Drive';\n } else if (actualParentId) {\n try {\n const parentResponse = await drive.files.get({\n fileId: actualParentId,\n fields: 'name',\n });\n parentName = (parentResponse.data.name as string | undefined) || actualParentId;\n } catch (e) {\n logger.info('Failed to fetch parent name', {\n parentId: actualParentId,\n error: e,\n });\n parentName = actualParentId; // Fallback to ID\n }\n }\n }\n\n const locationSummary = parentName ? ` in \"${parentName}\"` : ' in My Drive';\n\n logger.info('drive.folder.create success', {\n id,\n name,\n parentId: actualParentId,\n });\n\n // Build result object with operation metadata\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Created folder \"${name}\"${locationSummary}`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n name,\n webViewLink,\n ...(actualParentId && { parentId: actualParentId }),\n ...(parentName && { parentName }),\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('drive.folder.create error', { error: message });\n\n // Throw McpError for proper MCP error handling\n throw new McpError(ErrorCode.InternalError, `Error creating folder: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-create' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","name","string","trim","min","describe","parentId","optional","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","id","webViewLink","parentName","outputSchema","discriminatedUnion","config","title","description","result","handler","extra","folderName","logger","res","drive","folderMimeType","response","parents","actualParentId","parentResponse","e","locationSummary","error","message","info","google","version","auth","authContext","files","create","requestBody","mimeType","fields","data","length","get","fileId","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-drive/src/mcp/tools/folder-path.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport type { drive_v3 } from 'googleapis';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport type { Logger } from '../../types.js';\n\nconst inputSchema = z.object({\n folderId: z.string().min(1).describe('Folder ID to get path for (or \"root\")'),\n});\n\n// Success branch schema - uses items: for consistency with standard vocabulary\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n path: z.string().describe('Full path from root (e.g., /Work/Projects/2024)'),\n items: z\n .array(\n z.object({\n id: z.string().describe('Folder ID'),\n name: z.string().describe('Folder name'),\n })\n )\n .describe('Path items from root to target folder'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Get Folder Path',\n description: 'Get full path from folder to root. Returns human-readable path and items with IDs.',\n inputSchema: 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/**\n * Resolves the full path for a folder by walking up the parent chain.\n * Returns both the path string and structured segments with IDs and names.\n */\nasync function resolveFolderPath(drive: drive_v3.Drive, folderId: string, logger: Logger): Promise<{ path: string; segments: Array<{ id: string; name: string }> }> {\n // Handle root specially\n if (folderId === 'root') {\n return {\n path: '/',\n segments: [{ id: 'root', name: 'My Drive' }],\n };\n }\n\n const segments: Array<{ id: string; name: string }> = [];\n let currentId = folderId;\n const visited = new Set<string>();\n\n // Walk up the parent chain\n while (currentId && currentId !== 'root') {\n // Prevent infinite loops\n if (visited.has(currentId)) {\n logger.info('Circular folder reference detected', {\n folderId: currentId,\n });\n break;\n }\n visited.add(currentId);\n\n // Fetch folder metadata\n try {\n const response = await drive.files.get({\n fileId: currentId,\n fields: 'id,name,parents',\n });\n\n const id = response.data.id as string;\n const name = (response.data.name as string) || id;\n const parents = response.data.parents as string[] | undefined;\n\n // Add to segments at beginning (we're walking from child to root)\n segments.unshift({ id, name });\n\n // Move to parent\n currentId = (parents && parents.length > 0 ? parents[0] : '') || '';\n } catch (e) {\n logger.info('Failed to resolve folder path', {\n folderId: currentId,\n error: e,\n });\n break;\n }\n }\n\n // Add root if we reached it\n if (currentId === 'root') {\n segments.unshift({ id: 'root', name: 'My Drive' });\n }\n\n // Build path string\n const pathParts = segments.slice(1).map((seg) => seg.name); // Skip root\n const path = pathParts.length > 0 ? `/${pathParts.join('/')}` : '/';\n\n return { path, segments };\n}\n\nasync function handler({ folderId }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('drive.folder.path called', { folderId });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const pathResult = await resolveFolderPath(drive, folderId, logger);\n\n logger.info('drive.folder.path returning', {\n path: pathResult.path,\n segmentCount: pathResult.segments.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n path: pathResult.path,\n items: pathResult.segments,\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('drive.folder.path error', { error: message });\n\n // Throw McpError\n throw new McpError(ErrorCode.InternalError, `Error getting folder path: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-path' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","folderId","string","min","describe","successBranchSchema","type","literal","path","items","array","id","name","outputSchema","discriminatedUnion","config","title","description","result","resolveFolderPath","drive","logger","segments","currentId","visited","response","parents","e","pathParts","Set","has","info","add","files","get","fileId","fields","data","unshift","length","error","slice","map","seg","join","handler","extra","pathResult","message","google","version","auth","authContext","segmentCount","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/mcp/tools/folder-path.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport type { drive_v3 } from 'googleapis';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport type { Logger } from '../../types.ts';\n\nconst inputSchema = z.object({\n folderId: z.string().min(1).describe('Folder ID to get path for (or \"root\")'),\n});\n\n// Success branch schema - uses items: for consistency with standard vocabulary\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n path: z.string().describe('Full path from root (e.g., /Work/Projects/2024)'),\n items: z\n .array(\n z.object({\n id: z.string().describe('Folder ID'),\n name: z.string().describe('Folder name'),\n })\n )\n .describe('Path items from root to target folder'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Get Folder Path',\n description: 'Get full path from folder to root. Returns human-readable path and items with IDs.',\n inputSchema: 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/**\n * Resolves the full path for a folder by walking up the parent chain.\n * Returns both the path string and structured segments with IDs and names.\n */\nasync function resolveFolderPath(drive: drive_v3.Drive, folderId: string, logger: Logger): Promise<{ path: string; segments: Array<{ id: string; name: string }> }> {\n // Handle root specially\n if (folderId === 'root') {\n return {\n path: '/',\n segments: [{ id: 'root', name: 'My Drive' }],\n };\n }\n\n const segments: Array<{ id: string; name: string }> = [];\n let currentId = folderId;\n const visited = new Set<string>();\n\n // Walk up the parent chain\n while (currentId && currentId !== 'root') {\n // Prevent infinite loops\n if (visited.has(currentId)) {\n logger.info('Circular folder reference detected', {\n folderId: currentId,\n });\n break;\n }\n visited.add(currentId);\n\n // Fetch folder metadata\n try {\n const response = await drive.files.get({\n fileId: currentId,\n fields: 'id,name,parents',\n });\n\n const id = response.data.id as string;\n const name = (response.data.name as string) || id;\n const parents = response.data.parents as string[] | undefined;\n\n // Add to segments at beginning (we're walking from child to root)\n segments.unshift({ id, name });\n\n // Move to parent\n currentId = (parents && parents.length > 0 ? parents[0] : '') || '';\n } catch (e) {\n logger.info('Failed to resolve folder path', {\n folderId: currentId,\n error: e,\n });\n break;\n }\n }\n\n // Add root if we reached it\n if (currentId === 'root') {\n segments.unshift({ id: 'root', name: 'My Drive' });\n }\n\n // Build path string\n const pathParts = segments.slice(1).map((seg) => seg.name); // Skip root\n const path = pathParts.length > 0 ? `/${pathParts.join('/')}` : '/';\n\n return { path, segments };\n}\n\nasync function handler({ folderId }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('drive.folder.path called', { folderId });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const pathResult = await resolveFolderPath(drive, folderId, logger);\n\n logger.info('drive.folder.path returning', {\n path: pathResult.path,\n segmentCount: pathResult.segments.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n path: pathResult.path,\n items: pathResult.segments,\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('drive.folder.path error', { error: message });\n\n // Throw McpError\n throw new McpError(ErrorCode.InternalError, `Error getting folder path: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-path' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","folderId","string","min","describe","successBranchSchema","type","literal","path","items","array","id","name","outputSchema","discriminatedUnion","config","title","description","result","resolveFolderPath","drive","logger","segments","currentId","visited","response","parents","e","pathParts","Set","has","info","add","files","get","fileId","fields","data","unshift","length","error","slice","map","seg","join","handler","extra","pathResult","message","google","version","auth","authContext","segmentCount","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined"],"mappings":"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"}
@@ -13,8 +13,8 @@ var _server = require("@mcp-z/server");
13
13
  var _types = require("@modelcontextprotocol/sdk/types.js");
14
14
  var _googleapis = require("googleapis");
15
15
  var _zod = require("zod");
16
- var _querybuilder = require("../../lib/query-builder.js");
17
- var _index = require("../../schemas/index.js");
16
+ var _querybuilderts = require("../../lib/query-builder.js");
17
+ var _indexts = require("../../schemas/index.js");
18
18
  function _array_like_to_array(arr, len) {
19
19
  if (len == null || len > arr.length) len = arr.length;
20
20
  for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
@@ -233,15 +233,15 @@ function _ts_generator(thisArg, body) {
233
233
  }
234
234
  var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
235
235
  var inputSchema = _zod.z.object(_object_spread_props(_object_spread({
236
- query: _index.DriveQuerySchema.optional().describe('Drive query object with structured search fields. See DriveQuerySchema for detailed query syntax and examples.'),
236
+ query: _indexts.DriveQuerySchema.optional().describe('Drive query object with structured search fields. See DriveQuerySchema for detailed query syntax and examples.'),
237
237
  fields: (0, _server.createFieldsSchema)({
238
- availableFields: _to_consumable_array(_index.DRIVE_FILE_FIELDS).concat([
238
+ availableFields: _to_consumable_array(_indexts.DRIVE_FILE_FIELDS).concat([
239
239
  'path'
240
240
  ]),
241
- fieldDescriptions: _object_spread_props(_object_spread({}, _index.DRIVE_FILE_FIELD_DESCRIPTIONS), {
241
+ fieldDescriptions: _object_spread_props(_object_spread({}, _indexts.DRIVE_FILE_FIELD_DESCRIPTIONS), {
242
242
  path: 'Full folder path like /Work/Projects (requires resolvePaths=true)'
243
243
  }),
244
- commonPatterns: _index.DRIVE_FILE_COMMON_PATTERNS,
244
+ commonPatterns: _indexts.DRIVE_FILE_COMMON_PATTERNS,
245
245
  resourceName: 'Drive folder'
246
246
  }),
247
247
  resolvePaths: _zod.z.boolean().optional().describe('Resolve full folder paths like /Work/Projects/2024 (requires additional API calls per result)')
@@ -256,7 +256,7 @@ var inputSchema = _zod.z.object(_object_spread_props(_object_spread({
256
256
  var successObjectsBranchSchema = _zod.z.object({
257
257
  type: _zod.z.literal('success'),
258
258
  shape: _zod.z.literal('objects'),
259
- items: _zod.z.array(_index.DriveFileSchema.extend({
259
+ items: _zod.z.array(_indexts.DriveFileSchema.extend({
260
260
  path: _zod.z.string().optional().describe('Full folder path (if resolvePaths=true)')
261
261
  })).describe('Matching Drive folders'),
262
262
  count: _zod.z.number().describe('Number of folders in this page'),
@@ -422,7 +422,7 @@ function handler(_0, _1) {
422
422
  case 0:
423
423
  query = param.query, _param_resolvePaths = param.resolvePaths, resolvePaths = _param_resolvePaths === void 0 ? false : _param_resolvePaths, _param_pageSize = param.pageSize, pageSize = _param_pageSize === void 0 ? 50 : _param_pageSize, pageToken = param.pageToken, fields = param.fields, _param_shape = param.shape, shape = _param_shape === void 0 ? 'arrays' : _param_shape;
424
424
  logger = extra.logger;
425
- requestedFields = (0, _server.parseFields)(fields, _to_consumable_array(_index.DRIVE_FILE_FIELDS).concat([
425
+ requestedFields = (0, _server.parseFields)(fields, _to_consumable_array(_indexts.DRIVE_FILE_FIELDS).concat([
426
426
  'path'
427
427
  ]));
428
428
  // Validate and clamp pageSize to Google Drive API limits (1-1000)
@@ -455,7 +455,7 @@ function handler(_0, _1) {
455
455
  qStr = "(".concat(query.rawDriveQuery, ") and mimeType='").concat(folderMimeType, "' and trashed = false");
456
456
  } else if (query) {
457
457
  // Structured query object - convert to Drive query string
458
- q = (0, _querybuilder.toDriveQuery)(query).q;
458
+ q = (0, _querybuilderts.toDriveQuery)(query).q;
459
459
  qStr = q ? "(".concat(q, ") and mimeType='").concat(folderMimeType, "' and trashed = false") : "mimeType='".concat(folderMimeType, "' and trashed = false");
460
460
  } else {
461
461
  // No query - return all folders
@@ -672,7 +672,7 @@ function handler(_0, _1) {
672
672
  result = shape === 'arrays' ? _object_spread(_object_spread_props(_object_spread({
673
673
  type: 'success',
674
674
  shape: 'arrays'
675
- }, (0, _server.toColumnarFormat)(filteredItems, requestedFields, _to_consumable_array(_index.DRIVE_FILE_FIELDS).concat([
675
+ }, (0, _server.toColumnarFormat)(filteredItems, requestedFields, _to_consumable_array(_indexts.DRIVE_FILE_FIELDS).concat([
676
676
  'path'
677
677
  ]))), {
678
678
  count: filteredItems.length
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-drive/src/mcp/tools/folder-search.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { createFieldsSchema, createPaginationSchema, createShapeSchema, filterFields, parseFields, toColumnarFormat } from '@mcp-z/server';\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport type { drive_v3 } from 'googleapis';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { toDriveQuery } from '../../lib/query-builder.js';\nimport { DRIVE_FILE_COMMON_PATTERNS, DRIVE_FILE_FIELD_DESCRIPTIONS, DRIVE_FILE_FIELDS, type DriveFile, DriveFileSchema, DriveQuerySchema } from '../../schemas/index.js';\nimport type { Logger } from '../../types.js';\n\nconst inputSchema = z.object({\n query: DriveQuerySchema.optional().describe('Drive query object with structured search fields. See DriveQuerySchema for detailed query syntax and examples.'),\n fields: createFieldsSchema({\n availableFields: [...DRIVE_FILE_FIELDS, 'path'] as const,\n fieldDescriptions: {\n ...DRIVE_FILE_FIELD_DESCRIPTIONS,\n path: 'Full folder path like /Work/Projects (requires resolvePaths=true)',\n },\n commonPatterns: DRIVE_FILE_COMMON_PATTERNS,\n resourceName: 'Drive folder',\n }),\n resolvePaths: z.boolean().optional().describe('Resolve full folder paths like /Work/Projects/2024 (requires additional API calls per result)'),\n ...createPaginationSchema({\n defaultPageSize: 50,\n maxPageSize: 1000,\n provider: 'drive',\n }).shape,\n shape: createShapeSchema(),\n});\n\n// Success branch schemas for different shapes\nconst successObjectsBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('objects'),\n items: z.array(DriveFileSchema.extend({ path: z.string().optional().describe('Full folder path (if resolvePaths=true)') })).describe('Matching Drive folders'),\n count: z.number().describe('Number of folders in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\nconst successArraysBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('arrays'),\n columns: z.array(z.string()).describe('Column names in canonical order'),\n rows: z.array(z.array(z.unknown())).describe('Row data matching column order'),\n count: z.number().describe('Number of folders in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\n// Output schema with auth_required support\n// Using z.union instead of discriminatedUnion since we have two success branches with different shapes\nconst outputSchema = z.union([successObjectsBranchSchema, successArraysBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Search Folders',\n description: 'Search Google Drive folders with flexible field selection and optional path resolution.',\n inputSchema: 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// Type for the raw Google Drive API response\ntype DriveFolder = {\n id?: string;\n name?: string;\n mimeType?: string;\n webViewLink?: string;\n modifiedTime?: string;\n parents?: string[];\n shared?: boolean;\n starred?: boolean;\n owners?: Array<{\n displayName?: string;\n emailAddress?: string;\n kind?: string;\n me?: boolean;\n permissionId?: string;\n photoLink?: string;\n }>;\n};\n\ntype DriveFolderResponse = {\n files?: DriveFolder[];\n nextPageToken?: string;\n};\n\n/**\n * Resolves the full path for a folder by walking up the parent chain\n * Caches folder names to reduce redundant API calls\n */\nasync function resolveFolderPath(drive: drive_v3.Drive, folderId: string, folderCache: Map<string, string>, logger: Logger): Promise<string> {\n if (folderId === 'root') return '/';\n\n const pathParts: string[] = [];\n let currentId = folderId;\n const visited = new Set<string>();\n\n while (currentId && currentId !== 'root') {\n // Prevent infinite loops\n if (visited.has(currentId)) {\n logger.info('Circular folder reference detected', {\n folderId: currentId,\n });\n break;\n }\n visited.add(currentId);\n\n // Check cache first\n if (folderCache.has(currentId)) {\n const cachedName = folderCache.get(currentId);\n if (cachedName) {\n pathParts.unshift(cachedName);\n }\n\n // Get parent of cached folder\n try {\n const response = await drive.files.get({\n fileId: currentId,\n fields: 'parents',\n });\n const parents = response.data.parents as string[] | undefined;\n currentId = (parents && parents.length > 0 ? parents[0] : '') || '';\n } catch (_e) {\n logger.info('Failed to get parent for cached folder', {\n folderId: currentId,\n });\n break;\n }\n } else {\n // Fetch folder metadata\n try {\n const response = await drive.files.get({\n fileId: currentId,\n fields: 'name,parents',\n });\n const folderName = response.data.name as string | undefined;\n const parents = response.data.parents as string[] | undefined;\n\n if (folderName) {\n folderCache.set(currentId, folderName);\n pathParts.unshift(folderName);\n }\n\n currentId = (parents && parents.length > 0 ? parents[0] : '') || '';\n } catch (e) {\n logger.info('Failed to resolve folder path', {\n folderId: currentId,\n error: e,\n });\n break;\n }\n }\n }\n\n return `/${pathParts.join('/')}`;\n}\n\nasync function handler({ query, resolvePaths = false, pageSize = 50, pageToken, fields, shape = 'arrays' }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n\n const requestedFields = parseFields(fields, [...DRIVE_FILE_FIELDS, 'path'] as const);\n\n // Validate and clamp pageSize to Google Drive API limits (1-1000)\n const validPageSize = Math.max(1, Math.min(1000, Math.floor(pageSize || 50)));\n\n logger.info('drive.folder.search called', {\n query,\n resolvePaths,\n pageSize: validPageSize,\n pageToken: pageToken ? '[provided]' : undefined,\n fields: fields || 'all',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const folderMimeType = 'application/vnd.google-apps.folder';\n let qStr: string;\n\n if (typeof query === 'string') {\n // String query - treat as raw Drive query\n qStr = `(${query}) and mimeType='${folderMimeType}' and trashed = false`;\n } else if (query && typeof query === 'object' && 'rawDriveQuery' in query && query.rawDriveQuery) {\n // Object with rawDriveQuery field - use it directly\n qStr = `(${query.rawDriveQuery}) and mimeType='${folderMimeType}' and trashed = false`;\n } else if (query) {\n // Structured query object - convert to Drive query string\n const { q } = toDriveQuery(query);\n qStr = q ? `(${q}) and mimeType='${folderMimeType}' and trashed = false` : `mimeType='${folderMimeType}' and trashed = false`;\n } else {\n // No query - return all folders\n qStr = `mimeType='${folderMimeType}' and trashed = false`;\n }\n\n const listOptions: {\n q: string;\n pageSize: number;\n fields: string;\n orderBy: string;\n pageToken?: string;\n } = {\n q: qStr,\n pageSize: validPageSize,\n fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',\n orderBy: 'modifiedTime desc',\n };\n if (pageToken && pageToken.trim().length > 0) {\n listOptions.pageToken = pageToken;\n }\n\n const response = await drive.files.list(listOptions);\n\n const res = response.data as DriveFolderResponse;\n const folders = Array.isArray(res?.files) ? res.files : [];\n\n const parentIds = new Set<string>();\n for (const f of folders) {\n if (f?.parents && f.parents.length > 0) {\n for (const parentId of f.parents) {\n if (parentId && parentId !== 'root') {\n parentIds.add(parentId);\n }\n }\n }\n }\n\n const parentNameMap = new Map<string, string>();\n if (parentIds.size > 0) {\n logger.info('Fetching parent names', { count: parentIds.size });\n const parentFetches = Array.from(parentIds).map(async (parentId) => {\n try {\n const parentRes = await drive.files.get({\n fileId: parentId,\n fields: 'id,name',\n });\n const parentName = (parentRes.data.name as string | undefined) || parentId;\n parentNameMap.set(parentId, parentName);\n } catch (e) {\n logger.info('Failed to fetch parent name', { parentId, error: e });\n parentNameMap.set(parentId, parentId); // Fallback to ID\n }\n });\n await Promise.all(parentFetches);\n }\n\n // Cache for folder names to reduce API calls during path resolution\n const folderCache = new Map<string, string>();\n\n const items: (DriveFile & { path?: string })[] = await Promise.all(\n folders.map(async (f: DriveFolder) => {\n const id = f?.id ? String(f.id) : 'unknown';\n const name = f?.name || id;\n const result: DriveFile & { path?: string } = { id, name };\n\n // Only include properties that have actual values\n if (f?.mimeType) result.mimeType = f.mimeType;\n if (f?.webViewLink) result.webViewLink = f.webViewLink;\n if (f?.modifiedTime) result.modifiedTime = f.modifiedTime;\n\n // Build parent objects with names\n if (f?.parents && f.parents.length > 0) {\n result.parents = f.parents.map((parentId) => {\n if (parentId === 'root') {\n return { id: 'root', name: 'My Drive' };\n }\n const parentName = parentNameMap.get(parentId) || parentId;\n return { id: parentId, name: parentName };\n });\n }\n\n if (f?.shared !== undefined) result.shared = f.shared;\n if (f?.starred !== undefined) result.starred = f.starred;\n\n if (f?.owners && f.owners.length > 0) {\n result.owners = f.owners.map((o) => {\n const owner: NonNullable<DriveFile['owners']>[number] = {};\n if (o?.displayName) owner.displayName = o.displayName;\n if (o?.emailAddress) owner.emailAddress = o.emailAddress;\n if (o?.kind) owner.kind = o.kind;\n if (o?.me !== undefined) owner.me = o.me;\n if (o?.permissionId) owner.permissionId = o.permissionId;\n if (o?.photoLink) owner.photoLink = o.photoLink;\n return owner;\n });\n }\n\n // Resolve path if requested\n if (resolvePaths && id !== 'unknown') {\n result.path = await resolveFolderPath(drive, id, folderCache, logger);\n }\n\n return result;\n })\n );\n\n const filteredItems = items.map((item) => filterFields(item, requestedFields));\n\n logger.info('drive.folder.search returning', {\n query,\n pageSize,\n resultCount: filteredItems.length,\n resolvePaths,\n fields: fields || 'all',\n });\n\n const nextPageToken = res.nextPageToken && res.nextPageToken.trim().length > 0 ? res.nextPageToken : undefined;\n\n // Build result based on shape\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n ...toColumnarFormat(filteredItems, requestedFields, [...DRIVE_FILE_FIELDS, 'path'] as const),\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: filteredItems,\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\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('drive.folder.search error', { error: message });\n\n // Check if this is a Drive API validation error (invalid query, invalid pageToken, etc.)\n // These should return empty results rather than throw\n const isDriveValidationError = message.includes('Invalid Value') || message.includes('Invalid value') || message.includes('File not found') || message.includes('Bad Request');\n\n if (isDriveValidationError) {\n // Return empty result set for validation errors\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n columns: [],\n rows: [],\n count: 0,\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: [],\n count: 0,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n }\n\n // Throw McpError for other errors\n throw new McpError(ErrorCode.InternalError, `Error searching folders: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-search' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","query","DriveQuerySchema","optional","describe","fields","createFieldsSchema","availableFields","DRIVE_FILE_FIELDS","fieldDescriptions","DRIVE_FILE_FIELD_DESCRIPTIONS","path","commonPatterns","DRIVE_FILE_COMMON_PATTERNS","resourceName","resolvePaths","boolean","createPaginationSchema","defaultPageSize","maxPageSize","provider","shape","createShapeSchema","successObjectsBranchSchema","type","literal","items","array","DriveFileSchema","extend","string","count","number","nextPageToken","successArraysBranchSchema","columns","rows","unknown","outputSchema","union","config","title","description","result","resolveFolderPath","drive","folderId","folderCache","logger","pathParts","currentId","visited","cachedName","response","parents","_e","folderName","e","Set","has","info","add","get","unshift","files","fileId","data","length","name","set","error","join","handler","extra","pageSize","pageToken","requestedFields","validPageSize","folderMimeType","qStr","q","listOptions","res","folders","parentIds","f","parentId","parentNameMap","parentFetches","filteredItems","message","isDriveValidationError","parseFields","Math","max","min","floor","undefined","google","version","auth","authContext","rawDriveQuery","toDriveQuery","orderBy","trim","list","Array","isArray","Map","size","from","map","parentRes","parentName","Promise","all","id","String","mimeType","webViewLink","modifiedTime","shared","starred","owners","o","owner","displayName","emailAddress","kind","me","permissionId","photoLink","item","filterFields","resultCount","toColumnarFormat","content","text","JSON","stringify","structuredContent","Error","includes","McpError","ErrorCode","InternalError","stack"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/mcp/tools/folder-search.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport { createFieldsSchema, createPaginationSchema, createShapeSchema, filterFields, parseFields, toColumnarFormat } from '@mcp-z/server';\nimport { type CallToolResult, ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport type { drive_v3 } from 'googleapis';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { toDriveQuery } from '../../lib/query-builder.ts';\nimport { DRIVE_FILE_COMMON_PATTERNS, DRIVE_FILE_FIELD_DESCRIPTIONS, DRIVE_FILE_FIELDS, type DriveFile, DriveFileSchema, DriveQuerySchema } from '../../schemas/index.ts';\nimport type { Logger } from '../../types.ts';\n\nconst inputSchema = z.object({\n query: DriveQuerySchema.optional().describe('Drive query object with structured search fields. See DriveQuerySchema for detailed query syntax and examples.'),\n fields: createFieldsSchema({\n availableFields: [...DRIVE_FILE_FIELDS, 'path'] as const,\n fieldDescriptions: {\n ...DRIVE_FILE_FIELD_DESCRIPTIONS,\n path: 'Full folder path like /Work/Projects (requires resolvePaths=true)',\n },\n commonPatterns: DRIVE_FILE_COMMON_PATTERNS,\n resourceName: 'Drive folder',\n }),\n resolvePaths: z.boolean().optional().describe('Resolve full folder paths like /Work/Projects/2024 (requires additional API calls per result)'),\n ...createPaginationSchema({\n defaultPageSize: 50,\n maxPageSize: 1000,\n provider: 'drive',\n }).shape,\n shape: createShapeSchema(),\n});\n\n// Success branch schemas for different shapes\nconst successObjectsBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('objects'),\n items: z.array(DriveFileSchema.extend({ path: z.string().optional().describe('Full folder path (if resolvePaths=true)') })).describe('Matching Drive folders'),\n count: z.number().describe('Number of folders in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\nconst successArraysBranchSchema = z.object({\n type: z.literal('success'),\n shape: z.literal('arrays'),\n columns: z.array(z.string()).describe('Column names in canonical order'),\n rows: z.array(z.array(z.unknown())).describe('Row data matching column order'),\n count: z.number().describe('Number of folders in this page'),\n nextPageToken: z.string().optional().describe('Token for fetching next page of results'),\n});\n\n// Output schema with auth_required support\n// Using z.union instead of discriminatedUnion since we have two success branches with different shapes\nconst outputSchema = z.union([successObjectsBranchSchema, successArraysBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n title: 'Search Folders',\n description: 'Search Google Drive folders with flexible field selection and optional path resolution.',\n inputSchema: 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// Type for the raw Google Drive API response\ntype DriveFolder = {\n id?: string;\n name?: string;\n mimeType?: string;\n webViewLink?: string;\n modifiedTime?: string;\n parents?: string[];\n shared?: boolean;\n starred?: boolean;\n owners?: Array<{\n displayName?: string;\n emailAddress?: string;\n kind?: string;\n me?: boolean;\n permissionId?: string;\n photoLink?: string;\n }>;\n};\n\ntype DriveFolderResponse = {\n files?: DriveFolder[];\n nextPageToken?: string;\n};\n\n/**\n * Resolves the full path for a folder by walking up the parent chain\n * Caches folder names to reduce redundant API calls\n */\nasync function resolveFolderPath(drive: drive_v3.Drive, folderId: string, folderCache: Map<string, string>, logger: Logger): Promise<string> {\n if (folderId === 'root') return '/';\n\n const pathParts: string[] = [];\n let currentId = folderId;\n const visited = new Set<string>();\n\n while (currentId && currentId !== 'root') {\n // Prevent infinite loops\n if (visited.has(currentId)) {\n logger.info('Circular folder reference detected', {\n folderId: currentId,\n });\n break;\n }\n visited.add(currentId);\n\n // Check cache first\n if (folderCache.has(currentId)) {\n const cachedName = folderCache.get(currentId);\n if (cachedName) {\n pathParts.unshift(cachedName);\n }\n\n // Get parent of cached folder\n try {\n const response = await drive.files.get({\n fileId: currentId,\n fields: 'parents',\n });\n const parents = response.data.parents as string[] | undefined;\n currentId = (parents && parents.length > 0 ? parents[0] : '') || '';\n } catch (_e) {\n logger.info('Failed to get parent for cached folder', {\n folderId: currentId,\n });\n break;\n }\n } else {\n // Fetch folder metadata\n try {\n const response = await drive.files.get({\n fileId: currentId,\n fields: 'name,parents',\n });\n const folderName = response.data.name as string | undefined;\n const parents = response.data.parents as string[] | undefined;\n\n if (folderName) {\n folderCache.set(currentId, folderName);\n pathParts.unshift(folderName);\n }\n\n currentId = (parents && parents.length > 0 ? parents[0] : '') || '';\n } catch (e) {\n logger.info('Failed to resolve folder path', {\n folderId: currentId,\n error: e,\n });\n break;\n }\n }\n }\n\n return `/${pathParts.join('/')}`;\n}\n\nasync function handler({ query, resolvePaths = false, pageSize = 50, pageToken, fields, shape = 'arrays' }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n\n const requestedFields = parseFields(fields, [...DRIVE_FILE_FIELDS, 'path'] as const);\n\n // Validate and clamp pageSize to Google Drive API limits (1-1000)\n const validPageSize = Math.max(1, Math.min(1000, Math.floor(pageSize || 50)));\n\n logger.info('drive.folder.search called', {\n query,\n resolvePaths,\n pageSize: validPageSize,\n pageToken: pageToken ? '[provided]' : undefined,\n fields: fields || 'all',\n });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const folderMimeType = 'application/vnd.google-apps.folder';\n let qStr: string;\n\n if (typeof query === 'string') {\n // String query - treat as raw Drive query\n qStr = `(${query}) and mimeType='${folderMimeType}' and trashed = false`;\n } else if (query && typeof query === 'object' && 'rawDriveQuery' in query && query.rawDriveQuery) {\n // Object with rawDriveQuery field - use it directly\n qStr = `(${query.rawDriveQuery}) and mimeType='${folderMimeType}' and trashed = false`;\n } else if (query) {\n // Structured query object - convert to Drive query string\n const { q } = toDriveQuery(query);\n qStr = q ? `(${q}) and mimeType='${folderMimeType}' and trashed = false` : `mimeType='${folderMimeType}' and trashed = false`;\n } else {\n // No query - return all folders\n qStr = `mimeType='${folderMimeType}' and trashed = false`;\n }\n\n const listOptions: {\n q: string;\n pageSize: number;\n fields: string;\n orderBy: string;\n pageToken?: string;\n } = {\n q: qStr,\n pageSize: validPageSize,\n fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',\n orderBy: 'modifiedTime desc',\n };\n if (pageToken && pageToken.trim().length > 0) {\n listOptions.pageToken = pageToken;\n }\n\n const response = await drive.files.list(listOptions);\n\n const res = response.data as DriveFolderResponse;\n const folders = Array.isArray(res?.files) ? res.files : [];\n\n const parentIds = new Set<string>();\n for (const f of folders) {\n if (f?.parents && f.parents.length > 0) {\n for (const parentId of f.parents) {\n if (parentId && parentId !== 'root') {\n parentIds.add(parentId);\n }\n }\n }\n }\n\n const parentNameMap = new Map<string, string>();\n if (parentIds.size > 0) {\n logger.info('Fetching parent names', { count: parentIds.size });\n const parentFetches = Array.from(parentIds).map(async (parentId) => {\n try {\n const parentRes = await drive.files.get({\n fileId: parentId,\n fields: 'id,name',\n });\n const parentName = (parentRes.data.name as string | undefined) || parentId;\n parentNameMap.set(parentId, parentName);\n } catch (e) {\n logger.info('Failed to fetch parent name', { parentId, error: e });\n parentNameMap.set(parentId, parentId); // Fallback to ID\n }\n });\n await Promise.all(parentFetches);\n }\n\n // Cache for folder names to reduce API calls during path resolution\n const folderCache = new Map<string, string>();\n\n const items: (DriveFile & { path?: string })[] = await Promise.all(\n folders.map(async (f: DriveFolder) => {\n const id = f?.id ? String(f.id) : 'unknown';\n const name = f?.name || id;\n const result: DriveFile & { path?: string } = { id, name };\n\n // Only include properties that have actual values\n if (f?.mimeType) result.mimeType = f.mimeType;\n if (f?.webViewLink) result.webViewLink = f.webViewLink;\n if (f?.modifiedTime) result.modifiedTime = f.modifiedTime;\n\n // Build parent objects with names\n if (f?.parents && f.parents.length > 0) {\n result.parents = f.parents.map((parentId) => {\n if (parentId === 'root') {\n return { id: 'root', name: 'My Drive' };\n }\n const parentName = parentNameMap.get(parentId) || parentId;\n return { id: parentId, name: parentName };\n });\n }\n\n if (f?.shared !== undefined) result.shared = f.shared;\n if (f?.starred !== undefined) result.starred = f.starred;\n\n if (f?.owners && f.owners.length > 0) {\n result.owners = f.owners.map((o) => {\n const owner: NonNullable<DriveFile['owners']>[number] = {};\n if (o?.displayName) owner.displayName = o.displayName;\n if (o?.emailAddress) owner.emailAddress = o.emailAddress;\n if (o?.kind) owner.kind = o.kind;\n if (o?.me !== undefined) owner.me = o.me;\n if (o?.permissionId) owner.permissionId = o.permissionId;\n if (o?.photoLink) owner.photoLink = o.photoLink;\n return owner;\n });\n }\n\n // Resolve path if requested\n if (resolvePaths && id !== 'unknown') {\n result.path = await resolveFolderPath(drive, id, folderCache, logger);\n }\n\n return result;\n })\n );\n\n const filteredItems = items.map((item) => filterFields(item, requestedFields));\n\n logger.info('drive.folder.search returning', {\n query,\n pageSize,\n resultCount: filteredItems.length,\n resolvePaths,\n fields: fields || 'all',\n });\n\n const nextPageToken = res.nextPageToken && res.nextPageToken.trim().length > 0 ? res.nextPageToken : undefined;\n\n // Build result based on shape\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n ...toColumnarFormat(filteredItems, requestedFields, [...DRIVE_FILE_FIELDS, 'path'] as const),\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: filteredItems,\n count: filteredItems.length,\n ...(nextPageToken && { nextPageToken }),\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('drive.folder.search error', { error: message });\n\n // Check if this is a Drive API validation error (invalid query, invalid pageToken, etc.)\n // These should return empty results rather than throw\n const isDriveValidationError = message.includes('Invalid Value') || message.includes('Invalid value') || message.includes('File not found') || message.includes('Bad Request');\n\n if (isDriveValidationError) {\n // Return empty result set for validation errors\n const result: Output =\n shape === 'arrays'\n ? {\n type: 'success' as const,\n shape: 'arrays' as const,\n columns: [],\n rows: [],\n count: 0,\n }\n : {\n type: 'success' as const,\n shape: 'objects' as const,\n items: [],\n count: 0,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n }\n\n // Throw McpError for other errors\n throw new McpError(ErrorCode.InternalError, `Error searching folders: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'folder-search' as const,\n config,\n handler,\n };\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","query","DriveQuerySchema","optional","describe","fields","createFieldsSchema","availableFields","DRIVE_FILE_FIELDS","fieldDescriptions","DRIVE_FILE_FIELD_DESCRIPTIONS","path","commonPatterns","DRIVE_FILE_COMMON_PATTERNS","resourceName","resolvePaths","boolean","createPaginationSchema","defaultPageSize","maxPageSize","provider","shape","createShapeSchema","successObjectsBranchSchema","type","literal","items","array","DriveFileSchema","extend","string","count","number","nextPageToken","successArraysBranchSchema","columns","rows","unknown","outputSchema","union","config","title","description","result","resolveFolderPath","drive","folderId","folderCache","logger","pathParts","currentId","visited","cachedName","response","parents","_e","folderName","e","Set","has","info","add","get","unshift","files","fileId","data","length","name","set","error","join","handler","extra","pageSize","pageToken","requestedFields","validPageSize","folderMimeType","qStr","q","listOptions","res","folders","parentIds","f","parentId","parentNameMap","parentFetches","filteredItems","message","isDriveValidationError","parseFields","Math","max","min","floor","undefined","google","version","auth","authContext","rawDriveQuery","toDriveQuery","orderBy","trim","list","Array","isArray","Map","size","from","map","parentRes","parentName","Promise","all","id","String","mimeType","webViewLink","modifiedTime","shared","starred","owners","o","owner","displayName","emailAddress","kind","me","permissionId","photoLink","item","filterFields","resultCount","toColumnarFormat","content","text","JSON","stringify","structuredContent","Error","includes","McpError","ErrorCode","InternalError","stack"],"mappings":"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"}
@@ -10,34 +10,34 @@ function _export(target, all) {
10
10
  }
11
11
  _export(exports, {
12
12
  get fileMove () {
13
- return _filemove.default;
13
+ return _filemovets.default;
14
14
  },
15
15
  get fileMoveToTrash () {
16
- return _filemovetotrash.default;
16
+ return _filemovetotrashts.default;
17
17
  },
18
18
  get filesSearch () {
19
- return _filessearch.default;
19
+ return _filessearchts.default;
20
20
  },
21
21
  get folderContents () {
22
- return _foldercontents.default;
22
+ return _foldercontentsts.default;
23
23
  },
24
24
  get folderCreate () {
25
- return _foldercreate.default;
25
+ return _foldercreatets.default;
26
26
  },
27
27
  get folderPath () {
28
- return _folderpath.default;
28
+ return _folderpathts.default;
29
29
  },
30
30
  get folderSearch () {
31
- return _foldersearch.default;
31
+ return _foldersearchts.default;
32
32
  }
33
33
  });
34
- var _filemove = /*#__PURE__*/ _interop_require_default(require("./file-move.js"));
35
- var _filemovetotrash = /*#__PURE__*/ _interop_require_default(require("./file-move-to-trash.js"));
36
- var _filessearch = /*#__PURE__*/ _interop_require_default(require("./files-search.js"));
37
- var _foldercontents = /*#__PURE__*/ _interop_require_default(require("./folder-contents.js"));
38
- var _foldercreate = /*#__PURE__*/ _interop_require_default(require("./folder-create.js"));
39
- var _folderpath = /*#__PURE__*/ _interop_require_default(require("./folder-path.js"));
40
- var _foldersearch = /*#__PURE__*/ _interop_require_default(require("./folder-search.js"));
34
+ var _filemovets = /*#__PURE__*/ _interop_require_default(require("./file-move.js"));
35
+ var _filemovetotrashts = /*#__PURE__*/ _interop_require_default(require("./file-move-to-trash.js"));
36
+ var _filessearchts = /*#__PURE__*/ _interop_require_default(require("./files-search.js"));
37
+ var _foldercontentsts = /*#__PURE__*/ _interop_require_default(require("./folder-contents.js"));
38
+ var _foldercreatets = /*#__PURE__*/ _interop_require_default(require("./folder-create.js"));
39
+ var _folderpathts = /*#__PURE__*/ _interop_require_default(require("./folder-path.js"));
40
+ var _foldersearchts = /*#__PURE__*/ _interop_require_default(require("./folder-search.js"));
41
41
  function _interop_require_default(obj) {
42
42
  return obj && obj.__esModule ? obj : {
43
43
  default: obj