directus 9.24.0 → 9.25.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 (861) hide show
  1. package/cli.js +1 -1
  2. package/package.json +5 -170
  3. package/LICENSE +0 -674
  4. package/dist/app.d.ts +0 -2
  5. package/dist/app.js +0 -250
  6. package/dist/app.test.d.ts +0 -1
  7. package/dist/auth/auth.d.ts +0 -46
  8. package/dist/auth/auth.js +0 -40
  9. package/dist/auth/drivers/index.d.ts +0 -5
  10. package/dist/auth/drivers/index.js +0 -21
  11. package/dist/auth/drivers/ldap.d.ts +0 -20
  12. package/dist/auth/drivers/ldap.js +0 -349
  13. package/dist/auth/drivers/local.d.ts +0 -9
  14. package/dist/auth/drivers/local.js +0 -91
  15. package/dist/auth/drivers/oauth2.d.ts +0 -19
  16. package/dist/auth/drivers/oauth2.js +0 -310
  17. package/dist/auth/drivers/openid.d.ts +0 -19
  18. package/dist/auth/drivers/openid.js +0 -332
  19. package/dist/auth/drivers/saml.d.ts +0 -14
  20. package/dist/auth/drivers/saml.js +0 -169
  21. package/dist/auth.d.ts +0 -3
  22. package/dist/auth.js +0 -70
  23. package/dist/cache.d.ts +0 -20
  24. package/dist/cache.js +0 -151
  25. package/dist/cli/commands/bootstrap/index.d.ts +0 -3
  26. package/dist/cli/commands/bootstrap/index.js +0 -98
  27. package/dist/cli/commands/count/index.d.ts +0 -1
  28. package/dist/cli/commands/count/index.js +0 -27
  29. package/dist/cli/commands/database/install.d.ts +0 -1
  30. package/dist/cli/commands/database/install.js +0 -22
  31. package/dist/cli/commands/database/migrate.d.ts +0 -1
  32. package/dist/cli/commands/database/migrate.js +0 -29
  33. package/dist/cli/commands/init/index.d.ts +0 -1
  34. package/dist/cli/commands/init/index.js +0 -108
  35. package/dist/cli/commands/init/questions.d.ts +0 -20
  36. package/dist/cli/commands/init/questions.js +0 -71
  37. package/dist/cli/commands/roles/create.d.ts +0 -4
  38. package/dist/cli/commands/roles/create.js +0 -29
  39. package/dist/cli/commands/schema/apply.d.ts +0 -4
  40. package/dist/cli/commands/schema/apply.js +0 -183
  41. package/dist/cli/commands/schema/snapshot.d.ts +0 -4
  42. package/dist/cli/commands/schema/snapshot.js +0 -63
  43. package/dist/cli/commands/security/key.d.ts +0 -1
  44. package/dist/cli/commands/security/key.js +0 -8
  45. package/dist/cli/commands/security/secret.d.ts +0 -1
  46. package/dist/cli/commands/security/secret.js +0 -8
  47. package/dist/cli/commands/users/create.d.ts +0 -5
  48. package/dist/cli/commands/users/create.js +0 -29
  49. package/dist/cli/commands/users/passwd.d.ts +0 -4
  50. package/dist/cli/commands/users/passwd.js +0 -41
  51. package/dist/cli/index.d.ts +0 -2
  52. package/dist/cli/index.js +0 -96
  53. package/dist/cli/index.test.d.ts +0 -1
  54. package/dist/cli/run.d.ts +0 -1
  55. package/dist/cli/run.js +0 -10
  56. package/dist/cli/utils/create-db-connection.d.ts +0 -13
  57. package/dist/cli/utils/create-db-connection.js +0 -61
  58. package/dist/cli/utils/create-env/env-stub.liquid +0 -325
  59. package/dist/cli/utils/create-env/index.d.ts +0 -3
  60. package/dist/cli/utils/create-env/index.js +0 -44
  61. package/dist/cli/utils/defaults.d.ts +0 -11
  62. package/dist/cli/utils/defaults.js +0 -14
  63. package/dist/cli/utils/drivers.d.ts +0 -3
  64. package/dist/cli/utils/drivers.js +0 -19
  65. package/dist/constants.d.ts +0 -13
  66. package/dist/constants.js +0 -59
  67. package/dist/controllers/activity.d.ts +0 -2
  68. package/dist/controllers/activity.js +0 -135
  69. package/dist/controllers/assets.d.ts +0 -2
  70. package/dist/controllers/assets.js +0 -186
  71. package/dist/controllers/auth.d.ts +0 -2
  72. package/dist/controllers/auth.js +0 -167
  73. package/dist/controllers/collections.d.ts +0 -2
  74. package/dist/controllers/collections.js +0 -105
  75. package/dist/controllers/dashboards.d.ts +0 -2
  76. package/dist/controllers/dashboards.js +0 -144
  77. package/dist/controllers/extensions.d.ts +0 -2
  78. package/dist/controllers/extensions.js +0 -40
  79. package/dist/controllers/fields.d.ts +0 -2
  80. package/dist/controllers/fields.js +0 -160
  81. package/dist/controllers/files.d.ts +0 -4
  82. package/dist/controllers/files.js +0 -274
  83. package/dist/controllers/files.test.d.ts +0 -1
  84. package/dist/controllers/flows.d.ts +0 -2
  85. package/dist/controllers/flows.js +0 -163
  86. package/dist/controllers/folders.d.ts +0 -2
  87. package/dist/controllers/folders.js +0 -153
  88. package/dist/controllers/graphql.d.ts +0 -2
  89. package/dist/controllers/graphql.js +0 -36
  90. package/dist/controllers/items.d.ts +0 -2
  91. package/dist/controllers/items.js +0 -183
  92. package/dist/controllers/not-found.d.ts +0 -14
  93. package/dist/controllers/not-found.js +0 -36
  94. package/dist/controllers/notifications.d.ts +0 -2
  95. package/dist/controllers/notifications.js +0 -153
  96. package/dist/controllers/operations.d.ts +0 -2
  97. package/dist/controllers/operations.js +0 -144
  98. package/dist/controllers/panels.d.ts +0 -2
  99. package/dist/controllers/panels.js +0 -144
  100. package/dist/controllers/permissions.d.ts +0 -2
  101. package/dist/controllers/permissions.js +0 -155
  102. package/dist/controllers/presets.d.ts +0 -2
  103. package/dist/controllers/presets.js +0 -153
  104. package/dist/controllers/relations.d.ts +0 -2
  105. package/dist/controllers/relations.js +0 -117
  106. package/dist/controllers/revisions.d.ts +0 -2
  107. package/dist/controllers/revisions.js +0 -39
  108. package/dist/controllers/roles.d.ts +0 -2
  109. package/dist/controllers/roles.js +0 -144
  110. package/dist/controllers/schema.d.ts +0 -2
  111. package/dist/controllers/schema.js +0 -98
  112. package/dist/controllers/server.d.ts +0 -2
  113. package/dist/controllers/server.js +0 -61
  114. package/dist/controllers/settings.d.ts +0 -2
  115. package/dist/controllers/settings.js +0 -41
  116. package/dist/controllers/shares.d.ts +0 -2
  117. package/dist/controllers/shares.js +0 -218
  118. package/dist/controllers/users.d.ts +0 -2
  119. package/dist/controllers/users.js +0 -358
  120. package/dist/controllers/utils.d.ts +0 -2
  121. package/dist/controllers/utils.js +0 -121
  122. package/dist/controllers/webhooks.d.ts +0 -2
  123. package/dist/controllers/webhooks.js +0 -141
  124. package/dist/database/helpers/date/dialects/default.d.ts +0 -3
  125. package/dist/database/helpers/date/dialects/default.js +0 -7
  126. package/dist/database/helpers/date/dialects/mssql.d.ts +0 -4
  127. package/dist/database/helpers/date/dialects/mssql.js +0 -12
  128. package/dist/database/helpers/date/dialects/mysql.d.ts +0 -5
  129. package/dist/database/helpers/date/dialects/mysql.js +0 -16
  130. package/dist/database/helpers/date/dialects/oracle.d.ts +0 -4
  131. package/dist/database/helpers/date/dialects/oracle.js +0 -15
  132. package/dist/database/helpers/date/dialects/sqlite.d.ts +0 -5
  133. package/dist/database/helpers/date/dialects/sqlite.js +0 -30
  134. package/dist/database/helpers/date/index.d.ts +0 -7
  135. package/dist/database/helpers/date/index.js +0 -17
  136. package/dist/database/helpers/date/types.d.ts +0 -7
  137. package/dist/database/helpers/date/types.js +0 -24
  138. package/dist/database/helpers/fn/dialects/mssql.d.ts +0 -13
  139. package/dist/database/helpers/fn/dialects/mssql.js +0 -48
  140. package/dist/database/helpers/fn/dialects/mysql.d.ts +0 -13
  141. package/dist/database/helpers/fn/dialects/mysql.js +0 -42
  142. package/dist/database/helpers/fn/dialects/oracle.d.ts +0 -13
  143. package/dist/database/helpers/fn/dialects/oracle.js +0 -48
  144. package/dist/database/helpers/fn/dialects/postgres.d.ts +0 -13
  145. package/dist/database/helpers/fn/dialects/postgres.js +0 -52
  146. package/dist/database/helpers/fn/dialects/sqlite.d.ts +0 -13
  147. package/dist/database/helpers/fn/dialects/sqlite.js +0 -72
  148. package/dist/database/helpers/fn/index.d.ts +0 -7
  149. package/dist/database/helpers/fn/index.js +0 -17
  150. package/dist/database/helpers/fn/types.d.ts +0 -22
  151. package/dist/database/helpers/fn/types.js +0 -30
  152. package/dist/database/helpers/geometry/dialects/mssql.d.ts +0 -14
  153. package/dist/database/helpers/geometry/dialects/mssql.js +0 -36
  154. package/dist/database/helpers/geometry/dialects/mysql.d.ts +0 -7
  155. package/dist/database/helpers/geometry/dialects/mysql.js +0 -16
  156. package/dist/database/helpers/geometry/dialects/oracle.d.ts +0 -15
  157. package/dist/database/helpers/geometry/dialects/oracle.js +0 -39
  158. package/dist/database/helpers/geometry/dialects/postgres.d.ts +0 -10
  159. package/dist/database/helpers/geometry/dialects/postgres.js +0 -22
  160. package/dist/database/helpers/geometry/dialects/redshift.d.ts +0 -7
  161. package/dist/database/helpers/geometry/dialects/redshift.js +0 -16
  162. package/dist/database/helpers/geometry/dialects/sqlite.d.ts +0 -6
  163. package/dist/database/helpers/geometry/dialects/sqlite.js +0 -14
  164. package/dist/database/helpers/geometry/index.d.ts +0 -7
  165. package/dist/database/helpers/geometry/index.js +0 -17
  166. package/dist/database/helpers/geometry/types.d.ts +0 -20
  167. package/dist/database/helpers/geometry/types.js +0 -53
  168. package/dist/database/helpers/index.d.ts +0 -13
  169. package/dist/database/helpers/index.js +0 -45
  170. package/dist/database/helpers/schema/dialects/cockroachdb.d.ts +0 -6
  171. package/dist/database/helpers/schema/dialects/cockroachdb.js +0 -21
  172. package/dist/database/helpers/schema/dialects/default.d.ts +0 -3
  173. package/dist/database/helpers/schema/dialects/default.js +0 -7
  174. package/dist/database/helpers/schema/dialects/mssql.d.ts +0 -7
  175. package/dist/database/helpers/schema/dialects/mssql.js +0 -24
  176. package/dist/database/helpers/schema/dialects/mysql.d.ts +0 -5
  177. package/dist/database/helpers/schema/dialects/mysql.js +0 -18
  178. package/dist/database/helpers/schema/dialects/oracle.d.ts +0 -9
  179. package/dist/database/helpers/schema/dialects/oracle.js +0 -36
  180. package/dist/database/helpers/schema/dialects/sqlite.d.ts +0 -5
  181. package/dist/database/helpers/schema/dialects/sqlite.js +0 -17
  182. package/dist/database/helpers/schema/index.d.ts +0 -7
  183. package/dist/database/helpers/schema/index.js +0 -17
  184. package/dist/database/helpers/schema/types.d.ts +0 -26
  185. package/dist/database/helpers/schema/types.js +0 -95
  186. package/dist/database/helpers/types.d.ts +0 -5
  187. package/dist/database/helpers/types.js +0 -10
  188. package/dist/database/index.d.ts +0 -20
  189. package/dist/database/index.js +0 -279
  190. package/dist/database/migrations/20201028A-remove-collection-foreign-keys.d.ts +0 -3
  191. package/dist/database/migrations/20201028A-remove-collection-foreign-keys.js +0 -47
  192. package/dist/database/migrations/20201029A-remove-system-relations.d.ts +0 -3
  193. package/dist/database/migrations/20201029A-remove-system-relations.js +0 -127
  194. package/dist/database/migrations/20201029B-remove-system-collections.d.ts +0 -3
  195. package/dist/database/migrations/20201029B-remove-system-collections.js +0 -98
  196. package/dist/database/migrations/20201029C-remove-system-fields.d.ts +0 -3
  197. package/dist/database/migrations/20201029C-remove-system-fields.js +0 -1648
  198. package/dist/database/migrations/20201105A-add-cascade-system-relations.d.ts +0 -8
  199. package/dist/database/migrations/20201105A-add-cascade-system-relations.js +0 -136
  200. package/dist/database/migrations/20201105B-change-webhook-url-type.d.ts +0 -3
  201. package/dist/database/migrations/20201105B-change-webhook-url-type.js +0 -17
  202. package/dist/database/migrations/20210225A-add-relations-sort-field.d.ts +0 -3
  203. package/dist/database/migrations/20210225A-add-relations-sort-field.js +0 -33
  204. package/dist/database/migrations/20210304A-remove-locked-fields.d.ts +0 -3
  205. package/dist/database/migrations/20210304A-remove-locked-fields.js +0 -15
  206. package/dist/database/migrations/20210312A-webhooks-collections-text.d.ts +0 -3
  207. package/dist/database/migrations/20210312A-webhooks-collections-text.js +0 -17
  208. package/dist/database/migrations/20210331A-add-refresh-interval.d.ts +0 -3
  209. package/dist/database/migrations/20210331A-add-refresh-interval.js +0 -15
  210. package/dist/database/migrations/20210415A-make-filesize-nullable.d.ts +0 -3
  211. package/dist/database/migrations/20210415A-make-filesize-nullable.js +0 -20
  212. package/dist/database/migrations/20210416A-add-collections-accountability.d.ts +0 -3
  213. package/dist/database/migrations/20210416A-add-collections-accountability.js +0 -16
  214. package/dist/database/migrations/20210422A-remove-files-interface.d.ts +0 -3
  215. package/dist/database/migrations/20210422A-remove-files-interface.js +0 -11
  216. package/dist/database/migrations/20210506A-rename-interfaces.d.ts +0 -3
  217. package/dist/database/migrations/20210506A-rename-interfaces.js +0 -79
  218. package/dist/database/migrations/20210510A-restructure-relations.d.ts +0 -3
  219. package/dist/database/migrations/20210510A-restructure-relations.js +0 -32
  220. package/dist/database/migrations/20210518A-add-foreign-key-constraints.d.ts +0 -3
  221. package/dist/database/migrations/20210518A-add-foreign-key-constraints.js +0 -114
  222. package/dist/database/migrations/20210519A-add-system-fk-triggers.d.ts +0 -3
  223. package/dist/database/migrations/20210519A-add-system-fk-triggers.js +0 -172
  224. package/dist/database/migrations/20210521A-add-collections-icon-color.d.ts +0 -3
  225. package/dist/database/migrations/20210521A-add-collections-icon-color.js +0 -15
  226. package/dist/database/migrations/20210525A-add-insights.d.ts +0 -3
  227. package/dist/database/migrations/20210525A-add-insights.js +0 -36
  228. package/dist/database/migrations/20210608A-add-deep-clone-config.d.ts +0 -3
  229. package/dist/database/migrations/20210608A-add-deep-clone-config.js +0 -15
  230. package/dist/database/migrations/20210626A-change-filesize-bigint.d.ts +0 -3
  231. package/dist/database/migrations/20210626A-change-filesize-bigint.js +0 -24
  232. package/dist/database/migrations/20210716A-add-conditions-to-fields.d.ts +0 -3
  233. package/dist/database/migrations/20210716A-add-conditions-to-fields.js +0 -15
  234. package/dist/database/migrations/20210721A-add-default-folder.d.ts +0 -3
  235. package/dist/database/migrations/20210721A-add-default-folder.js +0 -23
  236. package/dist/database/migrations/20210802A-replace-groups.d.ts +0 -3
  237. package/dist/database/migrations/20210802A-replace-groups.js +0 -53
  238. package/dist/database/migrations/20210803A-add-required-to-fields.d.ts +0 -3
  239. package/dist/database/migrations/20210803A-add-required-to-fields.js +0 -15
  240. package/dist/database/migrations/20210805A-update-groups.d.ts +0 -3
  241. package/dist/database/migrations/20210805A-update-groups.js +0 -34
  242. package/dist/database/migrations/20210805B-change-image-metadata-structure.d.ts +0 -3
  243. package/dist/database/migrations/20210805B-change-image-metadata-structure.js +0 -89
  244. package/dist/database/migrations/20210811A-add-geometry-config.d.ts +0 -3
  245. package/dist/database/migrations/20210811A-add-geometry-config.js +0 -17
  246. package/dist/database/migrations/20210831A-remove-limit-column.d.ts +0 -3
  247. package/dist/database/migrations/20210831A-remove-limit-column.js +0 -15
  248. package/dist/database/migrations/20210903A-add-auth-provider.d.ts +0 -3
  249. package/dist/database/migrations/20210903A-add-auth-provider.js +0 -40
  250. package/dist/database/migrations/20210907A-webhooks-collections-not-null.d.ts +0 -3
  251. package/dist/database/migrations/20210907A-webhooks-collections-not-null.js +0 -18
  252. package/dist/database/migrations/20210910A-move-module-setup.d.ts +0 -3
  253. package/dist/database/migrations/20210910A-move-module-setup.js +0 -21
  254. package/dist/database/migrations/20210920A-webhooks-url-not-null.d.ts +0 -3
  255. package/dist/database/migrations/20210920A-webhooks-url-not-null.js +0 -26
  256. package/dist/database/migrations/20210924A-add-collection-organization.d.ts +0 -3
  257. package/dist/database/migrations/20210924A-add-collection-organization.js +0 -19
  258. package/dist/database/migrations/20210927A-replace-fields-group.d.ts +0 -3
  259. package/dist/database/migrations/20210927A-replace-fields-group.js +0 -53
  260. package/dist/database/migrations/20210927B-replace-m2m-interface.d.ts +0 -3
  261. package/dist/database/migrations/20210927B-replace-m2m-interface.js +0 -21
  262. package/dist/database/migrations/20210929A-rename-login-action.d.ts +0 -3
  263. package/dist/database/migrations/20210929A-rename-login-action.js +0 -19
  264. package/dist/database/migrations/20211007A-update-presets.d.ts +0 -3
  265. package/dist/database/migrations/20211007A-update-presets.js +0 -103
  266. package/dist/database/migrations/20211009A-add-auth-data.d.ts +0 -3
  267. package/dist/database/migrations/20211009A-add-auth-data.js +0 -15
  268. package/dist/database/migrations/20211016A-add-webhook-headers.d.ts +0 -3
  269. package/dist/database/migrations/20211016A-add-webhook-headers.js +0 -15
  270. package/dist/database/migrations/20211103A-set-unique-to-user-token.d.ts +0 -3
  271. package/dist/database/migrations/20211103A-set-unique-to-user-token.js +0 -15
  272. package/dist/database/migrations/20211103B-update-special-geometry.d.ts +0 -3
  273. package/dist/database/migrations/20211103B-update-special-geometry.js +0 -25
  274. package/dist/database/migrations/20211104A-remove-collections-listing.d.ts +0 -3
  275. package/dist/database/migrations/20211104A-remove-collections-listing.js +0 -15
  276. package/dist/database/migrations/20211118A-add-notifications.d.ts +0 -3
  277. package/dist/database/migrations/20211118A-add-notifications.js +0 -28
  278. package/dist/database/migrations/20211211A-add-shares.d.ts +0 -3
  279. package/dist/database/migrations/20211211A-add-shares.js +0 -38
  280. package/dist/database/migrations/20211230A-add-project-descriptor.d.ts +0 -3
  281. package/dist/database/migrations/20211230A-add-project-descriptor.js +0 -15
  282. package/dist/database/migrations/20220303A-remove-default-project-color.d.ts +0 -3
  283. package/dist/database/migrations/20220303A-remove-default-project-color.js +0 -22
  284. package/dist/database/migrations/20220308A-add-bookmark-icon-and-color.d.ts +0 -3
  285. package/dist/database/migrations/20220308A-add-bookmark-icon-and-color.js +0 -17
  286. package/dist/database/migrations/20220314A-add-translation-strings.d.ts +0 -3
  287. package/dist/database/migrations/20220314A-add-translation-strings.js +0 -15
  288. package/dist/database/migrations/20220322A-rename-field-typecast-flags.d.ts +0 -3
  289. package/dist/database/migrations/20220322A-rename-field-typecast-flags.js +0 -77
  290. package/dist/database/migrations/20220323A-add-field-validation.d.ts +0 -3
  291. package/dist/database/migrations/20220323A-add-field-validation.js +0 -17
  292. package/dist/database/migrations/20220325A-fix-typecast-flags.d.ts +0 -3
  293. package/dist/database/migrations/20220325A-fix-typecast-flags.js +0 -49
  294. package/dist/database/migrations/20220325B-add-default-language.d.ts +0 -3
  295. package/dist/database/migrations/20220325B-add-default-language.js +0 -28
  296. package/dist/database/migrations/20220402A-remove-default-value-panel-icon.d.ts +0 -3
  297. package/dist/database/migrations/20220402A-remove-default-value-panel-icon.js +0 -22
  298. package/dist/database/migrations/20220429A-add-flows.d.ts +0 -3
  299. package/dist/database/migrations/20220429A-add-flows.js +0 -82
  300. package/dist/database/migrations/20220429B-add-color-to-insights-icon.d.ts +0 -3
  301. package/dist/database/migrations/20220429B-add-color-to-insights-icon.js +0 -15
  302. package/dist/database/migrations/20220429C-drop-non-null-from-ip-of-activity.d.ts +0 -3
  303. package/dist/database/migrations/20220429C-drop-non-null-from-ip-of-activity.js +0 -15
  304. package/dist/database/migrations/20220429D-drop-non-null-from-sender-of-notifications.d.ts +0 -3
  305. package/dist/database/migrations/20220429D-drop-non-null-from-sender-of-notifications.js +0 -15
  306. package/dist/database/migrations/20220614A-rename-hook-trigger-to-event.d.ts +0 -3
  307. package/dist/database/migrations/20220614A-rename-hook-trigger-to-event.js +0 -11
  308. package/dist/database/migrations/20220801A-update-notifications-timestamp-column.d.ts +0 -3
  309. package/dist/database/migrations/20220801A-update-notifications-timestamp-column.js +0 -19
  310. package/dist/database/migrations/20220802A-add-custom-aspect-ratios.d.ts +0 -3
  311. package/dist/database/migrations/20220802A-add-custom-aspect-ratios.js +0 -15
  312. package/dist/database/migrations/20220826A-add-origin-to-accountability.d.ts +0 -3
  313. package/dist/database/migrations/20220826A-add-origin-to-accountability.js +0 -21
  314. package/dist/database/migrations/run.d.ts +0 -2
  315. package/dist/database/migrations/run.js +0 -96
  316. package/dist/database/migrations/run.test.d.ts +0 -1
  317. package/dist/database/run-ast.d.ts +0 -26
  318. package/dist/database/run-ast.js +0 -474
  319. package/dist/database/seeds/01-collections.yaml +0 -42
  320. package/dist/database/seeds/02-roles.yaml +0 -36
  321. package/dist/database/seeds/03-users.yaml +0 -63
  322. package/dist/database/seeds/04-fields.yaml +0 -58
  323. package/dist/database/seeds/05-activity.yaml +0 -35
  324. package/dist/database/seeds/06-folders.yaml +0 -16
  325. package/dist/database/seeds/07-files.yaml +0 -74
  326. package/dist/database/seeds/08-permissions.yaml +0 -32
  327. package/dist/database/seeds/09-presets.yaml +0 -37
  328. package/dist/database/seeds/10-relations.yaml +0 -40
  329. package/dist/database/seeds/11-revisions.yaml +0 -33
  330. package/dist/database/seeds/12-sessions.yaml +0 -23
  331. package/dist/database/seeds/13-settings.yaml +0 -49
  332. package/dist/database/seeds/14-webhooks.yaml +0 -35
  333. package/dist/database/seeds/15-migrations.yaml +0 -14
  334. package/dist/database/seeds/run.d.ts +0 -2
  335. package/dist/database/seeds/run.js +0 -76
  336. package/dist/database/system-data/app-access-permissions/app-access-permissions.yaml +0 -102
  337. package/dist/database/system-data/app-access-permissions/index.d.ts +0 -3
  338. package/dist/database/system-data/app-access-permissions/index.js +0 -17
  339. package/dist/database/system-data/app-access-permissions/schema-access-permissions.yaml +0 -17
  340. package/dist/database/system-data/collections/collections.yaml +0 -74
  341. package/dist/database/system-data/collections/index.d.ts +0 -2
  342. package/dist/database/system-data/collections/index.js +0 -9
  343. package/dist/database/system-data/fields/_defaults.yaml +0 -16
  344. package/dist/database/system-data/fields/activity.yaml +0 -83
  345. package/dist/database/system-data/fields/collections.yaml +0 -214
  346. package/dist/database/system-data/fields/dashboards.yaml +0 -20
  347. package/dist/database/system-data/fields/fields.yaml +0 -104
  348. package/dist/database/system-data/fields/files.yaml +0 -144
  349. package/dist/database/system-data/fields/flows.yaml +0 -26
  350. package/dist/database/system-data/fields/folders.yaml +0 -14
  351. package/dist/database/system-data/fields/index.d.ts +0 -2
  352. package/dist/database/system-data/fields/index.js +0 -37
  353. package/dist/database/system-data/fields/migrations.yaml +0 -10
  354. package/dist/database/system-data/fields/notifications.yaml +0 -15
  355. package/dist/database/system-data/fields/operations.yaml +0 -23
  356. package/dist/database/system-data/fields/panels.yaml +0 -29
  357. package/dist/database/system-data/fields/permissions.yaml +0 -37
  358. package/dist/database/system-data/fields/presets.yaml +0 -56
  359. package/dist/database/system-data/fields/relations.yaml +0 -34
  360. package/dist/database/system-data/fields/revisions.yaml +0 -27
  361. package/dist/database/system-data/fields/roles.yaml +0 -61
  362. package/dist/database/system-data/fields/sessions.yaml +0 -16
  363. package/dist/database/system-data/fields/settings.yaml +0 -413
  364. package/dist/database/system-data/fields/shares.yaml +0 -83
  365. package/dist/database/system-data/fields/users.yaml +0 -182
  366. package/dist/database/system-data/fields/webhooks.yaml +0 -141
  367. package/dist/database/system-data/relations/index.d.ts +0 -2
  368. package/dist/database/system-data/relations/index.js +0 -9
  369. package/dist/database/system-data/relations/relations.yaml +0 -125
  370. package/dist/emitter.d.ts +0 -19
  371. package/dist/emitter.js +0 -86
  372. package/dist/env.d.ts +0 -15
  373. package/dist/env.js +0 -466
  374. package/dist/env.test.d.ts +0 -1
  375. package/dist/exceptions/database/contains-null-values.d.ts +0 -9
  376. package/dist/exceptions/database/contains-null-values.js +0 -10
  377. package/dist/exceptions/database/dialects/mssql.d.ts +0 -2
  378. package/dist/exceptions/database/dialects/mssql.js +0 -159
  379. package/dist/exceptions/database/dialects/mysql.d.ts +0 -2
  380. package/dist/exceptions/database/dialects/mysql.js +0 -148
  381. package/dist/exceptions/database/dialects/oracle.d.ts +0 -2
  382. package/dist/exceptions/database/dialects/oracle.js +0 -27
  383. package/dist/exceptions/database/dialects/postgres.d.ts +0 -2
  384. package/dist/exceptions/database/dialects/postgres.js +0 -106
  385. package/dist/exceptions/database/dialects/sqlite.d.ts +0 -2
  386. package/dist/exceptions/database/dialects/sqlite.js +0 -55
  387. package/dist/exceptions/database/dialects/types.d.ts +0 -41
  388. package/dist/exceptions/database/dialects/types.js +0 -2
  389. package/dist/exceptions/database/invalid-foreign-key.d.ts +0 -10
  390. package/dist/exceptions/database/invalid-foreign-key.js +0 -15
  391. package/dist/exceptions/database/not-null-violation.d.ts +0 -9
  392. package/dist/exceptions/database/not-null-violation.js +0 -10
  393. package/dist/exceptions/database/record-not-unique.d.ts +0 -10
  394. package/dist/exceptions/database/record-not-unique.js +0 -15
  395. package/dist/exceptions/database/translate.d.ts +0 -11
  396. package/dist/exceptions/database/translate.js +0 -74
  397. package/dist/exceptions/database/value-out-of-range.d.ts +0 -10
  398. package/dist/exceptions/database/value-out-of-range.js +0 -15
  399. package/dist/exceptions/database/value-too-long.d.ts +0 -9
  400. package/dist/exceptions/database/value-too-long.js +0 -15
  401. package/dist/exceptions/forbidden.d.ts +0 -4
  402. package/dist/exceptions/forbidden.js +0 -16
  403. package/dist/exceptions/graphql-validation.d.ts +0 -4
  404. package/dist/exceptions/graphql-validation.js +0 -10
  405. package/dist/exceptions/hit-rate-limit.d.ts +0 -9
  406. package/dist/exceptions/hit-rate-limit.js +0 -10
  407. package/dist/exceptions/illegal-asset-transformation.d.ts +0 -4
  408. package/dist/exceptions/illegal-asset-transformation.js +0 -10
  409. package/dist/exceptions/index.d.ts +0 -21
  410. package/dist/exceptions/index.js +0 -37
  411. package/dist/exceptions/invalid-config.d.ts +0 -4
  412. package/dist/exceptions/invalid-config.js +0 -10
  413. package/dist/exceptions/invalid-credentials.d.ts +0 -4
  414. package/dist/exceptions/invalid-credentials.js +0 -10
  415. package/dist/exceptions/invalid-ip.d.ts +0 -4
  416. package/dist/exceptions/invalid-ip.js +0 -10
  417. package/dist/exceptions/invalid-otp.d.ts +0 -4
  418. package/dist/exceptions/invalid-otp.js +0 -10
  419. package/dist/exceptions/invalid-payload.d.ts +0 -4
  420. package/dist/exceptions/invalid-payload.js +0 -10
  421. package/dist/exceptions/invalid-provider.d.ts +0 -4
  422. package/dist/exceptions/invalid-provider.js +0 -10
  423. package/dist/exceptions/invalid-query.d.ts +0 -4
  424. package/dist/exceptions/invalid-query.js +0 -10
  425. package/dist/exceptions/invalid-token.d.ts +0 -4
  426. package/dist/exceptions/invalid-token.js +0 -10
  427. package/dist/exceptions/method-not-allowed.d.ts +0 -8
  428. package/dist/exceptions/method-not-allowed.js +0 -10
  429. package/dist/exceptions/range-not-satisfiable.d.ts +0 -5
  430. package/dist/exceptions/range-not-satisfiable.js +0 -13
  431. package/dist/exceptions/route-not-found.d.ts +0 -4
  432. package/dist/exceptions/route-not-found.js +0 -10
  433. package/dist/exceptions/service-unavailable.d.ts +0 -9
  434. package/dist/exceptions/service-unavailable.js +0 -10
  435. package/dist/exceptions/token-expired.d.ts +0 -4
  436. package/dist/exceptions/token-expired.js +0 -10
  437. package/dist/exceptions/unexpected-response.d.ts +0 -4
  438. package/dist/exceptions/unexpected-response.js +0 -10
  439. package/dist/exceptions/unprocessable-entity.d.ts +0 -4
  440. package/dist/exceptions/unprocessable-entity.js +0 -10
  441. package/dist/exceptions/unsupported-media-type.d.ts +0 -4
  442. package/dist/exceptions/unsupported-media-type.js +0 -10
  443. package/dist/exceptions/user-suspended.d.ts +0 -4
  444. package/dist/exceptions/user-suspended.js +0 -10
  445. package/dist/extensions.d.ts +0 -49
  446. package/dist/extensions.js +0 -501
  447. package/dist/flows.d.ts +0 -22
  448. package/dist/flows.js +0 -377
  449. package/dist/index.d.ts +0 -3
  450. package/dist/index.js +0 -24
  451. package/dist/logger.d.ts +0 -7
  452. package/dist/logger.js +0 -134
  453. package/dist/logger.test.d.ts +0 -1
  454. package/dist/mailer.d.ts +0 -2
  455. package/dist/mailer.js +0 -71
  456. package/dist/messenger.d.ts +0 -24
  457. package/dist/messenger.js +0 -66
  458. package/dist/middleware/authenticate.d.ts +0 -8
  459. package/dist/middleware/authenticate.js +0 -82
  460. package/dist/middleware/authenticate.test.d.ts +0 -1
  461. package/dist/middleware/cache.d.ts +0 -3
  462. package/dist/middleware/cache.js +0 -61
  463. package/dist/middleware/check-ip.d.ts +0 -2
  464. package/dist/middleware/check-ip.js +0 -24
  465. package/dist/middleware/collection-exists.d.ts +0 -6
  466. package/dist/middleware/collection-exists.js +0 -30
  467. package/dist/middleware/cors.d.ts +0 -3
  468. package/dist/middleware/cors.js +0 -19
  469. package/dist/middleware/error-handler.d.ts +0 -3
  470. package/dist/middleware/error-handler.js +0 -95
  471. package/dist/middleware/extract-token.d.ts +0 -11
  472. package/dist/middleware/extract-token.js +0 -32
  473. package/dist/middleware/extract-token.test.d.ts +0 -1
  474. package/dist/middleware/get-permissions.d.ts +0 -3
  475. package/dist/middleware/get-permissions.js +0 -15
  476. package/dist/middleware/graphql.d.ts +0 -2
  477. package/dist/middleware/graphql.js +0 -69
  478. package/dist/middleware/rate-limiter-global.d.ts +0 -5
  479. package/dist/middleware/rate-limiter-global.js +0 -48
  480. package/dist/middleware/rate-limiter-ip.d.ts +0 -5
  481. package/dist/middleware/rate-limiter-ip.js +0 -34
  482. package/dist/middleware/respond.d.ts +0 -2
  483. package/dist/middleware/respond.js +0 -88
  484. package/dist/middleware/sanitize-query.d.ts +0 -7
  485. package/dist/middleware/sanitize-query.js +0 -21
  486. package/dist/middleware/schema.d.ts +0 -3
  487. package/dist/middleware/schema.js +0 -12
  488. package/dist/middleware/use-collection.d.ts +0 -7
  489. package/dist/middleware/use-collection.js +0 -11
  490. package/dist/middleware/validate-batch.d.ts +0 -3
  491. package/dist/middleware/validate-batch.js +0 -49
  492. package/dist/middleware/validate-batch.test.d.ts +0 -1
  493. package/dist/operations/condition/index.d.ts +0 -6
  494. package/dist/operations/condition/index.js +0 -15
  495. package/dist/operations/condition/index.test.d.ts +0 -1
  496. package/dist/operations/exec/index.d.ts +0 -5
  497. package/dist/operations/exec/index.js +0 -40
  498. package/dist/operations/exec/index.test.d.ts +0 -1
  499. package/dist/operations/item-create/index.d.ts +0 -8
  500. package/dist/operations/item-create/index.js +0 -38
  501. package/dist/operations/item-create/index.test.d.ts +0 -1
  502. package/dist/operations/item-delete/index.d.ts +0 -10
  503. package/dist/operations/item-delete/index.js +0 -46
  504. package/dist/operations/item-delete/index.test.d.ts +0 -1
  505. package/dist/operations/item-read/index.d.ts +0 -10
  506. package/dist/operations/item-read/index.js +0 -46
  507. package/dist/operations/item-read/index.test.d.ts +0 -1
  508. package/dist/operations/item-update/index.d.ts +0 -11
  509. package/dist/operations/item-update/index.js +0 -50
  510. package/dist/operations/item-update/index.test.d.ts +0 -1
  511. package/dist/operations/log/index.d.ts +0 -5
  512. package/dist/operations/log/index.js +0 -13
  513. package/dist/operations/log/index.test.d.ts +0 -1
  514. package/dist/operations/mail/index.d.ts +0 -8
  515. package/dist/operations/mail/index.js +0 -19
  516. package/dist/operations/notification/index.d.ts +0 -8
  517. package/dist/operations/notification/index.js +0 -40
  518. package/dist/operations/notification/index.test.d.ts +0 -1
  519. package/dist/operations/request/index.d.ts +0 -11
  520. package/dist/operations/request/index.js +0 -38
  521. package/dist/operations/request/index.test.d.ts +0 -1
  522. package/dist/operations/sleep/index.d.ts +0 -5
  523. package/dist/operations/sleep/index.js +0 -9
  524. package/dist/operations/sleep/index.test.d.ts +0 -1
  525. package/dist/operations/transform/index.d.ts +0 -5
  526. package/dist/operations/transform/index.js +0 -9
  527. package/dist/operations/transform/index.test.d.ts +0 -1
  528. package/dist/operations/trigger/index.d.ts +0 -8
  529. package/dist/operations/trigger/index.js +0 -39
  530. package/dist/operations/trigger/index.test.d.ts +0 -1
  531. package/dist/rate-limiter.d.ts +0 -4
  532. package/dist/rate-limiter.js +0 -38
  533. package/dist/request/index.d.ts +0 -5
  534. package/dist/request/index.js +0 -18
  535. package/dist/request/index.test.d.ts +0 -1
  536. package/dist/request/request-interceptor.d.ts +0 -2
  537. package/dist/request/request-interceptor.js +0 -33
  538. package/dist/request/request-interceptor.test.d.ts +0 -1
  539. package/dist/request/response-interceptor.d.ts +0 -2
  540. package/dist/request/response-interceptor.js +0 -9
  541. package/dist/request/response-interceptor.test.d.ts +0 -1
  542. package/dist/request/validate-ip.d.ts +0 -1
  543. package/dist/request/validate-ip.js +0 -27
  544. package/dist/request/validate-ip.test.d.ts +0 -1
  545. package/dist/server.d.ts +0 -4
  546. package/dist/server.js +0 -162
  547. package/dist/services/activity.d.ts +0 -10
  548. package/dist/services/activity.js +0 -101
  549. package/dist/services/assets.d.ts +0 -18
  550. package/dist/services/assets.js +0 -179
  551. package/dist/services/authentication.d.ts +0 -21
  552. package/dist/services/authentication.js +0 -332
  553. package/dist/services/authorization.d.ts +0 -17
  554. package/dist/services/authorization.js +0 -451
  555. package/dist/services/collections.d.ts +0 -64
  556. package/dist/services/collections.js +0 -595
  557. package/dist/services/dashboards.d.ts +0 -5
  558. package/dist/services/dashboards.js +0 -10
  559. package/dist/services/fields.d.ts +0 -32
  560. package/dist/services/fields.js +0 -625
  561. package/dist/services/fields.test.d.ts +0 -1
  562. package/dist/services/files.d.ts +0 -34
  563. package/dist/services/files.js +0 -280
  564. package/dist/services/files.test.d.ts +0 -1
  565. package/dist/services/flows.d.ts +0 -11
  566. package/dist/services/flows.js +0 -43
  567. package/dist/services/flows.test.d.ts +0 -1
  568. package/dist/services/folders.d.ts +0 -5
  569. package/dist/services/folders.js +0 -10
  570. package/dist/services/graphql/index.d.ts +0 -86
  571. package/dist/services/graphql/index.js +0 -2519
  572. package/dist/services/graphql/types/bigint.d.ts +0 -2
  573. package/dist/services/graphql/types/bigint.js +0 -39
  574. package/dist/services/graphql/types/date.d.ts +0 -2
  575. package/dist/services/graphql/types/date.js +0 -9
  576. package/dist/services/graphql/types/geojson.d.ts +0 -2
  577. package/dist/services/graphql/types/geojson.js +0 -10
  578. package/dist/services/graphql/types/hash.d.ts +0 -2
  579. package/dist/services/graphql/types/hash.js +0 -9
  580. package/dist/services/graphql/types/string-or-float.d.ts +0 -5
  581. package/dist/services/graphql/types/string-or-float.js +0 -34
  582. package/dist/services/graphql/types/void.d.ts +0 -2
  583. package/dist/services/graphql/types/void.js +0 -17
  584. package/dist/services/graphql/utils/add-path-to-validation-error.d.ts +0 -2
  585. package/dist/services/graphql/utils/add-path-to-validation-error.js +0 -19
  586. package/dist/services/graphql/utils/process-error.d.ts +0 -4
  587. package/dist/services/graphql/utils/process-error.js +0 -46
  588. package/dist/services/graphql/utils/process-error.test.d.ts +0 -1
  589. package/dist/services/import-export.d.ts +0 -37
  590. package/dist/services/import-export.js +0 -300
  591. package/dist/services/import-export.test.d.ts +0 -1
  592. package/dist/services/index.d.ts +0 -33
  593. package/dist/services/index.js +0 -50
  594. package/dist/services/items.d.ts +0 -83
  595. package/dist/services/items.js +0 -719
  596. package/dist/services/items.test.d.ts +0 -1
  597. package/dist/services/mail/index.d.ts +0 -20
  598. package/dist/services/mail/index.js +0 -96
  599. package/dist/services/mail/templates/base.liquid +0 -162
  600. package/dist/services/mail/templates/password-reset.liquid +0 -24
  601. package/dist/services/mail/templates/user-invitation.liquid +0 -19
  602. package/dist/services/meta.d.ts +0 -12
  603. package/dist/services/meta.js +0 -78
  604. package/dist/services/notifications.d.ts +0 -13
  605. package/dist/services/notifications.js +0 -59
  606. package/dist/services/notifications.test.d.ts +0 -1
  607. package/dist/services/operations.d.ts +0 -11
  608. package/dist/services/operations.js +0 -41
  609. package/dist/services/operations.test.d.ts +0 -1
  610. package/dist/services/panels.d.ts +0 -5
  611. package/dist/services/panels.js +0 -10
  612. package/dist/services/payload.d.ts +0 -73
  613. package/dist/services/payload.js +0 -644
  614. package/dist/services/payload.test.d.ts +0 -1
  615. package/dist/services/permissions.d.ts +0 -17
  616. package/dist/services/permissions.js +0 -84
  617. package/dist/services/permissions.test.d.ts +0 -1
  618. package/dist/services/presets.d.ts +0 -5
  619. package/dist/services/presets.js +0 -10
  620. package/dist/services/relations.d.ts +0 -60
  621. package/dist/services/relations.js +0 -477
  622. package/dist/services/revisions.d.ts +0 -6
  623. package/dist/services/revisions.js +0 -24
  624. package/dist/services/roles.d.ts +0 -14
  625. package/dist/services/roles.js +0 -148
  626. package/dist/services/roles.test.d.ts +0 -1
  627. package/dist/services/schema.d.ts +0 -15
  628. package/dist/services/schema.js +0 -56
  629. package/dist/services/schema.test.d.ts +0 -1
  630. package/dist/services/server.d.ts +0 -13
  631. package/dist/services/server.js +0 -366
  632. package/dist/services/settings.d.ts +0 -5
  633. package/dist/services/settings.js +0 -10
  634. package/dist/services/shares.d.ts +0 -17
  635. package/dist/services/shares.js +0 -136
  636. package/dist/services/specifications.d.ts +0 -53
  637. package/dist/services/specifications.js +0 -500
  638. package/dist/services/specifications.test.d.ts +0 -1
  639. package/dist/services/tfa.d.ts +0 -12
  640. package/dist/services/tfa.js +0 -57
  641. package/dist/services/users.d.ts +0 -55
  642. package/dist/services/users.js +0 -380
  643. package/dist/services/users.test.d.ts +0 -1
  644. package/dist/services/utils.d.ts +0 -13
  645. package/dist/services/utils.js +0 -115
  646. package/dist/services/webhooks.d.ts +0 -11
  647. package/dist/services/webhooks.js +0 -33
  648. package/dist/services/webhooks.test.d.ts +0 -1
  649. package/dist/start.d.ts +0 -1
  650. package/dist/start.js +0 -4
  651. package/dist/storage/get-storage-driver.d.ts +0 -3
  652. package/dist/storage/get-storage-driver.js +0 -20
  653. package/dist/storage/get-storage-driver.test.d.ts +0 -1
  654. package/dist/storage/index.d.ts +0 -5
  655. package/dist/storage/index.js +0 -20
  656. package/dist/storage/index.test.d.ts +0 -1
  657. package/dist/storage/register-drivers.d.ts +0 -2
  658. package/dist/storage/register-drivers.js +0 -22
  659. package/dist/storage/register-drivers.test.d.ts +0 -1
  660. package/dist/storage/register-locations.d.ts +0 -2
  661. package/dist/storage/register-locations.js +0 -17
  662. package/dist/storage/register-locations.test.d.ts +0 -1
  663. package/dist/types/assets.d.ts +0 -20
  664. package/dist/types/assets.js +0 -54
  665. package/dist/types/ast.d.ts +0 -56
  666. package/dist/types/ast.js +0 -2
  667. package/dist/types/auth.d.ts +0 -54
  668. package/dist/types/auth.js +0 -2
  669. package/dist/types/collection.d.ts +0 -19
  670. package/dist/types/collection.js +0 -2
  671. package/dist/types/database.d.ts +0 -3
  672. package/dist/types/database.js +0 -4
  673. package/dist/types/events.d.ts +0 -18
  674. package/dist/types/events.js +0 -2
  675. package/dist/types/files.d.ts +0 -29
  676. package/dist/types/files.js +0 -2
  677. package/dist/types/graphql.d.ts +0 -14
  678. package/dist/types/graphql.js +0 -2
  679. package/dist/types/index.d.ts +0 -15
  680. package/dist/types/index.js +0 -31
  681. package/dist/types/items.d.ts +0 -49
  682. package/dist/types/items.js +0 -6
  683. package/dist/types/meta.d.ts +0 -4
  684. package/dist/types/meta.js +0 -8
  685. package/dist/types/migration.d.ts +0 -5
  686. package/dist/types/migration.js +0 -2
  687. package/dist/types/revision.d.ts +0 -7
  688. package/dist/types/revision.js +0 -2
  689. package/dist/types/services.d.ts +0 -21
  690. package/dist/types/services.js +0 -2
  691. package/dist/types/snapshot.d.ts +0 -55
  692. package/dist/types/snapshot.js +0 -16
  693. package/dist/types/webhooks.d.ts +0 -15
  694. package/dist/types/webhooks.js +0 -2
  695. package/dist/utils/apply-diff.d.ts +0 -9
  696. package/dist/utils/apply-diff.js +0 -256
  697. package/dist/utils/apply-diff.test.d.ts +0 -1
  698. package/dist/utils/apply-function-to-column-name.d.ts +0 -12
  699. package/dist/utils/apply-function-to-column-name.js +0 -26
  700. package/dist/utils/apply-function-to-column-name.test.d.ts +0 -1
  701. package/dist/utils/apply-query.d.ts +0 -34
  702. package/dist/utils/apply-query.js +0 -568
  703. package/dist/utils/apply-snapshot.d.ts +0 -9
  704. package/dist/utils/apply-snapshot.js +0 -22
  705. package/dist/utils/apply-snapshot.test.d.ts +0 -1
  706. package/dist/utils/async-handler.d.ts +0 -3
  707. package/dist/utils/async-handler.js +0 -4
  708. package/dist/utils/async-handler.test.d.ts +0 -1
  709. package/dist/utils/calculate-field-depth.d.ts +0 -33
  710. package/dist/utils/calculate-field-depth.js +0 -75
  711. package/dist/utils/calculate-field-depth.test.d.ts +0 -1
  712. package/dist/utils/compress.d.ts +0 -3
  713. package/dist/utils/compress.js +0 -17
  714. package/dist/utils/construct-flow-tree.d.ts +0 -2
  715. package/dist/utils/construct-flow-tree.js +0 -31
  716. package/dist/utils/dynamic-import.d.ts +0 -1
  717. package/dist/utils/dynamic-import.js +0 -7
  718. package/dist/utils/filter-items.d.ts +0 -2
  719. package/dist/utils/filter-items.js +0 -37
  720. package/dist/utils/filter-items.test.d.ts +0 -1
  721. package/dist/utils/generate-hash.d.ts +0 -1
  722. package/dist/utils/generate-hash.js +0 -16
  723. package/dist/utils/get-accountability-for-role.d.ts +0 -7
  724. package/dist/utils/get-accountability-for-role.js +0 -45
  725. package/dist/utils/get-ast-from-query.d.ts +0 -13
  726. package/dist/utils/get-ast-from-query.js +0 -300
  727. package/dist/utils/get-auth-providers.d.ts +0 -8
  728. package/dist/utils/get-auth-providers.js +0 -19
  729. package/dist/utils/get-auth-providers.test.d.ts +0 -1
  730. package/dist/utils/get-cache-headers.d.ts +0 -10
  731. package/dist/utils/get-cache-headers.js +0 -43
  732. package/dist/utils/get-cache-headers.test.d.ts +0 -1
  733. package/dist/utils/get-cache-key.d.ts +0 -2
  734. package/dist/utils/get-cache-key.js +0 -21
  735. package/dist/utils/get-cache-key.test.d.ts +0 -1
  736. package/dist/utils/get-collection-from-alias.d.ts +0 -6
  737. package/dist/utils/get-collection-from-alias.js +0 -16
  738. package/dist/utils/get-collection-from-alias.test.d.ts +0 -1
  739. package/dist/utils/get-column-path.d.ts +0 -26
  740. package/dist/utils/get-column-path.js +0 -65
  741. package/dist/utils/get-column-path.test.d.ts +0 -1
  742. package/dist/utils/get-column.d.ts +0 -20
  743. package/dist/utils/get-column.js +0 -52
  744. package/dist/utils/get-config-from-env.d.ts +0 -1
  745. package/dist/utils/get-config-from-env.js +0 -48
  746. package/dist/utils/get-config-from-env.test.d.ts +0 -1
  747. package/dist/utils/get-date-formatted.d.ts +0 -1
  748. package/dist/utils/get-date-formatted.js +0 -14
  749. package/dist/utils/get-date-formatted.test.d.ts +0 -1
  750. package/dist/utils/get-default-index-name.d.ts +0 -10
  751. package/dist/utils/get-default-index-name.js +0 -25
  752. package/dist/utils/get-default-value.d.ts +0 -3
  753. package/dist/utils/get-default-value.js +0 -62
  754. package/dist/utils/get-graphql-query-and-variables.d.ts +0 -2
  755. package/dist/utils/get-graphql-query-and-variables.js +0 -9
  756. package/dist/utils/get-graphql-query-and-variables.test.d.ts +0 -1
  757. package/dist/utils/get-graphql-type.d.ts +0 -3
  758. package/dist/utils/get-graphql-type.js +0 -40
  759. package/dist/utils/get-ip-from-req.d.ts +0 -2
  760. package/dist/utils/get-ip-from-req.js +0 -24
  761. package/dist/utils/get-local-type.d.ts +0 -9
  762. package/dist/utils/get-local-type.js +0 -131
  763. package/dist/utils/get-milliseconds.d.ts +0 -4
  764. package/dist/utils/get-milliseconds.js +0 -14
  765. package/dist/utils/get-milliseconds.test.d.ts +0 -1
  766. package/dist/utils/get-module-default.d.ts +0 -3
  767. package/dist/utils/get-module-default.js +0 -9
  768. package/dist/utils/get-os-info.d.ts +0 -9
  769. package/dist/utils/get-os-info.js +0 -47
  770. package/dist/utils/get-permissions.d.ts +0 -2
  771. package/dist/utils/get-permissions.js +0 -158
  772. package/dist/utils/get-relation-info.d.ts +0 -7
  773. package/dist/utils/get-relation-info.js +0 -49
  774. package/dist/utils/get-relation-info.test.d.ts +0 -1
  775. package/dist/utils/get-relation-type.d.ts +0 -6
  776. package/dist/utils/get-relation-type.js +0 -22
  777. package/dist/utils/get-relation-type.test.d.ts +0 -1
  778. package/dist/utils/get-schema.d.ts +0 -10
  779. package/dist/utils/get-schema.js +0 -138
  780. package/dist/utils/get-snapshot-diff.d.ts +0 -2
  781. package/dist/utils/get-snapshot-diff.js +0 -82
  782. package/dist/utils/get-snapshot.d.ts +0 -7
  783. package/dist/utils/get-snapshot.js +0 -80
  784. package/dist/utils/get-string-byte-size.d.ts +0 -4
  785. package/dist/utils/get-string-byte-size.js +0 -10
  786. package/dist/utils/get-string-byte-size.test.d.ts +0 -1
  787. package/dist/utils/get-versioned-hash.d.ts +0 -1
  788. package/dist/utils/get-versioned-hash.js +0 -12
  789. package/dist/utils/get-versioned-hash.test.d.ts +0 -1
  790. package/dist/utils/is-directus-jwt.d.ts +0 -5
  791. package/dist/utils/is-directus-jwt.js +0 -22
  792. package/dist/utils/is-directus-jwt.test.d.ts +0 -1
  793. package/dist/utils/is-url-allowed.d.ts +0 -4
  794. package/dist/utils/is-url-allowed.js +0 -36
  795. package/dist/utils/job-queue.d.ts +0 -9
  796. package/dist/utils/job-queue.js +0 -26
  797. package/dist/utils/jwt.d.ts +0 -2
  798. package/dist/utils/jwt.js +0 -53
  799. package/dist/utils/jwt.test.d.ts +0 -1
  800. package/dist/utils/map-values-deep.d.ts +0 -1
  801. package/dist/utils/map-values-deep.js +0 -29
  802. package/dist/utils/map-values-deep.test.d.ts +0 -1
  803. package/dist/utils/md.d.ts +0 -4
  804. package/dist/utils/md.js +0 -15
  805. package/dist/utils/md.test.d.ts +0 -1
  806. package/dist/utils/merge-permissions-for-share.d.ts +0 -4
  807. package/dist/utils/merge-permissions-for-share.js +0 -115
  808. package/dist/utils/merge-permissions.d.ts +0 -14
  809. package/dist/utils/merge-permissions.js +0 -100
  810. package/dist/utils/merge-permissions.test.d.ts +0 -1
  811. package/dist/utils/parse-image-metadata.d.ts +0 -3
  812. package/dist/utils/parse-image-metadata.js +0 -73
  813. package/dist/utils/reduce-schema.d.ts +0 -9
  814. package/dist/utils/reduce-schema.js +0 -82
  815. package/dist/utils/require-yaml.d.ts +0 -1
  816. package/dist/utils/require-yaml.js +0 -13
  817. package/dist/utils/sanitize-query.d.ts +0 -2
  818. package/dist/utils/sanitize-query.js +0 -179
  819. package/dist/utils/sanitize-query.test.d.ts +0 -1
  820. package/dist/utils/sanitize-schema.d.ts +0 -30
  821. package/dist/utils/sanitize-schema.js +0 -80
  822. package/dist/utils/sanitize-schema.test.d.ts +0 -1
  823. package/dist/utils/should-skip-cache.d.ts +0 -7
  824. package/dist/utils/should-skip-cache.js +0 -30
  825. package/dist/utils/should-skip-cache.test.d.ts +0 -1
  826. package/dist/utils/stall.d.ts +0 -26
  827. package/dist/utils/stall.js +0 -38
  828. package/dist/utils/stall.test.d.ts +0 -1
  829. package/dist/utils/strip-function.d.ts +0 -4
  830. package/dist/utils/strip-function.js +0 -16
  831. package/dist/utils/strip-function.test.d.ts +0 -1
  832. package/dist/utils/telemetry.d.ts +0 -1
  833. package/dist/utils/telemetry.js +0 -30
  834. package/dist/utils/transformations.d.ts +0 -6
  835. package/dist/utils/transformations.js +0 -55
  836. package/dist/utils/url.d.ts +0 -17
  837. package/dist/utils/url.js +0 -63
  838. package/dist/utils/url.test.d.ts +0 -1
  839. package/dist/utils/user-name.d.ts +0 -2
  840. package/dist/utils/user-name.js +0 -19
  841. package/dist/utils/user-name.test.d.ts +0 -1
  842. package/dist/utils/validate-diff.d.ts +0 -7
  843. package/dist/utils/validate-diff.js +0 -113
  844. package/dist/utils/validate-diff.test.d.ts +0 -1
  845. package/dist/utils/validate-env.d.ts +0 -1
  846. package/dist/utils/validate-env.js +0 -18
  847. package/dist/utils/validate-env.test.d.ts +0 -1
  848. package/dist/utils/validate-keys.d.ts +0 -6
  849. package/dist/utils/validate-keys.js +0 -28
  850. package/dist/utils/validate-keys.test.d.ts +0 -1
  851. package/dist/utils/validate-query.d.ts +0 -2
  852. package/dist/utils/validate-query.js +0 -205
  853. package/dist/utils/validate-query.test.d.ts +0 -1
  854. package/dist/utils/validate-snapshot.d.ts +0 -5
  855. package/dist/utils/validate-snapshot.js +0 -71
  856. package/dist/utils/validate-snapshot.test.d.ts +0 -1
  857. package/dist/utils/validate-storage.d.ts +0 -1
  858. package/dist/utils/validate-storage.js +0 -38
  859. package/dist/webhooks.d.ts +0 -4
  860. package/dist/webhooks.js +0 -89
  861. /package/{README.md → readme.md} +0 -0
