@mcp-z/mcp-sheets 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (363) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +181 -0
  3. package/bin/server.js +5 -0
  4. package/dist/cjs/constants.d.cts +7 -0
  5. package/dist/cjs/constants.d.ts +7 -0
  6. package/dist/cjs/constants.js +18 -0
  7. package/dist/cjs/constants.js.map +1 -0
  8. package/dist/cjs/index.d.cts +8 -0
  9. package/dist/cjs/index.d.ts +8 -0
  10. package/dist/cjs/index.js +314 -0
  11. package/dist/cjs/index.js.map +1 -0
  12. package/dist/cjs/lib/create-store.d.cts +2 -0
  13. package/dist/cjs/lib/create-store.d.ts +2 -0
  14. package/dist/cjs/lib/create-store.js +166 -0
  15. package/dist/cjs/lib/create-store.js.map +1 -0
  16. package/dist/cjs/mcp/index.d.cts +3 -0
  17. package/dist/cjs/mcp/index.d.ts +3 -0
  18. package/dist/cjs/mcp/index.js +66 -0
  19. package/dist/cjs/mcp/index.js.map +1 -0
  20. package/dist/cjs/mcp/prompts/a1-notation.d.cts +19 -0
  21. package/dist/cjs/mcp/prompts/a1-notation.d.ts +19 -0
  22. package/dist/cjs/mcp/prompts/a1-notation.js +169 -0
  23. package/dist/cjs/mcp/prompts/a1-notation.js.map +1 -0
  24. package/dist/cjs/mcp/prompts/index.d.cts +1 -0
  25. package/dist/cjs/mcp/prompts/index.d.ts +1 -0
  26. package/dist/cjs/mcp/prompts/index.js +17 -0
  27. package/dist/cjs/mcp/prompts/index.js.map +1 -0
  28. package/dist/cjs/mcp/resources/index.d.cts +1 -0
  29. package/dist/cjs/mcp/resources/index.d.ts +1 -0
  30. package/dist/cjs/mcp/resources/index.js +17 -0
  31. package/dist/cjs/mcp/resources/index.js.map +1 -0
  32. package/dist/cjs/mcp/resources/spreadsheet.d.cts +2 -0
  33. package/dist/cjs/mcp/resources/spreadsheet.d.ts +2 -0
  34. package/dist/cjs/mcp/resources/spreadsheet.js +258 -0
  35. package/dist/cjs/mcp/resources/spreadsheet.js.map +1 -0
  36. package/dist/cjs/mcp/tools/cells-format.d.cts +144 -0
  37. package/dist/cjs/mcp/tools/cells-format.d.ts +144 -0
  38. package/dist/cjs/mcp/tools/cells-format.js +484 -0
  39. package/dist/cjs/mcp/tools/cells-format.js.map +1 -0
  40. package/dist/cjs/mcp/tools/chart-create.d.cts +94 -0
  41. package/dist/cjs/mcp/tools/chart-create.d.ts +94 -0
  42. package/dist/cjs/mcp/tools/chart-create.js +575 -0
  43. package/dist/cjs/mcp/tools/chart-create.js.map +1 -0
  44. package/dist/cjs/mcp/tools/columns-get.d.cts +55 -0
  45. package/dist/cjs/mcp/tools/columns-get.d.ts +55 -0
  46. package/dist/cjs/mcp/tools/columns-get.js +289 -0
  47. package/dist/cjs/mcp/tools/columns-get.js.map +1 -0
  48. package/dist/cjs/mcp/tools/columns-update.d.cts +86 -0
  49. package/dist/cjs/mcp/tools/columns-update.d.ts +86 -0
  50. package/dist/cjs/mcp/tools/columns-update.js +482 -0
  51. package/dist/cjs/mcp/tools/columns-update.js.map +1 -0
  52. package/dist/cjs/mcp/tools/csv-get-columns.d.cts +43 -0
  53. package/dist/cjs/mcp/tools/csv-get-columns.d.ts +43 -0
  54. package/dist/cjs/mcp/tools/csv-get-columns.js +386 -0
  55. package/dist/cjs/mcp/tools/csv-get-columns.js.map +1 -0
  56. package/dist/cjs/mcp/tools/dimensions-batch-update.d.cts +118 -0
  57. package/dist/cjs/mcp/tools/dimensions-batch-update.d.ts +118 -0
  58. package/dist/cjs/mcp/tools/dimensions-batch-update.js +504 -0
  59. package/dist/cjs/mcp/tools/dimensions-batch-update.js.map +1 -0
  60. package/dist/cjs/mcp/tools/dimensions-move.d.cts +86 -0
  61. package/dist/cjs/mcp/tools/dimensions-move.d.ts +86 -0
  62. package/dist/cjs/mcp/tools/dimensions-move.js +359 -0
  63. package/dist/cjs/mcp/tools/dimensions-move.js.map +1 -0
  64. package/dist/cjs/mcp/tools/index.d.cts +26 -0
  65. package/dist/cjs/mcp/tools/index.d.ts +26 -0
  66. package/dist/cjs/mcp/tools/index.js +122 -0
  67. package/dist/cjs/mcp/tools/index.js.map +1 -0
  68. package/dist/cjs/mcp/tools/lib/dimension-operations.d.cts +48 -0
  69. package/dist/cjs/mcp/tools/lib/dimension-operations.d.ts +48 -0
  70. package/dist/cjs/mcp/tools/lib/dimension-operations.js +177 -0
  71. package/dist/cjs/mcp/tools/lib/dimension-operations.js.map +1 -0
  72. package/dist/cjs/mcp/tools/rows-append.d.cts +58 -0
  73. package/dist/cjs/mcp/tools/rows-append.d.ts +58 -0
  74. package/dist/cjs/mcp/tools/rows-append.js +335 -0
  75. package/dist/cjs/mcp/tools/rows-append.js.map +1 -0
  76. package/dist/cjs/mcp/tools/rows-csv-append.d.cts +67 -0
  77. package/dist/cjs/mcp/tools/rows-csv-append.d.ts +67 -0
  78. package/dist/cjs/mcp/tools/rows-csv-append.js +859 -0
  79. package/dist/cjs/mcp/tools/rows-csv-append.js.map +1 -0
  80. package/dist/cjs/mcp/tools/rows-get.d.cts +56 -0
  81. package/dist/cjs/mcp/tools/rows-get.d.ts +56 -0
  82. package/dist/cjs/mcp/tools/rows-get.js +292 -0
  83. package/dist/cjs/mcp/tools/rows-get.js.map +1 -0
  84. package/dist/cjs/mcp/tools/sheet-copy-to.d.cts +68 -0
  85. package/dist/cjs/mcp/tools/sheet-copy-to.d.ts +68 -0
  86. package/dist/cjs/mcp/tools/sheet-copy-to.js +341 -0
  87. package/dist/cjs/mcp/tools/sheet-copy-to.js.map +1 -0
  88. package/dist/cjs/mcp/tools/sheet-copy.d.cts +80 -0
  89. package/dist/cjs/mcp/tools/sheet-copy.d.ts +80 -0
  90. package/dist/cjs/mcp/tools/sheet-copy.js +394 -0
  91. package/dist/cjs/mcp/tools/sheet-copy.js.map +1 -0
  92. package/dist/cjs/mcp/tools/sheet-create.d.cts +56 -0
  93. package/dist/cjs/mcp/tools/sheet-create.d.ts +56 -0
  94. package/dist/cjs/mcp/tools/sheet-create.js +283 -0
  95. package/dist/cjs/mcp/tools/sheet-create.js.map +1 -0
  96. package/dist/cjs/mcp/tools/sheet-delete.d.cts +62 -0
  97. package/dist/cjs/mcp/tools/sheet-delete.d.ts +62 -0
  98. package/dist/cjs/mcp/tools/sheet-delete.js +341 -0
  99. package/dist/cjs/mcp/tools/sheet-delete.js.map +1 -0
  100. package/dist/cjs/mcp/tools/sheet-find.d.cts +48 -0
  101. package/dist/cjs/mcp/tools/sheet-find.d.ts +48 -0
  102. package/dist/cjs/mcp/tools/sheet-find.js +261 -0
  103. package/dist/cjs/mcp/tools/sheet-find.js.map +1 -0
  104. package/dist/cjs/mcp/tools/sheet-rename.d.cts +60 -0
  105. package/dist/cjs/mcp/tools/sheet-rename.d.ts +60 -0
  106. package/dist/cjs/mcp/tools/sheet-rename.js +305 -0
  107. package/dist/cjs/mcp/tools/sheet-rename.js.map +1 -0
  108. package/dist/cjs/mcp/tools/spreadsheet-copy.d.cts +58 -0
  109. package/dist/cjs/mcp/tools/spreadsheet-copy.d.ts +58 -0
  110. package/dist/cjs/mcp/tools/spreadsheet-copy.js +319 -0
  111. package/dist/cjs/mcp/tools/spreadsheet-copy.js.map +1 -0
  112. package/dist/cjs/mcp/tools/spreadsheet-create.d.cts +52 -0
  113. package/dist/cjs/mcp/tools/spreadsheet-create.d.ts +52 -0
  114. package/dist/cjs/mcp/tools/spreadsheet-create.js +270 -0
  115. package/dist/cjs/mcp/tools/spreadsheet-create.js.map +1 -0
  116. package/dist/cjs/mcp/tools/spreadsheet-find.d.cts +58 -0
  117. package/dist/cjs/mcp/tools/spreadsheet-find.d.ts +58 -0
  118. package/dist/cjs/mcp/tools/spreadsheet-find.js +334 -0
  119. package/dist/cjs/mcp/tools/spreadsheet-find.js.map +1 -0
  120. package/dist/cjs/mcp/tools/spreadsheet-rename.d.cts +56 -0
  121. package/dist/cjs/mcp/tools/spreadsheet-rename.d.ts +56 -0
  122. package/dist/cjs/mcp/tools/spreadsheet-rename.js +289 -0
  123. package/dist/cjs/mcp/tools/spreadsheet-rename.js.map +1 -0
  124. package/dist/cjs/mcp/tools/validation-set.d.cts +144 -0
  125. package/dist/cjs/mcp/tools/validation-set.d.ts +144 -0
  126. package/dist/cjs/mcp/tools/validation-set.js +564 -0
  127. package/dist/cjs/mcp/tools/validation-set.js.map +1 -0
  128. package/dist/cjs/mcp/tools/values-batch-update.d.cts +102 -0
  129. package/dist/cjs/mcp/tools/values-batch-update.d.ts +102 -0
  130. package/dist/cjs/mcp/tools/values-batch-update.js +409 -0
  131. package/dist/cjs/mcp/tools/values-batch-update.js.map +1 -0
  132. package/dist/cjs/mcp/tools/values-clear.d.cts +56 -0
  133. package/dist/cjs/mcp/tools/values-clear.d.ts +56 -0
  134. package/dist/cjs/mcp/tools/values-clear.js +308 -0
  135. package/dist/cjs/mcp/tools/values-clear.js.map +1 -0
  136. package/dist/cjs/mcp/tools/values-csv-update.d.cts +75 -0
  137. package/dist/cjs/mcp/tools/values-csv-update.d.ts +75 -0
  138. package/dist/cjs/mcp/tools/values-csv-update.js +500 -0
  139. package/dist/cjs/mcp/tools/values-csv-update.js.map +1 -0
  140. package/dist/cjs/mcp/tools/values-replace.d.cts +68 -0
  141. package/dist/cjs/mcp/tools/values-replace.d.ts +68 -0
  142. package/dist/cjs/mcp/tools/values-replace.js +378 -0
  143. package/dist/cjs/mcp/tools/values-replace.js.map +1 -0
  144. package/dist/cjs/mcp/tools/values-search.d.cts +74 -0
  145. package/dist/cjs/mcp/tools/values-search.d.ts +74 -0
  146. package/dist/cjs/mcp/tools/values-search.js +470 -0
  147. package/dist/cjs/mcp/tools/values-search.js.map +1 -0
  148. package/dist/cjs/package.json +1 -0
  149. package/dist/cjs/schemas/index.d.cts +14 -0
  150. package/dist/cjs/schemas/index.d.ts +14 -0
  151. package/dist/cjs/schemas/index.js +64 -0
  152. package/dist/cjs/schemas/index.js.map +1 -0
  153. package/dist/cjs/setup/config.d.cts +44 -0
  154. package/dist/cjs/setup/config.d.ts +44 -0
  155. package/dist/cjs/setup/config.js +201 -0
  156. package/dist/cjs/setup/config.js.map +1 -0
  157. package/dist/cjs/setup/http.d.cts +8 -0
  158. package/dist/cjs/setup/http.d.ts +8 -0
  159. package/dist/cjs/setup/http.js +260 -0
  160. package/dist/cjs/setup/http.js.map +1 -0
  161. package/dist/cjs/setup/index.d.cts +5 -0
  162. package/dist/cjs/setup/index.d.ts +5 -0
  163. package/dist/cjs/setup/index.js +46 -0
  164. package/dist/cjs/setup/index.js.map +1 -0
  165. package/dist/cjs/setup/oauth-google.d.cts +54 -0
  166. package/dist/cjs/setup/oauth-google.d.ts +54 -0
  167. package/dist/cjs/setup/oauth-google.js +332 -0
  168. package/dist/cjs/setup/oauth-google.js.map +1 -0
  169. package/dist/cjs/setup/runtime.d.cts +10 -0
  170. package/dist/cjs/setup/runtime.d.ts +10 -0
  171. package/dist/cjs/setup/runtime.js +353 -0
  172. package/dist/cjs/setup/runtime.js.map +1 -0
  173. package/dist/cjs/setup/stdio.d.cts +7 -0
  174. package/dist/cjs/setup/stdio.d.ts +7 -0
  175. package/dist/cjs/setup/stdio.js +239 -0
  176. package/dist/cjs/setup/stdio.js.map +1 -0
  177. package/dist/cjs/spreadsheet/column-utilities.d.cts +1 -0
  178. package/dist/cjs/spreadsheet/column-utilities.d.ts +1 -0
  179. package/dist/cjs/spreadsheet/column-utilities.js +21 -0
  180. package/dist/cjs/spreadsheet/column-utilities.js.map +1 -0
  181. package/dist/cjs/spreadsheet/csv-streaming.d.cts +19 -0
  182. package/dist/cjs/spreadsheet/csv-streaming.d.ts +19 -0
  183. package/dist/cjs/spreadsheet/csv-streaming.js +188 -0
  184. package/dist/cjs/spreadsheet/csv-streaming.js.map +1 -0
  185. package/dist/cjs/spreadsheet/data-operations.d.cts +115 -0
  186. package/dist/cjs/spreadsheet/data-operations.d.ts +115 -0
  187. package/dist/cjs/spreadsheet/data-operations.js +1515 -0
  188. package/dist/cjs/spreadsheet/data-operations.js.map +1 -0
  189. package/dist/cjs/spreadsheet/deduplication-utils.d.cts +31 -0
  190. package/dist/cjs/spreadsheet/deduplication-utils.d.ts +31 -0
  191. package/dist/cjs/spreadsheet/deduplication-utils.js +65 -0
  192. package/dist/cjs/spreadsheet/deduplication-utils.js.map +1 -0
  193. package/dist/cjs/spreadsheet/range-operations.d.cts +184 -0
  194. package/dist/cjs/spreadsheet/range-operations.d.ts +184 -0
  195. package/dist/cjs/spreadsheet/range-operations.js +672 -0
  196. package/dist/cjs/spreadsheet/range-operations.js.map +1 -0
  197. package/dist/cjs/spreadsheet/sheet-operations.d.cts +30 -0
  198. package/dist/cjs/spreadsheet/sheet-operations.d.ts +30 -0
  199. package/dist/cjs/spreadsheet/sheet-operations.js +811 -0
  200. package/dist/cjs/spreadsheet/sheet-operations.js.map +1 -0
  201. package/dist/cjs/spreadsheet/spreadsheet-management.d.cts +21 -0
  202. package/dist/cjs/spreadsheet/spreadsheet-management.d.ts +21 -0
  203. package/dist/cjs/spreadsheet/spreadsheet-management.js +310 -0
  204. package/dist/cjs/spreadsheet/spreadsheet-management.js.map +1 -0
  205. package/dist/cjs/types.d.cts +53 -0
  206. package/dist/cjs/types.d.ts +53 -0
  207. package/dist/cjs/types.js +5 -0
  208. package/dist/cjs/types.js.map +1 -0
  209. package/dist/esm/constants.d.ts +7 -0
  210. package/dist/esm/constants.js +7 -0
  211. package/dist/esm/constants.js.map +1 -0
  212. package/dist/esm/index.d.ts +8 -0
  213. package/dist/esm/index.js +34 -0
  214. package/dist/esm/index.js.map +1 -0
  215. package/dist/esm/lib/create-store.d.ts +2 -0
  216. package/dist/esm/lib/create-store.js +6 -0
  217. package/dist/esm/lib/create-store.js.map +1 -0
  218. package/dist/esm/mcp/index.d.ts +3 -0
  219. package/dist/esm/mcp/index.js +6 -0
  220. package/dist/esm/mcp/index.js.map +1 -0
  221. package/dist/esm/mcp/prompts/a1-notation.d.ts +19 -0
  222. package/dist/esm/mcp/prompts/a1-notation.js +49 -0
  223. package/dist/esm/mcp/prompts/a1-notation.js.map +1 -0
  224. package/dist/esm/mcp/prompts/index.d.ts +1 -0
  225. package/dist/esm/mcp/prompts/index.js +1 -0
  226. package/dist/esm/mcp/prompts/index.js.map +1 -0
  227. package/dist/esm/mcp/resources/index.d.ts +1 -0
  228. package/dist/esm/mcp/resources/index.js +1 -0
  229. package/dist/esm/mcp/resources/index.js.map +1 -0
  230. package/dist/esm/mcp/resources/spreadsheet.d.ts +2 -0
  231. package/dist/esm/mcp/resources/spreadsheet.js +88 -0
  232. package/dist/esm/mcp/resources/spreadsheet.js.map +1 -0
  233. package/dist/esm/mcp/tools/cells-format.d.ts +144 -0
  234. package/dist/esm/mcp/tools/cells-format.js +288 -0
  235. package/dist/esm/mcp/tools/cells-format.js.map +1 -0
  236. package/dist/esm/mcp/tools/chart-create.d.ts +94 -0
  237. package/dist/esm/mcp/tools/chart-create.js +408 -0
  238. package/dist/esm/mcp/tools/chart-create.js.map +1 -0
  239. package/dist/esm/mcp/tools/columns-get.d.ts +55 -0
  240. package/dist/esm/mcp/tools/columns-get.js +113 -0
  241. package/dist/esm/mcp/tools/columns-get.js.map +1 -0
  242. package/dist/esm/mcp/tools/columns-update.d.ts +86 -0
  243. package/dist/esm/mcp/tools/columns-update.js +296 -0
  244. package/dist/esm/mcp/tools/columns-update.js.map +1 -0
  245. package/dist/esm/mcp/tools/csv-get-columns.d.ts +43 -0
  246. package/dist/esm/mcp/tools/csv-get-columns.js +95 -0
  247. package/dist/esm/mcp/tools/csv-get-columns.js.map +1 -0
  248. package/dist/esm/mcp/tools/dimensions-batch-update.d.ts +118 -0
  249. package/dist/esm/mcp/tools/dimensions-batch-update.js +321 -0
  250. package/dist/esm/mcp/tools/dimensions-batch-update.js.map +1 -0
  251. package/dist/esm/mcp/tools/dimensions-move.d.ts +86 -0
  252. package/dist/esm/mcp/tools/dimensions-move.js +183 -0
  253. package/dist/esm/mcp/tools/dimensions-move.js.map +1 -0
  254. package/dist/esm/mcp/tools/index.d.ts +26 -0
  255. package/dist/esm/mcp/tools/index.js +26 -0
  256. package/dist/esm/mcp/tools/index.js.map +1 -0
  257. package/dist/esm/mcp/tools/lib/dimension-operations.d.ts +48 -0
  258. package/dist/esm/mcp/tools/lib/dimension-operations.js +93 -0
  259. package/dist/esm/mcp/tools/lib/dimension-operations.js.map +1 -0
  260. package/dist/esm/mcp/tools/rows-append.d.ts +58 -0
  261. package/dist/esm/mcp/tools/rows-append.js +151 -0
  262. package/dist/esm/mcp/tools/rows-append.js.map +1 -0
  263. package/dist/esm/mcp/tools/rows-csv-append.d.ts +67 -0
  264. package/dist/esm/mcp/tools/rows-csv-append.js +342 -0
  265. package/dist/esm/mcp/tools/rows-csv-append.js.map +1 -0
  266. package/dist/esm/mcp/tools/rows-get.d.ts +56 -0
  267. package/dist/esm/mcp/tools/rows-get.js +116 -0
  268. package/dist/esm/mcp/tools/rows-get.js.map +1 -0
  269. package/dist/esm/mcp/tools/sheet-copy-to.d.ts +68 -0
  270. package/dist/esm/mcp/tools/sheet-copy-to.js +156 -0
  271. package/dist/esm/mcp/tools/sheet-copy-to.js.map +1 -0
  272. package/dist/esm/mcp/tools/sheet-copy.d.ts +80 -0
  273. package/dist/esm/mcp/tools/sheet-copy.js +177 -0
  274. package/dist/esm/mcp/tools/sheet-copy.js.map +1 -0
  275. package/dist/esm/mcp/tools/sheet-create.d.ts +56 -0
  276. package/dist/esm/mcp/tools/sheet-create.js +110 -0
  277. package/dist/esm/mcp/tools/sheet-create.js.map +1 -0
  278. package/dist/esm/mcp/tools/sheet-delete.d.ts +62 -0
  279. package/dist/esm/mcp/tools/sheet-delete.js +125 -0
  280. package/dist/esm/mcp/tools/sheet-delete.js.map +1 -0
  281. package/dist/esm/mcp/tools/sheet-find.d.ts +48 -0
  282. package/dist/esm/mcp/tools/sheet-find.js +90 -0
  283. package/dist/esm/mcp/tools/sheet-find.js.map +1 -0
  284. package/dist/esm/mcp/tools/sheet-rename.d.ts +60 -0
  285. package/dist/esm/mcp/tools/sheet-rename.js +128 -0
  286. package/dist/esm/mcp/tools/sheet-rename.js.map +1 -0
  287. package/dist/esm/mcp/tools/spreadsheet-copy.d.ts +58 -0
  288. package/dist/esm/mcp/tools/spreadsheet-copy.js +117 -0
  289. package/dist/esm/mcp/tools/spreadsheet-copy.js.map +1 -0
  290. package/dist/esm/mcp/tools/spreadsheet-create.d.ts +52 -0
  291. package/dist/esm/mcp/tools/spreadsheet-create.js +97 -0
  292. package/dist/esm/mcp/tools/spreadsheet-create.js.map +1 -0
  293. package/dist/esm/mcp/tools/spreadsheet-find.d.ts +58 -0
  294. package/dist/esm/mcp/tools/spreadsheet-find.js +113 -0
  295. package/dist/esm/mcp/tools/spreadsheet-find.js.map +1 -0
  296. package/dist/esm/mcp/tools/spreadsheet-rename.d.ts +56 -0
  297. package/dist/esm/mcp/tools/spreadsheet-rename.js +112 -0
  298. package/dist/esm/mcp/tools/spreadsheet-rename.js.map +1 -0
  299. package/dist/esm/mcp/tools/validation-set.d.ts +144 -0
  300. package/dist/esm/mcp/tools/validation-set.js +366 -0
  301. package/dist/esm/mcp/tools/validation-set.js.map +1 -0
  302. package/dist/esm/mcp/tools/values-batch-update.d.ts +102 -0
  303. package/dist/esm/mcp/tools/values-batch-update.js +224 -0
  304. package/dist/esm/mcp/tools/values-batch-update.js.map +1 -0
  305. package/dist/esm/mcp/tools/values-clear.d.ts +56 -0
  306. package/dist/esm/mcp/tools/values-clear.js +131 -0
  307. package/dist/esm/mcp/tools/values-clear.js.map +1 -0
  308. package/dist/esm/mcp/tools/values-csv-update.d.ts +75 -0
  309. package/dist/esm/mcp/tools/values-csv-update.js +202 -0
  310. package/dist/esm/mcp/tools/values-csv-update.js.map +1 -0
  311. package/dist/esm/mcp/tools/values-replace.d.ts +68 -0
  312. package/dist/esm/mcp/tools/values-replace.js +171 -0
  313. package/dist/esm/mcp/tools/values-replace.js.map +1 -0
  314. package/dist/esm/mcp/tools/values-search.d.ts +74 -0
  315. package/dist/esm/mcp/tools/values-search.js +229 -0
  316. package/dist/esm/mcp/tools/values-search.js.map +1 -0
  317. package/dist/esm/package.json +1 -0
  318. package/dist/esm/schemas/index.d.ts +14 -0
  319. package/dist/esm/schemas/index.js +35 -0
  320. package/dist/esm/schemas/index.js.map +1 -0
  321. package/dist/esm/setup/config.d.ts +44 -0
  322. package/dist/esm/setup/config.js +151 -0
  323. package/dist/esm/setup/config.js.map +1 -0
  324. package/dist/esm/setup/http.d.ts +8 -0
  325. package/dist/esm/setup/http.js +54 -0
  326. package/dist/esm/setup/http.js.map +1 -0
  327. package/dist/esm/setup/index.d.ts +5 -0
  328. package/dist/esm/setup/index.js +5 -0
  329. package/dist/esm/setup/index.js.map +1 -0
  330. package/dist/esm/setup/oauth-google.d.ts +54 -0
  331. package/dist/esm/setup/oauth-google.js +142 -0
  332. package/dist/esm/setup/oauth-google.js.map +1 -0
  333. package/dist/esm/setup/runtime.d.ts +10 -0
  334. package/dist/esm/setup/runtime.js +84 -0
  335. package/dist/esm/setup/runtime.js.map +1 -0
  336. package/dist/esm/setup/stdio.d.ts +7 -0
  337. package/dist/esm/setup/stdio.js +38 -0
  338. package/dist/esm/setup/stdio.js.map +1 -0
  339. package/dist/esm/spreadsheet/column-utilities.d.ts +1 -0
  340. package/dist/esm/spreadsheet/column-utilities.js +10 -0
  341. package/dist/esm/spreadsheet/column-utilities.js.map +1 -0
  342. package/dist/esm/spreadsheet/csv-streaming.d.ts +19 -0
  343. package/dist/esm/spreadsheet/csv-streaming.js +43 -0
  344. package/dist/esm/spreadsheet/csv-streaming.js.map +1 -0
  345. package/dist/esm/spreadsheet/data-operations.d.ts +115 -0
  346. package/dist/esm/spreadsheet/data-operations.js +712 -0
  347. package/dist/esm/spreadsheet/data-operations.js.map +1 -0
  348. package/dist/esm/spreadsheet/deduplication-utils.d.ts +31 -0
  349. package/dist/esm/spreadsheet/deduplication-utils.js +54 -0
  350. package/dist/esm/spreadsheet/deduplication-utils.js.map +1 -0
  351. package/dist/esm/spreadsheet/range-operations.d.ts +184 -0
  352. package/dist/esm/spreadsheet/range-operations.js +591 -0
  353. package/dist/esm/spreadsheet/range-operations.js.map +1 -0
  354. package/dist/esm/spreadsheet/sheet-operations.d.ts +30 -0
  355. package/dist/esm/spreadsheet/sheet-operations.js +359 -0
  356. package/dist/esm/spreadsheet/sheet-operations.js.map +1 -0
  357. package/dist/esm/spreadsheet/spreadsheet-management.d.ts +21 -0
  358. package/dist/esm/spreadsheet/spreadsheet-management.js +73 -0
  359. package/dist/esm/spreadsheet/spreadsheet-management.js.map +1 -0
  360. package/dist/esm/types.d.ts +53 -0
  361. package/dist/esm/types.js +1 -0
  362. package/dist/esm/types.js.map +1 -0
  363. package/package.json +108 -0
