mage-ai 0.9.45__py3-none-any.whl → 0.9.47__py3-none-any.whl

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 (566) hide show
  1. mage_ai/api/constants.py +2 -0
  2. mage_ai/api/operations/base.py +230 -12
  3. mage_ai/api/policies/BasePolicy.py +3 -3
  4. mage_ai/api/policies/ComputeClusterPolicy.py +96 -0
  5. mage_ai/api/policies/ComputeConnectionPolicy.py +74 -0
  6. mage_ai/api/policies/ComputeServicePolicy.py +50 -0
  7. mage_ai/api/policies/DownloadPolicy.py +29 -0
  8. mage_ai/api/policies/GlobalHookPolicy.py +126 -0
  9. mage_ai/api/policies/IntegrationSourcePolicy.py +62 -0
  10. mage_ai/api/policies/OauthPolicy.py +56 -4
  11. mage_ai/api/policies/ProjectPolicy.py +1 -0
  12. mage_ai/api/presenters/ComputeClusterPresenter.py +19 -0
  13. mage_ai/api/presenters/ComputeConnectionPresenter.py +26 -0
  14. mage_ai/api/presenters/ComputeServicePresenter.py +15 -0
  15. mage_ai/api/presenters/DownloadPresenter.py +13 -0
  16. mage_ai/api/presenters/GlobalHookPresenter.py +74 -0
  17. mage_ai/api/presenters/IntegrationSourcePresenter.py +9 -2
  18. mage_ai/api/presenters/PipelinePresenter.py +3 -0
  19. mage_ai/api/presenters/PipelineRunPresenter.py +8 -3
  20. mage_ai/api/presenters/PipelineSchedulePresenter.py +22 -1
  21. mage_ai/api/presenters/ProjectPresenter.py +1 -0
  22. mage_ai/api/presenters/SparkApplicationPresenter.py +2 -0
  23. mage_ai/api/presenters/WorkspacePresenter.py +22 -22
  24. mage_ai/api/resources/AsyncBaseResource.py +39 -0
  25. mage_ai/api/resources/BlockResource.py +5 -0
  26. mage_ai/api/resources/ClusterResource.py +1 -1
  27. mage_ai/api/resources/ComputeClusterResource.py +109 -0
  28. mage_ai/api/resources/ComputeConnectionResource.py +103 -0
  29. mage_ai/api/resources/ComputeServiceResource.py +35 -0
  30. mage_ai/api/resources/DataProviderResource.py +2 -0
  31. mage_ai/api/resources/DownloadResource.py +56 -0
  32. mage_ai/api/resources/ExecutionStateResource.py +1 -1
  33. mage_ai/api/resources/GlobalHookResource.py +192 -0
  34. mage_ai/api/resources/IntegrationSourceResource.py +149 -2
  35. mage_ai/api/resources/KernelResource.py +10 -0
  36. mage_ai/api/resources/OauthResource.py +28 -33
  37. mage_ai/api/resources/PipelineResource.py +4 -4
  38. mage_ai/api/resources/PipelineScheduleResource.py +37 -16
  39. mage_ai/api/resources/ProjectResource.py +5 -3
  40. mage_ai/api/resources/SessionResource.py +0 -9
  41. mage_ai/api/resources/SparkApplicationResource.py +5 -5
  42. mage_ai/api/resources/SparkEnvironmentResource.py +1 -2
  43. mage_ai/api/resources/SparkExecutorResource.py +1 -2
  44. mage_ai/api/resources/SparkJobResource.py +3 -6
  45. mage_ai/api/resources/SparkSqlResource.py +6 -11
  46. mage_ai/api/resources/SparkStageAttemptResource.py +2 -3
  47. mage_ai/api/resources/SparkStageAttemptTaskResource.py +1 -2
  48. mage_ai/api/resources/SparkStageAttemptTaskSummaryResource.py +1 -2
  49. mage_ai/api/resources/SparkStageResource.py +3 -6
  50. mage_ai/api/resources/SparkThreadResource.py +1 -2
  51. mage_ai/api/resources/mixins/spark.py +25 -4
  52. mage_ai/authentication/oauth2.py +1 -3
  53. mage_ai/authentication/permissions/constants.py +4 -0
  54. mage_ai/authentication/providers/active_directory.py +136 -0
  55. mage_ai/authentication/providers/constants.py +3 -0
  56. mage_ai/authentication/providers/ghe.py +24 -25
  57. mage_ai/authentication/providers/google.py +25 -26
  58. mage_ai/authentication/providers/oauth.py +2 -2
  59. mage_ai/authentication/providers/okta.py +28 -29
  60. mage_ai/authentication/providers/sso.py +2 -2
  61. mage_ai/cluster_manager/aws/emr_cluster_manager.py +2 -1
  62. mage_ai/cluster_manager/workspace/base.py +7 -3
  63. mage_ai/data_integrations/destinations/constants.py +1 -0
  64. mage_ai/data_integrations/sources/constants.py +5 -0
  65. mage_ai/data_integrations/utils/scheduler.py +57 -2
  66. mage_ai/data_preparation/executors/block_executor.py +9 -1
  67. mage_ai/data_preparation/executors/pipeline_executor.py +9 -0
  68. mage_ai/data_preparation/models/block/__init__.py +82 -17
  69. mage_ai/data_preparation/models/block/data_integration/constants.py +3 -0
  70. mage_ai/data_preparation/models/block/data_integration/data.py +1 -1
  71. mage_ai/data_preparation/models/block/data_integration/utils.py +196 -37
  72. mage_ai/data_preparation/models/block/spark/mixins.py +82 -34
  73. mage_ai/data_preparation/models/block/sql/utils/shared.py +18 -1
  74. mage_ai/data_preparation/models/block/utils.py +28 -13
  75. mage_ai/data_preparation/models/download/__init__.py +8 -0
  76. mage_ai/data_preparation/models/global_hooks/__init__.py +0 -0
  77. mage_ai/data_preparation/models/global_hooks/constants.py +93 -0
  78. mage_ai/data_preparation/models/global_hooks/models.py +992 -0
  79. mage_ai/data_preparation/models/global_hooks/predicates.py +316 -0
  80. mage_ai/data_preparation/models/global_hooks/utils.py +21 -0
  81. mage_ai/data_preparation/models/pipeline.py +84 -6
  82. mage_ai/data_preparation/models/pipelines/integration_pipeline.py +0 -1
  83. mage_ai/data_preparation/models/pipelines/models.py +16 -0
  84. mage_ai/data_preparation/models/project/__init__.py +6 -0
  85. mage_ai/data_preparation/models/project/constants.py +1 -0
  86. mage_ai/data_preparation/models/project/models.py +12 -0
  87. mage_ai/data_preparation/preferences.py +29 -18
  88. mage_ai/data_preparation/repo_manager.py +35 -3
  89. mage_ai/data_preparation/sync/__init__.py +2 -0
  90. mage_ai/data_preparation/templates/constants.py +14 -0
  91. mage_ai/data_preparation/templates/data_exporters/chroma.py +24 -0
  92. mage_ai/data_preparation/templates/data_exporters/streaming/rabbitmq.yaml +7 -0
  93. mage_ai/data_preparation/templates/data_loaders/chroma.py +27 -0
  94. mage_ai/data_preparation/templates/data_loaders/streaming/activemq.yaml +6 -0
  95. mage_ai/data_preparation/templates/data_loaders/streaming/nats.yaml +20 -0
  96. mage_ai/data_preparation/templates/repo/io_config.yaml +3 -0
  97. mage_ai/io/base.py +1 -0
  98. mage_ai/io/chroma.py +153 -0
  99. mage_ai/io/config.py +8 -0
  100. mage_ai/orchestration/db/models/schedules.py +100 -36
  101. mage_ai/orchestration/pipeline_scheduler.py +58 -19
  102. mage_ai/orchestration/queue/process_queue.py +9 -1
  103. mage_ai/orchestration/triggers/api.py +11 -3
  104. mage_ai/orchestration/triggers/constants.py +1 -0
  105. mage_ai/server/active_kernel.py +37 -4
  106. mage_ai/server/api/downloads.py +76 -1
  107. mage_ai/server/constants.py +1 -1
  108. mage_ai/server/frontend_dist/404.html +2 -2
  109. mage_ai/server/frontend_dist/_next/static/N3FS4bHv0jpYeeg672uYK/_buildManifest.js +1 -0
  110. mage_ai/server/frontend_dist/_next/static/chunks/1749-bf512b4dabbab7fa.js +1 -0
  111. mage_ai/server/frontend_dist/_next/static/chunks/{7519-8c29bbb92e03cc77.js → 1845-5ce774d5ab81ed57.js} +1 -1
  112. mage_ai/server/frontend_dist/_next/static/chunks/1952-57858e7445d24413.js +1 -0
  113. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/2714-1e79e9f2e998b544.js → frontend_dist/_next/static/chunks/2714-68fef54789d7eaeb.js} +1 -1
  114. mage_ai/server/frontend_dist/_next/static/chunks/2717-92cdffd87b6f6e05.js +1 -0
  115. mage_ai/server/frontend_dist/_next/static/chunks/3419-715ca383fa15a5ef.js +1 -0
  116. mage_ai/server/frontend_dist/_next/static/chunks/3437-b4d6a037cf5781f8.js +1 -0
  117. mage_ai/server/frontend_dist/_next/static/chunks/3943-c9fb980f03df6450.js +1 -0
  118. mage_ai/server/frontend_dist/_next/static/chunks/4267-cb102e060a43d9bd.js +1 -0
  119. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/3932-0ceca9599d6e6d00.js → frontend_dist/_next/static/chunks/4366-3e52497942acbafe.js} +1 -1
  120. mage_ai/server/frontend_dist/_next/static/chunks/{4783-1a21d9be47574bba.js → 4783-422429203610c318.js} +1 -1
  121. mage_ai/server/frontend_dist/_next/static/chunks/5457-949640f4037bf12f.js +1 -0
  122. mage_ai/server/frontend_dist/_next/static/chunks/5499-76cf8f023c6b0985.js +1 -0
  123. mage_ai/server/frontend_dist/_next/static/chunks/553-7f7919e14392ca67.js +1 -0
  124. mage_ai/server/frontend_dist/_next/static/chunks/5638-a65610405a70961c.js +1 -0
  125. mage_ai/server/frontend_dist/_next/static/chunks/5810-e26a0768db1cfdba.js +1 -0
  126. mage_ai/server/frontend_dist/_next/static/chunks/5820-28adeabb5cda2b96.js +1 -0
  127. mage_ai/server/frontend_dist/_next/static/chunks/{5896-14e5a23b1c6a0769.js → 5896-7b8e36634d7d94eb.js} +1 -1
  128. mage_ai/server/frontend_dist/_next/static/chunks/600-705fe234320ec5de.js +1 -0
  129. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/3122-f27de34d0b5426af.js → frontend_dist/_next/static/chunks/6285-648f9a732e100b2f.js} +1 -1
  130. mage_ai/server/frontend_dist/_next/static/chunks/6798-b904395b0c18647b.js +1 -0
  131. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/5397-b5f2e477acc6bd6b.js → frontend_dist/_next/static/chunks/6965-c613d1834c8ed92d.js} +1 -1
  132. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/7022-18fde36eb46e1d65.js → frontend_dist/_next/static/chunks/7022-e76cae3ba5ee5312.js} +1 -1
  133. mage_ai/server/frontend_dist/_next/static/chunks/722-900f786d24f91b2e.js +1 -0
  134. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/7361-694e1e4fb9c97d68.js → frontend_dist/_next/static/chunks/7361-6c5c9063b9f91700.js} +1 -1
  135. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/7858-c83d25349d0e980f.js → frontend_dist/_next/static/chunks/7858-d9df72e95e438284.js} +1 -1
  136. mage_ai/server/frontend_dist/_next/static/chunks/{8146-92e7ccfed169ee9c.js → 8146-27f0e31f309897a5.js} +1 -1
  137. mage_ai/server/frontend_dist/_next/static/chunks/8264-0d582a6ca33c3dfa.js +1 -0
  138. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/3684-cbda680fd8927d07.js → frontend_dist/_next/static/chunks/8432-f191e39f9b5893f2.js} +1 -1
  139. mage_ai/server/frontend_dist/_next/static/chunks/845-9a73c65fe3fdc328.js +1 -0
  140. mage_ai/server/frontend_dist/_next/static/chunks/8487-8e1c09546dff4dbf.js +1 -0
  141. mage_ai/server/frontend_dist/_next/static/chunks/90-a7308bae028d7001.js +1 -0
  142. mage_ai/server/frontend_dist/_next/static/chunks/9264-cc44b07f248707b0.js +1 -0
  143. mage_ai/server/frontend_dist/_next/static/chunks/9618-4eb49cdbd1ba11d7.js +1 -0
  144. mage_ai/server/frontend_dist/_next/static/chunks/{976-18c98af60b76f1a7.js → 976-0a8c2c4d7acd957b.js} +1 -1
  145. mage_ai/server/frontend_dist/_next/static/chunks/framework-22b71764bf44ede4.js +1 -0
  146. mage_ai/server/frontend_dist/_next/static/chunks/pages/_app-78c4a077a2f279c2.js +1 -0
  147. mage_ai/server/frontend_dist/_next/static/chunks/pages/block-layout-a24cb24b6f08bbc9.js +1 -0
  148. mage_ai/server/frontend_dist/_next/static/chunks/pages/compute-419775ca1293b354.js +1 -0
  149. mage_ai/server/frontend_dist/_next/static/chunks/pages/files-b37d221eb5ddc248.js +1 -0
  150. mage_ai/server/frontend_dist/_next/static/chunks/pages/global-data-products/{[...slug]-3f6fc312f67ff72e.js → [...slug]-cfd68e760ae00958.js} +1 -1
  151. mage_ai/server/frontend_dist/_next/static/chunks/pages/{global-data-products-f4cd03036c3e8723.js → global-data-products-c3b79ef31007f95b.js} +1 -1
  152. mage_ai/server/frontend_dist/_next/static/chunks/pages/global-hooks/[...slug]-7adc543fc490367a.js +1 -0
  153. mage_ai/server/frontend_dist/_next/static/chunks/pages/global-hooks-51d366993f6dd449.js +1 -0
  154. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/files-fe6e73463a20d67c.js +1 -0
  155. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/settings-60845f0b59142f32.js +1 -0
  156. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/pages/manage/users/[user]-1d9b298fdceabbf1.js → frontend_dist/_next/static/chunks/pages/manage/users/[user]-9384c5f1efa2ac18.js} +1 -1
  157. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/users/new-abd8571907664fdf.js +1 -0
  158. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/{users-a7c970122a10afdc.js → users-28a930b148d99766.js} +1 -1
  159. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage-d8a38b5d1f50e798.js +1 -0
  160. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/pages/overview-a4647a274cf4dffa.js → frontend_dist/_next/static/chunks/pages/overview-f0c40645f385f23f.js} +1 -1
  161. mage_ai/server/frontend_dist/_next/static/chunks/pages/{pipeline-runs-c79819d6826e5416.js → pipeline-runs-b35d37bfba8fbccc.js} +1 -1
  162. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-9adc2974aada27ba.js +1 -0
  163. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills-51b1311dff2a974e.js +1 -0
  164. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/dashboard-571c0962333b92f0.js +1 -0
  165. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/edit-2333e524d34b474a.js +1 -0
  166. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/{logs-a52d2d3e0c2978f4.js → logs-ef680455ae54ccbe.js} +1 -1
  167. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runs-ddddcddd2f74b4f6.js +1 -0
  168. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runtime-4a238307feddb522.js +1 -0
  169. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors-6d1afeb4a84f50f7.js +1 -0
  170. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-1ff9bb8e22ca1e75.js +1 -0
  171. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/runs-ce717786f31e8f04.js → frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/runs-2d20b2cd08907afd.js} +1 -1
  172. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/settings-11363aa58d51f4e1.js +1 -0
  173. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/syncs-b75bf17498e87354.js +1 -0
  174. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-779c3ef0676a12ac.js +1 -0
  175. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers-bbea9a088657404a.js +1 -0
  176. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/{[pipeline]-35fe7762cb83a733.js → [pipeline]-02c843b9c8418bb5.js} +1 -1
  177. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines-3737f2b0afc2ede3.js +1 -0
  178. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/account/profile-3c8f062913c66f3e.js +1 -0
  179. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/permissions/{[...slug]-d6a62284c7c99cb3.js → [...slug]-b78b1be5b9ed84b9.js} +1 -1
  180. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/{permissions-b1389695f758c32b.js → permissions-37b78a436eeab258.js} +1 -1
  181. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/preferences-c1f4ed17d501ccca.js +1 -0
  182. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/roles/{[...slug]-0bdb66265286ab22.js → [...slug]-db05a80d18c168e5.js} +1 -1
  183. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/{roles-e04e18fc295ca76a.js → roles-f55c77e4f46c8d33.js} +1 -1
  184. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/sync-data-2a1f8737561fdd94.js +1 -0
  185. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/users/{[...slug]-0267358c91122109.js → [...slug]-e3bf6e5d8bb250c4.js} +1 -1
  186. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/{users-50fed18bb9b8d142.js → users-20f0a050a42a015d.js} +1 -1
  187. mage_ai/server/frontend_dist/_next/static/chunks/pages/{settings-56f83205752b1323.js → settings-0f0121db7f5ff93d.js} +1 -1
  188. mage_ai/server/frontend_dist/_next/static/chunks/pages/sign-in-99e2748e3c1d57a3.js +1 -0
  189. mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/pages/templates/[...slug]-9370551ffa462144.js → frontend_dist/_next/static/chunks/pages/templates/[...slug]-f44ccd1499ffd23a.js} +1 -1
  190. mage_ai/server/frontend_dist/_next/static/chunks/pages/{templates-3cff90df13a1a755.js → templates-1bfaa1c50e844813.js} +1 -1
  191. mage_ai/server/frontend_dist/_next/static/chunks/pages/terminal-ed121e305169cf1c.js +1 -0
  192. mage_ai/server/frontend_dist/_next/static/chunks/pages/test-9ae68758102cc843.js +1 -0
  193. mage_ai/server/frontend_dist/_next/static/chunks/pages/triggers-8bdd858240d5dbf6.js +1 -0
  194. mage_ai/server/frontend_dist/_next/static/chunks/pages/version-control-dd4fb405695f74bf.js +1 -0
  195. mage_ai/server/frontend_dist/_next/static/chunks/{webpack-8af2b89c5a3779fc.js → webpack-fea697dd168c6d0c.js} +1 -1
  196. mage_ai/server/frontend_dist/block-layout.html +2 -2
  197. mage_ai/server/frontend_dist/compute.html +5 -5
  198. mage_ai/server/frontend_dist/files.html +5 -5
  199. mage_ai/server/frontend_dist/global-data-products/[...slug].html +5 -5
  200. mage_ai/server/frontend_dist/global-data-products.html +5 -5
  201. mage_ai/server/frontend_dist/global-hooks/[...slug].html +24 -0
  202. mage_ai/server/frontend_dist/global-hooks.html +24 -0
  203. mage_ai/server/frontend_dist/index.html +2 -2
  204. mage_ai/server/frontend_dist/manage/files.html +5 -5
  205. mage_ai/server/frontend_dist/manage/settings.html +5 -5
  206. mage_ai/server/frontend_dist/manage/users/[user].html +5 -5
  207. mage_ai/server/frontend_dist/manage/users/new.html +5 -5
  208. mage_ai/server/frontend_dist/manage/users.html +5 -5
  209. mage_ai/server/frontend_dist/manage.html +5 -5
  210. mage_ai/server/frontend_dist/oauth.html +4 -4
  211. mage_ai/server/frontend_dist/overview.html +5 -5
  212. mage_ai/server/frontend_dist/pipeline-runs.html +5 -5
  213. mage_ai/server/frontend_dist/pipelines/[pipeline]/backfills/[...slug].html +5 -5
  214. mage_ai/server/frontend_dist/pipelines/[pipeline]/backfills.html +5 -5
  215. mage_ai/server/frontend_dist/pipelines/[pipeline]/dashboard.html +5 -5
  216. mage_ai/server/frontend_dist/pipelines/[pipeline]/edit.html +2 -2
  217. mage_ai/server/frontend_dist/pipelines/[pipeline]/logs.html +5 -5
  218. mage_ai/server/frontend_dist/pipelines/[pipeline]/monitors/block-runs.html +5 -5
  219. mage_ai/server/frontend_dist/pipelines/[pipeline]/monitors/block-runtime.html +5 -5
  220. mage_ai/server/frontend_dist/pipelines/[pipeline]/monitors.html +5 -5
  221. mage_ai/server/frontend_dist/pipelines/[pipeline]/runs/[run].html +5 -5
  222. mage_ai/server/frontend_dist/pipelines/[pipeline]/runs.html +5 -5
  223. mage_ai/server/frontend_dist/pipelines/[pipeline]/settings.html +5 -5
  224. mage_ai/server/frontend_dist/pipelines/[pipeline]/syncs.html +5 -5
  225. mage_ai/server/frontend_dist/pipelines/[pipeline]/triggers/[...slug].html +5 -5
  226. mage_ai/server/frontend_dist/pipelines/[pipeline]/triggers.html +5 -5
  227. mage_ai/server/frontend_dist/pipelines/[pipeline].html +2 -2
  228. mage_ai/server/frontend_dist/pipelines.html +5 -5
  229. mage_ai/server/frontend_dist/settings/account/profile.html +5 -5
  230. mage_ai/server/frontend_dist/settings/workspace/permissions/[...slug].html +5 -5
  231. mage_ai/server/frontend_dist/settings/workspace/permissions.html +5 -5
  232. mage_ai/server/frontend_dist/settings/workspace/preferences.html +5 -5
  233. mage_ai/server/frontend_dist/settings/workspace/roles/[...slug].html +5 -5
  234. mage_ai/server/frontend_dist/settings/workspace/roles.html +5 -5
  235. mage_ai/server/frontend_dist/settings/workspace/sync-data.html +5 -5
  236. mage_ai/server/frontend_dist/settings/workspace/users/[...slug].html +5 -5
  237. mage_ai/server/frontend_dist/settings/workspace/users.html +5 -5
  238. mage_ai/server/frontend_dist/settings.html +2 -2
  239. mage_ai/server/frontend_dist/sign-in.html +24 -25
  240. mage_ai/server/frontend_dist/templates/[...slug].html +5 -5
  241. mage_ai/server/frontend_dist/templates.html +5 -5
  242. mage_ai/server/frontend_dist/terminal.html +5 -5
  243. mage_ai/server/frontend_dist/test.html +15 -15
  244. mage_ai/server/frontend_dist/triggers.html +5 -5
  245. mage_ai/server/frontend_dist/version-control.html +5 -5
  246. mage_ai/server/frontend_dist_base_path_template/404.html +2 -2
  247. mage_ai/server/frontend_dist_base_path_template/_next/static/aoO6jYZLVlUGCCdY-wmy8/_buildManifest.js +1 -0
  248. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/1749-bf512b4dabbab7fa.js +1 -0
  249. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{7519-8c29bbb92e03cc77.js → 1845-5ce774d5ab81ed57.js} +1 -1
  250. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/1952-57858e7445d24413.js +1 -0
  251. mage_ai/server/{frontend_dist/_next/static/chunks/2714-1e79e9f2e998b544.js → frontend_dist_base_path_template/_next/static/chunks/2714-68fef54789d7eaeb.js} +1 -1
  252. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/2717-92cdffd87b6f6e05.js +1 -0
  253. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3419-715ca383fa15a5ef.js +1 -0
  254. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3437-b4d6a037cf5781f8.js +1 -0
  255. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3943-c9fb980f03df6450.js +1 -0
  256. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/4267-cb102e060a43d9bd.js +1 -0
  257. mage_ai/server/{frontend_dist/_next/static/chunks/3932-0ceca9599d6e6d00.js → frontend_dist_base_path_template/_next/static/chunks/4366-3e52497942acbafe.js} +1 -1
  258. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{4783-1a21d9be47574bba.js → 4783-422429203610c318.js} +1 -1
  259. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5457-949640f4037bf12f.js +1 -0
  260. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5499-76cf8f023c6b0985.js +1 -0
  261. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/553-7f7919e14392ca67.js +1 -0
  262. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5638-a65610405a70961c.js +1 -0
  263. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5810-e26a0768db1cfdba.js +1 -0
  264. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5820-28adeabb5cda2b96.js +1 -0
  265. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{5896-14e5a23b1c6a0769.js → 5896-7b8e36634d7d94eb.js} +1 -1
  266. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/600-705fe234320ec5de.js +1 -0
  267. mage_ai/server/{frontend_dist/_next/static/chunks/3122-f27de34d0b5426af.js → frontend_dist_base_path_template/_next/static/chunks/6285-648f9a732e100b2f.js} +1 -1
  268. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/6798-b904395b0c18647b.js +1 -0
  269. mage_ai/server/{frontend_dist/_next/static/chunks/5397-b5f2e477acc6bd6b.js → frontend_dist_base_path_template/_next/static/chunks/6965-c613d1834c8ed92d.js} +1 -1
  270. mage_ai/server/{frontend_dist/_next/static/chunks/7022-18fde36eb46e1d65.js → frontend_dist_base_path_template/_next/static/chunks/7022-e76cae3ba5ee5312.js} +1 -1
  271. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/722-900f786d24f91b2e.js +1 -0
  272. mage_ai/server/{frontend_dist/_next/static/chunks/7361-694e1e4fb9c97d68.js → frontend_dist_base_path_template/_next/static/chunks/7361-6c5c9063b9f91700.js} +1 -1
  273. mage_ai/server/{frontend_dist/_next/static/chunks/7858-c83d25349d0e980f.js → frontend_dist_base_path_template/_next/static/chunks/7858-d9df72e95e438284.js} +1 -1
  274. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{8146-92e7ccfed169ee9c.js → 8146-27f0e31f309897a5.js} +1 -1
  275. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/8264-0d582a6ca33c3dfa.js +1 -0
  276. mage_ai/server/{frontend_dist/_next/static/chunks/3684-cbda680fd8927d07.js → frontend_dist_base_path_template/_next/static/chunks/8432-f191e39f9b5893f2.js} +1 -1
  277. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/845-9a73c65fe3fdc328.js +1 -0
  278. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/8487-8e1c09546dff4dbf.js +1 -0
  279. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/90-a7308bae028d7001.js +1 -0
  280. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/9264-cc44b07f248707b0.js +1 -0
  281. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/9618-4eb49cdbd1ba11d7.js +1 -0
  282. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{976-18c98af60b76f1a7.js → 976-0a8c2c4d7acd957b.js} +1 -1
  283. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/framework-22b71764bf44ede4.js +1 -0
  284. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/_app-78c4a077a2f279c2.js +1 -0
  285. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/block-layout-a24cb24b6f08bbc9.js +1 -0
  286. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/compute-419775ca1293b354.js +1 -0
  287. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/files-b37d221eb5ddc248.js +1 -0
  288. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/global-data-products/{[...slug]-3f6fc312f67ff72e.js → [...slug]-cfd68e760ae00958.js} +1 -1
  289. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/{global-data-products-f4cd03036c3e8723.js → global-data-products-c3b79ef31007f95b.js} +1 -1
  290. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/global-hooks/[...slug]-7adc543fc490367a.js +1 -0
  291. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/global-hooks-51d366993f6dd449.js +1 -0
  292. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/files-fe6e73463a20d67c.js +1 -0
  293. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/settings-60845f0b59142f32.js +1 -0
  294. mage_ai/server/{frontend_dist/_next/static/chunks/pages/manage/users/[user]-1d9b298fdceabbf1.js → frontend_dist_base_path_template/_next/static/chunks/pages/manage/users/[user]-9384c5f1efa2ac18.js} +1 -1
  295. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/users/new-abd8571907664fdf.js +1 -0
  296. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/{users-a7c970122a10afdc.js → users-28a930b148d99766.js} +1 -1
  297. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage-d8a38b5d1f50e798.js +1 -0
  298. mage_ai/server/{frontend_dist/_next/static/chunks/pages/overview-a4647a274cf4dffa.js → frontend_dist_base_path_template/_next/static/chunks/pages/overview-f0c40645f385f23f.js} +1 -1
  299. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/{pipeline-runs-c79819d6826e5416.js → pipeline-runs-b35d37bfba8fbccc.js} +1 -1
  300. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-9adc2974aada27ba.js +1 -0
  301. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills-51b1311dff2a974e.js +1 -0
  302. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/dashboard-571c0962333b92f0.js +1 -0
  303. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/edit-2333e524d34b474a.js +1 -0
  304. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/{logs-a52d2d3e0c2978f4.js → logs-ef680455ae54ccbe.js} +1 -1
  305. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runs-ddddcddd2f74b4f6.js +1 -0
  306. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runtime-4a238307feddb522.js +1 -0
  307. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors-6d1afeb4a84f50f7.js +1 -0
  308. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-1ff9bb8e22ca1e75.js +1 -0
  309. mage_ai/server/{frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/runs-ce717786f31e8f04.js → frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/runs-2d20b2cd08907afd.js} +1 -1
  310. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/settings-11363aa58d51f4e1.js +1 -0
  311. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/syncs-b75bf17498e87354.js +1 -0
  312. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-779c3ef0676a12ac.js +1 -0
  313. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers-bbea9a088657404a.js +1 -0
  314. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/{[pipeline]-35fe7762cb83a733.js → [pipeline]-02c843b9c8418bb5.js} +1 -1
  315. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines-3737f2b0afc2ede3.js +1 -0
  316. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/account/profile-3c8f062913c66f3e.js +1 -0
  317. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/permissions/{[...slug]-d6a62284c7c99cb3.js → [...slug]-b78b1be5b9ed84b9.js} +1 -1
  318. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/{permissions-b1389695f758c32b.js → permissions-37b78a436eeab258.js} +1 -1
  319. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/preferences-c1f4ed17d501ccca.js +1 -0
  320. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/roles/{[...slug]-0bdb66265286ab22.js → [...slug]-db05a80d18c168e5.js} +1 -1
  321. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/{roles-e04e18fc295ca76a.js → roles-f55c77e4f46c8d33.js} +1 -1
  322. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/sync-data-2a1f8737561fdd94.js +1 -0
  323. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/users/{[...slug]-0267358c91122109.js → [...slug]-e3bf6e5d8bb250c4.js} +1 -1
  324. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/{users-50fed18bb9b8d142.js → users-20f0a050a42a015d.js} +1 -1
  325. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/{settings-56f83205752b1323.js → settings-0f0121db7f5ff93d.js} +1 -1
  326. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/sign-in-99e2748e3c1d57a3.js +1 -0
  327. mage_ai/server/{frontend_dist/_next/static/chunks/pages/templates/[...slug]-9370551ffa462144.js → frontend_dist_base_path_template/_next/static/chunks/pages/templates/[...slug]-f44ccd1499ffd23a.js} +1 -1
  328. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/{templates-3cff90df13a1a755.js → templates-1bfaa1c50e844813.js} +1 -1
  329. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/terminal-ed121e305169cf1c.js +1 -0
  330. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/test-9ae68758102cc843.js +1 -0
  331. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/triggers-8bdd858240d5dbf6.js +1 -0
  332. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/version-control-dd4fb405695f74bf.js +1 -0
  333. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{webpack-074f3eb2281fba79.js → webpack-d30cb09c85b4c4f0.js} +1 -1
  334. mage_ai/server/frontend_dist_base_path_template/block-layout.html +2 -2
  335. mage_ai/server/frontend_dist_base_path_template/compute.html +5 -5
  336. mage_ai/server/frontend_dist_base_path_template/files.html +5 -5
  337. mage_ai/server/frontend_dist_base_path_template/global-data-products/[...slug].html +5 -5
  338. mage_ai/server/frontend_dist_base_path_template/global-data-products.html +5 -5
  339. mage_ai/server/frontend_dist_base_path_template/global-hooks/[...slug].html +24 -0
  340. mage_ai/server/frontend_dist_base_path_template/global-hooks.html +24 -0
  341. mage_ai/server/frontend_dist_base_path_template/index.html +2 -2
  342. mage_ai/server/frontend_dist_base_path_template/manage/files.html +5 -5
  343. mage_ai/server/frontend_dist_base_path_template/manage/settings.html +5 -5
  344. mage_ai/server/frontend_dist_base_path_template/manage/users/[user].html +5 -5
  345. mage_ai/server/frontend_dist_base_path_template/manage/users/new.html +5 -5
  346. mage_ai/server/frontend_dist_base_path_template/manage/users.html +5 -5
  347. mage_ai/server/frontend_dist_base_path_template/manage.html +5 -5
  348. mage_ai/server/frontend_dist_base_path_template/oauth.html +4 -4
  349. mage_ai/server/frontend_dist_base_path_template/overview.html +5 -5
  350. mage_ai/server/frontend_dist_base_path_template/pipeline-runs.html +5 -5
  351. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/backfills/[...slug].html +5 -5
  352. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/backfills.html +5 -5
  353. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/dashboard.html +5 -5
  354. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/edit.html +2 -2
  355. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/logs.html +5 -5
  356. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/monitors/block-runs.html +5 -5
  357. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/monitors/block-runtime.html +5 -5
  358. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/monitors.html +5 -5
  359. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/runs/[run].html +5 -5
  360. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/runs.html +5 -5
  361. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/settings.html +5 -5
  362. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/syncs.html +5 -5
  363. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/triggers/[...slug].html +5 -5
  364. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/triggers.html +5 -5
  365. mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline].html +2 -2
  366. mage_ai/server/frontend_dist_base_path_template/pipelines.html +5 -5
  367. mage_ai/server/frontend_dist_base_path_template/settings/account/profile.html +5 -5
  368. mage_ai/server/frontend_dist_base_path_template/settings/workspace/permissions/[...slug].html +5 -5
  369. mage_ai/server/frontend_dist_base_path_template/settings/workspace/permissions.html +5 -5
  370. mage_ai/server/frontend_dist_base_path_template/settings/workspace/preferences.html +5 -5
  371. mage_ai/server/frontend_dist_base_path_template/settings/workspace/roles/[...slug].html +5 -5
  372. mage_ai/server/frontend_dist_base_path_template/settings/workspace/roles.html +5 -5
  373. mage_ai/server/frontend_dist_base_path_template/settings/workspace/sync-data.html +5 -5
  374. mage_ai/server/frontend_dist_base_path_template/settings/workspace/users/[...slug].html +5 -5
  375. mage_ai/server/frontend_dist_base_path_template/settings/workspace/users.html +5 -5
  376. mage_ai/server/frontend_dist_base_path_template/settings.html +2 -2
  377. mage_ai/server/frontend_dist_base_path_template/sign-in.html +28 -29
  378. mage_ai/server/frontend_dist_base_path_template/templates/[...slug].html +5 -5
  379. mage_ai/server/frontend_dist_base_path_template/templates.html +5 -5
  380. mage_ai/server/frontend_dist_base_path_template/terminal.html +5 -5
  381. mage_ai/server/frontend_dist_base_path_template/test.html +15 -15
  382. mage_ai/server/frontend_dist_base_path_template/triggers.html +5 -5
  383. mage_ai/server/frontend_dist_base_path_template/version-control.html +5 -5
  384. mage_ai/server/server.py +44 -12
  385. mage_ai/server/utils/output_display.py +6 -0
  386. mage_ai/server/websocket_server.py +14 -0
  387. mage_ai/services/aws/emr/config.py +1 -0
  388. mage_ai/services/aws/emr/constants.py +1 -0
  389. mage_ai/services/aws/emr/emr.py +20 -7
  390. mage_ai/services/compute/__init__.py +0 -0
  391. mage_ai/services/compute/aws/__init__.py +0 -0
  392. mage_ai/services/compute/aws/constants.py +21 -0
  393. mage_ai/services/compute/aws/models.py +459 -0
  394. mage_ai/services/compute/aws/steps.py +482 -0
  395. mage_ai/services/compute/constants.py +27 -0
  396. mage_ai/services/compute/models.py +212 -0
  397. mage_ai/services/k8s/job_manager.py +4 -0
  398. mage_ai/services/spark/api/aws_emr.py +38 -0
  399. mage_ai/services/spark/api/base.py +7 -4
  400. mage_ai/services/spark/api/constants.py +4 -0
  401. mage_ai/services/spark/api/local.py +25 -24
  402. mage_ai/services/spark/api/service.py +15 -5
  403. mage_ai/services/spark/constants.py +1 -1
  404. mage_ai/services/spark/models/applications.py +45 -3
  405. mage_ai/services/spark/models/base.py +3 -19
  406. mage_ai/services/spark/models/environments.py +16 -11
  407. mage_ai/services/spark/models/executors.py +2 -2
  408. mage_ai/services/spark/models/sqls.py +46 -15
  409. mage_ai/services/spark/models/stages.py +55 -32
  410. mage_ai/services/spark/models/threads.py +2 -2
  411. mage_ai/services/spark/utils.py +22 -6
  412. mage_ai/services/ssh/__init__.py +0 -0
  413. mage_ai/services/ssh/aws/__init__.py +0 -0
  414. mage_ai/services/ssh/aws/emr/__init__.py +0 -0
  415. mage_ai/services/ssh/aws/emr/constants.py +10 -0
  416. mage_ai/services/ssh/aws/emr/models.py +326 -0
  417. mage_ai/services/ssh/aws/emr/utils.py +151 -0
  418. mage_ai/settings/__init__.py +8 -1
  419. mage_ai/settings/repo.py +3 -0
  420. mage_ai/settings/secret_generation.py +7 -0
  421. mage_ai/settings/sso.py +8 -0
  422. mage_ai/shared/files.py +47 -0
  423. mage_ai/shared/hash.py +16 -0
  424. mage_ai/shared/models.py +254 -0
  425. mage_ai/streaming/constants.py +3 -0
  426. mage_ai/streaming/sinks/postgres.py +2 -0
  427. mage_ai/streaming/sinks/rabbitmq.py +76 -0
  428. mage_ai/streaming/sinks/sink_factory.py +4 -0
  429. mage_ai/streaming/sources/activemq.py +89 -0
  430. mage_ai/streaming/sources/nats_js.py +182 -0
  431. mage_ai/streaming/sources/source_factory.py +8 -0
  432. mage_ai/tests/ai/test_ai_functions.py +53 -8
  433. mage_ai/tests/api/endpoints/test_oauths.py +33 -0
  434. mage_ai/tests/api/endpoints/test_projects.py +1 -0
  435. mage_ai/tests/api/endpoints/test_workspaces.py +55 -0
  436. mage_ai/tests/api/operations/test_base.py +7 -5
  437. mage_ai/tests/api/operations/test_operations.py +0 -1
  438. mage_ai/tests/api/operations/test_operations_with_hooks.py +622 -0
  439. mage_ai/tests/api/operations/test_syncs.py +0 -1
  440. mage_ai/tests/api/operations/test_users.py +13 -2
  441. mage_ai/tests/api/policies/test_oauth_policy.py +38 -0
  442. mage_ai/tests/data_preparation/models/global_hooks/__init__.py +0 -0
  443. mage_ai/tests/data_preparation/models/global_hooks/test_global_hooks.py +600 -0
  444. mage_ai/tests/data_preparation/models/global_hooks/test_hook.py +804 -0
  445. mage_ai/tests/data_preparation/models/global_hooks/test_predicates.py +803 -0
  446. mage_ai/tests/data_preparation/models/global_hooks/test_utils.py +38 -0
  447. mage_ai/tests/data_preparation/models/test_block.py +26 -0
  448. mage_ai/tests/data_preparation/models/test_pipeline.py +15 -0
  449. mage_ai/tests/data_preparation/test_repo_manager.py +11 -0
  450. mage_ai/tests/factory.py +105 -5
  451. mage_ai/tests/orchestration/queue/test_process_queue.py +15 -2
  452. mage_ai/tests/orchestration/test_pipeline_scheduler.py +82 -1
  453. mage_ai/tests/services/k8s/test_job_manager.py +38 -1
  454. mage_ai/tests/shared/mixins.py +328 -0
  455. mage_ai/tests/shared/test_hash.py +17 -1
  456. mage_ai/tests/streaming/sinks/test_rabbitmq.py +36 -0
  457. mage_ai/tests/streaming/sources/test_activemq.py +32 -0
  458. mage_ai/tests/streaming/sources/test_nats_js.py +32 -0
  459. mage_ai/tests/streaming/sources/test_source_factory.py +26 -1
  460. {mage_ai-0.9.45.dist-info → mage_ai-0.9.47.dist-info}/METADATA +14 -4
  461. {mage_ai-0.9.45.dist-info → mage_ai-0.9.47.dist-info}/RECORD +467 -386
  462. {mage_ai-0.9.45.dist-info → mage_ai-0.9.47.dist-info}/WHEEL +1 -1
  463. mage_ai/authentication/oauth/active_directory.py +0 -17
  464. mage_ai/server/frontend_dist/_next/static/chunks/1125-91d3ce33140ef041.js +0 -1
  465. mage_ai/server/frontend_dist/_next/static/chunks/1749-607014ecf28268bf.js +0 -1
  466. mage_ai/server/frontend_dist/_next/static/chunks/1952-573c7fc7ad84da6e.js +0 -1
  467. mage_ai/server/frontend_dist/_next/static/chunks/3004-231cad9039ae5dcb.js +0 -1
  468. mage_ai/server/frontend_dist/_next/static/chunks/3419-0873e170ef7d6303.js +0 -1
  469. mage_ai/server/frontend_dist/_next/static/chunks/3943-9e1105393a3be0de.js +0 -1
  470. mage_ai/server/frontend_dist/_next/static/chunks/4267-335766a915ee2fa9.js +0 -1
  471. mage_ai/server/frontend_dist/_next/static/chunks/5457-8be2e0a3fe0ba64b.js +0 -1
  472. mage_ai/server/frontend_dist/_next/static/chunks/5499-bca977f466e259e1.js +0 -1
  473. mage_ai/server/frontend_dist/_next/static/chunks/553-edf533e634e85192.js +0 -1
  474. mage_ai/server/frontend_dist/_next/static/chunks/5810-37c6091b29a1fe53.js +0 -1
  475. mage_ai/server/frontend_dist/_next/static/chunks/600-0733eb84f0a0a9e0.js +0 -1
  476. mage_ai/server/frontend_dist/_next/static/chunks/6333-95ad799d13326dce.js +0 -1
  477. mage_ai/server/frontend_dist/_next/static/chunks/722-2a171fe616310f60.js +0 -1
  478. mage_ai/server/frontend_dist/_next/static/chunks/8224-39a93ee1058b6069.js +0 -1
  479. mage_ai/server/frontend_dist/_next/static/chunks/8264-6ef8fdb195694807.js +0 -1
  480. mage_ai/server/frontend_dist/_next/static/chunks/8487-032ef9b17d20aad9.js +0 -1
  481. mage_ai/server/frontend_dist/_next/static/chunks/9264-1b5c4b071ed544c3.js +0 -1
  482. mage_ai/server/frontend_dist/_next/static/chunks/framework-7c365855dab1bf41.js +0 -1
  483. mage_ai/server/frontend_dist/_next/static/chunks/pages/_app-1203afde83fa2d6e.js +0 -1
  484. mage_ai/server/frontend_dist/_next/static/chunks/pages/block-layout-c465c14d48392b11.js +0 -1
  485. mage_ai/server/frontend_dist/_next/static/chunks/pages/compute-b1f8d5a7a9a30f2d.js +0 -1
  486. mage_ai/server/frontend_dist/_next/static/chunks/pages/files-93c094bad0f299fb.js +0 -1
  487. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/files-891e5bd5935f7473.js +0 -1
  488. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/settings-d2e4ee4e68d36807.js +0 -1
  489. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/users/new-4a49126fcfe8ced0.js +0 -1
  490. mage_ai/server/frontend_dist/_next/static/chunks/pages/manage-5f8c5d0bc6ad1113.js +0 -1
  491. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-b4c0a36c69c346a4.js +0 -1
  492. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills-a9266d353f288e8c.js +0 -1
  493. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/dashboard-b5c29c852262312e.js +0 -1
  494. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/edit-9f233917aa72ad82.js +0 -1
  495. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runs-5af599da035252a7.js +0 -1
  496. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runtime-8597f8e13d80ee48.js +0 -1
  497. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors-5e0d047a6c9cb1fc.js +0 -1
  498. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-b0a508aa52914dad.js +0 -1
  499. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/settings-074c32397d341de9.js +0 -1
  500. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/syncs-50f5d8706ed0bc73.js +0 -1
  501. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-e151c1552fcb67bd.js +0 -1
  502. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers-95394769a783c6c7.js +0 -1
  503. mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines-8336c4326f1e7d96.js +0 -1
  504. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/account/profile-01dd679e4a21e0d9.js +0 -1
  505. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/preferences-4d9051c073a9b2ff.js +0 -1
  506. mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/sync-data-5a306deca6717862.js +0 -1
  507. mage_ai/server/frontend_dist/_next/static/chunks/pages/sign-in-0dbc5b11019e78a0.js +0 -1
  508. mage_ai/server/frontend_dist/_next/static/chunks/pages/terminal-578d862f3e56e6e6.js +0 -1
  509. mage_ai/server/frontend_dist/_next/static/chunks/pages/test-1c0588d685b909b9.js +0 -1
  510. mage_ai/server/frontend_dist/_next/static/chunks/pages/triggers-ffaab4c013e62ba1.js +0 -1
  511. mage_ai/server/frontend_dist/_next/static/chunks/pages/version-control-114000e84313994f.js +0 -1
  512. mage_ai/server/frontend_dist/_next/static/icIDjCezcfhiKL87kgeSY/_buildManifest.js +0 -1
  513. mage_ai/server/frontend_dist_base_path_template/_next/static/_O1kJQLGtZmoBMyWpQrea/_buildManifest.js +0 -1
  514. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/1125-91d3ce33140ef041.js +0 -1
  515. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/1749-607014ecf28268bf.js +0 -1
  516. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/1952-573c7fc7ad84da6e.js +0 -1
  517. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3004-231cad9039ae5dcb.js +0 -1
  518. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3419-0873e170ef7d6303.js +0 -1
  519. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3943-9e1105393a3be0de.js +0 -1
  520. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/4267-335766a915ee2fa9.js +0 -1
  521. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5457-8be2e0a3fe0ba64b.js +0 -1
  522. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5499-bca977f466e259e1.js +0 -1
  523. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/553-edf533e634e85192.js +0 -1
  524. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5810-37c6091b29a1fe53.js +0 -1
  525. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/600-0733eb84f0a0a9e0.js +0 -1
  526. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/6333-95ad799d13326dce.js +0 -1
  527. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/722-2a171fe616310f60.js +0 -1
  528. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/8224-39a93ee1058b6069.js +0 -1
  529. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/8264-6ef8fdb195694807.js +0 -1
  530. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/8487-032ef9b17d20aad9.js +0 -1
  531. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/9264-1b5c4b071ed544c3.js +0 -1
  532. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/framework-7c365855dab1bf41.js +0 -1
  533. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/_app-1203afde83fa2d6e.js +0 -1
  534. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/block-layout-c465c14d48392b11.js +0 -1
  535. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/compute-b1f8d5a7a9a30f2d.js +0 -1
  536. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/files-93c094bad0f299fb.js +0 -1
  537. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/files-891e5bd5935f7473.js +0 -1
  538. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/settings-d2e4ee4e68d36807.js +0 -1
  539. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/users/new-4a49126fcfe8ced0.js +0 -1
  540. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage-5f8c5d0bc6ad1113.js +0 -1
  541. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-b4c0a36c69c346a4.js +0 -1
  542. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills-a9266d353f288e8c.js +0 -1
  543. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/dashboard-b5c29c852262312e.js +0 -1
  544. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/edit-9f233917aa72ad82.js +0 -1
  545. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runs-5af599da035252a7.js +0 -1
  546. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors/block-runtime-8597f8e13d80ee48.js +0 -1
  547. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors-5e0d047a6c9cb1fc.js +0 -1
  548. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-b0a508aa52914dad.js +0 -1
  549. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/settings-074c32397d341de9.js +0 -1
  550. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/syncs-50f5d8706ed0bc73.js +0 -1
  551. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-e151c1552fcb67bd.js +0 -1
  552. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers-95394769a783c6c7.js +0 -1
  553. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines-8336c4326f1e7d96.js +0 -1
  554. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/account/profile-01dd679e4a21e0d9.js +0 -1
  555. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/preferences-4d9051c073a9b2ff.js +0 -1
  556. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/sync-data-5a306deca6717862.js +0 -1
  557. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/sign-in-0dbc5b11019e78a0.js +0 -1
  558. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/terminal-578d862f3e56e6e6.js +0 -1
  559. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/test-1c0588d685b909b9.js +0 -1
  560. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/triggers-ffaab4c013e62ba1.js +0 -1
  561. mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/version-control-114000e84313994f.js +0 -1
  562. /mage_ai/server/frontend_dist/_next/static/{icIDjCezcfhiKL87kgeSY → N3FS4bHv0jpYeeg672uYK}/_ssgManifest.js +0 -0
  563. /mage_ai/server/frontend_dist_base_path_template/_next/static/{_O1kJQLGtZmoBMyWpQrea → aoO6jYZLVlUGCCdY-wmy8}/_ssgManifest.js +0 -0
  564. {mage_ai-0.9.45.dist-info → mage_ai-0.9.47.dist-info}/LICENSE +0 -0
  565. {mage_ai-0.9.45.dist-info → mage_ai-0.9.47.dist-info}/entry_points.txt +0 -0
  566. {mage_ai-0.9.45.dist-info → mage_ai-0.9.47.dist-info}/top_level.txt +0 -0