@@ -1,310 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.createOAuth2AuthRouter = exports.OAuth2AuthDriver = void 0;
30
- const exceptions_1 = require("@directus/shared/exceptions");
31
- const utils_1 = require("@directus/shared/utils");
32
- const express_1 = __importStar(require("express"));
33
- const flat_1 = __importDefault(require("flat"));
34
- const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
35
- const openid_client_1 = require("openid-client");
36
- const auth_1 = require("../../auth");
37
- const env_1 = __importDefault(require("../../env"));
38
- const exceptions_2 = require("../../exceptions");
39
- const record_not_unique_1 = require("../../exceptions/database/record-not-unique");
40
- const logger_1 = __importDefault(require("../../logger"));
41
- const respond_1 = require("../../middleware/respond");
42
- const services_1 = require("../../services");
43
- const async_handler_1 = __importDefault(require("../../utils/async-handler"));
44
- const get_config_from_env_1 = require("../../utils/get-config-from-env");
45
- const get_ip_from_req_1 = require("../../utils/get-ip-from-req");
46
- const get_milliseconds_1 = require("../../utils/get-milliseconds");
47
- const url_1 = require("../../utils/url");
48
- const local_1 = require("./local");
49
- class OAuth2AuthDriver extends local_1.LocalAuthDriver {
50
- client;
51
- redirectUrl;
52
- usersService;
53
- config;
54
- constructor(options, config) {
55
- super(options, config);
56
- const { authorizeUrl, accessUrl, profileUrl, clientId, clientSecret, ...additionalConfig } = config;
57
- if (!authorizeUrl || !accessUrl || !profileUrl || !clientId || !clientSecret || !additionalConfig['provider']) {
58
- throw new exceptions_2.InvalidConfigException('Invalid provider config', { provider: additionalConfig['provider'] });
59
- }
60
- const redirectUrl = new url_1.Url(env_1.default['PUBLIC_URL']).addPath('auth', 'login', additionalConfig['provider'], 'callback');
61
- this.redirectUrl = redirectUrl.toString();
62
- this.usersService = new services_1.UsersService({ knex: this.knex, schema: this.schema });
63
- this.config = additionalConfig;
64
- const issuer = new openid_client_1.Issuer({
65
- authorization_endpoint: authorizeUrl,
66
- token_endpoint: accessUrl,
67
- userinfo_endpoint: profileUrl,
68
- issuer: additionalConfig['provider'],
69
- });
70
- const clientOptionsOverrides = (0, get_config_from_env_1.getConfigFromEnv)(`AUTH_${config['provider'].toUpperCase()}_CLIENT_`, [`AUTH_${config['provider'].toUpperCase()}_CLIENT_ID`, `AUTH_${config['provider'].toUpperCase()}_CLIENT_SECRET`], 'underscore');
71
- this.client = new issuer.Client({
72
- client_id: clientId,
73
- client_secret: clientSecret,
74
- redirect_uris: [this.redirectUrl],
75
- response_types: ['code'],
76
- ...clientOptionsOverrides,
77
- });
78
- }
79
- generateCodeVerifier() {
80
- return openid_client_1.generators.codeVerifier();
81
- }
82
- generateAuthUrl(codeVerifier, prompt = false) {
83
- try {
84
- const codeChallenge = openid_client_1.generators.codeChallenge(codeVerifier);
85
- const paramsConfig = typeof this.config['params'] === 'object' ? this.config['params'] : {};
86
- return this.client.authorizationUrl({
87
- scope: this.config['scope'] ?? 'email',
88
- access_type: 'offline',
89
- prompt: prompt ? 'consent' : undefined,
90
- ...paramsConfig,
91
- code_challenge: codeChallenge,
92
- code_challenge_method: 'S256',
93
- // Some providers require state even with PKCE
94
- state: codeChallenge,
95
- });
96
- }
97
- catch (e) {
98
- throw handleError(e);
99
- }
100
- }
101
- async fetchUserId(identifier) {
102
- const user = await this.knex
103
- .select('id')
104
- .from('directus_users')
105
- .whereRaw('LOWER(??) = ?', ['external_identifier', identifier.toLowerCase()])
106
- .first();
107
- return user?.id;
108
- }
109
- async getUserID(payload) {
110
- if (!payload['code'] || !payload['codeVerifier'] || !payload['state']) {
111
- logger_1.default.warn('[OAuth2] No code, codeVerifier or state in payload');
112
- throw new exceptions_2.InvalidCredentialsException();
113
- }
114
- let tokenSet;
115
- let userInfo;
116
- try {
117
- tokenSet = await this.client.oauthCallback(this.redirectUrl, { code: payload['code'], state: payload['state'] }, { code_verifier: payload['codeVerifier'], state: openid_client_1.generators.codeChallenge(payload['codeVerifier']) });
118
- userInfo = await this.client.userinfo(tokenSet.access_token);
119
- }
120
- catch (e) {
121
- throw handleError(e);
122
- }
123
- // Flatten response to support dot indexes
124
- userInfo = (0, flat_1.default)(userInfo);
125
- const { provider, emailKey, identifierKey, allowPublicRegistration } = this.config;
126
- const email = userInfo[emailKey ?? 'email'] ? String(userInfo[emailKey ?? 'email']) : undefined;
127
- // Fallback to email if explicit identifier not found
128
- const identifier = userInfo[identifierKey] ? String(userInfo[identifierKey]) : email;
129
- if (!identifier) {
130
- logger_1.default.warn(`[OAuth2] Failed to find user identifier for provider "${provider}"`);
131
- throw new exceptions_2.InvalidCredentialsException();
132
- }
133
- const userId = await this.fetchUserId(identifier);
134
- if (userId) {
135
- // Update user refreshToken if provided
136
- if (tokenSet.refresh_token) {
137
- await this.usersService.updateOne(userId, {
138
- auth_data: JSON.stringify({ refreshToken: tokenSet.refresh_token }),
139
- });
140
- }
141
- return userId;
142
- }
143
- // Is public registration allowed?
144
- if (!allowPublicRegistration) {
145
- logger_1.default.warn(`[OAuth2] User doesn't exist, and public registration not allowed for provider "${provider}"`);
146
- throw new exceptions_2.InvalidCredentialsException();
147
- }
148
- try {
149
- await this.usersService.createOne({
150
- provider,
151
- first_name: userInfo[this.config['firstNameKey']],
152
- last_name: userInfo[this.config['lastNameKey']],
153
- email: email,
154
- external_identifier: identifier,
155
- role: this.config['defaultRoleId'],
156
- auth_data: tokenSet.refresh_token && JSON.stringify({ refreshToken: tokenSet.refresh_token }),
157
- });
158
- }
159
- catch (e) {
160
- if (e instanceof record_not_unique_1.RecordNotUniqueException) {
161
- logger_1.default.warn(e, '[OAuth2] Failed to register user. User not unique');
162
- throw new exceptions_2.InvalidProviderException();
163
- }
164
- throw e;
165
- }
166
- return (await this.fetchUserId(identifier));
167
- }
168
- async login(user) {
169
- return this.refresh(user);
170
- }
171
- async refresh(user) {
172
- let authData = user.auth_data;
173
- if (typeof authData === 'string') {
174
- try {
175
- authData = (0, utils_1.parseJSON)(authData);
176
- }
177
- catch {
178
- logger_1.default.warn(`[OAuth2] Session data isn't valid JSON: ${authData}`);
179
- }
180
- }
181
- if (authData?.['refreshToken']) {
182
- try {
183
- const tokenSet = await this.client.refresh(authData['refreshToken']);
184
- // Update user refreshToken if provided
185
- if (tokenSet.refresh_token) {
186
- await this.usersService.updateOne(user.id, {
187
- auth_data: JSON.stringify({ refreshToken: tokenSet.refresh_token }),
188
- });
189
- }
190
- }
191
- catch (e) {
192
- throw handleError(e);
193
- }
194
- }
195
- }
196
- }
197
- exports.OAuth2AuthDriver = OAuth2AuthDriver;
198
- const handleError = (e) => {
199
- if (e instanceof openid_client_1.errors.OPError) {
200
- if (e.error === 'invalid_grant') {
201
- // Invalid token
202
- logger_1.default.trace(e, `[OAuth2] Invalid grant`);
203
- return new exceptions_2.InvalidTokenException();
204
- }
205
- // Server response error
206
- logger_1.default.trace(e, `[OAuth2] Unknown OP error`);
207
- return new exceptions_2.ServiceUnavailableException('Service returned unexpected response', {
208
- service: 'oauth2',
209
- message: e.error_description,
210
- });
211
- }
212
- else if (e instanceof openid_client_1.errors.RPError) {
213
- // Internal client error
214
- logger_1.default.trace(e, `[OAuth2] Unknown RP error`);
215
- return new exceptions_2.InvalidCredentialsException();
216
- }
217
- logger_1.default.trace(e, `[OAuth2] Unknown error`);
218
- return e;
219
- };
220
- function createOAuth2AuthRouter(providerName) {
221
- const router = (0, express_1.Router)();
222
- router.get('/', (req, res) => {
223
- const provider = (0, auth_1.getAuthProvider)(providerName);
224
- const codeVerifier = provider.generateCodeVerifier();
225
- const prompt = !!req.query['prompt'];
226
- const token = jsonwebtoken_1.default.sign({ verifier: codeVerifier, redirect: req.query['redirect'], prompt }, env_1.default['SECRET'], {
227
- expiresIn: '5m',
228
- issuer: 'directus',
229
- });
230
- res.cookie(`oauth2.${providerName}`, token, {
231
- httpOnly: true,
232
- sameSite: 'lax',
233
- });
234
- return res.redirect(provider.generateAuthUrl(codeVerifier, prompt));
235
- }, respond_1.respond);
236
- router.post('/callback', express_1.default.urlencoded({ extended: false }), (req, res) => {
237
- res.redirect(303, `./callback?${new URLSearchParams(req.body)}`);
238
- }, respond_1.respond);
239
- router.get('/callback', (0, async_handler_1.default)(async (req, res, next) => {
240
- let tokenData;
241
- try {
242
- tokenData = jsonwebtoken_1.default.verify(req.cookies[`oauth2.${providerName}`], env_1.default['SECRET'], {
243
- issuer: 'directus',
244
- });
245
- }
246
- catch (e) {
247
- logger_1.default.warn(e, `[OAuth2] Couldn't verify OAuth2 cookie`);
248
- throw new exceptions_2.InvalidCredentialsException();
249
- }
250
- const { verifier, redirect, prompt } = tokenData;
251
- const accountability = {
252
- ip: (0, get_ip_from_req_1.getIPFromReq)(req),
253
- role: null,
254
- };
255
- const userAgent = req.get('user-agent');
256
- if (userAgent)
257
- accountability.userAgent = userAgent;
258
- const origin = req.get('origin');
259
- if (origin)
260
- accountability.origin = origin;
261
- const authenticationService = new services_1.AuthenticationService({
262
- accountability,
263
- schema: req.schema,
264
- });
265
- let authResponse;
266
- try {
267
- res.clearCookie(`oauth2.${providerName}`);
268
- authResponse = await authenticationService.login(providerName, {
269
- code: req.query['code'],
270
- codeVerifier: verifier,
271
- state: req.query['state'],
272
- });
273
- }
274
- catch (error) {
275
- // Prompt user for a new refresh_token if invalidated
276
- if (error instanceof exceptions_2.InvalidTokenException && !prompt) {
277
- return res.redirect(`./?${redirect ? `redirect=${redirect}&` : ''}prompt=true`);
278
- }
279
- if (redirect) {
280
- let reason = 'UNKNOWN_EXCEPTION';
281
- if (error instanceof exceptions_1.BaseException) {
282
- reason = error.code;
283
- }
284
- else {
285
- logger_1.default.warn(error, `[OAuth2] Unexpected error during OAuth2 login`);
286
- }
287
- return res.redirect(`${redirect.split('?')[0]}?reason=${reason}`);
288
- }
289
- logger_1.default.warn(error, `[OAuth2] Unexpected error during OAuth2 login`);
290
- throw error;
291
- }
292
- const { accessToken, refreshToken, expires } = authResponse;
293
- if (redirect) {
294
- res.cookie(env_1.default['REFRESH_TOKEN_COOKIE_NAME'], refreshToken, {
295
- httpOnly: true,
296
- domain: env_1.default['REFRESH_TOKEN_COOKIE_DOMAIN'],
297
- maxAge: (0, get_milliseconds_1.getMilliseconds)(env_1.default['REFRESH_TOKEN_TTL']),
298
- secure: env_1.default['REFRESH_TOKEN_COOKIE_SECURE'] ?? false,
299
- sameSite: env_1.default['REFRESH_TOKEN_COOKIE_SAME_SITE'] || 'strict',
300
- });
301
- return res.redirect(redirect);
302
- }
303
- res.locals['payload'] = {
304
- data: { access_token: accessToken, refresh_token: refreshToken, expires },
305
- };
306
- next();
307
- }), respond_1.respond);
308
- return router;
309
- }
310
- exports.createOAuth2AuthRouter = createOAuth2AuthRouter;
@@ -1,19 +0,0 @@
1
- import { Router } from 'express';
2
- import { Client } from 'openid-client';
3
- import { UsersService } from '../../services';
4
- import type { AuthDriverOptions, User } from '../../types';
5
- import { LocalAuthDriver } from './local';
6
- export declare class OpenIDAuthDriver extends LocalAuthDriver {
7
- client: Promise<Client>;
8
- redirectUrl: string;
9
- usersService: UsersService;
10
- config: Record<string, any>;
11
- constructor(options: AuthDriverOptions, config: Record<string, any>);
12
- generateCodeVerifier(): string;
13
- generateAuthUrl(codeVerifier: string, prompt?: boolean): Promise<string>;
14
- private fetchUserId;
15
- getUserID(payload: Record<string, any>): Promise<string>;
16
- login(user: User): Promise<void>;
17
- refresh(user: User): Promise<void>;
18
- }
19
- export declare function createOpenIDAuthRouter(providerName: string): Router;
@@ -1,332 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.createOpenIDAuthRouter = exports.OpenIDAuthDriver = void 0;
30
- const exceptions_1 = require("@directus/shared/exceptions");
31
- const utils_1 = require("@directus/shared/utils");
32
- const express_1 = __importStar(require("express"));
33
- const flat_1 = __importDefault(require("flat"));
34
- const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
35
- const openid_client_1 = require("openid-client");
36
- const auth_1 = require("../../auth");
37
- const env_1 = __importDefault(require("../../env"));
38
- const exceptions_2 = require("../../exceptions");
39
- const record_not_unique_1 = require("../../exceptions/database/record-not-unique");
40
- const logger_1 = __importDefault(require("../../logger"));
41
- const respond_1 = require("../../middleware/respond");
42
- const services_1 = require("../../services");
43
- const async_handler_1 = __importDefault(require("../../utils/async-handler"));
44
- const get_config_from_env_1 = require("../../utils/get-config-from-env");
45
- const get_ip_from_req_1 = require("../../utils/get-ip-from-req");
46
- const get_milliseconds_1 = require("../../utils/get-milliseconds");
47
- const url_1 = require("../../utils/url");
48
- const local_1 = require("./local");
49
- class OpenIDAuthDriver extends local_1.LocalAuthDriver {
50
- client;
51
- redirectUrl;
52
- usersService;
53
- config;
54
- constructor(options, config) {
55
- super(options, config);
56
- const { issuerUrl, clientId, clientSecret, ...additionalConfig } = config;
57
- if (!issuerUrl || !clientId || !clientSecret || !additionalConfig['provider']) {
58
- throw new exceptions_2.InvalidConfigException('Invalid provider config', { provider: additionalConfig['provider'] });
59
- }
60
- const redirectUrl = new url_1.Url(env_1.default['PUBLIC_URL']).addPath('auth', 'login', additionalConfig['provider'], 'callback');
61
- const clientOptionsOverrides = (0, get_config_from_env_1.getConfigFromEnv)(`AUTH_${config['provider'].toUpperCase()}_CLIENT_`, [`AUTH_${config['provider'].toUpperCase()}_CLIENT_ID`, `AUTH_${config['provider'].toUpperCase()}_CLIENT_SECRET`], 'underscore');
62
- this.redirectUrl = redirectUrl.toString();
63
- this.usersService = new services_1.UsersService({ knex: this.knex, schema: this.schema });
64
- this.config = additionalConfig;
65
- this.client = new Promise((resolve, reject) => {
66
- openid_client_1.Issuer.discover(issuerUrl)
67
- .then((issuer) => {
68
- const supportedTypes = issuer.metadata['response_types_supported'];
69
- if (!supportedTypes?.includes('code')) {
70
- reject(new exceptions_2.InvalidConfigException('OpenID provider does not support required code flow', {
71
- provider: additionalConfig['provider'],
72
- }));
73
- }
74
- resolve(new issuer.Client({
75
- client_id: clientId,
76
- client_secret: clientSecret,
77
- redirect_uris: [this.redirectUrl],
78
- response_types: ['code'],
79
- ...clientOptionsOverrides,
80
- }));
81
- })
82
- .catch((e) => {
83
- logger_1.default.error(e, '[OpenID] Failed to fetch provider config');
84
- process.exit(1);
85
- });
86
- });
87
- }
88
- generateCodeVerifier() {
89
- return openid_client_1.generators.codeVerifier();
90
- }
91
- async generateAuthUrl(codeVerifier, prompt = false) {
92
- try {
93
- const client = await this.client;
94
- const codeChallenge = openid_client_1.generators.codeChallenge(codeVerifier);
95
- const paramsConfig = typeof this.config['params'] === 'object' ? this.config['params'] : {};
96
- return client.authorizationUrl({
97
- scope: this.config['scope'] ?? 'openid profile email',
98
- access_type: 'offline',
99
- prompt: prompt ? 'consent' : undefined,
100
- ...paramsConfig,
101
- code_challenge: codeChallenge,
102
- code_challenge_method: 'S256',
103
- // Some providers require state even with PKCE
104
- state: codeChallenge,
105
- nonce: codeChallenge,
106
- });
107
- }
108
- catch (e) {
109
- throw handleError(e);
110
- }
111
- }
112
- async fetchUserId(identifier) {
113
- const user = await this.knex
114
- .select('id')
115
- .from('directus_users')
116
- .whereRaw('LOWER(??) = ?', ['external_identifier', identifier.toLowerCase()])
117
- .first();
118
- return user?.id;
119
- }
120
- async getUserID(payload) {
121
- if (!payload['code'] || !payload['codeVerifier'] || !payload['state']) {
122
- logger_1.default.warn('[OpenID] No code, codeVerifier or state in payload');
123
- throw new exceptions_2.InvalidCredentialsException();
124
- }
125
- let tokenSet;
126
- let userInfo;
127
- try {
128
- const client = await this.client;
129
- const codeChallenge = openid_client_1.generators.codeChallenge(payload['codeVerifier']);
130
- tokenSet = await client.callback(this.redirectUrl, { code: payload['code'], state: payload['state'] }, { code_verifier: payload['codeVerifier'], state: codeChallenge, nonce: codeChallenge });
131
- userInfo = tokenSet.claims();
132
- if (client.issuer.metadata['userinfo_endpoint']) {
133
- userInfo = {
134
- ...userInfo,
135
- ...(await client.userinfo(tokenSet.access_token)),
136
- };
137
- }
138
- }
139
- catch (e) {
140
- throw handleError(e);
141
- }
142
- // Flatten response to support dot indexes
143
- userInfo = (0, flat_1.default)(userInfo);
144
- const { provider, identifierKey, allowPublicRegistration, requireVerifiedEmail } = this.config;
145
- const email = userInfo['email'] ? String(userInfo['email']) : undefined;
146
- // Fallback to email if explicit identifier not found
147
- const identifier = userInfo[identifierKey ?? 'sub'] ? String(userInfo[identifierKey ?? 'sub']) : email;
148
- if (!identifier) {
149
- logger_1.default.warn(`[OpenID] Failed to find user identifier for provider "${provider}"`);
150
- throw new exceptions_2.InvalidCredentialsException();
151
- }
152
- const userId = await this.fetchUserId(identifier);
153
- if (userId) {
154
- // Update user refreshToken if provided
155
- if (tokenSet.refresh_token) {
156
- await this.usersService.updateOne(userId, {
157
- auth_data: JSON.stringify({ refreshToken: tokenSet.refresh_token }),
158
- });
159
- }
160
- return userId;
161
- }
162
- const isEmailVerified = !requireVerifiedEmail || userInfo['email_verified'];
163
- // Is public registration allowed?
164
- if (!allowPublicRegistration || !isEmailVerified) {
165
- logger_1.default.warn(`[OpenID] User doesn't exist, and public registration not allowed for provider "${provider}"`);
166
- throw new exceptions_2.InvalidCredentialsException();
167
- }
168
- try {
169
- await this.usersService.createOne({
170
- provider,
171
- first_name: userInfo['given_name'],
172
- last_name: userInfo['family_name'],
173
- email: email,
174
- external_identifier: identifier,
175
- role: this.config['defaultRoleId'],
176
- auth_data: tokenSet.refresh_token && JSON.stringify({ refreshToken: tokenSet.refresh_token }),
177
- });
178
- }
179
- catch (e) {
180
- if (e instanceof record_not_unique_1.RecordNotUniqueException) {
181
- logger_1.default.warn(e, '[OpenID] Failed to register user. User not unique');
182
- throw new exceptions_2.InvalidProviderException();
183
- }
184
- throw e;
185
- }
186
- return (await this.fetchUserId(identifier));
187
- }
188
- async login(user) {
189
- return this.refresh(user);
190
- }
191
- async refresh(user) {
192
- let authData = user.auth_data;
193
- if (typeof authData === 'string') {
194
- try {
195
- authData = (0, utils_1.parseJSON)(authData);
196
- }
197
- catch {
198
- logger_1.default.warn(`[OpenID] Session data isn't valid JSON: ${authData}`);
199
- }
200
- }
201
- if (authData?.['refreshToken']) {
202
- try {
203
- const client = await this.client;
204
- const tokenSet = await client.refresh(authData['refreshToken']);
205
- // Update user refreshToken if provided
206
- if (tokenSet.refresh_token) {
207
- await this.usersService.updateOne(user.id, {
208
- auth_data: JSON.stringify({ refreshToken: tokenSet.refresh_token }),
209
- });
210
- }
211
- }
212
- catch (e) {
213
- throw handleError(e);
214
- }
215
- }
216
- }
217
- }
218
- exports.OpenIDAuthDriver = OpenIDAuthDriver;
219
- const handleError = (e) => {
220
- if (e instanceof openid_client_1.errors.OPError) {
221
- if (e.error === 'invalid_grant') {
222
- // Invalid token
223
- logger_1.default.trace(e, `[OpenID] Invalid grant`);
224
- return new exceptions_2.InvalidTokenException();
225
- }
226
- // Server response error
227
- logger_1.default.trace(e, `[OpenID] Unknown OP error`);
228
- return new exceptions_2.ServiceUnavailableException('Service returned unexpected response', {
229
- service: 'openid',
230
- message: e.error_description,
231
- });
232
- }
233
- else if (e instanceof openid_client_1.errors.RPError) {
234
- // Internal client error
235
- logger_1.default.trace(e, `[OpenID] Unknown RP error`);
236
- return new exceptions_2.InvalidCredentialsException();
237
- }
238
- logger_1.default.trace(e, `[OpenID] Unknown error`);
239
- return e;
240
- };
241
- function createOpenIDAuthRouter(providerName) {
242
- const router = (0, express_1.Router)();
243
- router.get('/', (0, async_handler_1.default)(async (req, res) => {
244
- const provider = (0, auth_1.getAuthProvider)(providerName);
245
- const codeVerifier = provider.generateCodeVerifier();
246
- const prompt = !!req.query['prompt'];
247
- const token = jsonwebtoken_1.default.sign({ verifier: codeVerifier, redirect: req.query['redirect'], prompt }, env_1.default['SECRET'], {
248
- expiresIn: '5m',
249
- issuer: 'directus',
250
- });
251
- res.cookie(`openid.${providerName}`, token, {
252
- httpOnly: true,
253
- sameSite: 'lax',
254
- });
255
- return res.redirect(await provider.generateAuthUrl(codeVerifier, prompt));
256
- }), respond_1.respond);
257
- router.post('/callback', express_1.default.urlencoded({ extended: false }), (req, res) => {
258
- res.redirect(303, `./callback?${new URLSearchParams(req.body)}`);
259
- }, respond_1.respond);
260
- router.get('/callback', (0, async_handler_1.default)(async (req, res, next) => {
261
- let tokenData;
262
- try {
263
- tokenData = jsonwebtoken_1.default.verify(req.cookies[`openid.${providerName}`], env_1.default['SECRET'], {
264
- issuer: 'directus',
265
- });
266
- }
267
- catch (e) {
268
- logger_1.default.warn(e, `[OpenID] Couldn't verify OpenID cookie`);
269
- throw new exceptions_2.InvalidCredentialsException();
270
- }
271
- const { verifier, redirect, prompt } = tokenData;
272
- const accountability = {
273
- ip: (0, get_ip_from_req_1.getIPFromReq)(req),
274
- role: null,
275
- };
276
- const userAgent = req.get('user-agent');
277
- if (userAgent)
278
- accountability.userAgent = userAgent;
279
- const origin = req.get('origin');
280
- if (origin)
281
- accountability.origin = origin;
282
- const authenticationService = new services_1.AuthenticationService({
283
- accountability,
284
- schema: req.schema,
285
- });
286
- let authResponse;
287
- try {
288
- res.clearCookie(`openid.${providerName}`);
289
- authResponse = await authenticationService.login(providerName, {
290
- code: req.query['code'],
291
- codeVerifier: verifier,
292
- state: req.query['state'],
293
- });
294
- }
295
- catch (error) {
296
- // Prompt user for a new refresh_token if invalidated
297
- if (error instanceof exceptions_2.InvalidTokenException && !prompt) {
298
- return res.redirect(`./?${redirect ? `redirect=${redirect}&` : ''}prompt=true`);
299
- }
300
- logger_1.default.warn(error);
301
- if (redirect) {
302
- let reason = 'UNKNOWN_EXCEPTION';
303
- if (error instanceof exceptions_1.BaseException) {
304
- reason = error.code;
305
- }
306
- else {
307
- logger_1.default.warn(error, `[OpenID] Unexpected error during OpenID login`);
308
- }
309
- return res.redirect(`${redirect.split('?')[0]}?reason=${reason}`);
310
- }
311
- logger_1.default.warn(error, `[OpenID] Unexpected error during OpenID login`);
312
- throw error;
313
- }
314
- const { accessToken, refreshToken, expires } = authResponse;
315
- if (redirect) {
316
- res.cookie(env_1.default['REFRESH_TOKEN_COOKIE_NAME'], refreshToken, {
317
- httpOnly: true,
318
- domain: env_1.default['REFRESH_TOKEN_COOKIE_DOMAIN'],
319
- maxAge: (0, get_milliseconds_1.getMilliseconds)(env_1.default['REFRESH_TOKEN_TTL']),
320
- secure: env_1.default['REFRESH_TOKEN_COOKIE_SECURE'] ?? false,
321
- sameSite: env_1.default['REFRESH_TOKEN_COOKIE_SAME_SITE'] || 'strict',
322
- });
323
- return res.redirect(redirect);
324
- }
325
- res.locals['payload'] = {
326
- data: { access_token: accessToken, refresh_token: refreshToken, expires },
327
- };
328
- next();
329
- }), respond_1.respond);
330
- return router;
331
- }
332
- exports.createOpenIDAuthRouter = createOpenIDAuthRouter;
@@ -1,14 +0,0 @@
1
- import { UsersService } from '../../services';
2
- import type { AuthDriverOptions, User } from '../../types';
3
- import { LocalAuthDriver } from './local';
4
- export declare class SAMLAuthDriver extends LocalAuthDriver {
5
- idp: any;
6
- sp: any;
7
- usersService: UsersService;
8
- config: Record<string, any>;
9
- constructor(options: AuthDriverOptions, config: Record<string, any>);
10
- fetchUserID(identifier: string): Promise<any>;
11
- getUserID(payload: Record<string, any>): Promise<any>;
12
- login(_user: User): Promise<void>;
13
- }
14
- export declare function createSAMLAuthRouter(providerName: string): import("express-serve-static-core").Router;