@@ -0,0 +1,482 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "default", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return createTool;
9
+ }
10
+ });
11
+ var _oauthgoogle = require("@mcp-z/oauth-google");
12
+ var _types = require("@modelcontextprotocol/sdk/types.js");
13
+ var _googleapis = require("googleapis");
14
+ var _zod = require("zod");
15
+ var _index = require("../../schemas/index.js");
16
+ var _dataoperations = require("../../spreadsheet/data-operations.js");
17
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
18
+ try {
19
+ var info = gen[key](arg);
20
+ var value = info.value;
21
+ } catch (error) {
22
+ reject(error);
23
+ return;
24
+ }
25
+ if (info.done) {
26
+ resolve(value);
27
+ } else {
28
+ Promise.resolve(value).then(_next, _throw);
29
+ }
30
+ }
31
+ function _async_to_generator(fn) {
32
+ return function() {
33
+ var self = this, args = arguments;
34
+ return new Promise(function(resolve, reject) {
35
+ var gen = fn.apply(self, args);
36
+ function _next(value) {
37
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
38
+ }
39
+ function _throw(err) {
40
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
41
+ }
42
+ _next(undefined);
43
+ });
44
+ };
45
+ }
46
+ function _instanceof(left, right) {
47
+ if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
48
+ return !!right[Symbol.hasInstance](left);
49
+ } else {
50
+ return left instanceof right;
51
+ }
52
+ }
53
+ function _ts_generator(thisArg, body) {
54
+ var f, y, t, _ = {
55
+ label: 0,
56
+ sent: function() {
57
+ if (t[0] & 1) throw t[1];
58
+ return t[1];
59
+ },
60
+ trys: [],
61
+ ops: []
62
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype), d = Object.defineProperty;
63
+ return d(g, "next", {
64
+ value: verb(0)
65
+ }), d(g, "throw", {
66
+ value: verb(1)
67
+ }), d(g, "return", {
68
+ value: verb(2)
69
+ }), typeof Symbol === "function" && d(g, Symbol.iterator, {
70
+ value: function() {
71
+ return this;
72
+ }
73
+ }), g;
74
+ function verb(n) {
75
+ return function(v) {
76
+ return step([
77
+ n,
78
+ v
79
+ ]);
80
+ };
81
+ }
82
+ function step(op) {
83
+ if (f) throw new TypeError("Generator is already executing.");
84
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
85
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
86
+ if (y = 0, t) op = [
87
+ op[0] & 2,
88
+ t.value
89
+ ];
90
+ switch(op[0]){
91
+ case 0:
92
+ case 1:
93
+ t = op;
94
+ break;
95
+ case 4:
96
+ _.label++;
97
+ return {
98
+ value: op[1],
99
+ done: false
100
+ };
101
+ case 5:
102
+ _.label++;
103
+ y = op[1];
104
+ op = [
105
+ 0
106
+ ];
107
+ continue;
108
+ case 7:
109
+ op = _.ops.pop();
110
+ _.trys.pop();
111
+ continue;
112
+ default:
113
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
114
+ _ = 0;
115
+ continue;
116
+ }
117
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
118
+ _.label = op[1];
119
+ break;
120
+ }
121
+ if (op[0] === 6 && _.label < t[1]) {
122
+ _.label = t[1];
123
+ t = op;
124
+ break;
125
+ }
126
+ if (t && _.label < t[2]) {
127
+ _.label = t[2];
128
+ _.ops.push(op);
129
+ break;
130
+ }
131
+ if (t[2]) _.ops.pop();
132
+ _.trys.pop();
133
+ continue;
134
+ }
135
+ op = body.call(thisArg, _);
136
+ } catch (e) {
137
+ op = [
138
+ 6,
139
+ e
140
+ ];
141
+ y = 0;
142
+ } finally{
143
+ f = t = 0;
144
+ }
145
+ if (op[0] & 5) throw op[1];
146
+ return {
147
+ value: op[0] ? op[1] : void 0,
148
+ done: true
149
+ };
150
+ }
151
+ }
152
+ var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
153
+ // Input schema for columns update requests with enhanced validation
154
+ var inputSchema = _zod.z.object({
155
+ id: _index.SpreadsheetIdSchema,
156
+ gid: _index.SheetGidSchema,
157
+ rows: _zod.z.array(_zod.z.array(_index.SheetCellSchema)).min(1).max(1000).describe('Array of rows to upsert (max 1000 rows per request). Each row is an array of cell values matching the headers array'),
158
+ headers: _zod.z.array(_zod.z.string().min(1).max(100)).min(1).max(50).describe('Array of column names/headers (max 50 columns). Must match the length of each row in the rows array'),
159
+ updateBy: _zod.z.array(_zod.z.string().min(1).max(100)).min(1).max(10).describe('Array of column names to use as unique keys for matching existing rows (max 10 key columns). These columns must exist in the headers array'),
160
+ behavior: _zod.z.enum([
161
+ 'add-or-update',
162
+ 'update-only',
163
+ 'add-only'
164
+ ]).default('add-or-update').describe('Update behavior: add-or-update (default) adds new rows and updates existing, update-only skips new rows, add-only skips existing rows. BEST FOR: Bulk upsert operations with key matching in structured database or table contexts.'),
165
+ valueInputOption: _zod.z.enum([
166
+ 'RAW',
167
+ 'USER_ENTERED'
168
+ ]).default('USER_ENTERED').describe('How input data should be interpreted (RAW = exact values, USER_ENTERED = parsed like user input with formulas, dates, etc.)')
169
+ }).refine(function(data) {
170
+ // Validate that all updateBy columns exist in headers
171
+ var missingColumns = data.updateBy.filter(function(col) {
172
+ return !data.headers.includes(col);
173
+ });
174
+ return missingColumns.length === 0;
175
+ }, {
176
+ message: 'All updateBy columns must exist in the headers array',
177
+ path: [
178
+ 'updateBy'
179
+ ]
180
+ }).refine(function(data) {
181
+ // Validate that all rows have the same length as headers
182
+ var invalidRows = data.rows.findIndex(function(row) {
183
+ return row.length !== data.headers.length;
184
+ });
185
+ return invalidRows === -1;
186
+ }, {
187
+ message: 'All rows must have the same length as the headers array',
188
+ path: [
189
+ 'rows'
190
+ ]
191
+ }).refine(function(data) {
192
+ // Validate that updateBy columns are unique
193
+ var uniqueColumns = new Set(data.updateBy);
194
+ return uniqueColumns.size === data.updateBy.length;
195
+ }, {
196
+ message: 'updateBy columns must be unique',
197
+ path: [
198
+ 'updateBy'
199
+ ]
200
+ });
201
+ // Success branch schema
202
+ var successBranchSchema = _zod.z.object({
203
+ type: _zod.z.literal('success'),
204
+ id: _index.SpreadsheetIdOutput,
205
+ gid: _index.SheetGidOutput,
206
+ spreadsheetTitle: _zod.z.string().describe('Title of the updated spreadsheet'),
207
+ spreadsheetUrl: _zod.z.string().describe('URL of the updated spreadsheet'),
208
+ sheetTitle: _zod.z.string().describe('Title of the updated sheet'),
209
+ sheetUrl: _zod.z.string().describe('URL of the updated sheet'),
210
+ updatedRows: _zod.z.number().int().nonnegative().describe('Number of rows that were successfully updated or inserted'),
211
+ insertedKeys: _zod.z.array(_zod.z.string()).describe('Keys of rows that were successfully inserted (new rows)'),
212
+ rowsSkipped: _zod.z.number().int().nonnegative().describe('Number of rows that were skipped based on the update behavior and existing data'),
213
+ headersAdded: _zod.z.array(_zod.z.string()).describe('Column headers that were added to the sheet (if any were missing)'),
214
+ errors: _zod.z.array(_zod.z.string()).optional().describe('Any non-fatal errors encountered during the operation')
215
+ });
216
+ var outputSchema = _zod.z.discriminatedUnion('type', [
217
+ successBranchSchema,
218
+ AuthRequiredBranchSchema
219
+ ]);
220
+ var config = {
221
+ description: 'Update spreadsheet data by column headers with intelligent upsert logic. Supports adding missing columns, flexible update behaviors, and robust error handling. Uses column names as keys for matching existing rows, enabling context-aware data synchronization workflows.',
222
+ inputSchema: inputSchema,
223
+ outputSchema: _zod.z.object({
224
+ result: outputSchema
225
+ })
226
+ };
227
+ // Helper function to ensure consistent key generation
228
+ function generateConsistentRowKey(row, headers, strategy) {
229
+ return (0, _dataoperations.generateRowKey)(row, headers, strategy);
230
+ }
231
+ function handler(_0, _1) {
232
+ return _async_to_generator(function(param, extra) {
233
+ var id, gid, rows, headers, updateBy, _param_behavior, behavior, _param_valueInputOption, valueInputOption, _logger_debug, logger, _ref, _spreadsheetData_spreadsheetUrl, _sheet_properties_title, _sheet_properties_sheetId, _spreadsheetData_properties, _spreadsheetData_sheets, _logger_debug1, _upsertResult_errors, _logger_debug2, sheets, emptyKeyErrors, _logger_error, message, spreadsheetResponse, spreadsheetData, spreadsheetTitle, spreadsheetUrl, sheet, _logger_warn, sheetTitle, sheetGid, sheetUrl, upsertOptions, _ref1, existingKeys, processedRows, _logger_debug3, _logger_debug4, _logger_info, result, upsertResult, headersAdded, rowsFilteredByBehavior, totalRowsSkipped, result1, error, _logger_error1, message1;
234
+ return _ts_generator(this, function(_state) {
235
+ switch(_state.label){
236
+ case 0:
237
+ id = param.id, gid = param.gid, rows = param.rows, headers = param.headers, updateBy = param.updateBy, _param_behavior = param.behavior, behavior = _param_behavior === void 0 ? 'add-or-update' : _param_behavior, _param_valueInputOption = param.valueInputOption, valueInputOption = _param_valueInputOption === void 0 ? 'USER_ENTERED' : _param_valueInputOption;
238
+ logger = extra.logger;
239
+ (_logger_debug = logger.debug) === null || _logger_debug === void 0 ? void 0 : _logger_debug.call(logger, 'sheets.columns.update called', {
240
+ id: id,
241
+ gid: gid,
242
+ rowCount: rows.length,
243
+ headerCount: headers.length,
244
+ updateByColumns: updateBy,
245
+ behavior: behavior,
246
+ valueInputOption: valueInputOption
247
+ });
248
+ _state.label = 1;
249
+ case 1:
250
+ _state.trys.push([
251
+ 1,
252
+ 5,
253
+ ,
254
+ 6
255
+ ]);
256
+ sheets = _googleapis.google.sheets({
257
+ version: 'v4',
258
+ auth: extra.authContext.auth
259
+ });
260
+ // Note: Basic input validation is now handled by the enhanced Zod schema
261
+ // EARLY VALIDATION: Validate that updateBy columns have non-empty values for all rows
262
+ // This validation happens before finding spreadsheet/sheet to fail fast
263
+ emptyKeyErrors = [];
264
+ rows.forEach(function(row, rowIndex) {
265
+ var keyValues = updateBy.map(function(keyCol) {
266
+ var _row_colIndex;
267
+ var colIndex = headers.indexOf(keyCol);
268
+ return colIndex >= 0 ? String((_row_colIndex = row[colIndex]) !== null && _row_colIndex !== void 0 ? _row_colIndex : '').trim() : '';
269
+ });
270
+ if (keyValues.some(function(val) {
271
+ return val === '';
272
+ })) {
273
+ emptyKeyErrors.push("Row ".concat(rowIndex + 1, " has empty key values for columns: ").concat(updateBy.join(', ')));
274
+ }
275
+ });
276
+ if (emptyKeyErrors.length > 0) {
277
+ ;
278
+ message = "Silent data loss prevented - empty key columns detected:\n".concat(emptyKeyErrors.join('\n'));
279
+ (_logger_error = logger.error) === null || _logger_error === void 0 ? void 0 : _logger_error.call(logger, 'sheets.columns.update error', {
280
+ error: message
281
+ });
282
+ throw new _types.McpError(_types.ErrorCode.InvalidParams, message);
283
+ }
284
+ return [
285
+ 4,
286
+ sheets.spreadsheets.get({
287
+ spreadsheetId: id,
288
+ fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title'
289
+ })
290
+ ];
291
+ case 2:
292
+ spreadsheetResponse = _state.sent();
293
+ spreadsheetData = spreadsheetResponse.data;
294
+ spreadsheetTitle = (_ref = (_spreadsheetData_properties = spreadsheetData.properties) === null || _spreadsheetData_properties === void 0 ? void 0 : _spreadsheetData_properties.title) !== null && _ref !== void 0 ? _ref : '';
295
+ spreadsheetUrl = (_spreadsheetData_spreadsheetUrl = spreadsheetData.spreadsheetUrl) !== null && _spreadsheetData_spreadsheetUrl !== void 0 ? _spreadsheetData_spreadsheetUrl : '';
296
+ // Find sheet by gid
297
+ sheet = (_spreadsheetData_sheets = spreadsheetData.sheets) === null || _spreadsheetData_sheets === void 0 ? void 0 : _spreadsheetData_sheets.find(function(s) {
298
+ var _s_properties;
299
+ return String((_s_properties = s.properties) === null || _s_properties === void 0 ? void 0 : _s_properties.sheetId) === gid;
300
+ });
301
+ if (!(sheet === null || sheet === void 0 ? void 0 : sheet.properties)) {
302
+ ;
303
+ (_logger_warn = logger.warn) === null || _logger_warn === void 0 ? void 0 : _logger_warn.call(logger, 'Sheet not found for columns update', {
304
+ id: id,
305
+ gid: gid,
306
+ rowCount: rows.length
307
+ });
308
+ throw new _types.McpError(_types.ErrorCode.InvalidParams, "Sheet not found: ".concat(gid));
309
+ }
310
+ sheetTitle = (_sheet_properties_title = sheet.properties.title) !== null && _sheet_properties_title !== void 0 ? _sheet_properties_title : gid;
311
+ sheetGid = (_sheet_properties_sheetId = sheet.properties.sheetId) !== null && _sheet_properties_sheetId !== void 0 ? _sheet_properties_sheetId : 0;
312
+ sheetUrl = "https://docs.google.com/spreadsheets/d/".concat(id, "/edit#gid=").concat(sheetGid);
313
+ // Configure upsert options based on behavior
314
+ upsertOptions = {
315
+ keyStrategy: {
316
+ keyColumns: updateBy,
317
+ useProviderIdLogic: false,
318
+ separator: '\\'
319
+ },
320
+ allowUpdates: behavior === 'add-or-update' || behavior === 'update-only',
321
+ batchSize: 50,
322
+ valueInputOption: valueInputOption
323
+ };
324
+ return [
325
+ 4,
326
+ (0, _dataoperations.snapshotHeaderKeysAndPositions)(sheets, id, sheetTitle, updateBy, upsertOptions.keyStrategy)
327
+ ];
328
+ case 3:
329
+ _ref1 = _state.sent(), existingKeys = _ref1.keySet;
330
+ // Filter rows based on behavior using consistent key generation
331
+ processedRows = rows;
332
+ if (behavior === 'add-only') {
333
+ ;
334
+ // Only include rows that don't exist yet
335
+ processedRows = rows.filter(function(row) {
336
+ // Use the same key generation strategy as the upsert function
337
+ var key = generateConsistentRowKey(row, headers, upsertOptions.keyStrategy);
338
+ return key !== '' && !existingKeys.has(key);
339
+ });
340
+ (_logger_debug3 = logger.debug) === null || _logger_debug3 === void 0 ? void 0 : _logger_debug3.call(logger, 'Filtered rows for add-only behavior', {
341
+ originalCount: rows.length,
342
+ filteredCount: processedRows.length
343
+ });
344
+ } else if (behavior === 'update-only') {
345
+ ;
346
+ // Only include rows that already exist
347
+ processedRows = rows.filter(function(row) {
348
+ // Use the same key generation strategy as the upsert function
349
+ var key = generateConsistentRowKey(row, headers, upsertOptions.keyStrategy);
350
+ return key !== '' && existingKeys.has(key);
351
+ });
352
+ (_logger_debug4 = logger.debug) === null || _logger_debug4 === void 0 ? void 0 : _logger_debug4.call(logger, 'Filtered rows for update-only behavior', {
353
+ originalCount: rows.length,
354
+ filteredCount: processedRows.length
355
+ });
356
+ }
357
+ // Early return if no rows to process after behavior filtering
358
+ if (processedRows.length === 0) {
359
+ ;
360
+ (_logger_info = logger.info) === null || _logger_info === void 0 ? void 0 : _logger_info.call(logger, 'No rows to process after behavior filtering', {
361
+ behavior: behavior,
362
+ originalCount: rows.length
363
+ });
364
+ result = {
365
+ type: 'success',
366
+ id: id,
367
+ gid: String(sheetGid),
368
+ spreadsheetTitle: spreadsheetTitle || '',
369
+ spreadsheetUrl: spreadsheetUrl || '',
370
+ sheetTitle: sheetTitle,
371
+ sheetUrl: sheetUrl,
372
+ updatedRows: 0,
373
+ insertedKeys: [],
374
+ rowsSkipped: rows.length,
375
+ headersAdded: [],
376
+ errors: [
377
+ "No rows matched behavior '".concat(behavior, "' - all ").concat(rows.length, " rows were skipped")
378
+ ]
379
+ };
380
+ return [
381
+ 2,
382
+ {
383
+ content: [
384
+ {
385
+ type: 'text',
386
+ text: JSON.stringify(result)
387
+ }
388
+ ],
389
+ structuredContent: {
390
+ result: result
391
+ }
392
+ }
393
+ ];
394
+ }
395
+ (_logger_debug1 = logger.debug) === null || _logger_debug1 === void 0 ? void 0 : _logger_debug1.call(logger, 'sheets.columns.update executing upsert operation', {
396
+ spreadsheetId: id,
397
+ sheetTitle: sheetTitle,
398
+ canonicalHeaders: headers,
399
+ keyColumns: updateBy,
400
+ behavior: behavior,
401
+ processedRowsCount: processedRows.length
402
+ });
403
+ return [
404
+ 4,
405
+ (0, _dataoperations.upsertByKey)(sheets, {
406
+ spreadsheetId: id,
407
+ sheetTitle: sheetTitle,
408
+ rows: processedRows,
409
+ canonicalHeaders: headers,
410
+ options: upsertOptions,
411
+ logger: logger
412
+ })
413
+ ];
414
+ case 4:
415
+ upsertResult = _state.sent();
416
+ // Track headers that were added (if any)
417
+ // This would require additional logic in upsertByKey to return added headers
418
+ headersAdded = [];
419
+ // Calculate total rows skipped: behavior filter + upsert duplicates
420
+ rowsFilteredByBehavior = rows.length - processedRows.length;
421
+ totalRowsSkipped = upsertResult.rowsSkipped + rowsFilteredByBehavior;
422
+ (_logger_debug2 = logger.debug) === null || _logger_debug2 === void 0 ? void 0 : _logger_debug2.call(logger, 'sheets.columns.update completed successfully', {
423
+ updatedRows: upsertResult.updatedRows,
424
+ insertedCount: upsertResult.inserted.length,
425
+ rowsSkipped: totalRowsSkipped,
426
+ rowsFilteredByBehavior: rowsFilteredByBehavior,
427
+ rowsSkippedByUpsert: upsertResult.rowsSkipped,
428
+ errorsCount: ((_upsertResult_errors = upsertResult.errors) === null || _upsertResult_errors === void 0 ? void 0 : _upsertResult_errors.length) || 0
429
+ });
430
+ result1 = {
431
+ type: 'success',
432
+ id: id,
433
+ gid: String(sheetGid),
434
+ spreadsheetTitle: spreadsheetTitle || '',
435
+ spreadsheetUrl: spreadsheetUrl || '',
436
+ sheetTitle: sheetTitle,
437
+ sheetUrl: sheetUrl,
438
+ updatedRows: upsertResult.updatedRows,
439
+ insertedKeys: upsertResult.inserted,
440
+ rowsSkipped: totalRowsSkipped,
441
+ headersAdded: headersAdded,
442
+ errors: upsertResult.errors
443
+ };
444
+ return [
445
+ 2,
446
+ {
447
+ content: [
448
+ {
449
+ type: 'text',
450
+ text: JSON.stringify(result1)
451
+ }
452
+ ],
453
+ structuredContent: {
454
+ result: result1
455
+ }
456
+ }
457
+ ];
458
+ case 5:
459
+ error = _state.sent();
460
+ message1 = _instanceof(error, Error) ? error.message : String(error);
461
+ (_logger_error1 = logger.error) === null || _logger_error1 === void 0 ? void 0 : _logger_error1.call(logger, 'sheets.columns.update error', {
462
+ error: message1
463
+ });
464
+ throw new _types.McpError(_types.ErrorCode.InternalError, "Error updating columns: ".concat(message1), {
465
+ stack: _instanceof(error, Error) ? error.stack : undefined
466
+ });
467
+ case 6:
468
+ return [
469
+ 2
470
+ ];
471
+ }
472
+ });
473
+ }).apply(this, arguments);
474
+ }
475
+ function createTool() {
476
+ return {
477
+ name: 'columns-update',
478
+ config: config,
479
+ handler: handler
480
+ };
481
+ }
482
+ /* CJS INTEROP */ if (exports.__esModule && exports.default) { try { Object.defineProperty(exports.default, '__esModule', { value: true }); for (var key in exports) { exports.default[key] = exports[key]; } } catch (_) {}; module.exports = exports.default; }
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/columns-update.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport type { ToolModule } from '@mcp-z/server';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { SheetCellSchema, SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\nimport { generateRowKey, type KeyGenerationStrategy, type Row, snapshotHeaderKeysAndPositions, type UpsertOptions, upsertByKey } from '../../spreadsheet/data-operations.js';\n\n// Input schema for columns update requests with enhanced validation\nconst inputSchema = z\n .object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n rows: z.array(z.array(SheetCellSchema)).min(1).max(1000).describe('Array of rows to upsert (max 1000 rows per request). Each row is an array of cell values matching the headers array'),\n headers: z.array(z.string().min(1).max(100)).min(1).max(50).describe('Array of column names/headers (max 50 columns). Must match the length of each row in the rows array'),\n updateBy: z.array(z.string().min(1).max(100)).min(1).max(10).describe('Array of column names to use as unique keys for matching existing rows (max 10 key columns). These columns must exist in the headers array'),\n behavior: z\n .enum(['add-or-update', 'update-only', 'add-only'])\n .default('add-or-update')\n .describe('Update behavior: add-or-update (default) adds new rows and updates existing, update-only skips new rows, add-only skips existing rows. BEST FOR: Bulk upsert operations with key matching in structured database or table contexts.'),\n valueInputOption: z.enum(['RAW', 'USER_ENTERED']).default('USER_ENTERED').describe('How input data should be interpreted (RAW = exact values, USER_ENTERED = parsed like user input with formulas, dates, etc.)'),\n })\n .refine(\n (data) => {\n // Validate that all updateBy columns exist in headers\n const missingColumns = data.updateBy.filter((col) => !data.headers.includes(col));\n return missingColumns.length === 0;\n },\n {\n message: 'All updateBy columns must exist in the headers array',\n path: ['updateBy'],\n }\n )\n .refine(\n (data) => {\n // Validate that all rows have the same length as headers\n const invalidRows = data.rows.findIndex((row) => row.length !== data.headers.length);\n return invalidRows === -1;\n },\n {\n message: 'All rows must have the same length as the headers array',\n path: ['rows'],\n }\n )\n .refine(\n (data) => {\n // Validate that updateBy columns are unique\n const uniqueColumns = new Set(data.updateBy);\n return uniqueColumns.size === data.updateBy.length;\n },\n {\n message: 'updateBy columns must be unique',\n path: ['updateBy'],\n }\n );\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n spreadsheetTitle: z.string().describe('Title of the updated spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the updated spreadsheet'),\n sheetTitle: z.string().describe('Title of the updated sheet'),\n sheetUrl: z.string().describe('URL of the updated sheet'),\n updatedRows: z.number().int().nonnegative().describe('Number of rows that were successfully updated or inserted'),\n insertedKeys: z.array(z.string()).describe('Keys of rows that were successfully inserted (new rows)'),\n rowsSkipped: z.number().int().nonnegative().describe('Number of rows that were skipped based on the update behavior and existing data'),\n headersAdded: z.array(z.string()).describe('Column headers that were added to the sheet (if any were missing)'),\n errors: z.array(z.string()).optional().describe('Any non-fatal errors encountered during the operation'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Update spreadsheet data by column headers with intelligent upsert logic. Supports adding missing columns, flexible update behaviors, and robust error handling. Uses column names as keys for matching existing rows, enabling context-aware data synchronization workflows.',\n inputSchema,\n outputSchema: z.object({\n result: outputSchema,\n }),\n} as const;\n\nexport type Input = z.infer<typeof inputSchema>;\nexport type Output = z.infer<typeof outputSchema>;\n\n// Helper function to ensure consistent key generation\nfunction generateConsistentRowKey(row: Row, headers: string[], strategy: KeyGenerationStrategy): string {\n return generateRowKey(row, headers, strategy);\n}\n\nasync function handler({ id, gid, rows, headers, updateBy, behavior = 'add-or-update', valueInputOption = 'USER_ENTERED' }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.debug?.('sheets.columns.update called', {\n id,\n gid,\n rowCount: rows.length,\n headerCount: headers.length,\n updateByColumns: updateBy,\n behavior,\n valueInputOption,\n });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Note: Basic input validation is now handled by the enhanced Zod schema\n\n // EARLY VALIDATION: Validate that updateBy columns have non-empty values for all rows\n // This validation happens before finding spreadsheet/sheet to fail fast\n const emptyKeyErrors: string[] = [];\n rows.forEach((row, rowIndex) => {\n const keyValues = updateBy.map((keyCol) => {\n const colIndex = headers.indexOf(keyCol);\n return colIndex >= 0 ? String(row[colIndex] ?? '').trim() : '';\n });\n\n if (keyValues.some((val) => val === '')) {\n emptyKeyErrors.push(`Row ${rowIndex + 1} has empty key values for columns: ${updateBy.join(', ')}`);\n }\n });\n\n if (emptyKeyErrors.length > 0) {\n const message = `Silent data loss prevented - empty key columns detected:\\n${emptyKeyErrors.join('\\n')}`;\n logger.error?.('sheets.columns.update error', { error: message });\n throw new McpError(ErrorCode.InvalidParams, message);\n }\n\n // Get spreadsheet and sheet info in single API call\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title',\n });\n\n const spreadsheetData = spreadsheetResponse.data;\n const spreadsheetTitle = spreadsheetData.properties?.title ?? '';\n const spreadsheetUrl = spreadsheetData.spreadsheetUrl ?? '';\n\n // Find sheet by gid\n const sheet = spreadsheetData.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheet?.properties) {\n logger.warn?.('Sheet not found for columns update', { id, gid, rowCount: rows.length });\n throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);\n }\n\n const sheetTitle = sheet.properties.title ?? gid;\n const sheetGid = sheet.properties.sheetId ?? 0;\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetGid}`;\n\n // Configure upsert options based on behavior\n const upsertOptions: UpsertOptions = {\n keyStrategy: {\n keyColumns: updateBy,\n useProviderIdLogic: false, // Use standard key generation for column-based updates\n separator: '\\\\',\n },\n allowUpdates: behavior === 'add-or-update' || behavior === 'update-only',\n batchSize: 50,\n valueInputOption: valueInputOption,\n };\n\n // Get existing keys to implement behavior filtering\n const { keySet: existingKeys } = await snapshotHeaderKeysAndPositions(sheets, id, sheetTitle, updateBy, upsertOptions.keyStrategy);\n\n // Filter rows based on behavior using consistent key generation\n let processedRows = rows;\n if (behavior === 'add-only') {\n // Only include rows that don't exist yet\n processedRows = rows.filter((row) => {\n // Use the same key generation strategy as the upsert function\n const key = generateConsistentRowKey(row, headers, upsertOptions.keyStrategy);\n return key !== '' && !existingKeys.has(key);\n });\n logger.debug?.('Filtered rows for add-only behavior', {\n originalCount: rows.length,\n filteredCount: processedRows.length,\n });\n } else if (behavior === 'update-only') {\n // Only include rows that already exist\n processedRows = rows.filter((row) => {\n // Use the same key generation strategy as the upsert function\n const key = generateConsistentRowKey(row, headers, upsertOptions.keyStrategy);\n return key !== '' && existingKeys.has(key);\n });\n logger.debug?.('Filtered rows for update-only behavior', {\n originalCount: rows.length,\n filteredCount: processedRows.length,\n });\n }\n\n // Early return if no rows to process after behavior filtering\n if (processedRows.length === 0) {\n logger.info?.('No rows to process after behavior filtering', { behavior, originalCount: rows.length });\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetGid),\n spreadsheetTitle: spreadsheetTitle || '',\n spreadsheetUrl: spreadsheetUrl || '',\n sheetTitle,\n sheetUrl,\n updatedRows: 0,\n insertedKeys: [],\n rowsSkipped: rows.length,\n headersAdded: [],\n errors: [`No rows matched behavior '${behavior}' - all ${rows.length} rows were skipped`],\n };\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n }\n\n logger.debug?.('sheets.columns.update executing upsert operation', {\n spreadsheetId: id,\n sheetTitle,\n canonicalHeaders: headers,\n keyColumns: updateBy,\n behavior,\n processedRowsCount: processedRows.length,\n });\n\n // Execute the upsert operation using the shared function\n const upsertResult = await upsertByKey(sheets, {\n spreadsheetId: id,\n sheetTitle,\n rows: processedRows,\n canonicalHeaders: headers,\n options: upsertOptions,\n logger,\n });\n\n // Track headers that were added (if any)\n // This would require additional logic in upsertByKey to return added headers\n const headersAdded: string[] = [];\n\n // Calculate total rows skipped: behavior filter + upsert duplicates\n const rowsFilteredByBehavior = rows.length - processedRows.length;\n const totalRowsSkipped = upsertResult.rowsSkipped + rowsFilteredByBehavior;\n\n logger.debug?.('sheets.columns.update completed successfully', {\n updatedRows: upsertResult.updatedRows,\n insertedCount: upsertResult.inserted.length,\n rowsSkipped: totalRowsSkipped,\n rowsFilteredByBehavior,\n rowsSkippedByUpsert: upsertResult.rowsSkipped,\n errorsCount: upsertResult.errors?.length || 0,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetGid),\n spreadsheetTitle: spreadsheetTitle || '',\n spreadsheetUrl: spreadsheetUrl || '',\n sheetTitle,\n sheetUrl,\n updatedRows: upsertResult.updatedRows,\n insertedKeys: upsertResult.inserted,\n rowsSkipped: totalRowsSkipped,\n headersAdded,\n errors: upsertResult.errors,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error?.('sheets.columns.update error', { error: message });\n throw new McpError(ErrorCode.InternalError, `Error updating columns: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'columns-update',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","rows","array","SheetCellSchema","min","max","describe","headers","string","updateBy","behavior","enum","default","valueInputOption","refine","data","missingColumns","filter","col","includes","length","message","path","invalidRows","findIndex","row","uniqueColumns","Set","size","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","spreadsheetTitle","spreadsheetUrl","sheetTitle","sheetUrl","updatedRows","number","int","nonnegative","insertedKeys","rowsSkipped","headersAdded","errors","optional","outputSchema","discriminatedUnion","config","description","result","generateConsistentRowKey","strategy","generateRowKey","handler","extra","logger","spreadsheetData","sheet","upsertResult","sheets","emptyKeyErrors","spreadsheetResponse","sheetGid","upsertOptions","existingKeys","processedRows","rowsFilteredByBehavior","totalRowsSkipped","error","debug","rowCount","headerCount","updateByColumns","google","version","auth","authContext","forEach","rowIndex","keyValues","map","keyCol","colIndex","indexOf","String","trim","some","val","push","join","McpError","ErrorCode","InvalidParams","spreadsheets","get","spreadsheetId","fields","properties","title","find","s","sheetId","warn","keyStrategy","keyColumns","useProviderIdLogic","separator","allowUpdates","batchSize","snapshotHeaderKeysAndPositions","keySet","key","has","originalCount","filteredCount","info","content","text","JSON","stringify","structuredContent","canonicalHeaders","processedRowsCount","upsertByKey","options","insertedCount","inserted","rowsSkippedByUpsert","errorsCount","Error","InternalError","stack","undefined","name"],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ /** Get column names from CSV file (peek at first row only) */
2
+ import type { EnrichedExtra } from '@mcp-z/oauth-google';
3
+ import type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';
4
+ import { z } from 'zod';
5
+ declare const inputSchema: z.ZodObject<{
6
+ sourceUri: z.ZodString;
7
+ }, z.core.$strip>;
8
+ declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
9
+ type: z.ZodLiteral<"success">;
10
+ columns: z.ZodArray<z.ZodString>;
11
+ isEmpty: z.ZodBoolean;
12
+ }, z.core.$strip>, z.ZodObject<{
13
+ type: z.ZodLiteral<"auth_required">;
14
+ provider: z.ZodString;
15
+ message: z.ZodString;
16
+ url: z.ZodOptional<z.ZodString>;
17
+ }, z.core.$strip>], "type">;
18
+ export type Input = z.infer<typeof inputSchema>;
19
+ export type Output = z.infer<typeof outputSchema>;
20
+ declare function handler({ sourceUri }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
21
+ export default function createTool(): {
22
+ name: string;
23
+ config: {
24
+ readonly description: "Get first row from CSV file (streaming, no memory overhead). Returns columns array and isEmpty flag.";
25
+ readonly inputSchema: z.ZodObject<{
26
+ sourceUri: z.ZodString;
27
+ }, z.core.$strip>;
28
+ readonly outputSchema: z.ZodObject<{
29
+ result: z.ZodDiscriminatedUnion<[z.ZodObject<{
30
+ type: z.ZodLiteral<"success">;
31
+ columns: z.ZodArray<z.ZodString>;
32
+ isEmpty: z.ZodBoolean;
33
+ }, z.core.$strip>, z.ZodObject<{
34
+ type: z.ZodLiteral<"auth_required">;
35
+ provider: z.ZodString;
36
+ message: z.ZodString;
37
+ url: z.ZodOptional<z.ZodString>;
38
+ }, z.core.$strip>], "type">;
39
+ }, z.core.$strip>;
40
+ };
41
+ handler: typeof handler;
42
+ };
43
+ export {};
@@ -0,0 +1,43 @@
1
+ /** Get column names from CSV file (peek at first row only) */
2
+ import type { EnrichedExtra } from '@mcp-z/oauth-google';
3
+ import type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';
4
+ import { z } from 'zod';
5
+ declare const inputSchema: z.ZodObject<{
6
+ sourceUri: z.ZodString;
7
+ }, z.core.$strip>;
8
+ declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
9
+ type: z.ZodLiteral<"success">;
10
+ columns: z.ZodArray<z.ZodString>;
11
+ isEmpty: z.ZodBoolean;
12
+ }, z.core.$strip>, z.ZodObject<{
13
+ type: z.ZodLiteral<"auth_required">;
14
+ provider: z.ZodString;
15
+ message: z.ZodString;
16
+ url: z.ZodOptional<z.ZodString>;
17
+ }, z.core.$strip>], "type">;
18
+ export type Input = z.infer<typeof inputSchema>;
19
+ export type Output = z.infer<typeof outputSchema>;
20
+ declare function handler({ sourceUri }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
21
+ export default function createTool(): {
22
+ name: string;
23
+ config: {
24
+ readonly description: "Get first row from CSV file (streaming, no memory overhead). Returns columns array and isEmpty flag.";
25
+ readonly inputSchema: z.ZodObject<{
26
+ sourceUri: z.ZodString;
27
+ }, z.core.$strip>;
28
+ readonly outputSchema: z.ZodObject<{
29
+ result: z.ZodDiscriminatedUnion<[z.ZodObject<{
30
+ type: z.ZodLiteral<"success">;
31
+ columns: z.ZodArray<z.ZodString>;
32
+ isEmpty: z.ZodBoolean;
33
+ }, z.core.$strip>, z.ZodObject<{
34
+ type: z.ZodLiteral<"auth_required">;
35
+ provider: z.ZodString;
36
+ message: z.ZodString;
37
+ url: z.ZodOptional<z.ZodString>;
38
+ }, z.core.$strip>], "type">;
39
+ }, z.core.$strip>;
40
+ };
41
+ handler: typeof handler;
42
+ };
43
+ export {};