@payloadcms/plugin-mcp 3.86.0-internal.ac46214 → 4.0.0-canary.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (368) hide show
  1. package/README.md +2 -2
  2. package/bin.js +39 -0
  3. package/dist/collection/getAccessField.d.ts +12 -0
  4. package/dist/collection/getAccessField.d.ts.map +1 -0
  5. package/dist/collection/getAccessField.js +57 -0
  6. package/dist/collection/getAccessField.js.map +1 -0
  7. package/dist/collection/index.d.ts +6 -0
  8. package/dist/collection/index.d.ts.map +1 -0
  9. package/dist/collection/index.js +60 -0
  10. package/dist/collection/index.js.map +1 -0
  11. package/dist/components/AccessField/index.client.d.ts +10 -0
  12. package/dist/components/AccessField/index.client.d.ts.map +1 -0
  13. package/dist/components/AccessField/index.client.js +305 -0
  14. package/dist/components/AccessField/index.client.js.map +1 -0
  15. package/dist/components/AccessField/index.css +93 -0
  16. package/dist/defineTool.d.ts +26 -0
  17. package/dist/defineTool.d.ts.map +1 -0
  18. package/dist/defineTool.js +37 -0
  19. package/dist/defineTool.js.map +1 -0
  20. package/dist/endpoint/access.d.ts +10 -0
  21. package/dist/endpoint/access.d.ts.map +1 -0
  22. package/dist/endpoint/access.js +106 -0
  23. package/dist/endpoint/access.js.map +1 -0
  24. package/dist/endpoint/index.d.ts +3 -0
  25. package/dist/endpoint/index.d.ts.map +1 -0
  26. package/dist/endpoint/index.js +36 -0
  27. package/dist/endpoint/index.js.map +1 -0
  28. package/dist/exports/client.d.ts +2 -0
  29. package/dist/exports/client.d.ts.map +1 -0
  30. package/dist/exports/client.js +4 -0
  31. package/dist/exports/client.js.map +1 -0
  32. package/dist/index.d.ts +4 -7
  33. package/dist/index.d.ts.map +1 -1
  34. package/dist/index.js +44 -67
  35. package/dist/index.js.map +1 -1
  36. package/dist/mcp/buildMcpServer.d.ts +19 -0
  37. package/dist/mcp/buildMcpServer.d.ts.map +1 -0
  38. package/dist/mcp/buildMcpServer.js +199 -0
  39. package/dist/mcp/buildMcpServer.js.map +1 -0
  40. package/dist/mcp/builtin/collections/authTools.d.ts +7 -0
  41. package/dist/mcp/builtin/collections/authTools.d.ts.map +1 -0
  42. package/dist/mcp/builtin/collections/authTools.js +250 -0
  43. package/dist/mcp/builtin/collections/authTools.js.map +1 -0
  44. package/dist/mcp/builtin/collections/createTool.d.ts +2 -0
  45. package/dist/mcp/builtin/collections/createTool.d.ts.map +1 -0
  46. package/dist/mcp/builtin/collections/createTool.js +94 -0
  47. package/dist/mcp/builtin/collections/createTool.js.map +1 -0
  48. package/dist/mcp/builtin/collections/deleteTool.d.ts +2 -0
  49. package/dist/mcp/builtin/collections/deleteTool.d.ts.map +1 -0
  50. package/dist/mcp/builtin/collections/deleteTool.js +102 -0
  51. package/dist/mcp/builtin/collections/deleteTool.js.map +1 -0
  52. package/dist/mcp/builtin/collections/findTool.d.ts +2 -0
  53. package/dist/mcp/builtin/collections/findTool.d.ts.map +1 -0
  54. package/dist/mcp/builtin/collections/findTool.js +144 -0
  55. package/dist/mcp/builtin/collections/findTool.js.map +1 -0
  56. package/dist/mcp/builtin/collections/formatCollectionError.d.ts +9 -0
  57. package/dist/mcp/builtin/collections/formatCollectionError.d.ts.map +1 -0
  58. package/dist/mcp/builtin/collections/formatCollectionError.js +60 -0
  59. package/dist/mcp/builtin/collections/formatCollectionError.js.map +1 -0
  60. package/dist/mcp/builtin/collections/getCollectionSchemaTool.d.ts +2 -0
  61. package/dist/mcp/builtin/collections/getCollectionSchemaTool.d.ts.map +1 -0
  62. package/dist/mcp/builtin/collections/getCollectionSchemaTool.js +35 -0
  63. package/dist/mcp/builtin/collections/getCollectionSchemaTool.js.map +1 -0
  64. package/dist/mcp/builtin/collections/updateTool.d.ts +2 -0
  65. package/dist/mcp/builtin/collections/updateTool.d.ts.map +1 -0
  66. package/dist/mcp/builtin/collections/updateTool.js +199 -0
  67. package/dist/mcp/builtin/collections/updateTool.js.map +1 -0
  68. package/dist/mcp/builtin/getConfigInfoTool.d.ts +2 -0
  69. package/dist/mcp/builtin/getConfigInfoTool.d.ts.map +1 -0
  70. package/dist/mcp/builtin/getConfigInfoTool.js +49 -0
  71. package/dist/mcp/builtin/getConfigInfoTool.js.map +1 -0
  72. package/dist/mcp/builtin/globals/findTool.d.ts +2 -0
  73. package/dist/mcp/builtin/globals/findTool.d.ts.map +1 -0
  74. package/dist/mcp/builtin/globals/findTool.js +76 -0
  75. package/dist/mcp/builtin/globals/findTool.js.map +1 -0
  76. package/dist/mcp/builtin/globals/getGlobalSchemaTool.d.ts +2 -0
  77. package/dist/mcp/builtin/globals/getGlobalSchemaTool.d.ts.map +1 -0
  78. package/dist/mcp/builtin/globals/getGlobalSchemaTool.js +35 -0
  79. package/dist/mcp/builtin/globals/getGlobalSchemaTool.js.map +1 -0
  80. package/dist/mcp/builtin/globals/updateTool.d.ts +2 -0
  81. package/dist/mcp/builtin/globals/updateTool.d.ts.map +1 -0
  82. package/dist/mcp/builtin/globals/updateTool.js +94 -0
  83. package/dist/mcp/builtin/globals/updateTool.js.map +1 -0
  84. package/dist/mcp/builtin/validateEntityData.d.ts +14 -0
  85. package/dist/mcp/builtin/validateEntityData.d.ts.map +1 -0
  86. package/dist/mcp/builtin/validateEntityData.js +82 -0
  87. package/dist/mcp/builtin/validateEntityData.js.map +1 -0
  88. package/dist/mcp/builtinTools.d.ts +105 -0
  89. package/dist/mcp/builtinTools.d.ts.map +1 -0
  90. package/dist/mcp/builtinTools.js +107 -0
  91. package/dist/mcp/builtinTools.js.map +1 -0
  92. package/dist/mcp/sanitizeMCPConfig.d.ts +17 -0
  93. package/dist/mcp/sanitizeMCPConfig.d.ts.map +1 -0
  94. package/dist/mcp/sanitizeMCPConfig.js +188 -0
  95. package/dist/mcp/sanitizeMCPConfig.js.map +1 -0
  96. package/dist/stdio.d.ts +8 -0
  97. package/dist/stdio.d.ts.map +1 -0
  98. package/dist/stdio.js +89 -0
  99. package/dist/stdio.js.map +1 -0
  100. package/dist/types.d.ts +251 -455
  101. package/dist/types.d.ts.map +1 -1
  102. package/dist/types.js +6 -1
  103. package/dist/types.js.map +1 -1
  104. package/dist/utils/camelCase.d.ts.map +1 -1
  105. package/dist/utils/getLogger.d.ts +10 -0
  106. package/dist/utils/getLogger.d.ts.map +1 -0
  107. package/dist/utils/getLogger.js +22 -0
  108. package/dist/utils/getLogger.js.map +1 -0
  109. package/dist/utils/getPluginConfig.d.ts +12 -0
  110. package/dist/utils/getPluginConfig.d.ts.map +1 -0
  111. package/dist/utils/getPluginConfig.js +15 -0
  112. package/dist/utils/getPluginConfig.js.map +1 -0
  113. package/dist/utils/localAPIDefaults.d.ts +20 -0
  114. package/dist/utils/localAPIDefaults.d.ts.map +1 -0
  115. package/dist/utils/localAPIDefaults.js +19 -0
  116. package/dist/utils/localAPIDefaults.js.map +1 -0
  117. package/dist/utils/resolveProjectRoot.d.ts +7 -0
  118. package/dist/utils/resolveProjectRoot.d.ts.map +1 -0
  119. package/dist/utils/resolveProjectRoot.js +15 -0
  120. package/dist/utils/resolveProjectRoot.js.map +1 -0
  121. package/dist/utils/schemaConversion/getEntityInputSchema.d.ts +11 -0
  122. package/dist/utils/schemaConversion/getEntityInputSchema.d.ts.map +1 -0
  123. package/dist/utils/schemaConversion/getEntityInputSchema.js +34 -0
  124. package/dist/utils/schemaConversion/getEntityInputSchema.js.map +1 -0
  125. package/dist/utils/schemaConversion/removeVirtualFieldsFromSchema.d.ts +2 -2
  126. package/dist/utils/schemaConversion/removeVirtualFieldsFromSchema.d.ts.map +1 -1
  127. package/dist/utils/schemaConversion/removeVirtualFieldsFromSchema.js.map +1 -1
  128. package/dist/utils/schemaConversion/sanitizeEntitySchema.d.ts +15 -0
  129. package/dist/utils/schemaConversion/sanitizeEntitySchema.d.ts.map +1 -0
  130. package/dist/utils/schemaConversion/sanitizeEntitySchema.js +464 -0
  131. package/dist/utils/schemaConversion/sanitizeEntitySchema.js.map +1 -0
  132. package/dist/utils/schemaConversion/sanitizeEntitySchema.spec.js +158 -0
  133. package/dist/utils/schemaConversion/sanitizeEntitySchema.spec.js.map +1 -0
  134. package/dist/utils/toStandardSchema.d.ts +5 -0
  135. package/dist/utils/toStandardSchema.d.ts.map +1 -0
  136. package/dist/utils/toStandardSchema.js +4 -0
  137. package/dist/utils/toStandardSchema.js.map +1 -0
  138. package/dist/utils/whereSchema.d.ts +9 -0
  139. package/dist/utils/whereSchema.d.ts.map +1 -0
  140. package/dist/utils/whereSchema.js +13 -0
  141. package/dist/utils/whereSchema.js.map +1 -0
  142. package/package.json +35 -10
  143. package/src/collection/getAccessField.ts +64 -0
  144. package/src/collection/index.ts +64 -0
  145. package/src/components/AccessField/index.client.tsx +347 -0
  146. package/src/components/AccessField/index.css +93 -0
  147. package/src/defineTool.ts +44 -0
  148. package/src/endpoint/access.ts +132 -0
  149. package/src/endpoint/index.ts +35 -0
  150. package/src/exports/client.ts +2 -0
  151. package/src/index.ts +35 -85
  152. package/src/mcp/buildMcpServer.ts +257 -0
  153. package/src/mcp/builtin/collections/authTools.ts +233 -0
  154. package/src/mcp/builtin/collections/createTool.ts +112 -0
  155. package/src/mcp/builtin/collections/deleteTool.ts +116 -0
  156. package/src/mcp/builtin/collections/findTool.ts +177 -0
  157. package/src/mcp/builtin/collections/formatCollectionError.ts +84 -0
  158. package/src/mcp/builtin/collections/getCollectionSchemaTool.ts +28 -0
  159. package/src/mcp/builtin/collections/updateTool.ts +211 -0
  160. package/src/mcp/builtin/getConfigInfoTool.ts +44 -0
  161. package/src/mcp/builtin/globals/findTool.ts +96 -0
  162. package/src/mcp/builtin/globals/getGlobalSchemaTool.ts +28 -0
  163. package/src/mcp/builtin/globals/updateTool.ts +115 -0
  164. package/src/mcp/builtin/validateEntityData.ts +132 -0
  165. package/src/mcp/builtinTools.ts +98 -0
  166. package/src/mcp/sanitizeMCPConfig.ts +260 -0
  167. package/src/stdio.ts +98 -0
  168. package/src/types.ts +290 -490
  169. package/src/utils/getLogger.ts +22 -0
  170. package/src/utils/getPluginConfig.ts +24 -0
  171. package/src/utils/localAPIDefaults.ts +22 -0
  172. package/src/utils/resolveProjectRoot.ts +17 -0
  173. package/src/utils/schemaConversion/getEntityInputSchema.ts +78 -0
  174. package/src/utils/schemaConversion/removeVirtualFieldsFromSchema.ts +3 -3
  175. package/src/utils/schemaConversion/sanitizeEntitySchema.spec.ts +103 -0
  176. package/src/utils/schemaConversion/sanitizeEntitySchema.ts +529 -0
  177. package/src/utils/toStandardSchema.ts +9 -0
  178. package/src/utils/whereSchema.ts +24 -0
  179. package/dist/collections/createApiKeysCollection.d.ts +0 -7
  180. package/dist/collections/createApiKeysCollection.d.ts.map +0 -1
  181. package/dist/collections/createApiKeysCollection.js +0 -317
  182. package/dist/collections/createApiKeysCollection.js.map +0 -1
  183. package/dist/defaults.d.ts +0 -4
  184. package/dist/defaults.d.ts.map +0 -1
  185. package/dist/defaults.js +0 -5
  186. package/dist/defaults.js.map +0 -1
  187. package/dist/endpoints/mcp.d.ts +0 -4
  188. package/dist/endpoints/mcp.d.ts.map +0 -1
  189. package/dist/endpoints/mcp.js +0 -71
  190. package/dist/endpoints/mcp.js.map +0 -1
  191. package/dist/mcp/createRequest.d.ts +0 -3
  192. package/dist/mcp/createRequest.d.ts.map +0 -1
  193. package/dist/mcp/createRequest.js +0 -14
  194. package/dist/mcp/createRequest.js.map +0 -1
  195. package/dist/mcp/getMcpHandler.d.ts +0 -4
  196. package/dist/mcp/getMcpHandler.d.ts.map +0 -1
  197. package/dist/mcp/getMcpHandler.js +0 -231
  198. package/dist/mcp/getMcpHandler.js.map +0 -1
  199. package/dist/mcp/helpers/config.d.ts +0 -22
  200. package/dist/mcp/helpers/config.d.ts.map +0 -1
  201. package/dist/mcp/helpers/config.js +0 -153
  202. package/dist/mcp/helpers/config.js.map +0 -1
  203. package/dist/mcp/helpers/fields.d.ts +0 -19
  204. package/dist/mcp/helpers/fields.d.ts.map +0 -1
  205. package/dist/mcp/helpers/fields.js +0 -102
  206. package/dist/mcp/helpers/fields.js.map +0 -1
  207. package/dist/mcp/helpers/fileValidation.d.ts +0 -67
  208. package/dist/mcp/helpers/fileValidation.d.ts.map +0 -1
  209. package/dist/mcp/helpers/fileValidation.js +0 -267
  210. package/dist/mcp/helpers/fileValidation.js.map +0 -1
  211. package/dist/mcp/registerTool.d.ts +0 -6
  212. package/dist/mcp/registerTool.d.ts.map +0 -1
  213. package/dist/mcp/registerTool.js +0 -18
  214. package/dist/mcp/registerTool.js.map +0 -1
  215. package/dist/mcp/tools/auth/auth.d.ts +0 -4
  216. package/dist/mcp/tools/auth/auth.d.ts.map +0 -1
  217. package/dist/mcp/tools/auth/auth.js +0 -57
  218. package/dist/mcp/tools/auth/auth.js.map +0 -1
  219. package/dist/mcp/tools/auth/forgotPassword.d.ts +0 -4
  220. package/dist/mcp/tools/auth/forgotPassword.d.ts.map +0 -1
  221. package/dist/mcp/tools/auth/forgotPassword.js +0 -48
  222. package/dist/mcp/tools/auth/forgotPassword.js.map +0 -1
  223. package/dist/mcp/tools/auth/login.d.ts +0 -4
  224. package/dist/mcp/tools/auth/login.d.ts.map +0 -1
  225. package/dist/mcp/tools/auth/login.js +0 -51
  226. package/dist/mcp/tools/auth/login.js.map +0 -1
  227. package/dist/mcp/tools/auth/resetPassword.d.ts +0 -4
  228. package/dist/mcp/tools/auth/resetPassword.d.ts.map +0 -1
  229. package/dist/mcp/tools/auth/resetPassword.js +0 -49
  230. package/dist/mcp/tools/auth/resetPassword.js.map +0 -1
  231. package/dist/mcp/tools/auth/unlock.d.ts +0 -4
  232. package/dist/mcp/tools/auth/unlock.d.ts.map +0 -1
  233. package/dist/mcp/tools/auth/unlock.js +0 -48
  234. package/dist/mcp/tools/auth/unlock.js.map +0 -1
  235. package/dist/mcp/tools/auth/verify.d.ts +0 -4
  236. package/dist/mcp/tools/auth/verify.d.ts.map +0 -1
  237. package/dist/mcp/tools/auth/verify.js +0 -45
  238. package/dist/mcp/tools/auth/verify.js.map +0 -1
  239. package/dist/mcp/tools/collection/create.d.ts +0 -10
  240. package/dist/mcp/tools/collection/create.d.ts.map +0 -1
  241. package/dist/mcp/tools/collection/create.js +0 -139
  242. package/dist/mcp/tools/collection/create.js.map +0 -1
  243. package/dist/mcp/tools/collection/delete.d.ts +0 -10
  244. package/dist/mcp/tools/collection/delete.d.ts.map +0 -1
  245. package/dist/mcp/tools/collection/delete.js +0 -154
  246. package/dist/mcp/tools/collection/delete.js.map +0 -1
  247. package/dist/mcp/tools/collection/find.d.ts +0 -10
  248. package/dist/mcp/tools/collection/find.d.ts.map +0 -1
  249. package/dist/mcp/tools/collection/find.js +0 -165
  250. package/dist/mcp/tools/collection/find.js.map +0 -1
  251. package/dist/mcp/tools/collection/update.d.ts +0 -10
  252. package/dist/mcp/tools/collection/update.d.ts.map +0 -1
  253. package/dist/mcp/tools/collection/update.js +0 -209
  254. package/dist/mcp/tools/collection/update.js.map +0 -1
  255. package/dist/mcp/tools/config/find.d.ts +0 -10
  256. package/dist/mcp/tools/config/find.d.ts.map +0 -1
  257. package/dist/mcp/tools/config/find.js +0 -97
  258. package/dist/mcp/tools/config/find.js.map +0 -1
  259. package/dist/mcp/tools/config/update.d.ts +0 -10
  260. package/dist/mcp/tools/config/update.d.ts.map +0 -1
  261. package/dist/mcp/tools/config/update.js +0 -215
  262. package/dist/mcp/tools/config/update.js.map +0 -1
  263. package/dist/mcp/tools/global/find.d.ts +0 -5
  264. package/dist/mcp/tools/global/find.d.ts.map +0 -1
  265. package/dist/mcp/tools/global/find.js +0 -82
  266. package/dist/mcp/tools/global/find.js.map +0 -1
  267. package/dist/mcp/tools/global/update.d.ts +0 -6
  268. package/dist/mcp/tools/global/update.d.ts.map +0 -1
  269. package/dist/mcp/tools/global/update.js +0 -124
  270. package/dist/mcp/tools/global/update.js.map +0 -1
  271. package/dist/mcp/tools/job/create.d.ts +0 -10
  272. package/dist/mcp/tools/job/create.d.ts.map +0 -1
  273. package/dist/mcp/tools/job/create.js +0 -293
  274. package/dist/mcp/tools/job/create.js.map +0 -1
  275. package/dist/mcp/tools/job/run.d.ts +0 -10
  276. package/dist/mcp/tools/job/run.d.ts.map +0 -1
  277. package/dist/mcp/tools/job/run.js +0 -129
  278. package/dist/mcp/tools/job/run.js.map +0 -1
  279. package/dist/mcp/tools/job/update.d.ts +0 -11
  280. package/dist/mcp/tools/job/update.d.ts.map +0 -1
  281. package/dist/mcp/tools/job/update.js +0 -186
  282. package/dist/mcp/tools/job/update.js.map +0 -1
  283. package/dist/mcp/tools/resource/create.d.ts +0 -6
  284. package/dist/mcp/tools/resource/create.d.ts.map +0 -1
  285. package/dist/mcp/tools/resource/create.js +0 -124
  286. package/dist/mcp/tools/resource/create.js.map +0 -1
  287. package/dist/mcp/tools/resource/delete.d.ts +0 -5
  288. package/dist/mcp/tools/resource/delete.d.ts.map +0 -1
  289. package/dist/mcp/tools/resource/delete.js +0 -151
  290. package/dist/mcp/tools/resource/delete.js.map +0 -1
  291. package/dist/mcp/tools/resource/find.d.ts +0 -5
  292. package/dist/mcp/tools/resource/find.d.ts.map +0 -1
  293. package/dist/mcp/tools/resource/find.js +0 -170
  294. package/dist/mcp/tools/resource/find.js.map +0 -1
  295. package/dist/mcp/tools/resource/update.d.ts +0 -6
  296. package/dist/mcp/tools/resource/update.d.ts.map +0 -1
  297. package/dist/mcp/tools/resource/update.js +0 -256
  298. package/dist/mcp/tools/resource/update.js.map +0 -1
  299. package/dist/mcp/tools/schemas.d.ts +0 -457
  300. package/dist/mcp/tools/schemas.d.ts.map +0 -1
  301. package/dist/mcp/tools/schemas.js +0 -243
  302. package/dist/mcp/tools/schemas.js.map +0 -1
  303. package/dist/utils/adminEntitySettings.d.ts +0 -17
  304. package/dist/utils/adminEntitySettings.d.ts.map +0 -1
  305. package/dist/utils/adminEntitySettings.js +0 -41
  306. package/dist/utils/adminEntitySettings.js.map +0 -1
  307. package/dist/utils/createApiKeyFields.d.ts +0 -15
  308. package/dist/utils/createApiKeyFields.d.ts.map +0 -1
  309. package/dist/utils/createApiKeyFields.js +0 -57
  310. package/dist/utils/createApiKeyFields.js.map +0 -1
  311. package/dist/utils/getEnabledSlugs.d.ts +0 -13
  312. package/dist/utils/getEnabledSlugs.d.ts.map +0 -1
  313. package/dist/utils/getEnabledSlugs.js +0 -32
  314. package/dist/utils/getEnabledSlugs.js.map +0 -1
  315. package/dist/utils/schemaConversion/convertCollectionSchemaToZod.d.ts +0 -3
  316. package/dist/utils/schemaConversion/convertCollectionSchemaToZod.d.ts.map +0 -1
  317. package/dist/utils/schemaConversion/convertCollectionSchemaToZod.js +0 -43
  318. package/dist/utils/schemaConversion/convertCollectionSchemaToZod.js.map +0 -1
  319. package/dist/utils/schemaConversion/sanitizeJsonSchema.d.ts +0 -13
  320. package/dist/utils/schemaConversion/sanitizeJsonSchema.d.ts.map +0 -1
  321. package/dist/utils/schemaConversion/sanitizeJsonSchema.js +0 -56
  322. package/dist/utils/schemaConversion/sanitizeJsonSchema.js.map +0 -1
  323. package/dist/utils/schemaConversion/simplifyRelationshipFields.d.ts +0 -20
  324. package/dist/utils/schemaConversion/simplifyRelationshipFields.d.ts.map +0 -1
  325. package/dist/utils/schemaConversion/simplifyRelationshipFields.js +0 -53
  326. package/dist/utils/schemaConversion/simplifyRelationshipFields.js.map +0 -1
  327. package/dist/utils/schemaConversion/transformPointFields.d.ts +0 -3
  328. package/dist/utils/schemaConversion/transformPointFields.d.ts.map +0 -1
  329. package/dist/utils/schemaConversion/transformPointFields.js +0 -51
  330. package/dist/utils/schemaConversion/transformPointFields.js.map +0 -1
  331. package/src/collections/createApiKeysCollection.ts +0 -373
  332. package/src/defaults.ts +0 -3
  333. package/src/endpoints/mcp.ts +0 -91
  334. package/src/mcp/createRequest.ts +0 -13
  335. package/src/mcp/getMcpHandler.ts +0 -545
  336. package/src/mcp/helpers/config.ts +0 -213
  337. package/src/mcp/helpers/fields.ts +0 -154
  338. package/src/mcp/helpers/fileValidation.ts +0 -362
  339. package/src/mcp/registerTool.ts +0 -22
  340. package/src/mcp/tools/auth/auth.ts +0 -71
  341. package/src/mcp/tools/auth/forgotPassword.ts +0 -70
  342. package/src/mcp/tools/auth/login.ts +0 -72
  343. package/src/mcp/tools/auth/resetPassword.ts +0 -61
  344. package/src/mcp/tools/auth/unlock.ts +0 -64
  345. package/src/mcp/tools/auth/verify.ts +0 -57
  346. package/src/mcp/tools/collection/create.ts +0 -210
  347. package/src/mcp/tools/collection/delete.ts +0 -211
  348. package/src/mcp/tools/collection/find.ts +0 -224
  349. package/src/mcp/tools/collection/update.ts +0 -290
  350. package/src/mcp/tools/config/find.ts +0 -128
  351. package/src/mcp/tools/config/update.ts +0 -280
  352. package/src/mcp/tools/global/find.ts +0 -128
  353. package/src/mcp/tools/global/update.ts +0 -207
  354. package/src/mcp/tools/job/create.ts +0 -416
  355. package/src/mcp/tools/job/run.ts +0 -167
  356. package/src/mcp/tools/job/update.ts +0 -274
  357. package/src/mcp/tools/resource/create.ts +0 -211
  358. package/src/mcp/tools/resource/delete.ts +0 -218
  359. package/src/mcp/tools/resource/find.ts +0 -246
  360. package/src/mcp/tools/resource/update.ts +0 -383
  361. package/src/mcp/tools/schemas.ts +0 -520
  362. package/src/utils/adminEntitySettings.ts +0 -40
  363. package/src/utils/createApiKeyFields.ts +0 -72
  364. package/src/utils/getEnabledSlugs.ts +0 -42
  365. package/src/utils/schemaConversion/convertCollectionSchemaToZod.ts +0 -52
  366. package/src/utils/schemaConversion/sanitizeJsonSchema.ts +0 -62
  367. package/src/utils/schemaConversion/simplifyRelationshipFields.ts +0 -65
  368. package/src/utils/schemaConversion/transformPointFields.ts +0 -55
