@mcp-z/mcp-drive 1.0.6 → 1.0.8

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 (36) hide show
  1. package/dist/cjs/lib/create-store.js +2 -29
  2. package/dist/cjs/lib/create-store.js.map +1 -1
  3. package/dist/cjs/lib/query-builder.d.cts +2 -2
  4. package/dist/cjs/lib/query-builder.d.ts +2 -2
  5. package/dist/cjs/lib/query-builder.js.map +1 -1
  6. package/dist/cjs/mcp/prompts/query-syntax.js +1 -1
  7. package/dist/cjs/mcp/prompts/query-syntax.js.map +1 -1
  8. package/dist/cjs/mcp/tools/files-search.d.cts +2 -2
  9. package/dist/cjs/mcp/tools/files-search.d.ts +2 -2
  10. package/dist/cjs/mcp/tools/files-search.js +24 -58
  11. package/dist/cjs/mcp/tools/files-search.js.map +1 -1
  12. package/dist/cjs/mcp/tools/folder-search.d.cts +2 -2
  13. package/dist/cjs/mcp/tools/folder-search.d.ts +2 -2
  14. package/dist/cjs/mcp/tools/folder-search.js +21 -59
  15. package/dist/cjs/mcp/tools/folder-search.js.map +1 -1
  16. package/dist/cjs/schemas/drive-query-schema.d.cts +32 -6
  17. package/dist/cjs/schemas/drive-query-schema.d.ts +32 -6
  18. package/dist/cjs/schemas/drive-query-schema.js +38 -30
  19. package/dist/cjs/schemas/drive-query-schema.js.map +1 -1
  20. package/dist/esm/lib/create-store.js +1 -26
  21. package/dist/esm/lib/create-store.js.map +1 -1
  22. package/dist/esm/lib/query-builder.d.ts +2 -2
  23. package/dist/esm/lib/query-builder.js +1 -1
  24. package/dist/esm/lib/query-builder.js.map +1 -1
  25. package/dist/esm/mcp/prompts/query-syntax.js +1 -1
  26. package/dist/esm/mcp/prompts/query-syntax.js.map +1 -1
  27. package/dist/esm/mcp/tools/files-search.d.ts +2 -2
  28. package/dist/esm/mcp/tools/files-search.js +24 -51
  29. package/dist/esm/mcp/tools/files-search.js.map +1 -1
  30. package/dist/esm/mcp/tools/folder-search.d.ts +2 -2
  31. package/dist/esm/mcp/tools/folder-search.js +25 -56
  32. package/dist/esm/mcp/tools/folder-search.js.map +1 -1
  33. package/dist/esm/schemas/drive-query-schema.d.ts +32 -6
  34. package/dist/esm/schemas/drive-query-schema.js +29 -12
  35. package/dist/esm/schemas/drive-query-schema.js.map +1 -1
  36. package/package.json +1 -1
@@ -142,46 +142,19 @@ function _ts_generator(thisArg, body) {
142
142
  };
143
143
  }
144
144
  }