@@ -8,7 +8,9 @@ from mage_ai.data_integrations.sources.constants import SQL_SOURCES
8
8
  from mage_ai.data_integrations.utils.config import build_config, get_batch_fetch_limit
9
9
  from mage_ai.data_preparation.logging.logger import DictLogger
10
10
  from mage_ai.data_preparation.models.block.data_integration.constants import (
11
+ KEY_REPLICATION_METHOD,
11
12
  MAX_QUERY_STRING_SIZE,
13
+ REPLICATION_METHOD_INCREMENTAL,
12
14
  )
13
15
  from mage_ai.data_preparation.models.block.data_integration.utils import (
14
16
  convert_block_output_data_for_destination,
@@ -19,6 +21,7 @@ from mage_ai.data_preparation.models.block.data_integration.utils import (
19
21
  from mage_ai.data_preparation.models.pipelines.integration_pipeline import (
20
22
  IntegrationPipeline,
21
23
  )
24
+ from mage_ai.data_preparation.models.triggers import ScheduleInterval
22
25
  from mage_ai.orchestration.db import db_connection
23
26
  from mage_ai.orchestration.db.models.schedules import BlockRun, PipelineRun
24
27
  from mage_ai.orchestration.metrics.pipeline_run import calculate_metrics
@@ -253,6 +256,7 @@ def build_block_run_metadata(
253
256
  logging_tags: Dict = None,
254
257
  parent_stream: str = None,
255
258
  partition: str = None,
259
+ pipeline_run: PipelineRun = None,
256
260
  selected_streams: List[str] = None,
257
261
  ) -> List[Dict]:
258
262
  block_run_metadata = []
@@ -270,9 +274,11 @@ def build_block_run_metadata(
270
274
 
271
275
  if block.is_source():
272
276
  return __build_block_run_metadata_for_source(
277
+ block,
273
278
  data_integration_settings,
274
279
  logger,
275
280
  logging_tags=logging_tags,
281
+ pipeline_run=pipeline_run,
276
282
  selected_streams=selected_streams,
277
283
  )
278
284
 
@@ -377,9 +383,11 @@ def __build_block_run_metadata_for_destination(
377
383
 
378
384
 
379
385
  def __build_block_run_metadata_for_source(
386
+ block,
380
387
  data_integration_settings: Dict,
381
388
  logger: DictLogger,
382
389
  logging_tags: Dict = None,
390
+ pipeline_run: PipelineRun = None,
383
391
  selected_streams: List[str] = None,
384
392
  ) -> List[Dict]:
385
393
  block_run_metadata = []
@@ -388,20 +396,66 @@ def __build_block_run_metadata_for_source(
388
396
  config = data_integration_settings.get('config')
389
397
  batch_fetch_limit = get_batch_fetch_limit(config)
390
398
 
391
- streams = selected_streams or \
392
- [s.get('tap_stream_id') for s in get_selected_streams(catalog)]
399
+ stream_dicts_by_stream_id = index_by(
400
+ lambda x: x.get('tap_stream_id') or x.get('stream'),
401
+ get_selected_streams(catalog),
402
+ )
403
+
404
+ streams = []
405
+
406
+ if selected_streams:
407
+ streams = selected_streams
408
+ else:
409
+ streams = list(stream_dicts_by_stream_id.keys())
410
+
411
+ at_least_one_incremental = False
412
+
413
+ for stream_id in streams:
414
+ if at_least_one_incremental:
415
+ break
416
+
417
+ stream_dict = stream_dicts_by_stream_id.get(stream_id)
418
+ if not stream_dict:
419
+ continue
420
+
421
+ if REPLICATION_METHOD_INCREMENTAL == stream_dict.get(KEY_REPLICATION_METHOD):
422
+ at_least_one_incremental = True
423
+ break
424
+
425
+ execution_partition_previous = None
426
+
427
+ if at_least_one_incremental and pipeline_run:
428
+ pipeline_runs_completed = \
429
+ PipelineRun.recently_completed_pipeline_runs(
430
+ pipeline_run.pipeline_uuid,
431
+ pipeline_run_id=pipeline_run.id,
432
+ pipeline_schedule_id=(
433
+ None if
434
+ ScheduleInterval.ONCE == pipeline_run.pipeline_schedule.schedule_interval else
435
+ pipeline_run.pipeline_schedule_id
436
+ ),
437
+ sample_size=1,
438
+ )
439
+
440
+ if pipeline_runs_completed:
441
+ execution_partition_previous = pipeline_runs_completed[0].execution_partition
442
+
393
443
  data_integration_uuid = data_integration_settings.get('data_integration_uuid')
394
444
 
395
445
  is_sql_source = data_integration_uuid in SQL_SOURCES_UUID
396
446
  record_counts_by_stream = {}
397
447
  if is_sql_source:
448
+
398
449
  record_counts_by_stream = index_by(
399
450
  lambda x: x['id'],
400
451
  count_records(
401
452
  config,
402
453
  data_integration_uuid,
403
454
  streams,
455
+ block=block,
404
456
  catalog=catalog,
457
+ partition=execution_partition_previous,
458
+ variables=pipeline_run.variables if pipeline_run else None,
405
459
  ),
406
460
  )
407
461
 
@@ -432,6 +486,7 @@ def __build_block_run_metadata_for_source(
432
486
 
433
487
  for idx in range(number_of_batches):
434
488
  block_run_metadata.append(dict(
489
+ execution_partition_previous=execution_partition_previous,
435
490
  index=idx,
436
491
  number_of_batches=number_of_batches,
437
492
  stream=tap_stream_id,
@@ -735,6 +735,14 @@ class BlockExecutor:
735
735
  except Exception as err:
736
736
  print(f'[WARNING] BlockExecutor._execute: {err}')
737
737
 
738
+ is_source = self.block.is_source()
739
+ if is_source and data_integration_metadata:
740
+ execution_partition_previous = data_integration_metadata.get(
741
+ 'execution_partition_previous',
742
+ )
743
+ if execution_partition_previous:
744
+ extra_options['execution_partition_previous'] = execution_partition_previous
745
+
738
746
  if di_settings and \
739
747
  data_integration_metadata and \
740
748
  data_integration_metadata.get('controller') and \
@@ -746,7 +754,6 @@ class BlockExecutor:
746
754
  if is_data_integration:
747
755
  arr = []
748
756
 
749
- is_source = self.block.is_source()
750
757
  data_integration_uuid = di_settings.get('data_integration_uuid')
751
758
  catalog = di_settings.get('catalog', [])
752
759
 
@@ -770,6 +777,7 @@ class BlockExecutor:
770
777
  logging_tags=logging_tags,
771
778
  parent_stream=data_integration_metadata.get('parent_stream'),
772
779
  partition=self.execution_partition,
780
+ pipeline_run=pipeline_run,
773
781
  selected_streams=[stream],
774
782
  )
775
783
  for br_metadata in block_run_metadata:
@@ -1,6 +1,9 @@
1
1
  import asyncio
2
+ from datetime import datetime
2
3
  from typing import Dict, List
3
4
 
5
+ import pytz
6
+
4
7
  from mage_ai.data_preparation.executors.block_executor import BlockExecutor
5
8
  from mage_ai.data_preparation.logging.logger import DictLogger
6
9
  from mage_ai.data_preparation.logging.logger_manager_factory import LoggerManagerFactory
@@ -93,6 +96,12 @@ class PipelineExecutor:
93
96
  block_uuid=block_run.block_uuid,
94
97
  execution_partition=self.execution_partition,
95
98
  )
99
+ block_run_data = dict(status=BlockRun.BlockRunStatus.RUNNING)
100
+ if not block_run.started_at or \
101
+ (block_run.metrics and not block_run.metrics.get('controller')):
102
+ block_run_data['started_at'] = datetime.now(tz=pytz.UTC)
103
+
104
+ block_run.update(**block_run_data)
96
105
  BlockExecutor(**executor_kwargs).execute(
97
106
  block_run_id=block_run.id,
98
107
  global_vars=global_vars,
@@ -23,6 +23,7 @@ from jinja2 import Template
23
23
  import mage_ai.data_preparation.decorators
24
24
  from mage_ai.cache.block import BlockCache
25
25
  from mage_ai.data_cleaner.shared.utils import is_geo_dataframe, is_spark_dataframe
26
+ from mage_ai.data_integrations.sources.constants import SQL_SOURCES_MAPPING
26
27
  from mage_ai.data_preparation.logging.logger import DictLogger
27
28
  from mage_ai.data_preparation.logging.logger_manager_factory import LoggerManagerFactory
28
29
  from mage_ai.data_preparation.models.block.data_integration.mixins import (
@@ -189,6 +190,7 @@ def run_blocks_sync(
189
190
  run_sensors: bool = True,
190
191
  run_tests: bool = True,
191
192
  selected_blocks: Set[str] = None,
193
+ update_status: bool = True,
192
194
  ) -> None:
193
195
  tries_by_block_uuid = {}
194
196
  tasks = dict()
@@ -243,6 +245,7 @@ def run_blocks_sync(
243
245
  from_notebook=not run_sensors,
244
246
  global_vars=global_vars,
245
247
  run_all_blocks=True,
248
+ update_status=update_status,
246
249
  )
247
250
 
248
251
  if run_tests:
@@ -278,6 +281,7 @@ class Block(DataIntegrationMixin, SparkBlock):
278
281
  language: BlockLanguage = BlockLanguage.PYTHON,
279
282
  configuration: Dict = None,
280
283
  has_callback: bool = False,
284
+ repo_config=None,
281
285
  timeout: int = None,
282
286
  ) -> None:
283
287
  if configuration is None:
@@ -339,12 +343,26 @@ class Block(DataIntegrationMixin, SparkBlock):
339
343
 
340
344
  self.execution_timestamp_start = None
341
345
  self.execution_timestamp_end = None
346
+ self.execution_uuid = None
347
+ self._compute_service_uuid = None
348
+ self._repo_config = repo_config
342
349
  self._spark_session_current = None
350
+ self.global_vars = None
343
351
 
344
352
  @property
345
353
  def uuid(self) -> str:
346
354
  return self._uuid
347
355
 
356
+ @property
357
+ def repo_config(self):
358
+ if self._repo_config:
359
+ return self._repo_config
360
+
361
+ if self.pipeline:
362
+ self._repo_config = self.pipeline.repo_config
363
+
364
+ return self._repo_config
365
+
348
366
  @property
349
367
  def uuid_replicated(self) -> str:
350
368
  if self.replicated_block:
@@ -449,11 +467,14 @@ class Block(DataIntegrationMixin, SparkBlock):
449
467
  uuid = settings.get('source') or settings.get('destination')
450
468
  mapping = grouped_templates.get(uuid) or {}
451
469
 
470
+ di_metadata = merge_dict(
471
+ extract(mapping or {}, ['name']),
472
+ settings,
473
+ )
474
+ di_metadata['sql'] = uuid in SQL_SOURCES_MAPPING
475
+
452
476
  return dict(
453
- data_integration=merge_dict(
454
- extract(mapping or {}, ['name']),
455
- settings,
456
- ),
477
+ data_integration=di_metadata,
457
478
  )
458
479
  elif BlockLanguage.PYTHON == self.language:
459
480
  try:
@@ -465,15 +486,18 @@ class Block(DataIntegrationMixin, SparkBlock):
465
486
  uuid = di_settings.get('data_integration_uuid')
466
487
  mapping = grouped_templates.get(uuid) or {}
467
488
 
489
+ di_metadata = merge_dict(
490
+ extract(mapping or {}, ['name']),
491
+ ignore_keys(di_settings or {}, [
492
+ 'catalog',
493
+ 'config',
494
+ 'data_integration_uuid',
495
+ ]),
496
+ )
497
+ di_metadata['sql'] = uuid in SQL_SOURCES_MAPPING
498
+
468
499
  return dict(
469
- data_integration=merge_dict(
470
- extract(mapping or {}, ['name']),
471
- ignore_keys(di_settings or {}, [
472
- 'catalog',
473
- 'config',
474
- 'data_integration_uuid',
475
- ]),
476
- ),
500
+ data_integration=di_metadata,
477
501
  )
478
502
  except Exception as err:
479
503
  if is_debug():
@@ -874,6 +898,7 @@ class Block(DataIntegrationMixin, SparkBlock):
874
898
  global_vars: Dict = None,
875
899
  logger: Logger = None,
876
900
  logging_tags: Dict = None,
901
+ execution_uuid: str = None,
877
902
  from_notebook: bool = False,
878
903
  **kwargs
879
904
  ) -> Dict:
@@ -883,6 +908,9 @@ class Block(DataIntegrationMixin, SparkBlock):
883
908
  websocket as a way to test the code in the callback. To run a block in a pipeline
884
909
  run, use a BlockExecutor.
885
910
  """
911
+ if execution_uuid:
912
+ self.execution_uuid = execution_uuid
913
+
886
914
  if logging_tags is None:
887
915
  logging_tags = dict()
888
916
 
@@ -970,6 +998,7 @@ class Block(DataIntegrationMixin, SparkBlock):
970
998
  output_messages_to_logs: bool = False,
971
999
  disable_json_serialization: bool = False,
972
1000
  data_integration_runtime_settings: Dict = None,
1001
+ execution_partition_previous: str = None,
973
1002
  **kwargs,
974
1003
  ) -> Dict:
975
1004
  if logging_tags is None:
@@ -1023,6 +1052,7 @@ class Block(DataIntegrationMixin, SparkBlock):
1023
1052
  dynamic_upstream_block_uuids=dynamic_upstream_block_uuids,
1024
1053
  run_settings=run_settings,
1025
1054
  data_integration_runtime_settings=data_integration_runtime_settings,
1055
+ execution_partition_previous=execution_partition_previous,
1026
1056
  **kwargs,
1027
1057
  )
1028
1058
 
@@ -1202,6 +1232,7 @@ class Block(DataIntegrationMixin, SparkBlock):
1202
1232
  dynamic_upstream_block_uuids: List[str] = None,
1203
1233
  run_settings: Dict = None,
1204
1234
  data_integration_runtime_settings: str = None,
1235
+ execution_partition_previous: str = None,
1205
1236
  **kwargs,
1206
1237
  ) -> Dict:
1207
1238
  if logging_tags is None:
@@ -1280,6 +1311,7 @@ class Block(DataIntegrationMixin, SparkBlock):
1280
1311
  upstream_block_uuids=upstream_block_uuids,
1281
1312
  run_settings=run_settings,
1282
1313
  data_integration_runtime_settings=data_integration_runtime_settings,
1314
+ execution_partition_previous=execution_partition_previous,
1283
1315
  **kwargs,
1284
1316
  )
1285
1317
 
@@ -1335,6 +1367,7 @@ class Block(DataIntegrationMixin, SparkBlock):
1335
1367
  upstream_block_uuids: List[str] = None,
1336
1368
  run_settings: Dict = None,
1337
1369
  data_integration_runtime_settings: str = None,
1370
+ execution_partition_previous: str = None,
1338
1371
  **kwargs,
1339
1372
  ) -> List:
1340
1373
  if logging_tags is None:
@@ -1358,6 +1391,7 @@ class Block(DataIntegrationMixin, SparkBlock):
1358
1391
  dynamic_block_index=dynamic_block_index,
1359
1392
  dynamic_upstream_block_uuids=dynamic_upstream_block_uuids,
1360
1393
  execution_partition=execution_partition,
1394
+ execution_partition_previous=execution_partition_previous,
1361
1395
  from_notebook=from_notebook,
1362
1396
  global_vars=global_vars,
1363
1397
  input_vars=input_vars,
@@ -1406,8 +1440,7 @@ class Block(DataIntegrationMixin, SparkBlock):
1406
1440
  if logger and 'logger' not in global_vars:
1407
1441
  global_vars['logger'] = logger
1408
1442
 
1409
- track_spark = from_notebook and self.is_using_spark() and \
1410
- self.compute_management_enabled()
1443
+ track_spark = from_notebook and self.should_track_spark()
1411
1444
 
1412
1445
  if track_spark:
1413
1446
  self.clear_spark_jobs_cache()
@@ -1490,7 +1523,8 @@ class Block(DataIntegrationMixin, SparkBlock):
1490
1523
  self.module = module
1491
1524
 
1492
1525
  return block_function_updated
1493
- except Exception:
1526
+ except Exception as err:
1527
+ print(f'[WARNING] Block.initialize_decorator_modules: {err}')
1494
1528
  print('Falling back to default block execution...')
1495
1529
 
1496
1530
  return block_function
@@ -2475,6 +2509,31 @@ df = get_variable('{self.pipeline.uuid}', '{block_uuid}', 'df')
2475
2509
  return variable_mapping
2476
2510
 
2477
2511
  def __enrich_global_vars(self, global_vars: Dict = None) -> Dict:
2512
+ """
2513
+ Enriches the provided global variables dictionary with additional context, Spark session,
2514
+ environment, configuration, and an empty context dictionary.
2515
+
2516
+ Args:
2517
+ global_vars (Optional[Dict]): A dictionary of global variables to be enriched.
2518
+ If not provided, an empty dictionary is created.
2519
+
2520
+ Returns:
2521
+ Dict: The enriched global variables dictionary.
2522
+
2523
+ This method checks if the pipeline type is DATABRICKS or if the environment is a Spark
2524
+ environment. If true, it adds the Spark session to the global variables if not already
2525
+ present.
2526
+
2527
+ If 'env' is not in the global variables, it adds the environment information using the
2528
+ 'get_env()' function.
2529
+
2530
+ Adds the block configuration to the global variables.
2531
+
2532
+ If 'context' is not in global_vars, it adds an empty context dictionary.
2533
+
2534
+ The final enriched global variables dictionary is assigned to the object's 'global_vars'
2535
+ attribute and returned.
2536
+ """
2478
2537
  if global_vars is None:
2479
2538
  global_vars = dict()
2480
2539
  if ((self.pipeline is not None and self.pipeline.type == PipelineType.DATABRICKS) or
@@ -2485,16 +2544,19 @@ df = get_variable('{self.pipeline.uuid}', '{block_uuid}', 'df')
2485
2544
  global_vars['spark'] = spark
2486
2545
  if 'env' not in global_vars:
2487
2546
  global_vars['env'] = get_env()
2488
- if 'configuration' not in global_vars:
2489
- global_vars['configuration'] = self.configuration
2547
+ global_vars['configuration'] = self.configuration
2490
2548
  if 'context' not in global_vars:
2491
2549
  global_vars['context'] = dict()
2550
+
2551
+ self.global_vars = global_vars
2552
+
2492
2553
  return global_vars
2493
2554
 
2494
2555
  def get_spark_session(self):
2495
2556
  if self.spark_init and (not self.pipeline or
2496
2557
  not self.pipeline.spark_config):
2497
2558
  return self.spark
2559
+
2498
2560
  try:
2499
2561
  if self.pipeline and self.pipeline.spark_config:
2500
2562
  spark_config = SparkConfig.load(
@@ -2507,6 +2569,9 @@ df = get_variable('{self.pipeline.uuid}', '{block_uuid}', 'df')
2507
2569
  except Exception:
2508
2570
  self.spark = None
2509
2571
 
2572
+ if not self.spark and self.global_vars and self.global_vars.get('spark'):
2573
+ self.spark = self.global_vars.get('spark')
2574
+
2510
2575
  self.spark_init = True
2511
2576
  return self.spark
2512
2577
 
@@ -50,6 +50,7 @@ EXECUTION_PARTITION_FROM_NOTEBOOK = '_from_notebook'
50
50
 
51
51
  OUTPUT_TYPE_RECORD = 'RECORD'
52
52
  OUTPUT_TYPE_SCHEMA = 'SCHEMA'
53
+ OUTPUT_TYPE_STATE = 'STATE'
53
54
  TYPE_OBJECT = 'object'
54
55
 
55
56
  KEY_BOOKMARK_PROPERTIES = 'bookmark_properties'
@@ -77,6 +78,8 @@ REPLICATION_METHOD_LOG_BASED = 'LOG_BASED'
77
78
  MB_1 = 1024 * 1000
78
79
  MAX_QUERY_STRING_SIZE = 10 * MB_1
79
80
 
81
+ VARIABLE_BOOKMARK_VALUES_KEY = '__bookmark_values__'
82
+
80
83
 
81
84
  class IngestMode(str, Enum):
82
85
  DISK = 'disk'
@@ -75,7 +75,7 @@ def convert_dataframe_to_output(
75
75
  if log_message:
76
76
  log_message(
77
77
  f'Writing {len(records_in_batch)} records from stream {stream} to {file_path} '
78
- f'for batch index {index} ({index + 1 } out of {batches} batch(s)).',
78
+ f'for batch index {index} ({index + 1} out of {batches} batch(s)).',
79
79
  )
80
80
 
81
81
  output_file_paths.append(file_path)