@@ -0,0 +1,464 @@
1
+ /**
2
+ * Turns the JSON Schema that Payload generates for a collection or global into the input schema for
3
+ * an MCP create/update tool. In short, it:
4
+ *
5
+ * - drops fields a client can't set (`id`, `createdAt`, the draft `_status`, …),
6
+ * - rewrites Payload-specific field shapes (points, relationships) into plain JSON the model can fill,
7
+ * - and shrinks the result so it's cheaper for the model to read,
8
+ *
9
+ * while keeping every node valid JSON Schema draft 2020-12. Each step below is tagged with why it runs -
10
+ * **Correctness** (valid input the API accepts), **Size** (equivalence-preserving shrink), or **LLM
11
+ * ergonomics** (easier for the model to read/fill) - and carries a before/after example on its definition.
12
+ */ export const sanitizeEntitySchema = (schema)=>{
13
+ // Work on a copy — the caller reuses the original schema elsewhere (e.g. when listing tools).
14
+ let result = structuredClone(schema);
15
+ // Correctness — drop the fields a client can't set (id, createdAt, updatedAt, draft _status) + collapse nullable types.
16
+ result = removeManagedFields(result);
17
+ // LLM ergonomics — rewrite point fields from a `[number, number]` tuple into a `{ longitude, latitude }` object.
18
+ result = pointFieldsToObjects(result);
19
+ // Correctness — a relationship value can be an ID or a populated doc; on input only the ID is valid, so keep that.
20
+ result = relationshipsToIds(result);
21
+ // Size — strip inert type-gen leftovers that only bloat the schema (`tsType`, block-collision notes).
22
+ result = removeTypeGenArtifacts(result);
23
+ // Size — where a `const` already pins a value, the sibling `type` is redundant; remove it.
24
+ result = dropRedundantConstType(result);
25
+ // Size — fold per-collection relationship/upload variants (identical but for `relationTo`) into one `enum`.
26
+ result = mergeConstDiscriminatedUnions(result);
27
+ // Size — pull any subschema that appears more than once into a single shared `$defs` entry.
28
+ result = deduplicateIntoDefinitions(result);
29
+ // LLM ergonomics — give `$defs` short, readable names (`Code`, `paragraph`, `node`) so the `$ref`s read nicely.
30
+ result = shortenDefinitionNames(result);
31
+ return result;
32
+ };
33
+ /**
34
+ * Rebuilds a schema bottom-up, calling `visit` on each node after its children. Shared by the
35
+ * transforms that need to touch every node in the tree.
36
+ */ const mapNodes = (node, visit)=>{
37
+ if (Array.isArray(node)) {
38
+ return node.map((child)=>mapNodes(child, visit));
39
+ }
40
+ if (!node || typeof node !== 'object') {
41
+ return node;
42
+ }
43
+ const out = {};
44
+ for (const [key, value] of Object.entries(node)){
45
+ out[key] = mapNodes(value, visit);
46
+ }
47
+ return visit(out);
48
+ };
49
+ // Payload sets these on every document, so an MCP client never provides them when creating/updating.
50
+ const PAYLOAD_MANAGED_FIELDS = new Set([
51
+ '_status',
52
+ 'createdAt',
53
+ 'id',
54
+ 'updatedAt'
55
+ ]);
56
+ /**
57
+ * **Correctness.** Removes the fields a client can't set on create/update - `id`, `createdAt`, `updatedAt`, and the draft
58
+ * `_status` - from every field object's `properties` and `required` (recursing into nested objects and
59
+ * array items). Along the way it also collapses optional array/object types via {@link collapseNullableType}.
60
+ *
61
+ * @example
62
+ * { properties: { id: { type: 'string' }, tags: { type: ['array', 'null'], items: {} } }, required: ['id', 'tags'] }
63
+ * → { properties: { tags: { type: 'array', items: {} } }, required: ['tags'] }
64
+ */ const removeManagedFields = (schema)=>{
65
+ if (schema.properties && typeof schema.properties === 'object') {
66
+ for (const field of PAYLOAD_MANAGED_FIELDS){
67
+ delete schema.properties[field];
68
+ }
69
+ for (const key of Object.keys(schema.properties)){
70
+ const prop = schema.properties[key];
71
+ if (!prop || typeof prop !== 'object') {
72
+ continue;
73
+ }
74
+ const isRequired = Array.isArray(schema.required) && schema.required.includes(key);
75
+ collapseNullableType(prop, isRequired);
76
+ if (prop.properties) {
77
+ removeManagedFields(prop);
78
+ }
79
+ if (prop.items && typeof prop.items === 'object' && !Array.isArray(prop.items)) {
80
+ removeManagedFields(prop.items);
81
+ }
82
+ }
83
+ }
84
+ if (Array.isArray(schema.required)) {
85
+ schema.required = schema.required.filter((name)=>!PAYLOAD_MANAGED_FIELDS.has(name));
86
+ if (schema.required.length === 0) {
87
+ delete schema.required;
88
+ }
89
+ }
90
+ return schema;
91
+ };
92
+ /**
93
+ * Drops the `'null'` from an optional array/object type (`['array', 'null']` → `'array'`, likewise
94
+ * `'object'`). Payload marks a field optional by unioning its type with `'null'`, but a create/update
95
+ * tool already conveys "optional" through the `required` list - the client just omits the field - so the
96
+ * `'null'` is redundant here. Dropping it shows the model a plain `type: 'array'` instead of implying it
97
+ * should send a literal `null`.
98
+ *
99
+ * We never touch the `required` list, so this can't change whether a field is required. And we skip fields
100
+ * that ARE required (`isRequired`): there a `'null'` is a value the field genuinely accepts, not optionality
101
+ * encoding. Nullable scalars (`['string', 'null']`) are also left alone - they read fine as `string | null`.
102
+ *
103
+ * @example
104
+ * optional { type: ['array', 'null'] } → { type: 'array' } (still optional, just no longer null-valued)
105
+ * required { type: ['array', 'null'] } → unchanged
106
+ * { type: ['string', 'null'] } → unchanged
107
+ */ const collapseNullableType = (schema, isRequired)=>{
108
+ if (isRequired || !Array.isArray(schema.type)) {
109
+ return;
110
+ }
111
+ const nonNullTypes = schema.type.filter((t)=>t !== 'null');
112
+ if (nonNullTypes.length === 1 && (nonNullTypes[0] === 'array' || nonNullTypes[0] === 'object')) {
113
+ schema.type = nonNullTypes[0];
114
+ }
115
+ };
116
+ /**
117
+ * **LLM ergonomics.** Rewrites a point field (stored as a two-number tuple) into a `{ longitude, latitude }` object, which
118
+ * is far easier for the model to fill in than a positional array. This is input-only and lossless: the
119
+ * create/update handler converts the object back to the `[longitude, latitude]` tuple Payload stores,
120
+ * via `transformPointDataToPayload`.
121
+ *
122
+ * @example
123
+ * { type: 'array', items: [{ type: 'number' }, { type: 'number' }] }
124
+ * → { type: 'object', properties: { longitude: { type: 'number' }, latitude: { type: 'number' } }, required: ['longitude', 'latitude'] }
125
+ */ const pointFieldsToObjects = (schema)=>{
126
+ if (!schema || typeof schema !== 'object') {
127
+ return schema;
128
+ }
129
+ const transformed = {
130
+ ...schema
131
+ };
132
+ if (transformed.properties && typeof transformed.properties === 'object') {
133
+ transformed.properties = Object.fromEntries(Object.entries(transformed.properties).map(([key, value])=>{
134
+ if (!value || typeof value !== 'object') {
135
+ return [
136
+ key,
137
+ value
138
+ ];
139
+ }
140
+ const isArrayType = value.type === 'array' || Array.isArray(value.type) && value.type.includes('array');
141
+ const isPointField = isArrayType && Array.isArray(value.items) && value.items.length === 2 && value.items.every((item)=>item && typeof item === 'object' && item.type === 'number');
142
+ if (isPointField) {
143
+ const isNullable = Array.isArray(value.type) && value.type.includes('null');
144
+ return [
145
+ key,
146
+ {
147
+ type: isNullable ? [
148
+ 'object',
149
+ 'null'
150
+ ] : 'object',
151
+ description: value.description || 'Geographic coordinates (longitude, latitude)',
152
+ properties: {
153
+ latitude: {
154
+ type: 'number',
155
+ description: 'Latitude coordinate'
156
+ },
157
+ longitude: {
158
+ type: 'number',
159
+ description: 'Longitude coordinate'
160
+ }
161
+ },
162
+ required: [
163
+ 'longitude',
164
+ 'latitude'
165
+ ]
166
+ }
167
+ ];
168
+ }
169
+ return [
170
+ key,
171
+ pointFieldsToObjects(value)
172
+ ];
173
+ }));
174
+ }
175
+ if (transformed.items && typeof transformed.items === 'object' && !Array.isArray(transformed.items)) {
176
+ transformed.items = pointFieldsToObjects(transformed.items);
177
+ }
178
+ return transformed;
179
+ };
180
+ /**
181
+ * **Correctness.** Reduces relationship/upload fields to the IDs a client actually sends. Payload types the value as
182
+ * "an ID or the full related document" - but the populated-document form only appears in read responses;
183
+ * on create/update you always reference a relationship by its ID. So we drop that `$ref` option, leaving
184
+ * the bare ID. A single remaining target collapses inline (with a description naming the target
185
+ * collection); several targets become an `anyOf` of IDs.
186
+ *
187
+ * @example
188
+ * { oneOf: [{ type: 'string' }, { $ref: '#/$defs/posts' }] }
189
+ * → { type: 'string', description: 'The ID of the related "posts" document.' }
190
+ */ const relationshipsToIds = (schema)=>{
191
+ if (!schema || typeof schema !== 'object') {
192
+ return schema;
193
+ }
194
+ const processed = {
195
+ ...schema
196
+ };
197
+ if (Array.isArray(processed.oneOf)) {
198
+ const isRelatedDocRef = (option)=>!!option && typeof option === 'object' && '$ref' in option;
199
+ if (processed.oneOf.some(isRelatedDocRef)) {
200
+ // A relationship value is "an ID, or the populated related document". Keep the ID option(s) and
201
+ // drop the `$ref`s to the related collections, since a client only ever sends the ID.
202
+ const idOptions = processed.oneOf.filter((option)=>!isRelatedDocRef(option)).map((option)=>typeof option === 'object' ? relationshipsToIds(option) : option);
203
+ const targetCollections = processed.oneOf.filter(isRelatedDocRef).map((option)=>option.$ref.replace('#/$defs/', ''));
204
+ if (idOptions.length === 1) {
205
+ delete processed.oneOf;
206
+ Object.assign(processed, idOptions[0]);
207
+ if (targetCollections.length > 0 && !processed.description) {
208
+ processed.description = `The ID of the related "${targetCollections.join('" or "')}" document.`;
209
+ }
210
+ } else if (idOptions.length > 1) {
211
+ delete processed.oneOf;
212
+ processed.anyOf = idOptions;
213
+ }
214
+ } else {
215
+ processed.oneOf = processed.oneOf.map((option)=>typeof option === 'object' ? relationshipsToIds(option) : option);
216
+ }
217
+ }
218
+ if (processed.properties && typeof processed.properties === 'object') {
219
+ processed.properties = Object.fromEntries(Object.entries(processed.properties).map(([key, value])=>[
220
+ key,
221
+ typeof value === 'object' ? relationshipsToIds(value) : value
222
+ ]));
223
+ }
224
+ if (processed.items && typeof processed.items === 'object' && !Array.isArray(processed.items)) {
225
+ processed.items = relationshipsToIds(processed.items);
226
+ }
227
+ // Lexical node unions and blocks live under `$defs` and have their own relationship fields, so walk
228
+ // those too — otherwise their `$ref`s would dangle once we don't bundle the related collections.
229
+ if (processed.$defs && typeof processed.$defs === 'object') {
230
+ processed.$defs = Object.fromEntries(Object.entries(processed.$defs).map(([key, value])=>[
231
+ key,
232
+ typeof value === 'object' ? relationshipsToIds(value) : value
233
+ ]));
234
+ }
235
+ return processed;
236
+ };
237
+ /**
238
+ * **Size.** Strips type-generation leftovers that bloat the schema without helping the model: the `tsType`
239
+ * hint (a `json-schema-to-typescript` extension; JSON Schema validators just ignore it, they don't reject it)
240
+ * and the block-interface-collision note Payload adds to some block descriptions (the
241
+ * `block-interface-name-collisions` docs link set in `registerBlockInterface`, see configToJSONSchema.ts).
242
+ * Both are inert here - removing them only shrinks the schema (and spares the model irrelevant noise).
243
+ *
244
+ * @example
245
+ * { type: 'object', tsType: 'SerializedBlockNode', description: 'see …#block-interface-name-collisions' }
246
+ * → { type: 'object' }
247
+ */ const removeTypeGenArtifacts = (schema)=>mapNodes(schema, (node)=>{
248
+ delete node.tsType;
249
+ const { description } = node;
250
+ if (typeof description === 'string' && description.includes('block-interface-name-collisions')) {
251
+ delete node.description;
252
+ }
253
+ return node;
254
+ });
255
+ /**
256
+ * **Size.** Removes `type` whenever a `const` sits next to it — the constant already fixes the value.
257
+ *
258
+ * @example
259
+ * { type: 'string', const: 'paragraph' } → { const: 'paragraph' }
260
+ */ const dropRedundantConstType = (schema)=>mapNodes(schema, (node)=>{
261
+ if ('const' in node && 'type' in node) {
262
+ delete node.type;
263
+ }
264
+ return node;
265
+ });
266
+ /**
267
+ * **Size.** Merges the members of a `oneOf`/`anyOf` that are identical except for one `const`-valued property
268
+ * into a single member with that property as an `enum`. Since the members differ only by that one
269
+ * constant, the `enum` form accepts exactly the same values - it's just smaller. This folds the
270
+ * per-collection relationship and upload variants, which differ only in their `relationTo` constant.
271
+ *
272
+ * @example
273
+ * { oneOf: [
274
+ * { properties: { relationTo: { const: 'posts' }, value: { type: 'string' } } },
275
+ * { properties: { relationTo: { const: 'pages' }, value: { type: 'string' } } },
276
+ * ] }
277
+ * → { properties: { relationTo: { enum: ['posts', 'pages'] }, value: { type: 'string' } } }
278
+ */ const mergeConstDiscriminatedUnions = (schema)=>mapNodes(schema, (node)=>{
279
+ for (const keyword of [
280
+ 'oneOf',
281
+ 'anyOf'
282
+ ]){
283
+ const members = node[keyword];
284
+ if (Array.isArray(members) && members.length > 1) {
285
+ const merged = mergeMembersByConst(members);
286
+ if (merged) {
287
+ delete node[keyword];
288
+ Object.assign(node, merged);
289
+ }
290
+ }
291
+ }
292
+ return node;
293
+ });
294
+ /** Returns the merged member for {@link mergeConstDiscriminatedUnions}, or `null` if they can't merge. */ const mergeMembersByConst = (members)=>{
295
+ const objects = members.filter((member)=>typeof member === 'object' && member !== null && typeof member.properties === 'object');
296
+ if (objects.length < 2 || objects.length !== members.length) {
297
+ return null;
298
+ }
299
+ for (const discriminator of Object.keys(objects[0].properties)){
300
+ // Each member must pin this property to a `const`...
301
+ const constValues = [];
302
+ const everyMemberPinsConst = objects.every((member)=>{
303
+ const prop = member.properties[discriminator];
304
+ if (prop && typeof prop === 'object' && 'const' in prop) {
305
+ constValues.push(prop.const);
306
+ return true;
307
+ }
308
+ return false;
309
+ });
310
+ if (!everyMemberPinsConst) {
311
+ continue;
312
+ }
313
+ // ...and be otherwise identical (compare each member with the discriminator removed).
314
+ const fingerprintWithoutDiscriminator = (member)=>{
315
+ const { [discriminator]: _discriminator, ...otherProperties } = member.properties;
316
+ return JSON.stringify({
317
+ ...member,
318
+ properties: otherProperties
319
+ });
320
+ };
321
+ if (new Set(objects.map(fingerprintWithoutDiscriminator)).size !== 1) {
322
+ continue;
323
+ }
324
+ const uniqueConstValues = [
325
+ ...new Set(constValues)
326
+ ];
327
+ if (uniqueConstValues.length < 2) {
328
+ continue;
329
+ }
330
+ // Replace the per-member `const` with a single `enum` of every value.
331
+ const merged = structuredClone(objects[0]);
332
+ const discriminatorProp = merged.properties[discriminator];
333
+ if (discriminatorProp && typeof discriminatorProp === 'object') {
334
+ delete discriminatorProp.const;
335
+ discriminatorProp.enum = uniqueConstValues;
336
+ }
337
+ return merged;
338
+ }
339
+ return null;
340
+ };
341
+ // A `$ref` costs ~30 characters once names are shortened, so sharing a subschema only pays off when
342
+ // it's larger than that and appears more than once.
343
+ const MIN_SHARED_SIZE = 64;
344
+ /** A subschema worth sharing: a standalone object/union/described schema, not a `$ref` or a primitive. */ const isShareable = (node)=>{
345
+ if (!node || typeof node !== 'object' || Array.isArray(node) || '$ref' in node) {
346
+ return false;
347
+ }
348
+ const schema = node;
349
+ return Array.isArray(schema.oneOf) || Array.isArray(schema.anyOf) || Boolean(schema.properties) || Boolean(schema.items) || typeof schema.description === 'string';
350
+ };
351
+ /**
352
+ * **Size.** Replaces any subschema that appears more than once with a single shared `$defs` entry referenced by
353
+ * `$ref`. Lossless — only the serialized size shrinks. A collection with several rich-text fields, for
354
+ * example, inlines the same large lexical node schema once per field; this collapses them into one.
355
+ *
356
+ * @example
357
+ * { properties: { billing: address, shipping: address } }
358
+ * → { properties: { billing: { $ref: '#/$defs/shared_0' }, shipping: { $ref: '#/$defs/shared_0' } }, $defs: { shared_0: address } }
359
+ */ const deduplicateIntoDefinitions = (schema)=>{
360
+ // Count how often each shareable subschema appears, keyed by its serialized form.
361
+ const counts = new Map();
362
+ const count = (node)=>{
363
+ if (isShareable(node)) {
364
+ const key = JSON.stringify(node);
365
+ if (key.length >= MIN_SHARED_SIZE) {
366
+ counts.set(key, (counts.get(key) ?? 0) + 1);
367
+ }
368
+ }
369
+ if (Array.isArray(node)) {
370
+ node.forEach(count);
371
+ } else if (node && typeof node === 'object') {
372
+ Object.values(node).forEach(count);
373
+ }
374
+ };
375
+ count(schema);
376
+ if (![
377
+ ...counts.values()
378
+ ].some((n)=>n >= 2)) {
379
+ return schema;
380
+ }
381
+ // Replace each subschema seen 2+ times with a `$ref`. The first time we meet one it becomes a shared
382
+ // entry; we never descend into a stored entry, so shared entries never reference one another.
383
+ const sharedEntries = {};
384
+ const nameByKey = new Map();
385
+ const share = (node)=>{
386
+ if (isShareable(node)) {
387
+ const key = JSON.stringify(node);
388
+ if ((counts.get(key) ?? 0) >= 2) {
389
+ let name = nameByKey.get(key);
390
+ if (!name) {
391
+ name = `shared_${nameByKey.size}`;
392
+ nameByKey.set(key, name);
393
+ sharedEntries[name] = node;
394
+ }
395
+ return {
396
+ $ref: `#/$defs/${name}`
397
+ };
398
+ }
399
+ }
400
+ if (Array.isArray(node)) {
401
+ return node.map(share);
402
+ }
403
+ if (node && typeof node === 'object') {
404
+ return Object.fromEntries(Object.entries(node).map(([childKey, value])=>[
405
+ childKey,
406
+ share(value)
407
+ ]));
408
+ }
409
+ return node;
410
+ };
411
+ const result = share(schema);
412
+ result.$defs = {
413
+ ...result.$defs,
414
+ ...sharedEntries
415
+ };
416
+ return result;
417
+ };
418
+ /**
419
+ * **LLM ergonomics.** Renames `$defs` entries to short, readable names so the `$ref`s stay legible to the model: a block's
420
+ * `blockType` (`Code`), a node's `type` (`paragraph`), `node` for a rich-text node union, otherwise the
421
+ * generated name with its disambiguating hash dropped. A numeric suffix keeps collisions unique.
422
+ *
423
+ * @example
424
+ * { properties: { body: { $ref: '#/$defs/LexicalNodes_9FBEC708' } }, $defs: { LexicalNodes_9FBEC708: {} } }
425
+ * → { properties: { body: { $ref: '#/$defs/node' } }, $defs: { node: {} } }
426
+ */ const shortenDefinitionNames = (schema)=>{
427
+ const definitions = schema.$defs;
428
+ if (!definitions || Object.keys(definitions).length === 0) {
429
+ return schema;
430
+ }
431
+ const shortNameFor = (name, definition)=>{
432
+ const properties = typeof definition === 'object' && definition.properties || {};
433
+ const constString = (key)=>{
434
+ const prop = properties[key];
435
+ return prop && typeof prop === 'object' && typeof prop.const === 'string' ? prop.const : undefined;
436
+ };
437
+ const members = typeof definition === 'object' ? definition.anyOf ?? definition.oneOf : undefined;
438
+ const isNodeUnion = Array.isArray(members) && members.some((m)=>typeof m === 'object' && Boolean(m.$ref || m.properties?.type));
439
+ return constString('blockType') ?? constString('type') ?? (isNodeUnion ? 'node' : undefined) ?? name.replace(/_[0-9A-F]{6,}$/i, '');
440
+ };
441
+ const prefix = '#/$defs/';
442
+ const usedNames = new Map();
443
+ const rename = new Map();
444
+ for (const [name, definition] of Object.entries(definitions)){
445
+ const shortName = shortNameFor(name, definition);
446
+ const used = usedNames.get(shortName) ?? 0;
447
+ usedNames.set(shortName, used + 1);
448
+ rename.set(name, used === 0 ? shortName : `${shortName}${used + 1}`);
449
+ }
450
+ const result = mapNodes(schema, (node)=>{
451
+ if (typeof node.$ref === 'string' && node.$ref.startsWith(prefix)) {
452
+ const name = node.$ref.slice(prefix.length);
453
+ node.$ref = `${prefix}${rename.get(name) ?? name}`;
454
+ }
455
+ return node;
456
+ });
457
+ result.$defs = Object.fromEntries(Object.entries(result.$defs).map(([name, body])=>[
458
+ rename.get(name) ?? name,
459
+ body
460
+ ]));
461
+ return result;
462
+ };
463
+
464
+ //# sourceMappingURL=sanitizeEntitySchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/utils/schemaConversion/sanitizeEntitySchema.ts"],"sourcesContent":["import type { JsonSchemaType } from '../../types.js'\n\n/**\n * Turns the JSON Schema that Payload generates for a collection or global into the input schema for\n * an MCP create/update tool. In short, it:\n *\n * - drops fields a client can't set (`id`, `createdAt`, the draft `_status`, …),\n * - rewrites Payload-specific field shapes (points, relationships) into plain JSON the model can fill,\n * - and shrinks the result so it's cheaper for the model to read,\n *\n * while keeping every node valid JSON Schema draft 2020-12. Each step below is tagged with why it runs -\n * **Correctness** (valid input the API accepts), **Size** (equivalence-preserving shrink), or **LLM\n * ergonomics** (easier for the model to read/fill) - and carries a before/after example on its definition.\n */\nexport const sanitizeEntitySchema = (schema: JsonSchemaType): JsonSchemaType => {\n // Work on a copy — the caller reuses the original schema elsewhere (e.g. when listing tools).\n let result = structuredClone(schema)\n\n // Correctness — drop the fields a client can't set (id, createdAt, updatedAt, draft _status) + collapse nullable types.\n result = removeManagedFields(result)\n\n // LLM ergonomics — rewrite point fields from a `[number, number]` tuple into a `{ longitude, latitude }` object.\n result = pointFieldsToObjects(result)\n\n // Correctness — a relationship value can be an ID or a populated doc; on input only the ID is valid, so keep that.\n result = relationshipsToIds(result)\n\n // Size — strip inert type-gen leftovers that only bloat the schema (`tsType`, block-collision notes).\n result = removeTypeGenArtifacts(result)\n\n // Size — where a `const` already pins a value, the sibling `type` is redundant; remove it.\n result = dropRedundantConstType(result)\n\n // Size — fold per-collection relationship/upload variants (identical but for `relationTo`) into one `enum`.\n result = mergeConstDiscriminatedUnions(result)\n\n // Size — pull any subschema that appears more than once into a single shared `$defs` entry.\n result = deduplicateIntoDefinitions(result)\n\n // LLM ergonomics — give `$defs` short, readable names (`Code`, `paragraph`, `node`) so the `$ref`s read nicely.\n result = shortenDefinitionNames(result)\n\n return result\n}\n\n/**\n * Rebuilds a schema bottom-up, calling `visit` on each node after its children. Shared by the\n * transforms that need to touch every node in the tree.\n */\nconst mapNodes = (node: unknown, visit: (node: JsonSchemaType) => JsonSchemaType): unknown => {\n if (Array.isArray(node)) {\n return node.map((child) => mapNodes(child, visit))\n }\n if (!node || typeof node !== 'object') {\n return node\n }\n const out: Record<string, unknown> = {}\n for (const [key, value] of Object.entries(node)) {\n out[key] = mapNodes(value, visit)\n }\n return visit(out as JsonSchemaType)\n}\n\n// Payload sets these on every document, so an MCP client never provides them when creating/updating.\nconst PAYLOAD_MANAGED_FIELDS = new Set(['_status', 'createdAt', 'id', 'updatedAt'])\n\n/**\n * **Correctness.** Removes the fields a client can't set on create/update - `id`, `createdAt`, `updatedAt`, and the draft\n * `_status` - from every field object's `properties` and `required` (recursing into nested objects and\n * array items). Along the way it also collapses optional array/object types via {@link collapseNullableType}.\n *\n * @example\n * { properties: { id: { type: 'string' }, tags: { type: ['array', 'null'], items: {} } }, required: ['id', 'tags'] }\n * → { properties: { tags: { type: 'array', items: {} } }, required: ['tags'] }\n */\nconst removeManagedFields = (schema: JsonSchemaType): JsonSchemaType => {\n if (schema.properties && typeof schema.properties === 'object') {\n for (const field of PAYLOAD_MANAGED_FIELDS) {\n delete schema.properties[field]\n }\n for (const key of Object.keys(schema.properties)) {\n const prop = schema.properties[key] as JsonSchemaType\n if (!prop || typeof prop !== 'object') {\n continue\n }\n const isRequired = Array.isArray(schema.required) && schema.required.includes(key)\n collapseNullableType(prop, isRequired)\n if (prop.properties) {\n removeManagedFields(prop)\n }\n if (prop.items && typeof prop.items === 'object' && !Array.isArray(prop.items)) {\n removeManagedFields(prop.items)\n }\n }\n }\n\n if (Array.isArray(schema.required)) {\n schema.required = schema.required.filter((name) => !PAYLOAD_MANAGED_FIELDS.has(name))\n if (schema.required.length === 0) {\n delete schema.required\n }\n }\n\n return schema\n}\n\n/**\n * Drops the `'null'` from an optional array/object type (`['array', 'null']` → `'array'`, likewise\n * `'object'`). Payload marks a field optional by unioning its type with `'null'`, but a create/update\n * tool already conveys \"optional\" through the `required` list - the client just omits the field - so the\n * `'null'` is redundant here. Dropping it shows the model a plain `type: 'array'` instead of implying it\n * should send a literal `null`.\n *\n * We never touch the `required` list, so this can't change whether a field is required. And we skip fields\n * that ARE required (`isRequired`): there a `'null'` is a value the field genuinely accepts, not optionality\n * encoding. Nullable scalars (`['string', 'null']`) are also left alone - they read fine as `string | null`.\n *\n * @example\n * optional { type: ['array', 'null'] } → { type: 'array' } (still optional, just no longer null-valued)\n * required { type: ['array', 'null'] } → unchanged\n * { type: ['string', 'null'] } → unchanged\n */\nconst collapseNullableType = (schema: JsonSchemaType, isRequired: boolean): void => {\n if (isRequired || !Array.isArray(schema.type)) {\n return\n }\n const nonNullTypes = schema.type.filter((t) => t !== 'null')\n if (nonNullTypes.length === 1 && (nonNullTypes[0] === 'array' || nonNullTypes[0] === 'object')) {\n schema.type = nonNullTypes[0]\n }\n}\n\n/**\n * **LLM ergonomics.** Rewrites a point field (stored as a two-number tuple) into a `{ longitude, latitude }` object, which\n * is far easier for the model to fill in than a positional array. This is input-only and lossless: the\n * create/update handler converts the object back to the `[longitude, latitude]` tuple Payload stores,\n * via `transformPointDataToPayload`.\n *\n * @example\n * { type: 'array', items: [{ type: 'number' }, { type: 'number' }] }\n * → { type: 'object', properties: { longitude: { type: 'number' }, latitude: { type: 'number' } }, required: ['longitude', 'latitude'] }\n */\nconst pointFieldsToObjects = (schema: JsonSchemaType): JsonSchemaType => {\n if (!schema || typeof schema !== 'object') {\n return schema\n }\n\n const transformed = { ...schema }\n\n if (transformed.properties && typeof transformed.properties === 'object') {\n transformed.properties = Object.fromEntries(\n Object.entries(transformed.properties).map(([key, value]) => {\n if (!value || typeof value !== 'object') {\n return [key, value]\n }\n const isArrayType =\n value.type === 'array' || (Array.isArray(value.type) && value.type.includes('array'))\n const isPointField =\n isArrayType &&\n Array.isArray(value.items) &&\n value.items.length === 2 &&\n value.items.every((item) => item && typeof item === 'object' && item.type === 'number')\n\n if (isPointField) {\n const isNullable = Array.isArray(value.type) && value.type.includes('null')\n return [\n key,\n {\n type: isNullable ? ['object', 'null'] : 'object',\n description: value.description || 'Geographic coordinates (longitude, latitude)',\n properties: {\n latitude: { type: 'number', description: 'Latitude coordinate' },\n longitude: { type: 'number', description: 'Longitude coordinate' },\n },\n required: ['longitude', 'latitude'],\n },\n ]\n }\n\n return [key, pointFieldsToObjects(value)]\n }),\n )\n }\n\n if (\n transformed.items &&\n typeof transformed.items === 'object' &&\n !Array.isArray(transformed.items)\n ) {\n transformed.items = pointFieldsToObjects(transformed.items)\n }\n\n return transformed\n}\n\n/**\n * **Correctness.** Reduces relationship/upload fields to the IDs a client actually sends. Payload types the value as\n * \"an ID or the full related document\" - but the populated-document form only appears in read responses;\n * on create/update you always reference a relationship by its ID. So we drop that `$ref` option, leaving\n * the bare ID. A single remaining target collapses inline (with a description naming the target\n * collection); several targets become an `anyOf` of IDs.\n *\n * @example\n * { oneOf: [{ type: 'string' }, { $ref: '#/$defs/posts' }] }\n * → { type: 'string', description: 'The ID of the related \"posts\" document.' }\n */\nconst relationshipsToIds = (schema: JsonSchemaType): JsonSchemaType => {\n if (!schema || typeof schema !== 'object') {\n return schema\n }\n\n const processed = { ...schema }\n\n if (Array.isArray(processed.oneOf)) {\n const isRelatedDocRef = (option: unknown): option is { $ref: string } =>\n !!option && typeof option === 'object' && '$ref' in option\n\n if (processed.oneOf.some(isRelatedDocRef)) {\n // A relationship value is \"an ID, or the populated related document\". Keep the ID option(s) and\n // drop the `$ref`s to the related collections, since a client only ever sends the ID.\n const idOptions = processed.oneOf\n .filter((option) => !isRelatedDocRef(option))\n .map((option) => (typeof option === 'object' ? relationshipsToIds(option) : option))\n const targetCollections = processed.oneOf\n .filter(isRelatedDocRef)\n .map((option) => option.$ref.replace('#/$defs/', ''))\n\n if (idOptions.length === 1) {\n delete processed.oneOf\n Object.assign(processed, idOptions[0])\n if (targetCollections.length > 0 && !processed.description) {\n processed.description = `The ID of the related \"${targetCollections.join('\" or \"')}\" document.`\n }\n } else if (idOptions.length > 1) {\n delete processed.oneOf\n processed.anyOf = idOptions\n }\n } else {\n processed.oneOf = processed.oneOf.map((option) =>\n typeof option === 'object' ? relationshipsToIds(option) : option,\n )\n }\n }\n\n if (processed.properties && typeof processed.properties === 'object') {\n processed.properties = Object.fromEntries(\n Object.entries(processed.properties).map(([key, value]) => [\n key,\n typeof value === 'object' ? relationshipsToIds(value) : value,\n ]),\n )\n }\n\n if (processed.items && typeof processed.items === 'object' && !Array.isArray(processed.items)) {\n processed.items = relationshipsToIds(processed.items)\n }\n\n // Lexical node unions and blocks live under `$defs` and have their own relationship fields, so walk\n // those too — otherwise their `$ref`s would dangle once we don't bundle the related collections.\n if (processed.$defs && typeof processed.$defs === 'object') {\n processed.$defs = Object.fromEntries(\n Object.entries(processed.$defs).map(([key, value]) => [\n key,\n typeof value === 'object' ? relationshipsToIds(value) : value,\n ]),\n )\n }\n\n return processed\n}\n\n/**\n * **Size.** Strips type-generation leftovers that bloat the schema without helping the model: the `tsType`\n * hint (a `json-schema-to-typescript` extension; JSON Schema validators just ignore it, they don't reject it)\n * and the block-interface-collision note Payload adds to some block descriptions (the\n * `block-interface-name-collisions` docs link set in `registerBlockInterface`, see configToJSONSchema.ts).\n * Both are inert here - removing them only shrinks the schema (and spares the model irrelevant noise).\n *\n * @example\n * { type: 'object', tsType: 'SerializedBlockNode', description: 'see …#block-interface-name-collisions' }\n * → { type: 'object' }\n */\nconst removeTypeGenArtifacts = (schema: JsonSchemaType): JsonSchemaType =>\n mapNodes(schema, (node) => {\n delete (node as { tsType?: unknown }).tsType\n const { description } = node as { description?: string }\n if (\n typeof description === 'string' &&\n description.includes('block-interface-name-collisions')\n ) {\n delete (node as { description?: unknown }).description\n }\n return node\n }) as JsonSchemaType\n\n/**\n * **Size.** Removes `type` whenever a `const` sits next to it — the constant already fixes the value.\n *\n * @example\n * { type: 'string', const: 'paragraph' } → { const: 'paragraph' }\n */\nconst dropRedundantConstType = (schema: JsonSchemaType): JsonSchemaType =>\n mapNodes(schema, (node) => {\n if ('const' in node && 'type' in node) {\n delete (node as { type?: unknown }).type\n }\n return node\n }) as JsonSchemaType\n\n/**\n * **Size.** Merges the members of a `oneOf`/`anyOf` that are identical except for one `const`-valued property\n * into a single member with that property as an `enum`. Since the members differ only by that one\n * constant, the `enum` form accepts exactly the same values - it's just smaller. This folds the\n * per-collection relationship and upload variants, which differ only in their `relationTo` constant.\n *\n * @example\n * { oneOf: [\n * { properties: { relationTo: { const: 'posts' }, value: { type: 'string' } } },\n * { properties: { relationTo: { const: 'pages' }, value: { type: 'string' } } },\n * ] }\n * → { properties: { relationTo: { enum: ['posts', 'pages'] }, value: { type: 'string' } } }\n */\nconst mergeConstDiscriminatedUnions = (schema: JsonSchemaType): JsonSchemaType =>\n mapNodes(schema, (node) => {\n for (const keyword of ['oneOf', 'anyOf'] as const) {\n const members = node[keyword]\n if (Array.isArray(members) && members.length > 1) {\n const merged = mergeMembersByConst(members)\n if (merged) {\n delete node[keyword]\n Object.assign(node, merged)\n }\n }\n }\n return node\n }) as JsonSchemaType\n\n/** Returns the merged member for {@link mergeConstDiscriminatedUnions}, or `null` if they can't merge. */\nconst mergeMembersByConst = (members: Array<boolean | JsonSchemaType>): JsonSchemaType | null => {\n const objects = members.filter(\n (member): member is JsonSchemaType =>\n typeof member === 'object' && member !== null && typeof member.properties === 'object',\n )\n if (objects.length < 2 || objects.length !== members.length) {\n return null\n }\n\n for (const discriminator of Object.keys(objects[0]!.properties!)) {\n // Each member must pin this property to a `const`...\n const constValues: unknown[] = []\n const everyMemberPinsConst = objects.every((member) => {\n const prop = member.properties![discriminator]\n if (prop && typeof prop === 'object' && 'const' in prop) {\n constValues.push(prop.const)\n return true\n }\n return false\n })\n if (!everyMemberPinsConst) {\n continue\n }\n\n // ...and be otherwise identical (compare each member with the discriminator removed).\n const fingerprintWithoutDiscriminator = (member: JsonSchemaType): string => {\n const { [discriminator]: _discriminator, ...otherProperties } = member.properties!\n return JSON.stringify({ ...member, properties: otherProperties })\n }\n if (new Set(objects.map(fingerprintWithoutDiscriminator)).size !== 1) {\n continue\n }\n\n const uniqueConstValues = [...new Set(constValues)]\n if (uniqueConstValues.length < 2) {\n continue\n }\n\n // Replace the per-member `const` with a single `enum` of every value.\n const merged = structuredClone(objects[0]!)\n const discriminatorProp = merged.properties![discriminator]\n if (discriminatorProp && typeof discriminatorProp === 'object') {\n delete discriminatorProp.const\n discriminatorProp.enum = uniqueConstValues as NonNullable<typeof discriminatorProp.enum>\n }\n return merged\n }\n return null\n}\n\n// A `$ref` costs ~30 characters once names are shortened, so sharing a subschema only pays off when\n// it's larger than that and appears more than once.\nconst MIN_SHARED_SIZE = 64\n\n/** A subschema worth sharing: a standalone object/union/described schema, not a `$ref` or a primitive. */\nconst isShareable = (node: unknown): node is Record<string, unknown> => {\n if (!node || typeof node !== 'object' || Array.isArray(node) || '$ref' in node) {\n return false\n }\n const schema = node as JsonSchemaType\n return (\n Array.isArray(schema.oneOf) ||\n Array.isArray(schema.anyOf) ||\n Boolean(schema.properties) ||\n Boolean(schema.items) ||\n typeof schema.description === 'string'\n )\n}\n\n/**\n * **Size.** Replaces any subschema that appears more than once with a single shared `$defs` entry referenced by\n * `$ref`. Lossless — only the serialized size shrinks. A collection with several rich-text fields, for\n * example, inlines the same large lexical node schema once per field; this collapses them into one.\n *\n * @example\n * { properties: { billing: address, shipping: address } }\n * → { properties: { billing: { $ref: '#/$defs/shared_0' }, shipping: { $ref: '#/$defs/shared_0' } }, $defs: { shared_0: address } }\n */\nconst deduplicateIntoDefinitions = (schema: JsonSchemaType): JsonSchemaType => {\n // Count how often each shareable subschema appears, keyed by its serialized form.\n const counts = new Map<string, number>()\n const count = (node: unknown): void => {\n if (isShareable(node)) {\n const key = JSON.stringify(node)\n if (key.length >= MIN_SHARED_SIZE) {\n counts.set(key, (counts.get(key) ?? 0) + 1)\n }\n }\n if (Array.isArray(node)) {\n node.forEach(count)\n } else if (node && typeof node === 'object') {\n Object.values(node).forEach(count)\n }\n }\n count(schema)\n\n if (![...counts.values()].some((n) => n >= 2)) {\n return schema\n }\n\n // Replace each subschema seen 2+ times with a `$ref`. The first time we meet one it becomes a shared\n // entry; we never descend into a stored entry, so shared entries never reference one another.\n const sharedEntries: Record<string, JsonSchemaType> = {}\n const nameByKey = new Map<string, string>()\n const share = (node: unknown): unknown => {\n if (isShareable(node)) {\n const key = JSON.stringify(node)\n if ((counts.get(key) ?? 0) >= 2) {\n let name = nameByKey.get(key)\n if (!name) {\n name = `shared_${nameByKey.size}`\n nameByKey.set(key, name)\n sharedEntries[name] = node as JsonSchemaType\n }\n return { $ref: `#/$defs/${name}` }\n }\n }\n if (Array.isArray(node)) {\n return node.map(share)\n }\n if (node && typeof node === 'object') {\n return Object.fromEntries(\n Object.entries(node).map(([childKey, value]) => [childKey, share(value)]),\n )\n }\n return node\n }\n\n const result = share(schema) as JsonSchemaType\n result.$defs = { ...result.$defs, ...sharedEntries }\n return result\n}\n\n/**\n * **LLM ergonomics.** Renames `$defs` entries to short, readable names so the `$ref`s stay legible to the model: a block's\n * `blockType` (`Code`), a node's `type` (`paragraph`), `node` for a rich-text node union, otherwise the\n * generated name with its disambiguating hash dropped. A numeric suffix keeps collisions unique.\n *\n * @example\n * { properties: { body: { $ref: '#/$defs/LexicalNodes_9FBEC708' } }, $defs: { LexicalNodes_9FBEC708: {} } }\n * → { properties: { body: { $ref: '#/$defs/node' } }, $defs: { node: {} } }\n */\nconst shortenDefinitionNames = (schema: JsonSchemaType): JsonSchemaType => {\n const definitions = schema.$defs\n if (!definitions || Object.keys(definitions).length === 0) {\n return schema\n }\n\n const shortNameFor = (name: string, definition: boolean | JsonSchemaType): string => {\n const properties = (typeof definition === 'object' && definition.properties) || {}\n const constString = (key: string): string | undefined => {\n const prop = properties[key]\n return prop && typeof prop === 'object' && typeof prop.const === 'string'\n ? prop.const\n : undefined\n }\n const members =\n typeof definition === 'object' ? (definition.anyOf ?? definition.oneOf) : undefined\n const isNodeUnion =\n Array.isArray(members) &&\n members.some((m) => typeof m === 'object' && Boolean(m.$ref || m.properties?.type))\n return (\n constString('blockType') ??\n constString('type') ??\n (isNodeUnion ? 'node' : undefined) ??\n name.replace(/_[0-9A-F]{6,}$/i, '')\n )\n }\n\n const prefix = '#/$defs/'\n const usedNames = new Map<string, number>()\n const rename = new Map<string, string>()\n for (const [name, definition] of Object.entries(definitions)) {\n const shortName = shortNameFor(name, definition)\n const used = usedNames.get(shortName) ?? 0\n usedNames.set(shortName, used + 1)\n rename.set(name, used === 0 ? shortName : `${shortName}${used + 1}`)\n }\n\n const result = mapNodes(schema, (node) => {\n if (typeof node.$ref === 'string' && node.$ref.startsWith(prefix)) {\n const name = node.$ref.slice(prefix.length)\n node.$ref = `${prefix}${rename.get(name) ?? name}`\n }\n return node\n }) as JsonSchemaType\n result.$defs = Object.fromEntries(\n Object.entries(result.$defs!).map(([name, body]) => [rename.get(name) ?? name, body]),\n )\n return result\n}\n"],"names":["sanitizeEntitySchema","schema","result","structuredClone","removeManagedFields","pointFieldsToObjects","relationshipsToIds","removeTypeGenArtifacts","dropRedundantConstType","mergeConstDiscriminatedUnions","deduplicateIntoDefinitions","shortenDefinitionNames","mapNodes","node","visit","Array","isArray","map","child","out","key","value","Object","entries","PAYLOAD_MANAGED_FIELDS","Set","properties","field","keys","prop","isRequired","required","includes","collapseNullableType","items","filter","name","has","length","type","nonNullTypes","t","transformed","fromEntries","isArrayType","isPointField","every","item","isNullable","description","latitude","longitude","processed","oneOf","isRelatedDocRef","option","some","idOptions","targetCollections","$ref","replace","assign","join","anyOf","$defs","tsType","keyword","members","merged","mergeMembersByConst","objects","member","discriminator","constValues","everyMemberPinsConst","push","const","fingerprintWithoutDiscriminator","_discriminator","otherProperties","JSON","stringify","size","uniqueConstValues","discriminatorProp","enum","MIN_SHARED_SIZE","isShareable","Boolean","counts","Map","count","set","get","forEach","values","n","sharedEntries","nameByKey","share","childKey","definitions","shortNameFor","definition","constString","undefined","isNodeUnion","m","prefix","usedNames","rename","shortName","used","startsWith","slice","body"],"mappings":"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"}