145
- function parseDefaultTtl(uri) {
146
- try {
147
- var url = new URL(uri);
148
- var ttlParam = url.searchParams.get('ttl');
149
- var ttlSecondsParam = url.searchParams.get('ttlSeconds');
150
- var ttlMs = ttlSecondsParam ? Number(ttlSecondsParam) * 1000 : ttlParam ? Number(ttlParam) : undefined;
151
- url.searchParams.delete('ttl');
152
- url.searchParams.delete('ttlSeconds');
153
- return Number.isFinite(ttlMs) && ttlMs > 0 ? {
154
- uri: url.toString(),
155
- ttl: ttlMs
156
- } : {
157
- uri: url.toString()
158
- };
159
- } catch (unused) {
160
- return {
161
- uri: uri
162
- };
163
- }
164
- }
165
145
  function createStore(uri) {
166
146
  return _async_to_generator(function() {
167
- var _parseDefaultTtl, parsedUri, defaultTtl, store, originalSet;
147
+ var store;
168
148
  return _ts_generator(this, function(_state) {
169
149
  switch(_state.label){
170
150
  case 0:
171
- _parseDefaultTtl = parseDefaultTtl(uri), parsedUri = _parseDefaultTtl.uri, defaultTtl = _parseDefaultTtl.ttl;
172
151
  return [
173
152
  4,
174
- (0, _keyvregistry.default)(parsedUri)
153
+ (0, _keyvregistry.default)(uri)
175
154
  ];
176
155
  case 1:
177
156
  store = _state.sent();
178
157
  if (!store) throw new Error("Failed to create store for URI: ".concat(uri));
179
- if (defaultTtl !== undefined) {
180
- originalSet = store.set.bind(store);
181
- store.set = function(key, value, ttl) {
182
- return originalSet(key, value, ttl !== null && ttl !== void 0 ? ttl : defaultTtl);
183
- };
184
- }
185
158
  return [
186
159
  2,
187
160
  store
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/lib/create-store.ts"],"sourcesContent":["import type Keyv from 'keyv';\nimport keyvRegistry from 'keyv-registry';\n\nfunction parseDefaultTtl(uri: string): { uri: string; ttl?: number } {\n try {\n const url = new URL(uri);\n const ttlParam = url.searchParams.get('ttl');\n const ttlSecondsParam = url.searchParams.get('ttlSeconds');\n const ttlMs = ttlSecondsParam ? Number(ttlSecondsParam) * 1000 : ttlParam ? Number(ttlParam) : undefined;\n url.searchParams.delete('ttl');\n url.searchParams.delete('ttlSeconds');\n return Number.isFinite(ttlMs) && (ttlMs as number) > 0 ? { uri: url.toString(), ttl: ttlMs } : { uri: url.toString() };\n } catch {\n return { uri };\n }\n}\n\nexport default async function createStore<T>(uri: string): Promise<Keyv<T>> {\n const { uri: parsedUri, ttl: defaultTtl } = parseDefaultTtl(uri);\n const store = await keyvRegistry<T>(parsedUri);\n if (!store) throw new Error(`Failed to create store for URI: ${uri}`);\n if (defaultTtl !== undefined) {\n const originalSet = store.set.bind(store);\n store.set = ((key, value, ttl) => originalSet(key, value, ttl ?? defaultTtl)) as typeof store.set;\n }\n return store;\n}\n"],"names":["createStore","parseDefaultTtl","uri","url","URL","ttlParam","searchParams","get","ttlSecondsParam","ttlMs","Number","undefined","delete","isFinite","toString","ttl","parsedUri","defaultTtl","store","originalSet","keyvRegistry","Error","set","bind","key","value"],"mappings":";;;;+BAiBA;;;eAA8BA;;;mEAhBL;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEzB,SAASC,gBAAgBC,GAAW;IAClC,IAAI;QACF,IAAMC,MAAM,IAAIC,IAAIF;QACpB,IAAMG,WAAWF,IAAIG,YAAY,CAACC,GAAG,CAAC;QACtC,IAAMC,kBAAkBL,IAAIG,YAAY,CAACC,GAAG,CAAC;QAC7C,IAAME,QAAQD,kBAAkBE,OAAOF,mBAAmB,OAAOH,WAAWK,OAAOL,YAAYM;QAC/FR,IAAIG,YAAY,CAACM,MAAM,CAAC;QACxBT,IAAIG,YAAY,CAACM,MAAM,CAAC;QACxB,OAAOF,OAAOG,QAAQ,CAACJ,UAAU,AAACA,QAAmB,IAAI;YAAEP,KAAKC,IAAIW,QAAQ;YAAIC,KAAKN;QAAM,IAAI;YAAEP,KAAKC,IAAIW,QAAQ;QAAG;IACvH,EAAE,eAAM;QACN,OAAO;YAAEZ,KAAAA;QAAI;IACf;AACF;AAEe,SAAeF,YAAeE,GAAW;;YACVD,kBAA/Be,WAAgBC,YACvBC,OAGEC;;;;oBAJoClB,mBAAAA,gBAAgBC,MAA/Cc,YAA+Bf,iBAApCC,KAAqBe,aAAehB,iBAApBc;oBACV;;wBAAMK,IAAAA,qBAAY,EAAIJ;;;oBAA9BE,QAAQ;oBACd,IAAI,CAACA,OAAO,MAAM,IAAIG,MAAM,AAAC,mCAAsC,OAAJnB;oBAC/D,IAAIe,eAAeN,WAAW;wBACtBQ,cAAcD,MAAMI,GAAG,CAACC,IAAI,CAACL;wBACnCA,MAAMI,GAAG,GAAI,SAACE,KAAKC,OAAOV;mCAAQI,YAAYK,KAAKC,OAAOV,gBAAAA,iBAAAA,MAAOE;;oBACnE;oBACA;;wBAAOC;;;;IACT"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/lib/create-store.ts"],"sourcesContent":["import type Keyv from 'keyv';\nimport keyvRegistry from 'keyv-registry';\n\nexport default async function createStore<T>(uri: string): Promise<Keyv<T>> {\n const store = await keyvRegistry<T>(uri);\n if (!store) throw new Error(`Failed to create store for URI: ${uri}`);\n return store;\n}\n"],"names":["createStore","uri","store","keyvRegistry","Error"],"mappings":";;;;+BAGA;;;eAA8BA;;;mEAFL;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEV,SAAeA,YAAeC,GAAW;;YAChDC;;;;oBAAQ;;wBAAMC,IAAAA,qBAAY,EAAIF;;;oBAA9BC,QAAQ;oBACd,IAAI,CAACA,OAAO,MAAM,IAAIE,MAAM,AAAC,mCAAsC,OAAJH;oBAC/D;;wBAAOC;;;;IACT"}
@@ -36,9 +36,9 @@ interface FiltersObject {
36
36
  * - sharedWithMe = true - Filter by shared status
37
37
  * - modifiedTime >= 'date' - Date filtering
38
38
  * - 'email' in owners - Filter by owner
39
- * - trashed = false - Exclude trashed files (always added)
39
+ * - trashed = true/false - Filter by trash status
40
40
  */
41
- export declare function toDriveQuery(query: DriveQuery): {
41
+ export declare function toDriveQuery(query: DriveQuery | string): {
42
42
  q: string;
43
43
  filters: FiltersObject;
44
44
  };
@@ -36,9 +36,9 @@ interface FiltersObject {
36
36
  * - sharedWithMe = true - Filter by shared status
37
37
  * - modifiedTime >= 'date' - Date filtering
38
38
  * - 'email' in owners - Filter by owner
39
- * - trashed = false - Exclude trashed files (always added)
39
+ * - trashed = true/false - Filter by trash status
40
40
  */
41
- export declare function toDriveQuery(query: DriveQuery): {
41
+ export declare function toDriveQuery(query: DriveQuery | string): {
42
42
  q: string;
43
43
  filters: FiltersObject;
44
44
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/lib/query-builder.ts"],"sourcesContent":["import type { DriveQuery, DriveQueryObject } from '../schemas/drive-query-schema.ts';\n\n/**\n * Field operator interface for query filters\n */\nexport interface FieldOperator {\n $any?: string[];\n $all?: string[];\n $none?: string[];\n}\n\n/**\n * Filters object returned by toDriveQuery for debugging/logging\n */\ninterface FiltersObject {\n nameIncludes?: string[];\n mimeTypeIncludes?: string[];\n fullTextIncludes?: string[];\n parentIdIncludes?: string[];\n ownerIncludes?: string[];\n starred?: boolean;\n sharedWithMe?: boolean;\n trashed?: boolean;\n}\n\n/**\n * Convert structured DriveQuery to Google Drive query string\n *\n * Accepts either:\n * - A raw Drive query string (returned as-is)\n * - A structured DriveQueryObject (converted to Drive query syntax)\n *\n * Drive query syntax reference:\n * - name contains 'text' - Search by filename\n * - mimeType = 'type' - Filter by MIME type\n * - fullText contains 'text' - Search content and metadata\n * - 'parent_id' in parents - Search in folder\n * - starred = true/false - Filter by starred status\n * - sharedWithMe = true - Filter by shared status\n * - modifiedTime >= 'date' - Date filtering\n * - 'email' in owners - Filter by owner\n * - trashed = false - Exclude trashed files (always added)\n */\nexport function toDriveQuery(query: DriveQuery): {\n q: string;\n filters: FiltersObject;\n} {\n // Handle string queries - return as raw query with empty filters\n if (typeof query === 'string') {\n return { q: query, filters: {} };\n }\n const nameIncludes: string[] = [];\n const mimeTypeIncludes: string[] = [];\n const fullTextIncludes: string[] = [];\n const parentIdIncludes: string[] = [];\n const ownerIncludes: string[] = [];\n\n let starredFlag: boolean | undefined;\n let sharedWithMeFlag: boolean | undefined;\n let trashedFlag: boolean | undefined;\n\n function p(s: unknown) {\n return `(${String(s ?? '')})`;\n }\n\n function quote(s?: unknown) {\n const str = String(s ?? '');\n // Escape single quotes for Drive query syntax\n return `'${str.replace(/'/g, \"\\\\'\")}'`;\n }\n\n function fv(field: string, raw?: unknown) {\n const rawVal = String(raw ?? '');\n const v = quote(rawVal);\n\n if (field === 'name') {\n nameIncludes.push(rawVal);\n return `name contains ${v}`;\n }\n if (field === 'mimeType') {\n mimeTypeIncludes.push(rawVal);\n return `mimeType = ${v}`;\n }\n if (field === 'fullText') {\n fullTextIncludes.push(rawVal);\n return `fullText contains ${v}`;\n }\n if (field === 'parentId') {\n parentIdIncludes.push(rawVal);\n return `${v} in parents`;\n }\n if (field === 'owner') {\n ownerIncludes.push(rawVal);\n return `${v} in owners`;\n }\n\n return '';\n }\n\n function chain(op: 'and' | 'or', arr: string[]) {\n const filtered = arr.filter((s) => s && s.trim() !== '');\n if (filtered.length === 0) return '';\n if (filtered.length === 1) {\n const first = filtered[0];\n return first ?? '';\n }\n return p(filtered.join(` ${op} `));\n }\n\n function fieldExpr(field: string, op: FieldOperator) {\n if (op.$any) {\n const nonEmpty = op.$any.filter((v: string) => String(v ?? '').trim() !== '');\n const results = nonEmpty.map((v: string) => fv(field, String(v ?? ''))).filter((result: string) => result.trim() !== '');\n return results.length > 0 ? chain('or', results) : '';\n }\n if (op.$all) {\n const nonEmpty = op.$all.filter((v: string) => String(v ?? '').trim() !== '');\n const results = nonEmpty.map((v: string) => fv(field, String(v ?? ''))).filter((result: string) => result.trim() !== '');\n return results.length > 0 ? chain('and', results) : '';\n }\n if (op.$none) {\n const nonEmpty = op.$none.filter((v: string) => String(v ?? '').trim() !== '');\n const results = nonEmpty.map((v: string) => fv(field, String(v ?? ''))).filter((result: string) => result.trim() !== '');\n return results.length > 0 ? `not ${p(chain('or', results))}` : '';\n }\n throw new Error(`Unknown field operator ${JSON.stringify(op)}`);\n }\n\n function dateExpr(d: { $gte?: string; $lt?: string }) {\n const parts: string[] = [];\n if (d.$gte) parts.push(`modifiedTime >= '${d.$gte}'`);\n if (d.$lt) parts.push(`modifiedTime < '${d.$lt}'`);\n return parts.length > 1 ? p(parts.join(' and ')) : (parts[0] ?? '');\n }\n\n function fieldKeys() {\n return ['name', 'mimeType', 'fullText', 'parentId', 'owner'];\n }\n\n function emit(n: DriveQueryObject): string {\n if (n.$and) return p(n.$and.map(emit).join(' and '));\n if (n.$or) return p(n.$or.map(emit).join(' or '));\n if (n.$not) return `not ${emit(n.$not)}`;\n\n const expressions: string[] = [];\n\n if (typeof n.starred === 'boolean') {\n starredFlag = n.starred;\n expressions.push(`starred = ${n.starred}`);\n }\n if (typeof n.sharedWithMe === 'boolean') {\n sharedWithMeFlag = n.sharedWithMe;\n expressions.push(`sharedWithMe = ${n.sharedWithMe}`);\n }\n if (typeof n.trashed === 'boolean') {\n trashedFlag = n.trashed;\n expressions.push(`trashed = ${n.trashed}`);\n }\n if (n.modifiedTime) {\n expressions.push(dateExpr(n.modifiedTime));\n }\n\n for (const k of fieldKeys()) {\n if (typeof n === 'object' && n !== null && k in n) {\n const op = (n as Record<string, string | FieldOperator>)[k];\n const normalizedOp: FieldOperator = typeof op === 'string' ? { $any: [op] } : (op ?? {});\n const result = fieldExpr(k, normalizedOp);\n if (result.trim() !== '') {\n expressions.push(result);\n }\n }\n }\n\n // Handle empty objects\n if (expressions.length === 0 && typeof n === 'object' && n !== null && Object.keys(n).length === 0) {\n return '';\n }\n\n // Combine multiple expressions with AND\n if (expressions.length > 1) {\n return chain('and', expressions);\n }\n if (expressions.length === 1) {\n return expressions[0] ?? '';\n }\n\n throw new Error(`Unknown node: ${JSON.stringify(n)}`);\n }\n\n function emitTop(n: DriveQueryObject): string {\n if (!n) return '';\n\n // Handle empty objects\n if (typeof n === 'object' && n !== null && Object.keys(n).length === 0) return '';\n\n if (n.$and) return n.$and.map(emit).join(' and ');\n if (n.$or) return n.$or.map(emit).join(' or ');\n if (n.$not) return `not ${emit(n.$not)}`;\n\n const result = emit(n);\n return result.trim() === '' ? '' : result;\n }\n\n const q = emitTop(query);\n const cleanedQuery = q.replace(/\\s+and\\s+$|\\s+or\\s+$|^\\s+and\\s+|^\\s+or\\s+/gi, '').trim();\n\n const filters: FiltersObject = {};\n if (nameIncludes.length) filters.nameIncludes = nameIncludes;\n if (mimeTypeIncludes.length) filters.mimeTypeIncludes = mimeTypeIncludes;\n if (fullTextIncludes.length) filters.fullTextIncludes = fullTextIncludes;\n if (parentIdIncludes.length) filters.parentIdIncludes = parentIdIncludes;\n if (ownerIncludes.length) filters.ownerIncludes = ownerIncludes;\n // Use tracked flags from emit() to capture nested boolean conditions\n if (typeof starredFlag === 'boolean') filters.starred = starredFlag;\n if (typeof sharedWithMeFlag === 'boolean') filters.sharedWithMe = sharedWithMeFlag;\n if (typeof trashedFlag === 'boolean') filters.trashed = trashedFlag;\n\n return { q: cleanedQuery ?? '', filters };\n}\n"],"names":["toDriveQuery","query","q","filters","nameIncludes","mimeTypeIncludes","fullTextIncludes","parentIdIncludes","ownerIncludes","starredFlag","sharedWithMeFlag","trashedFlag","p","s","String","quote","str","replace","fv","field","raw","rawVal","v","push","chain","op","arr","filtered","filter","trim","length","first","join","fieldExpr","$any","nonEmpty","results","map","result","$all","$none","Error","JSON","stringify","dateExpr","d","parts","$gte","$lt","fieldKeys","emit","n","$and","$or","$not","expressions","starred","sharedWithMe","trashed","modifiedTime","k","normalizedOp","Object","keys","emitTop","cleanedQuery"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/lib/query-builder.ts"],"sourcesContent":["import type { DriveQuery, DriveQueryObject } from '../schemas/drive-query-schema.ts';\n\n/**\n * Field operator interface for query filters\n */\nexport interface FieldOperator {\n $any?: string[];\n $all?: string[];\n $none?: string[];\n}\n\n/**\n * Filters object returned by toDriveQuery for debugging/logging\n */\ninterface FiltersObject {\n nameIncludes?: string[];\n mimeTypeIncludes?: string[];\n fullTextIncludes?: string[];\n parentIdIncludes?: string[];\n ownerIncludes?: string[];\n starred?: boolean;\n sharedWithMe?: boolean;\n trashed?: boolean;\n}\n\n/**\n * Convert structured DriveQuery to Google Drive query string\n *\n * Accepts either:\n * - A raw Drive query string (returned as-is)\n * - A structured DriveQueryObject (converted to Drive query syntax)\n *\n * Drive query syntax reference:\n * - name contains 'text' - Search by filename\n * - mimeType = 'type' - Filter by MIME type\n * - fullText contains 'text' - Search content and metadata\n * - 'parent_id' in parents - Search in folder\n * - starred = true/false - Filter by starred status\n * - sharedWithMe = true - Filter by shared status\n * - modifiedTime >= 'date' - Date filtering\n * - 'email' in owners - Filter by owner\n * - trashed = true/false - Filter by trash status\n */\nexport function toDriveQuery(query: DriveQuery | string): {\n q: string;\n filters: FiltersObject;\n} {\n // Handle string queries - return as raw query with empty filters\n if (typeof query === 'string') {\n return { q: query, filters: {} };\n }\n const nameIncludes: string[] = [];\n const mimeTypeIncludes: string[] = [];\n const fullTextIncludes: string[] = [];\n const parentIdIncludes: string[] = [];\n const ownerIncludes: string[] = [];\n\n let starredFlag: boolean | undefined;\n let sharedWithMeFlag: boolean | undefined;\n let trashedFlag: boolean | undefined;\n\n function p(s: unknown) {\n return `(${String(s ?? '')})`;\n }\n\n function quote(s?: unknown) {\n const str = String(s ?? '');\n // Escape single quotes for Drive query syntax\n return `'${str.replace(/'/g, \"\\\\'\")}'`;\n }\n\n function fv(field: string, raw?: unknown) {\n const rawVal = String(raw ?? '');\n const v = quote(rawVal);\n\n if (field === 'name') {\n nameIncludes.push(rawVal);\n return `name contains ${v}`;\n }\n if (field === 'mimeType') {\n mimeTypeIncludes.push(rawVal);\n return `mimeType = ${v}`;\n }\n if (field === 'fullText') {\n fullTextIncludes.push(rawVal);\n return `fullText contains ${v}`;\n }\n if (field === 'parentId') {\n parentIdIncludes.push(rawVal);\n return `${v} in parents`;\n }\n if (field === 'owner') {\n ownerIncludes.push(rawVal);\n return `${v} in owners`;\n }\n\n return '';\n }\n\n function chain(op: 'and' | 'or', arr: string[]) {\n const filtered = arr.filter((s) => s && s.trim() !== '');\n if (filtered.length === 0) return '';\n if (filtered.length === 1) {\n const first = filtered[0];\n return first ?? '';\n }\n return p(filtered.join(` ${op} `));\n }\n\n function fieldExpr(field: string, op: FieldOperator) {\n if (op.$any) {\n const nonEmpty = op.$any.filter((v: string) => String(v ?? '').trim() !== '');\n const results = nonEmpty.map((v: string) => fv(field, String(v ?? ''))).filter((result: string) => result.trim() !== '');\n return results.length > 0 ? chain('or', results) : '';\n }\n if (op.$all) {\n const nonEmpty = op.$all.filter((v: string) => String(v ?? '').trim() !== '');\n const results = nonEmpty.map((v: string) => fv(field, String(v ?? ''))).filter((result: string) => result.trim() !== '');\n return results.length > 0 ? chain('and', results) : '';\n }\n if (op.$none) {\n const nonEmpty = op.$none.filter((v: string) => String(v ?? '').trim() !== '');\n const results = nonEmpty.map((v: string) => fv(field, String(v ?? ''))).filter((result: string) => result.trim() !== '');\n return results.length > 0 ? `not ${p(chain('or', results))}` : '';\n }\n throw new Error(`Unknown field operator ${JSON.stringify(op)}`);\n }\n\n function dateExpr(d: { $gte?: string; $lt?: string }) {\n const parts: string[] = [];\n if (d.$gte) parts.push(`modifiedTime >= '${d.$gte}'`);\n if (d.$lt) parts.push(`modifiedTime < '${d.$lt}'`);\n return parts.length > 1 ? p(parts.join(' and ')) : (parts[0] ?? '');\n }\n\n function fieldKeys() {\n return ['name', 'mimeType', 'fullText', 'parentId', 'owner'];\n }\n\n function emit(n: DriveQueryObject): string {\n if (n.$and) return p(n.$and.map(emit).join(' and '));\n if (n.$or) return p(n.$or.map(emit).join(' or '));\n if (n.$not) return `not ${emit(n.$not)}`;\n\n const expressions: string[] = [];\n\n if (typeof n.starred === 'boolean') {\n starredFlag = n.starred;\n expressions.push(`starred = ${n.starred}`);\n }\n if (typeof n.sharedWithMe === 'boolean') {\n sharedWithMeFlag = n.sharedWithMe;\n expressions.push(`sharedWithMe = ${n.sharedWithMe}`);\n }\n if (typeof n.trashed === 'boolean') {\n trashedFlag = n.trashed;\n expressions.push(`trashed = ${n.trashed}`);\n }\n if (n.modifiedTime) {\n expressions.push(dateExpr(n.modifiedTime));\n }\n\n for (const k of fieldKeys()) {\n if (typeof n === 'object' && n !== null && k in n) {\n const op = (n as Record<string, string | FieldOperator>)[k];\n const normalizedOp: FieldOperator = typeof op === 'string' ? { $any: [op] } : (op ?? {});\n const result = fieldExpr(k, normalizedOp);\n if (result.trim() !== '') {\n expressions.push(result);\n }\n }\n }\n\n // Handle empty objects\n if (expressions.length === 0 && typeof n === 'object' && n !== null && Object.keys(n).length === 0) {\n return '';\n }\n\n // Combine multiple expressions with AND\n if (expressions.length > 1) {\n return chain('and', expressions);\n }\n if (expressions.length === 1) {\n return expressions[0] ?? '';\n }\n\n throw new Error(`Unknown node: ${JSON.stringify(n)}`);\n }\n\n function emitTop(n: DriveQueryObject): string {\n if (!n) return '';\n\n // Handle empty objects\n if (typeof n === 'object' && n !== null && Object.keys(n).length === 0) return '';\n\n if (n.$and) return n.$and.map(emit).join(' and ');\n if (n.$or) return n.$or.map(emit).join(' or ');\n if (n.$not) return `not ${emit(n.$not)}`;\n\n const result = emit(n);\n return result.trim() === '' ? '' : result;\n }\n\n const q = emitTop(query);\n const cleanedQuery = q.replace(/\\s+and\\s+$|\\s+or\\s+$|^\\s+and\\s+|^\\s+or\\s+/gi, '').trim();\n\n const filters: FiltersObject = {};\n if (nameIncludes.length) filters.nameIncludes = nameIncludes;\n if (mimeTypeIncludes.length) filters.mimeTypeIncludes = mimeTypeIncludes;\n if (fullTextIncludes.length) filters.fullTextIncludes = fullTextIncludes;\n if (parentIdIncludes.length) filters.parentIdIncludes = parentIdIncludes;\n if (ownerIncludes.length) filters.ownerIncludes = ownerIncludes;\n // Use tracked flags from emit() to capture nested boolean conditions\n if (typeof starredFlag === 'boolean') filters.starred = starredFlag;\n if (typeof sharedWithMeFlag === 'boolean') filters.sharedWithMe = sharedWithMeFlag;\n if (typeof trashedFlag === 'boolean') filters.trashed = trashedFlag;\n\n return { q: cleanedQuery ?? '', filters };\n}\n"],"names":["toDriveQuery","query","q","filters","nameIncludes","mimeTypeIncludes","fullTextIncludes","parentIdIncludes","ownerIncludes","starredFlag","sharedWithMeFlag","trashedFlag","p","s","String","quote","str","replace","fv","field","raw","rawVal","v","push","chain","op","arr","filtered","filter","trim","length","first","join","fieldExpr","$any","nonEmpty","results","map","result","$all","$none","Error","JSON","stringify","dateExpr","d","parts","$gte","$lt","fieldKeys","emit","n","$and","$or","$not","expressions","starred","sharedWithMe","trashed","modifiedTime","k","normalizedOp","Object","keys","emitTop","cleanedQuery"],"mappings":"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"}
@@ -151,7 +151,7 @@ function createPrompt() {
151
151
  role: 'user',
152
152
  content: {
153
153
  type: 'text',
154
- text: '# Google Drive Query Syntax Reference\n\n## Logical Operators\n- `$and`: Array of conditions that ALL must match\n- `$or`: Array of conditions where ANY must match\n- `$not`: Condition that must NOT match\n\n## File/Folder Fields\n- `name`: Search by name (partial match, case-insensitive)\n- `mimeType`: Filter by MIME type\n- `fullText`: Search file content and metadata\n- `parentId`: Search within folder (use "root" for My Drive)\n- `owner`: Filter by owner email\n\n## Boolean Flags\n- `starred`: true/false\n- `sharedWithMe`: true/false\n- `trashed`: true/false (tools auto-filter trashed by default)\n\n## Date Range\n```json\n{ "modifiedTime": { "$gte": "2024-01-01", "$lt": "2024-12-31" } }\n```\n\n## Common MIME Types\n- `application/vnd.google-apps.folder`: Folders\n- `application/vnd.google-apps.document`: Google Docs\n- `application/vnd.google-apps.spreadsheet`: Google Sheets\n- `application/vnd.google-apps.presentation`: Google Slides\n- `application/pdf`: PDF files\n- `image/jpeg`, `image/png`: Images\n\n## Field Operators (for multi-value fields)\n- `$any`: OR - matches if ANY value matches\n- `$all`: AND - matches if ALL values match\n- `$none`: NOT - matches if NONE match\n\n## Escape Hatch\n- `rawDriveQuery`: Raw Google Drive query syntax\n\n## Example Queries\n```json\n// PDFs modified this year\n{ "mimeType": "application/pdf", "modifiedTime": { "$gte": "2024-01-01" } }\n\n// Starred spreadsheets\n{ "mimeType": "application/vnd.google-apps.spreadsheet", "starred": true }\n\n// Files in specific folder\n{ "parentId": "1abc123xyz" }\n\n// Search by name\n{ "name": "budget" }\n\n// Complex: shared PDFs or Docs\n{ "$or": [\n { "mimeType": "application/pdf", "sharedWithMe": true },\n { "mimeType": "application/vnd.google-apps.document", "sharedWithMe": true }\n]}\n```'
154
+ text: '# Google Drive Query Syntax Reference\n\n## Logical Operators\n- `$and`: Array of conditions that ALL must match\n- `$or`: Array of conditions where ANY must match\n- `$not`: Condition that must NOT match\n\n## File/Folder Fields\n- `name`: Search by name (partial match, case-insensitive)\n- `mimeType`: Filter by MIME type\n- `fullText`: Search file content and metadata\n- `parentId`: Search within folder (use "root" for My Drive)\n- `owner`: Filter by owner email\n\n## Boolean Flags\n- `starred`: true/false\n- `sharedWithMe`: true/false\n- `trashed`: true/false\n\n## Date Range\n```json\n{ "modifiedTime": { "$gte": "2024-01-01", "$lt": "2024-12-31" } }\n```\n\n## Common MIME Types\n- `application/vnd.google-apps.folder`: Folders\n- `application/vnd.google-apps.document`: Google Docs\n- `application/vnd.google-apps.spreadsheet`: Google Sheets\n- `application/vnd.google-apps.presentation`: Google Slides\n- `application/pdf`: PDF files\n- `image/jpeg`, `image/png`: Images\n\n## Field Operators (for multi-value fields)\n- `$any`: OR - matches if ANY value matches\n- `$all`: AND - matches if ALL values match\n- `$none`: NOT - matches if NONE match\n\n## Escape Hatch\n- `rawDriveQuery`: Raw Google Drive query syntax\n\n## Example Queries\n```json\n// PDFs modified this year\n{ "mimeType": "application/pdf", "modifiedTime": { "$gte": "2024-01-01" } }\n\n// Starred spreadsheets\n{ "mimeType": "application/vnd.google-apps.spreadsheet", "starred": true }\n\n// Files in specific folder\n{ "parentId": "1abc123xyz" }\n\n// Search by name\n{ "name": "budget" }\n\n// Complex: shared PDFs or Docs\n{ "$or": [\n { "mimeType": "application/pdf", "sharedWithMe": true },\n { "mimeType": "application/vnd.google-apps.document", "sharedWithMe": true }\n]}\n```'
155
155
  }
156
156
  }
157
157
  ]
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/mcp/prompts/query-syntax.ts"],"sourcesContent":["import type { PromptModule } from '@mcp-z/server';\nimport type { RequestHandlerExtra } from '@modelcontextprotocol/sdk/shared/protocol.js';\nimport type { ServerNotification, ServerRequest } from '@modelcontextprotocol/sdk/types.js';\n\nexport default function createPrompt() {\n const config = {\n description: 'Reference guide for Google Drive query syntax',\n };\n\n const handler = async (_args: { [x: string]: unknown }, _extra: RequestHandlerExtra<ServerRequest, ServerNotification>) => {\n return {\n messages: [\n {\n role: 'user' as const,\n content: {\n type: 'text' as const,\n text: `# Google Drive Query Syntax Reference\n\n## Logical Operators\n- \\`$and\\`: Array of conditions that ALL must match\n- \\`$or\\`: Array of conditions where ANY must match\n- \\`$not\\`: Condition that must NOT match\n\n## File/Folder Fields\n- \\`name\\`: Search by name (partial match, case-insensitive)\n- \\`mimeType\\`: Filter by MIME type\n- \\`fullText\\`: Search file content and metadata\n- \\`parentId\\`: Search within folder (use \"root\" for My Drive)\n- \\`owner\\`: Filter by owner email\n\n## Boolean Flags\n- \\`starred\\`: true/false\n- \\`sharedWithMe\\`: true/false\n- \\`trashed\\`: true/false (tools auto-filter trashed by default)\n\n## Date Range\n\\`\\`\\`json\n{ \"modifiedTime\": { \"$gte\": \"2024-01-01\", \"$lt\": \"2024-12-31\" } }\n\\`\\`\\`\n\n## Common MIME Types\n- \\`application/vnd.google-apps.folder\\`: Folders\n- \\`application/vnd.google-apps.document\\`: Google Docs\n- \\`application/vnd.google-apps.spreadsheet\\`: Google Sheets\n- \\`application/vnd.google-apps.presentation\\`: Google Slides\n- \\`application/pdf\\`: PDF files\n- \\`image/jpeg\\`, \\`image/png\\`: Images\n\n## Field Operators (for multi-value fields)\n- \\`$any\\`: OR - matches if ANY value matches\n- \\`$all\\`: AND - matches if ALL values match\n- \\`$none\\`: NOT - matches if NONE match\n\n## Escape Hatch\n- \\`rawDriveQuery\\`: Raw Google Drive query syntax\n\n## Example Queries\n\\`\\`\\`json\n// PDFs modified this year\n{ \"mimeType\": \"application/pdf\", \"modifiedTime\": { \"$gte\": \"2024-01-01\" } }\n\n// Starred spreadsheets\n{ \"mimeType\": \"application/vnd.google-apps.spreadsheet\", \"starred\": true }\n\n// Files in specific folder\n{ \"parentId\": \"1abc123xyz\" }\n\n// Search by name\n{ \"name\": \"budget\" }\n\n// Complex: shared PDFs or Docs\n{ \"$or\": [\n { \"mimeType\": \"application/pdf\", \"sharedWithMe\": true },\n { \"mimeType\": \"application/vnd.google-apps.document\", \"sharedWithMe\": true }\n]}\n\\`\\`\\``,\n },\n },\n ],\n };\n };\n\n return {\n name: 'query-syntax',\n config,\n handler,\n } satisfies PromptModule;\n}\n"],"names":["createPrompt","config","description","handler","_args","_extra","messages","role","content","type","text","name"],"mappings":";;;;+BAIA;;;eAAwBA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAT,SAASA;IACtB,IAAMC,SAAS;QACbC,aAAa;IACf;IAEA,IAAMC,UAAU,SAAOC,OAAiCC;;;gBACtD;;oBAAO;wBACLC,QAAQ;4BACN;gCACEC,MAAM;gCACNC,SAAS;oCACPC,MAAM;oCACNC,MAAM;gCA4DR;4BACF;;oBAEJ;;;QACF;;IAEA,OAAO;QACLC,MAAM;QACNV,QAAAA;QACAE,SAAAA;IACF;AACF"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-drive/src/mcp/prompts/query-syntax.ts"],"sourcesContent":["import type { PromptModule } from '@mcp-z/server';\nimport type { RequestHandlerExtra } from '@modelcontextprotocol/sdk/shared/protocol.js';\nimport type { ServerNotification, ServerRequest } from '@modelcontextprotocol/sdk/types.js';\n\nexport default function createPrompt() {\n const config = {\n description: 'Reference guide for Google Drive query syntax',\n };\n\n const handler = async (_args: { [x: string]: unknown }, _extra: RequestHandlerExtra<ServerRequest, ServerNotification>) => {\n return {\n messages: [\n {\n role: 'user' as const,\n content: {\n type: 'text' as const,\n text: `# Google Drive Query Syntax Reference\n\n## Logical Operators\n- \\`$and\\`: Array of conditions that ALL must match\n- \\`$or\\`: Array of conditions where ANY must match\n- \\`$not\\`: Condition that must NOT match\n\n## File/Folder Fields\n- \\`name\\`: Search by name (partial match, case-insensitive)\n- \\`mimeType\\`: Filter by MIME type\n- \\`fullText\\`: Search file content and metadata\n- \\`parentId\\`: Search within folder (use \"root\" for My Drive)\n- \\`owner\\`: Filter by owner email\n\n## Boolean Flags\n- \\`starred\\`: true/false\n- \\`sharedWithMe\\`: true/false\n- \\`trashed\\`: true/false\n\n## Date Range\n\\`\\`\\`json\n{ \"modifiedTime\": { \"$gte\": \"2024-01-01\", \"$lt\": \"2024-12-31\" } }\n\\`\\`\\`\n\n## Common MIME Types\n- \\`application/vnd.google-apps.folder\\`: Folders\n- \\`application/vnd.google-apps.document\\`: Google Docs\n- \\`application/vnd.google-apps.spreadsheet\\`: Google Sheets\n- \\`application/vnd.google-apps.presentation\\`: Google Slides\n- \\`application/pdf\\`: PDF files\n- \\`image/jpeg\\`, \\`image/png\\`: Images\n\n## Field Operators (for multi-value fields)\n- \\`$any\\`: OR - matches if ANY value matches\n- \\`$all\\`: AND - matches if ALL values match\n- \\`$none\\`: NOT - matches if NONE match\n\n## Escape Hatch\n- \\`rawDriveQuery\\`: Raw Google Drive query syntax\n\n## Example Queries\n\\`\\`\\`json\n// PDFs modified this year\n{ \"mimeType\": \"application/pdf\", \"modifiedTime\": { \"$gte\": \"2024-01-01\" } }\n\n// Starred spreadsheets\n{ \"mimeType\": \"application/vnd.google-apps.spreadsheet\", \"starred\": true }\n\n// Files in specific folder\n{ \"parentId\": \"1abc123xyz\" }\n\n// Search by name\n{ \"name\": \"budget\" }\n\n// Complex: shared PDFs or Docs\n{ \"$or\": [\n { \"mimeType\": \"application/pdf\", \"sharedWithMe\": true },\n { \"mimeType\": \"application/vnd.google-apps.document\", \"sharedWithMe\": true }\n]}\n\\`\\`\\``,\n },\n },\n ],\n };\n };\n\n return {\n name: 'query-syntax',\n config,\n handler,\n } satisfies PromptModule;\n}\n"],"names":["createPrompt","config","description","handler","_args","_extra","messages","role","content","type","text","name"],"mappings":";;;;+BAIA;;;eAAwBA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAT,SAASA;IACtB,IAAMC,SAAS;QACbC,aAAa;IACf;IAEA,IAAMC,UAAU,SAAOC,OAAiCC;;;gBACtD;;oBAAO;wBACLC,QAAQ;4BACN;gCACEC,MAAM;gCACNC,SAAS;oCACPC,MAAM;oCACNC,MAAM;gCA4DR;4BACF;;oBAEJ;;;QACF;;IAEA,OAAO;QACLC,MAAM;QACNV,QAAAA;QACAE,SAAAA;IACF;AACF"}
@@ -8,7 +8,7 @@ declare const inputSchema: z.ZodObject<{
8
8
  }>>>;
9
9
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
10
10
  pageToken: z.ZodOptional<z.ZodString>;
11
- query: z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>]>;
11
+ query: z.ZodType<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>;
12
12
  fields: z.ZodOptional<z.ZodString>;
13
13
  }, z.core.$strip>;
14
14
  declare const outputSchema: z.ZodUnion<readonly [z.ZodObject<{
@@ -75,7 +75,7 @@ export default function createTool(): {
75
75
  }>>>;
76
76
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
77
77
  pageToken: z.ZodOptional<z.ZodString>;
78
- query: z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>]>;
78
+ query: z.ZodType<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>;
79
79
  fields: z.ZodOptional<z.ZodString>;
80
80
  }, z.core.$strip>;
81
81
  readonly outputSchema: z.ZodObject<{
@@ -8,7 +8,7 @@ declare const inputSchema: z.ZodObject<{
8
8
  }>>>;
9
9
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
10
10
  pageToken: z.ZodOptional<z.ZodString>;
11
- query: z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>]>;
11
+ query: z.ZodType<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>;
12
12
  fields: z.ZodOptional<z.ZodString>;
13
13
  }, z.core.$strip>;
14
14
  declare const outputSchema: z.ZodUnion<readonly [z.ZodObject<{
@@ -75,7 +75,7 @@ export default function createTool(): {
75
75
  }>>>;
76
76
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
77
77
  pageToken: z.ZodOptional<z.ZodString>;
78
- query: z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>]>;
78
+ query: z.ZodType<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../schemas/drive-query-schema.js").DriveQueryObject, unknown>>;
79
79
  fields: z.ZodOptional<z.ZodString>;
80
80
  }, z.core.$strip>;
81
81
  readonly outputSchema: z.ZodObject<{
@@ -103,10 +103,6 @@ function _object_spread_props(target, source) {
103
103
  }
104
104
  return target;
105
105
  }
106
- function _type_of(obj) {
107
- "@swc/helpers - typeof";
108
- return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
109
- }
110
106
  function _ts_generator(thisArg, body) {
111
107
  var f, y, t, _ = {
112
108
  label: 0,
@@ -208,7 +204,7 @@ function _ts_generator(thisArg, body) {
208
204
  }
209
205
  var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
210
206
  var inputSchema = _zod.z.object(_object_spread_props(_object_spread({
211
- query: _indexts.DriveQuerySchema.describe('Drive query object with structured search fields. See DriveQuerySchema for detailed query syntax and examples.'),
207
+ query: _indexts.DriveQueryParameterSchema.describe('Structured Drive query object or JSON string. Use rawDriveQuery for raw Drive syntax.'),
212
208
  fields: (0, _server.createFieldsSchema)({
213
209
  availableFields: _indexts.DRIVE_FILE_FIELDS,
214
210
  fieldDescriptions: _indexts.DRIVE_FILE_FIELD_DESCRIPTIONS,
@@ -255,21 +251,12 @@ var config = {
255
251
  };
256
252
  function handler(_0, _1) {
257
253
  return _async_to_generator(function(param, extra) {
258
- var query, _param_pageSize, pageSize, pageToken, fields, _param_shape, shape, logger, requestedFields, validPageSize, drive, qStr, q, listOptions, response, res, files, parentIds, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, f, _iteratorNormalCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, parentId, parentNameMap, parentFetches, items, filteredItems, nextPageToken, result, error, message, isDriveValidationError, result1;
254
+ var query, _param_pageSize, pageSize, pageToken, fields, _param_shape, shape, logger, parsedQuery, requestedFields, validPageSize, drive, qStr, q, listOptions, response, res, files, parentIds, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, f, _iteratorNormalCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, parentId, parentNameMap, parentFetches, items, filteredItems, nextPageToken, result, error, message;
259
255
  return _ts_generator(this, function(_state) {
260
256
  switch(_state.label){
261
257
  case 0:
262
258
  query = param.query, _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;
263
259
  logger = extra.logger;
264
- requestedFields = (0, _server.parseFields)(fields, _indexts.DRIVE_FILE_FIELDS);
265
- // Validate and clamp pageSize to Google Drive API limits (1-1000)
266
- validPageSize = Math.max(1, Math.min(1000, Math.floor(pageSize || 50)));
267
- logger.info('drive.files-search called', {
268
- query: query,
269
- pageSize: validPageSize,
270
- pageToken: pageToken ? '[provided]' : undefined,
271
- fields: fields || 'all'
272
- });
273
260
  _state.label = 1;
274
261
  case 1:
275
262
  _state.trys.push([
@@ -278,27 +265,38 @@ function handler(_0, _1) {
278
265
  ,
279
266
  6
280
267
  ]);
268
+ parsedQuery = (0, _indexts.parseDriveQueryParameter)(query);
269
+ requestedFields = (0, _server.parseFields)(fields, _indexts.DRIVE_FILE_FIELDS);
270
+ // Validate and clamp pageSize to Google Drive API limits (1-1000)
271
+ validPageSize = Math.max(1, Math.min(1000, Math.floor(pageSize || 50)));
272
+ logger.info('drive.files-search called', {
273
+ query: parsedQuery,
274
+ pageSize: validPageSize,
275
+ pageToken: pageToken ? '[provided]' : undefined,
276
+ fields: fields || 'all'
277
+ });
281
278
  drive = _googleapis.google.drive({
282
279
  version: 'v3',
283
280
  auth: extra.authContext.auth
284
281
  });
285
- if (typeof query === 'string') {
286
- // String query - treat as raw Drive query
287
- qStr = "(".concat(query, ") and trashed = false");
288
- } else if (query && (typeof query === "undefined" ? "undefined" : _type_of(query)) === 'object' && 'rawDriveQuery' in query && query.rawDriveQuery) {
282
+ if (parsedQuery && 'rawDriveQuery' in parsedQuery && parsedQuery.rawDriveQuery) {
289
283
  // Object with rawDriveQuery field - use it directly
290
- qStr = "(".concat(query.rawDriveQuery, ") and trashed = false");
291
- } else {
284
+ qStr = parsedQuery.rawDriveQuery;
285
+ } else if (parsedQuery) {
292
286
  // Structured query object - convert to Drive query string
293
- q = (0, _querybuilderts.toDriveQuery)(query).q;
294
- qStr = q ? "(".concat(q, ") and trashed = false") : 'trashed = false';
287
+ q = (0, _querybuilderts.toDriveQuery)(parsedQuery).q;
288
+ qStr = q || '';
289
+ } else {
290
+ qStr = '';
295
291
  }
296
292
  listOptions = {
297
- q: qStr,
298
293
  pageSize: validPageSize,
299
294
  fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',
300
295
  orderBy: 'modifiedTime desc'
301
296
  };
297
+ if (qStr.trim().length > 0) {
298
+ listOptions.q = qStr;
299
+ }
302
300
  if (pageToken && pageToken.trim().length > 0) {
303
301
  listOptions.pageToken = pageToken;
304
302
  }
@@ -462,7 +460,7 @@ function handler(_0, _1) {
462
460
  return (0, _server.filterFields)(item, requestedFields);
463
461
  });
464
462
  logger.info('drive.files-search returning', {
465
- query: query,
463
+ query: parsedQuery,
466
464
  pageSize: pageSize,
467
465
  resultCount: filteredItems.length,
468
466
  fields: fields || 'all'
@@ -504,39 +502,7 @@ function handler(_0, _1) {
504
502
  logger.error('drive.files-search error', {
505
503
  error: message
506
504
  });
507
- // Check if this is a Drive API validation error (invalid query, invalid pageToken, etc.)
508
- // These should return empty results rather than throw
509
- isDriveValidationError = message.includes('Invalid Value') || message.includes('Invalid value') || message.includes('File not found') || message.includes('Bad Request');
510
- if (isDriveValidationError) {
511
- // Return empty result set for validation errors
512
- result1 = shape === 'arrays' ? {
513
- type: 'success',
514
- shape: 'arrays',
515
- columns: [],
516
- rows: [],
517
- count: 0
518
- } : {
519
- type: 'success',
520
- shape: 'objects',
521
- items: [],
522
- count: 0
523
- };
524
- return [
525
- 2,
526
- {
527
- content: [
528
- {
529
- type: 'text',
530
- text: JSON.stringify(result1)
531
- }
532
- ],
533
- structuredContent: {
534
- result: result1
535
- }
536
- }
537
- ];
538
- }
539
- // Throw McpError for other errors
505
+ // Throw McpError for all errors so callers can see Drive validation details
540
506
  throw new _types.McpError(_types.ErrorCode.InternalError, "Error searching files: ".concat(message), {
541
507
  stack: _instanceof(error, Error) ? error.stack : undefined
542
508
  });
@@ -1 +1 @@
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":";;;;+BA8QA;;;eAAwBA;;;2BA7QA;sBAImG;qBAClE;0BACnB;mBACpB;8BACW;uBACmH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAPhJ,IAAM,AAAEC,2BAA6BC,oBAAO,CAApCD;AASR,IAAME,cAAcC,MAAC,CAACC,MAAM,CAAC;IAC3BC,OAAOC,yBAAgB,CAACC,QAAQ,CAAC;IACjCC,QAAQC,IAAAA,0BAAkB,EAAC;QACzBC,iBAAiBC,0BAAiB;QAClCC,mBAAmBC,sCAA6B;QAChDC,gBAAgBC,mCAA0B;QAC1CC,cAAc;IAChB;GACGC,IAAAA,8BAAsB,EAAC;IACxBC,iBAAiB;IACjBC,aAAa;IACbC,UAAU;AACZ,GAAGC,KAAK;IACRA,OAAOC,IAAAA,yBAAiB;;AAG1B,8CAA8C;AAC9C,IAAMC,6BAA6BpB,MAAC,CAACC,MAAM,CAAC;IAC1CoB,MAAMrB,MAAC,CAACsB,OAAO,CAAC;IAChBJ,OAAOlB,MAAC,CAACsB,OAAO,CAAC;IACjBC,OAAOvB,MAAC,CAACwB,KAAK,CAACC,wBAAe,EAAErB,QAAQ,CAAC;IACzCsB,OAAO1B,MAAC,CAAC2B,MAAM,GAAGvB,QAAQ,CAAC;IAC3BwB,eAAe5B,MAAC,CAAC6B,MAAM,GAAGC,QAAQ,GAAG1B,QAAQ,CAAC;AAChD;AAEA,IAAM2B,4BAA4B/B,MAAC,CAACC,MAAM,CAAC;IACzCoB,MAAMrB,MAAC,CAACsB,OAAO,CAAC;IAChBJ,OAAOlB,MAAC,CAACsB,OAAO,CAAC;IACjBU,SAAShC,MAAC,CAACwB,KAAK,CAACxB,MAAC,CAAC6B,MAAM,IAAIzB,QAAQ,CAAC;IACtC6B,MAAMjC,MAAC,CAACwB,KAAK,CAACxB,MAAC,CAACwB,KAAK,CAACxB,MAAC,CAACkC,OAAO,KAAK9B,QAAQ,CAAC;IAC7CsB,OAAO1B,MAAC,CAAC2B,MAAM,GAAGvB,QAAQ,CAAC;IAC3BwB,eAAe5B,MAAC,CAAC6B,MAAM,GAAGC,QAAQ,GAAG1B,QAAQ,CAAC;AAChD;AAEA,2CAA2C;AAC3C,uGAAuG;AACvG,IAAM+B,eAAenC,MAAC,CAACoC,KAAK,CAAC;IAAChB;IAA4BW;IAA2BlC;CAAyB;AAE9G,IAAMwC,SAAS;IACbC,OAAO;IACPC,aAAa;IACbxC,aAAaA;IACboC,cAAcnC,MAAC,CAACC,MAAM,CAAC;QACrBuC,QAAQL;IACV;AACF;AAUA,SAAeM;wCAAQ,KAAoE,EAAEC,KAAoB;YAAxFxC,wBAAOyC,UAAeC,WAAWvC,sBAAQa,OAC1D2B,QAEAC,iBAGAC,eAUEC,OAGFC,MASMC,GAIJC,aAgBAC,UACAC,KACAC,OAEAC,WACD,2BAAA,mBAAA,gBAAA,WAAA,OAAMC,GAEF,4BAAA,oBAAA,iBAAA,YAAA,QAAMC,UAQTC,eAGEC,eAgBFpC,OAuCAqC,eASAhC,eAGAY,QA0BCqB,OACDC,SAKAC,wBAIEvB;;;;oBAzKatC,QAAF,MAAEA,yBAAF,MAASyC,UAAAA,wCAAW,sBAAIC,YAAxB,MAAwBA,WAAWvC,SAAnC,MAAmCA,uBAAnC,MAA2Ca,OAAAA,kCAAQ;oBAClE2B,SAASH,MAAMG,MAAM;oBAErBC,kBAAkBkB,IAAAA,mBAAW,EAAC3D,QAAQG,0BAAiB;oBAE7D,kEAAkE;oBAC5DuC,gBAAgBkB,KAAKC,GAAG,CAAC,GAAGD,KAAKE,GAAG,CAAC,MAAMF,KAAKG,KAAK,CAACzB,YAAY;oBAExEE,OAAOwB,IAAI,CAAC,6BAA6B;wBACvCnE,OAAAA;wBACAyC,UAAUI;wBACVH,WAAWA,YAAY,eAAe0B;wBACtCjE,QAAQA,UAAU;oBACpB;;;;;;;;;oBAGQ2C,QAAQuB,kBAAM,CAACvB,KAAK,CAAC;wBAAEwB,SAAS;wBAAMC,MAAM/B,MAAMgC,WAAW,CAACD,IAAI;oBAAC;oBAIzE,IAAI,OAAOvE,UAAU,UAAU;wBAC7B,0CAA0C;wBAC1C+C,OAAO,AAAC,IAAS,OAAN/C,OAAM;oBACnB,OAAO,IAAIA,SAAS,CAAA,OAAOA,sCAAP,SAAOA,MAAI,MAAM,YAAY,mBAAmBA,SAASA,MAAMyE,aAAa,EAAE;wBAChG,oDAAoD;wBACpD1B,OAAO,AAAC,IAAuB,OAApB/C,MAAMyE,aAAa,EAAC;oBACjC,OAAO;wBACL,0DAA0D;wBAClDzB,IAAM0B,IAAAA,4BAAY,EAAC1E,OAAnBgD;wBACRD,OAAOC,IAAI,AAAC,IAAK,OAAFA,GAAE,2BAAyB;oBAC5C;oBAEMC,cAMF;wBACFD,GAAGD;wBACHN,UAAUI;wBACV1C,QAAQ;wBACRwE,SAAS;oBACX;oBACA,IAAIjC,aAAaA,UAAUkC,IAAI,GAAGC,MAAM,GAAG,GAAG;wBAC5C5B,YAAYP,SAAS,GAAGA;oBAC1B;oBAEiB;;wBAAMI,MAAMM,KAAK,CAAC0B,IAAI,CAAC7B;;;oBAAlCC,WAAW;oBACXC,MAAMD,SAAS6B,IAAI;oBACnB3B,QAAQ4B,MAAMC,OAAO,CAAC9B,gBAAAA,0BAAAA,IAAKC,KAAK,IAAID,IAAIC,KAAK;oBAE7CC,YAAY,IAAI6B;oBACjB,kCAAA,2BAAA;;wBAAL,IAAK,YAAW9B,4BAAX,6BAAA,QAAA,yBAAA,iCAAkB;4BAAZE,IAAN;4BACH,IAAIA,CAAAA,cAAAA,wBAAAA,EAAG6B,OAAO,KAAI7B,EAAE6B,OAAO,CAACN,MAAM,GAAG,GAAG;gCACjC,mCAAA,4BAAA;;oCAAL,IAAK,aAAkBvB,EAAE6B,OAAO,uBAA3B,8BAAA,SAAA,0BAAA,kCAA6B;wCAAvB5B,WAAN;wCACH,IAAIA,YAAYA,aAAa,QAAQ;4CACnCF,UAAU+B,GAAG,CAAC7B;wCAChB;oCACF;;oCAJK;oCAAA;;;6CAAA,8BAAA;4CAAA;;;4CAAA;kDAAA;;;;4BAKP;wBACF;;wBARK;wBAAA;;;iCAAA,6BAAA;gCAAA;;;gCAAA;sCAAA;;;;oBAUCC,gBAAgB,IAAI6B;yBACtBhC,CAAAA,UAAUiC,IAAI,GAAG,CAAA,GAAjBjC;;;;oBACFV,OAAOwB,IAAI,CAAC,yBAAyB;wBAAE3C,OAAO6B,UAAUiC,IAAI;oBAAC;oBACvD7B,gBAAgBuB,MAAMO,IAAI,CAAClC,WAAWmC,GAAG,CAAC,SAAOjC;;gCAE7CkC,WAIAC,YAECC;;;;;;;;;;wCANW;;4CAAM7C,MAAMM,KAAK,CAACwC,GAAG,CAAC;gDACtCC,QAAQtC;gDACRpD,QAAQ;4CACV;;;wCAHMsF,YAAY;wCAIZC,aAAa,AAACD,UAAUV,IAAI,CAACe,IAAI,IAA2BvC;wCAClEC,cAAcuC,GAAG,CAACxC,UAAUmC;;;;;;wCACrBC;wCACPhD,OAAOwB,IAAI,CAAC,+BAA+B;4CAAEZ,UAAAA;4CAAUI,OAAOgC;wCAAE;wCAChEnC,cAAcuC,GAAG,CAACxC,UAAUA,WAAW,iBAAiB;;;;;;;;;;;wBAE5D;;oBACA;;wBAAMyC,QAAQC,GAAG,CAACxC;;;oBAAlB;;;oBAGIpC,QAAqB+B,MAAMoC,GAAG,CAAC,SAAClC;wBACpC,IAAM4C,KAAK5C,CAAAA,cAAAA,wBAAAA,EAAG4C,EAAE,IAAGC,OAAO7C,EAAE4C,EAAE,IAAI;wBAClC,IAAMJ,OAAOxC,CAAAA,cAAAA,wBAAAA,EAAGwC,IAAI,KAAII;wBACxB,IAAM5D,SAAoB;4BAAE4D,IAAAA;4BAAIJ,MAAAA;wBAAK;wBAErC,kDAAkD;wBAClD,IAAIxC,cAAAA,wBAAAA,EAAG8C,QAAQ,EAAE9D,OAAO8D,QAAQ,GAAG9C,EAAE8C,QAAQ;wBAC7C,IAAI9C,cAAAA,wBAAAA,EAAG+C,WAAW,EAAE/D,OAAO+D,WAAW,GAAG/C,EAAE+C,WAAW;wBACtD,IAAI/C,cAAAA,wBAAAA,EAAGgD,YAAY,EAAEhE,OAAOgE,YAAY,GAAGhD,EAAEgD,YAAY;wBAEzD,IAAIhD,CAAAA,cAAAA,wBAAAA,EAAG6B,OAAO,KAAI7B,EAAE6B,OAAO,CAACN,MAAM,GAAG,GAAG;4BACtCvC,OAAO6C,OAAO,GAAG7B,EAAE6B,OAAO,CAACK,GAAG,CAAC,SAACjC;gCAC9B,IAAIA,aAAa,QAAQ;oCACvB,OAAO;wCAAE2C,IAAI;wCAAQJ,MAAM;oCAAW;gCACxC;gCACA,IAAMJ,aAAalC,cAAcoC,GAAG,CAACrC,aAAaA;gCAClD,OAAO;oCAAE2C,IAAI3C;oCAAUuC,MAAMJ;gCAAW;4BAC1C;wBACF;wBAEA,IAAIpC,CAAAA,cAAAA,wBAAAA,EAAGiD,MAAM,KAAI,MAAMjE,OAAOiE,MAAM,GAAGjD,EAAEiD,MAAM;wBAC/C,IAAIjD,CAAAA,cAAAA,wBAAAA,EAAGkD,OAAO,KAAI,MAAMlE,OAAOkE,OAAO,GAAGlD,EAAEkD,OAAO;wBAElD,IAAIlD,CAAAA,cAAAA,wBAAAA,EAAGmD,MAAM,KAAInD,EAAEmD,MAAM,CAAC5B,MAAM,GAAG,GAAG;4BACpCvC,OAAOmE,MAAM,GAAGnD,EAAEmD,MAAM,CAACjB,GAAG,CAAC,SAACkB;gCAC5B,IAAMC,QAAkD,CAAC;gCACzD,IAAID,cAAAA,wBAAAA,EAAGE,WAAW,EAAED,MAAMC,WAAW,GAAGF,EAAEE,WAAW;gCACrD,IAAIF,cAAAA,wBAAAA,EAAGG,YAAY,EAAEF,MAAME,YAAY,GAAGH,EAAEG,YAAY;gCACxD,IAAIH,cAAAA,wBAAAA,EAAGI,IAAI,EAAEH,MAAMG,IAAI,GAAGJ,EAAEI,IAAI;gCAChC,IAAIJ,CAAAA,cAAAA,wBAAAA,EAAGK,EAAE,KAAI,MAAMJ,MAAMI,EAAE,GAAGL,EAAEK,EAAE;gCAClC,IAAIL,cAAAA,wBAAAA,EAAGM,YAAY,EAAEL,MAAMK,YAAY,GAAGN,EAAEM,YAAY;gCACxD,IAAIN,cAAAA,wBAAAA,EAAGO,SAAS,EAAEN,MAAMM,SAAS,GAAGP,EAAEO,SAAS;gCAC/C,OAAON;4BACT;wBACF;wBAEA,OAAOrE;oBACT;oBAEMoB,gBAAgBrC,MAAMmE,GAAG,CAAC,SAAC0B;+BAASC,IAAAA,oBAAY,EAACD,MAAMtE;;oBAE7DD,OAAOwB,IAAI,CAAC,gCAAgC;wBAC1CnE,OAAAA;wBACAyC,UAAAA;wBACA2E,aAAa1D,cAAcmB,MAAM;wBACjC1E,QAAQA,UAAU;oBACpB;oBAEMuB,gBAAgByB,IAAIzB,aAAa,IAAIyB,IAAIzB,aAAa,CAACkD,IAAI,GAAGC,MAAM,GAAG,IAAI1B,IAAIzB,aAAa,GAAG0C;oBAErG,8BAA8B;oBACxB9B,SACJtB,UAAU,WACN;wBACEG,MAAM;wBACNH,OAAO;uBACJqG,IAAAA,wBAAgB,EAAC3D,eAAed,iBAAiBtC,0BAAiB;wBACrEkB,OAAOkC,cAAcmB,MAAM;wBACvBnD,iBAAiB;wBAAEA,eAAAA;oBAAc,KAEvC;wBACEP,MAAM;wBACNH,OAAO;wBACPK,OAAOqC;wBACPlC,OAAOkC,cAAcmB,MAAM;uBACvBnD,iBAAiB;wBAAEA,eAAAA;oBAAc;oBAG7C;;wBAAO;4BACL4F,OAAO;gCACL;oCACEnG,MAAM;oCACNoG,MAAMC,KAAKC,SAAS,CAACnF;gCACvB;;4BAEFoF,mBAAmB;gCAAEpF,QAAAA;4BAAO;wBAC9B;;;oBACOqB;oBACDC,UAAUD,AAAK,YAALA,OAAiBgE,SAAQhE,MAAMC,OAAO,GAAGuC,OAAOxC;oBAChEhB,OAAOgB,KAAK,CAAC,4BAA4B;wBAAEA,OAAOC;oBAAQ;oBAE1D,yFAAyF;oBACzF,sDAAsD;oBAChDC,yBAAyBD,QAAQgE,QAAQ,CAAC,oBAAoBhE,QAAQgE,QAAQ,CAAC,oBAAoBhE,QAAQgE,QAAQ,CAAC,qBAAqBhE,QAAQgE,QAAQ,CAAC;oBAEhK,IAAI/D,wBAAwB;wBAC1B,gDAAgD;wBAC1CvB,UACJtB,UAAU,WACN;4BACEG,MAAM;4BACNH,OAAO;4BACPc,OAAO;4BACPC,IAAI;4BACJP,OAAO;wBACT,IACA;4BACEL,MAAM;4BACNH,OAAO;4BACPK,KAAK;4BACLG,OAAO;wBACT;wBAEN;;4BAAO;gCACL8F,OAAO;oCACL;wCACEnG,MAAM;wCACNoG,MAAMC,KAAKC,SAAS,CAACnF;oCACvB;;gCAEFoF,mBAAmB;oCAAEpF,QAAAA;gCAAO;4BAC9B;;oBACF;oBAEA,kCAAkC;oBAClC,MAAM,IAAIuF,eAAQ,CAACC,gBAAS,CAACC,aAAa,EAAE,AAAC,0BAAiC,OAARnE,UAAW;wBAC/EoE,OAAOrE,AAAK,YAALA,OAAiBgE,SAAQhE,MAAMqE,KAAK,GAAG5D;oBAChD;;;;;;;IAEJ;;AAEe,SAAS1E;IACtB,OAAO;QACLoG,MAAM;QACN3D,QAAAA;QACAI,SAAAA;IACF;AACF"}
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, DriveQueryParameterSchema, parseDriveQueryParameter } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n query: DriveQueryParameterSchema.describe('Structured Drive query object or JSON string. Use rawDriveQuery for raw Drive syntax.'),\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 try {\n const parsedQuery = parseDriveQueryParameter(query);\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: parsedQuery,\n pageSize: validPageSize,\n pageToken: pageToken ? '[provided]' : undefined,\n fields: fields || 'all',\n });\n\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n // Handle query parameter\n let qStr: string;\n if (parsedQuery && 'rawDriveQuery' in parsedQuery && parsedQuery.rawDriveQuery) {\n // Object with rawDriveQuery field - use it directly\n qStr = parsedQuery.rawDriveQuery;\n } else if (parsedQuery) {\n // Structured query object - convert to Drive query string\n const { q } = toDriveQuery(parsedQuery);\n qStr = q || '';\n } else {\n qStr = '';\n }\n\n const listOptions: {\n q?: string;\n pageSize: number;\n fields: string;\n orderBy: string;\n pageToken?: string;\n } = {\n pageSize: validPageSize,\n fields: 'files(id,name,mimeType,webViewLink,modifiedTime,parents,shared,starred,owners),nextPageToken',\n orderBy: 'modifiedTime desc',\n };\n if (qStr.trim().length > 0) {\n listOptions.q = qStr;\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: parsedQuery,\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 // Throw McpError for all errors so callers can see Drive validation details\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","DriveQueryParameterSchema","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","parsedQuery","requestedFields","validPageSize","drive","qStr","q","listOptions","response","res","files","parentIds","f","parentId","parentNameMap","parentFetches","filteredItems","error","message","parseDriveQueryParameter","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","McpError","ErrorCode","InternalError","stack"],"mappings":"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"}
@@ -8,7 +8,7 @@ declare const inputSchema: z.ZodObject<{
8
8
  }>>>;
9
9
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
10
10
  pageToken: z.ZodOptional<z.ZodString>;
11
- query: z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../types.js").DriveQueryObject, unknown>>]>>;
11
+ query: z.ZodOptional<z.ZodType<string | import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../types.js").DriveQueryObject, unknown>>>;
12
12
  fields: z.ZodOptional<z.ZodString>;
13
13
  resolvePaths: z.ZodOptional<z.ZodBoolean>;
14
14
  }, z.core.$strip>;
@@ -77,7 +77,7 @@ export default function createTool(): {
77
77
  }>>>;
78
78
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
79
79
  pageToken: z.ZodOptional<z.ZodString>;
80
- query: z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../types.js").DriveQueryObject, unknown>>]>>;
80
+ query: z.ZodOptional<z.ZodType<string | import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../types.js").DriveQueryObject, unknown>>>;
81
81
  fields: z.ZodOptional<z.ZodString>;
82
82
  resolvePaths: z.ZodOptional<z.ZodBoolean>;
83
83
  }, z.core.$strip>;
@@ -8,7 +8,7 @@ declare const inputSchema: z.ZodObject<{
8
8
  }>>>;
9
9
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
10
10
  pageToken: z.ZodOptional<z.ZodString>;
11
- query: z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../types.js").DriveQueryObject, unknown>>]>>;
11
+ query: z.ZodOptional<z.ZodType<string | import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../types.js").DriveQueryObject, unknown>>>;
12
12
  fields: z.ZodOptional<z.ZodString>;
13
13
  resolvePaths: z.ZodOptional<z.ZodBoolean>;
14
14
  }, z.core.$strip>;
@@ -77,7 +77,7 @@ export default function createTool(): {
77
77
  }>>>;
78
78
  pageSize: z.ZodDefault<z.ZodOptional<z.ZodCoercedNumber<unknown>>>;
79
79
  pageToken: z.ZodOptional<z.ZodString>;
80
- query: z.ZodOptional<z.ZodUnion<readonly [z.ZodString, z.ZodType<import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<import("../../types.js").DriveQueryObject, unknown>>]>>;
80
+ query: z.ZodOptional<z.ZodType<string | import("../../types.js").DriveQueryObject, unknown, z.core.$ZodTypeInternals<string | import("../../types.js").DriveQueryObject, unknown>>>;
81
81
  fields: z.ZodOptional<z.ZodString>;
82
82
  resolvePaths: z.ZodOptional<z.ZodBoolean>;
83
83
  }, z.core.$strip>;