mage-ai 0.9.46__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.
- mage_ai/api/operations/base.py +27 -5
- mage_ai/api/policies/GlobalHookPolicy.py +1 -1
- mage_ai/api/policies/IntegrationSourcePolicy.py +62 -0
- mage_ai/api/policies/OauthPolicy.py +6 -6
- mage_ai/api/presenters/GlobalHookPresenter.py +1 -1
- mage_ai/api/presenters/IntegrationSourcePresenter.py +9 -2
- mage_ai/api/presenters/PipelinePresenter.py +2 -0
- mage_ai/api/presenters/PipelineRunPresenter.py +8 -3
- mage_ai/api/presenters/PipelineSchedulePresenter.py +22 -1
- mage_ai/api/resources/BlockResource.py +5 -0
- mage_ai/api/resources/DataProviderResource.py +2 -0
- mage_ai/api/resources/IntegrationSourceResource.py +149 -2
- mage_ai/data_integrations/sources/constants.py +5 -0
- mage_ai/data_integrations/utils/scheduler.py +57 -2
- mage_ai/data_preparation/executors/block_executor.py +9 -1
- mage_ai/data_preparation/models/block/__init__.py +25 -12
- mage_ai/data_preparation/models/block/data_integration/constants.py +3 -0
- mage_ai/data_preparation/models/block/data_integration/utils.py +196 -37
- mage_ai/data_preparation/models/block/sql/utils/shared.py +18 -1
- mage_ai/data_preparation/models/block/utils.py +28 -13
- mage_ai/data_preparation/models/global_hooks/constants.py +50 -1
- mage_ai/data_preparation/models/global_hooks/models.py +148 -84
- mage_ai/data_preparation/models/global_hooks/predicates.py +316 -0
- mage_ai/data_preparation/models/pipeline.py +2 -0
- mage_ai/data_preparation/models/pipelines/integration_pipeline.py +0 -1
- mage_ai/data_preparation/preferences.py +29 -18
- mage_ai/data_preparation/repo_manager.py +12 -2
- mage_ai/data_preparation/sync/__init__.py +2 -0
- mage_ai/data_preparation/templates/constants.py +14 -0
- mage_ai/data_preparation/templates/data_exporters/chroma.py +24 -0
- mage_ai/data_preparation/templates/data_exporters/streaming/rabbitmq.yaml +7 -0
- mage_ai/data_preparation/templates/data_loaders/chroma.py +27 -0
- mage_ai/data_preparation/templates/repo/io_config.yaml +3 -0
- mage_ai/io/base.py +1 -0
- mage_ai/io/chroma.py +153 -0
- mage_ai/io/config.py +8 -0
- mage_ai/orchestration/db/models/schedules.py +98 -34
- mage_ai/orchestration/pipeline_scheduler.py +58 -19
- mage_ai/server/constants.py +1 -1
- mage_ai/server/frontend_dist/404.html +2 -2
- mage_ai/server/frontend_dist/_next/static/N3FS4bHv0jpYeeg672uYK/_buildManifest.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/{1749-9a6276b2918fdae1.js → 1749-bf512b4dabbab7fa.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/{1952-ac7722e8b1ab88fe.js → 1952-57858e7445d24413.js} +1 -1
- mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/2714-1e79e9f2e998b544.js → frontend_dist/_next/static/chunks/2714-68fef54789d7eaeb.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/2717-92cdffd87b6f6e05.js +1 -0
- mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/3419-f8d518d024e7b5c8.js → frontend_dist/_next/static/chunks/3419-715ca383fa15a5ef.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/3437-b4d6a037cf5781f8.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/3943-c9fb980f03df6450.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/4267-cb102e060a43d9bd.js +1 -0
- mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/4366-93e09e5a4a7e182c.js → frontend_dist/_next/static/chunks/4366-3e52497942acbafe.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/{4783-1a21d9be47574bba.js → 4783-422429203610c318.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/5810-e26a0768db1cfdba.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/{5896-14e5a23b1c6a0769.js → 5896-7b8e36634d7d94eb.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/{6285-e9b45335bfb9ccaf.js → 6285-648f9a732e100b2f.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/6798-b904395b0c18647b.js +1 -0
- mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/7022-070ec0144a4d029c.js → frontend_dist/_next/static/chunks/7022-e76cae3ba5ee5312.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/722-900f786d24f91b2e.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/{7361-694e1e4fb9c97d68.js → 7361-6c5c9063b9f91700.js} +1 -1
- mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/8146-92e7ccfed169ee9c.js → frontend_dist/_next/static/chunks/8146-27f0e31f309897a5.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/845-9a73c65fe3fdc328.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/8487-8e1c09546dff4dbf.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/9264-cc44b07f248707b0.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/9618-4eb49cdbd1ba11d7.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/{976-18c98af60b76f1a7.js → 976-0a8c2c4d7acd957b.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/_app-78c4a077a2f279c2.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/files-b37d221eb5ddc248.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/global-hooks/[...slug]-7adc543fc490367a.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/global-hooks-51d366993f6dd449.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/manage/{files-449a022f2f0f2d94.js → files-fe6e73463a20d67c.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/{manage-f83deb790548693b.js → manage-d8a38b5d1f50e798.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-9adc2974aada27ba.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills-51b1311dff2a974e.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/edit-2333e524d34b474a.js +1 -0
- mage_ai/server/{frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors-e051057d9fe94f23.js → frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors-6d1afeb4a84f50f7.js} +1 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-1ff9bb8e22ca1e75.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/settings-11363aa58d51f4e1.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-779c3ef0676a12ac.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers-bbea9a088657404a.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines-3737f2b0afc2ede3.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/account/profile-3c8f062913c66f3e.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/preferences-c1f4ed17d501ccca.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/triggers-8bdd858240d5dbf6.js +1 -0
- mage_ai/server/frontend_dist/_next/static/chunks/pages/version-control-dd4fb405695f74bf.js +1 -0
- mage_ai/server/frontend_dist/block-layout.html +2 -2
- mage_ai/server/frontend_dist/compute.html +5 -5
- mage_ai/server/frontend_dist/files.html +5 -5
- mage_ai/server/frontend_dist/global-data-products/[...slug].html +5 -5
- mage_ai/server/frontend_dist/global-data-products.html +5 -5
- mage_ai/server/frontend_dist/global-hooks/[...slug].html +5 -5
- mage_ai/server/frontend_dist/global-hooks.html +5 -5
- mage_ai/server/frontend_dist/index.html +2 -2
- mage_ai/server/frontend_dist/manage/files.html +5 -5
- mage_ai/server/frontend_dist/manage/settings.html +5 -5
- mage_ai/server/frontend_dist/manage/users/[user].html +5 -5
- mage_ai/server/frontend_dist/manage/users/new.html +5 -5
- mage_ai/server/frontend_dist/manage/users.html +5 -5
- mage_ai/server/frontend_dist/manage.html +5 -5
- mage_ai/server/frontend_dist/oauth.html +4 -4
- mage_ai/server/frontend_dist/overview.html +5 -5
- mage_ai/server/frontend_dist/pipeline-runs.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/backfills/[...slug].html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/backfills.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/dashboard.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/edit.html +2 -2
- mage_ai/server/frontend_dist/pipelines/[pipeline]/logs.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/monitors/block-runs.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/monitors/block-runtime.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/monitors.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/runs/[run].html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/runs.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/settings.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/syncs.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/triggers/[...slug].html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline]/triggers.html +5 -5
- mage_ai/server/frontend_dist/pipelines/[pipeline].html +2 -2
- mage_ai/server/frontend_dist/pipelines.html +5 -5
- mage_ai/server/frontend_dist/settings/account/profile.html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/permissions/[...slug].html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/permissions.html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/preferences.html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/roles/[...slug].html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/roles.html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/sync-data.html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/users/[...slug].html +5 -5
- mage_ai/server/frontend_dist/settings/workspace/users.html +5 -5
- mage_ai/server/frontend_dist/settings.html +2 -2
- mage_ai/server/frontend_dist/sign-in.html +20 -20
- mage_ai/server/frontend_dist/templates/[...slug].html +5 -5
- mage_ai/server/frontend_dist/templates.html +5 -5
- mage_ai/server/frontend_dist/terminal.html +5 -5
- mage_ai/server/frontend_dist/test.html +5 -5
- mage_ai/server/frontend_dist/triggers.html +5 -5
- mage_ai/server/frontend_dist/version-control.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/404.html +2 -2
- mage_ai/server/frontend_dist_base_path_template/_next/static/aoO6jYZLVlUGCCdY-wmy8/_buildManifest.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{1749-9a6276b2918fdae1.js → 1749-bf512b4dabbab7fa.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{1952-ac7722e8b1ab88fe.js → 1952-57858e7445d24413.js} +1 -1
- mage_ai/server/{frontend_dist/_next/static/chunks/2714-1e79e9f2e998b544.js → frontend_dist_base_path_template/_next/static/chunks/2714-68fef54789d7eaeb.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/2717-92cdffd87b6f6e05.js +1 -0
- mage_ai/server/{frontend_dist/_next/static/chunks/3419-f8d518d024e7b5c8.js → frontend_dist_base_path_template/_next/static/chunks/3419-715ca383fa15a5ef.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3437-b4d6a037cf5781f8.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3943-c9fb980f03df6450.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/4267-cb102e060a43d9bd.js +1 -0
- mage_ai/server/{frontend_dist/_next/static/chunks/4366-93e09e5a4a7e182c.js → frontend_dist_base_path_template/_next/static/chunks/4366-3e52497942acbafe.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{4783-1a21d9be47574bba.js → 4783-422429203610c318.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5810-e26a0768db1cfdba.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{5896-14e5a23b1c6a0769.js → 5896-7b8e36634d7d94eb.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{6285-e9b45335bfb9ccaf.js → 6285-648f9a732e100b2f.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/6798-b904395b0c18647b.js +1 -0
- mage_ai/server/{frontend_dist/_next/static/chunks/7022-070ec0144a4d029c.js → frontend_dist_base_path_template/_next/static/chunks/7022-e76cae3ba5ee5312.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/722-900f786d24f91b2e.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{7361-694e1e4fb9c97d68.js → 7361-6c5c9063b9f91700.js} +1 -1
- mage_ai/server/{frontend_dist/_next/static/chunks/8146-92e7ccfed169ee9c.js → frontend_dist_base_path_template/_next/static/chunks/8146-27f0e31f309897a5.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/845-9a73c65fe3fdc328.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/8487-8e1c09546dff4dbf.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/9264-cc44b07f248707b0.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/9618-4eb49cdbd1ba11d7.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/{976-18c98af60b76f1a7.js → 976-0a8c2c4d7acd957b.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/_app-78c4a077a2f279c2.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/files-b37d221eb5ddc248.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/global-hooks/[...slug]-7adc543fc490367a.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/global-hooks-51d366993f6dd449.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/manage/{files-449a022f2f0f2d94.js → files-fe6e73463a20d67c.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/{manage-f83deb790548693b.js → manage-d8a38b5d1f50e798.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-9adc2974aada27ba.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills-51b1311dff2a974e.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/edit-2333e524d34b474a.js +1 -0
- mage_ai/server/{frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/monitors-e051057d9fe94f23.js → frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/monitors-6d1afeb4a84f50f7.js} +1 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-1ff9bb8e22ca1e75.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/settings-11363aa58d51f4e1.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-779c3ef0676a12ac.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers-bbea9a088657404a.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines-3737f2b0afc2ede3.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/account/profile-3c8f062913c66f3e.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/preferences-c1f4ed17d501ccca.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/triggers-8bdd858240d5dbf6.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/version-control-dd4fb405695f74bf.js +1 -0
- mage_ai/server/frontend_dist_base_path_template/block-layout.html +2 -2
- mage_ai/server/frontend_dist_base_path_template/compute.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/files.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/global-data-products/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/global-data-products.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/global-hooks/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/global-hooks.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/index.html +2 -2
- mage_ai/server/frontend_dist_base_path_template/manage/files.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/manage/settings.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/manage/users/[user].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/manage/users/new.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/manage/users.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/manage.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/oauth.html +4 -4
- mage_ai/server/frontend_dist_base_path_template/overview.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipeline-runs.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/backfills/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/backfills.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/dashboard.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/edit.html +2 -2
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/logs.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/monitors/block-runs.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/monitors/block-runtime.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/monitors.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/runs/[run].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/runs.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/settings.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/syncs.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/triggers/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline]/triggers.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/pipelines/[pipeline].html +2 -2
- mage_ai/server/frontend_dist_base_path_template/pipelines.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/account/profile.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/permissions/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/permissions.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/preferences.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/roles/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/roles.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/sync-data.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/users/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings/workspace/users.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/settings.html +2 -2
- mage_ai/server/frontend_dist_base_path_template/sign-in.html +23 -23
- mage_ai/server/frontend_dist_base_path_template/templates/[...slug].html +5 -5
- mage_ai/server/frontend_dist_base_path_template/templates.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/terminal.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/test.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/triggers.html +5 -5
- mage_ai/server/frontend_dist_base_path_template/version-control.html +5 -5
- mage_ai/server/server.py +9 -3
- mage_ai/services/k8s/job_manager.py +1 -0
- mage_ai/settings/repo.py +3 -0
- mage_ai/shared/files.py +47 -0
- mage_ai/shared/models.py +1 -0
- mage_ai/streaming/constants.py +1 -0
- mage_ai/streaming/sinks/postgres.py +2 -0
- mage_ai/streaming/sinks/rabbitmq.py +76 -0
- mage_ai/streaming/sinks/sink_factory.py +4 -0
- mage_ai/tests/api/operations/test_operations_with_hooks.py +136 -91
- mage_ai/tests/api/policies/test_oauth_policy.py +38 -0
- mage_ai/tests/data_preparation/models/global_hooks/test_global_hooks.py +33 -8
- mage_ai/tests/data_preparation/models/global_hooks/test_hook.py +82 -38
- mage_ai/tests/data_preparation/models/global_hooks/test_predicates.py +803 -0
- mage_ai/tests/data_preparation/models/global_hooks/test_utils.py +6 -1
- mage_ai/tests/data_preparation/models/test_block.py +26 -0
- mage_ai/tests/data_preparation/models/test_pipeline.py +10 -0
- mage_ai/tests/factory.py +40 -2
- mage_ai/tests/orchestration/test_pipeline_scheduler.py +82 -1
- mage_ai/tests/services/k8s/test_job_manager.py +16 -0
- mage_ai/tests/shared/mixins.py +60 -23
- mage_ai/tests/streaming/sinks/test_rabbitmq.py +36 -0
- {mage_ai-0.9.46.dist-info → mage_ai-0.9.47.dist-info}/METADATA +7 -4
- {mage_ai-0.9.46.dist-info → mage_ai-0.9.47.dist-info}/RECORD +257 -243
- {mage_ai-0.9.46.dist-info → mage_ai-0.9.47.dist-info}/WHEEL +1 -1
- mage_ai/server/frontend_dist/_next/static/9jB4XPuz6BzxBcG9VNao5/_buildManifest.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/3943-9e1105393a3be0de.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/4267-fd4d8049e83178de.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/5810-12eadc488265d55b.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/595-0d174b1f9fbfce4f.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/6333-bc1b433b428a9095.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/722-a1584445357a276c.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/8487-032ef9b17d20aad9.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/9264-1d4f0327d42fed91.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/9618-2c5045255ac5a6e7.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/_app-ebef928183f9a3bb.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/files-0f2d4be6fdca86ca.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/global-hooks/[...slug]-77edfa32d000e88b.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/global-hooks-e561ae38cf5592e8.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-10e9a2d19541caa2.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/backfills-c8d3a5289ab93f88.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/edit-ff7e9108502f5716.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-0691711636fa95c7.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/settings-2914e326a5f1ffe0.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-3a7500e6e53084d3.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines/[pipeline]/triggers-c0e551d265a8d467.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/pipelines-e47db5c3eaf683af.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/account/profile-55ac955dfa9a5a8d.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/settings/workspace/preferences-29c92a9bc54ae5cd.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/triggers-572d82d6eb7a5d43.js +0 -1
- mage_ai/server/frontend_dist/_next/static/chunks/pages/version-control-2d26d80370a2e481.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/3943-9e1105393a3be0de.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/4267-fd4d8049e83178de.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/5810-12eadc488265d55b.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/595-0d174b1f9fbfce4f.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/6333-bc1b433b428a9095.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/722-a1584445357a276c.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/8487-032ef9b17d20aad9.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/9264-1d4f0327d42fed91.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/9618-2c5045255ac5a6e7.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/_app-ebef928183f9a3bb.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/files-0f2d4be6fdca86ca.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/global-hooks/[...slug]-77edfa32d000e88b.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/global-hooks-e561ae38cf5592e8.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills/[...slug]-10e9a2d19541caa2.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/backfills-c8d3a5289ab93f88.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/edit-ff7e9108502f5716.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/runs/[run]-0691711636fa95c7.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/settings-2914e326a5f1ffe0.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers/[...slug]-3a7500e6e53084d3.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines/[pipeline]/triggers-c0e551d265a8d467.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/pipelines-e47db5c3eaf683af.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/account/profile-55ac955dfa9a5a8d.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/settings/workspace/preferences-29c92a9bc54ae5cd.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/triggers-572d82d6eb7a5d43.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/chunks/pages/version-control-2d26d80370a2e481.js +0 -1
- mage_ai/server/frontend_dist_base_path_template/_next/static/uPDjJYpJMst1q6psbRyte/_buildManifest.js +0 -1
- /mage_ai/server/frontend_dist/_next/static/{9jB4XPuz6BzxBcG9VNao5 → N3FS4bHv0jpYeeg672uYK}/_ssgManifest.js +0 -0
- /mage_ai/server/frontend_dist_base_path_template/_next/static/{uPDjJYpJMst1q6psbRyte → aoO6jYZLVlUGCCdY-wmy8}/_ssgManifest.js +0 -0
- {mage_ai-0.9.46.dist-info → mage_ai-0.9.47.dist-info}/LICENSE +0 -0
- {mage_ai-0.9.46.dist-info → mage_ai-0.9.47.dist-info}/entry_points.txt +0 -0
- {mage_ai-0.9.46.dist-info → mage_ai-0.9.47.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import json
|
|
2
|
+
from dataclasses import dataclass
|
|
3
|
+
from typing import Dict, List
|
|
4
|
+
|
|
5
|
+
import pika
|
|
6
|
+
|
|
7
|
+
from mage_ai.shared.config import BaseConfig
|
|
8
|
+
from mage_ai.streaming.sinks.base import BaseSink
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
@dataclass
|
|
12
|
+
class RabbitMQConfig(BaseConfig):
|
|
13
|
+
connection_host: str
|
|
14
|
+
connection_port: int
|
|
15
|
+
queue_name: str
|
|
16
|
+
username: str = 'guest'
|
|
17
|
+
password: str = 'guest'
|
|
18
|
+
amqp_url_virtual_host: str = r'%2f'
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
class RabbitMQSink(BaseSink):
|
|
22
|
+
config_class = RabbitMQConfig
|
|
23
|
+
|
|
24
|
+
def init_client(self):
|
|
25
|
+
self._print('Start initializing producer.')
|
|
26
|
+
# Initialize RabbitMQ producer
|
|
27
|
+
queue_name = self.config.queue_name
|
|
28
|
+
username = self.config.username
|
|
29
|
+
password = self.config.password
|
|
30
|
+
connection_host = self.config.connection_host
|
|
31
|
+
connection_port = self.config.connection_port
|
|
32
|
+
vt_host = self.config.amqp_url_virtual_host
|
|
33
|
+
|
|
34
|
+
self._print(f'Starting to initialize producer for queue {queue_name}')
|
|
35
|
+
|
|
36
|
+
try:
|
|
37
|
+
generated_url = f"amqp://{username}:{password}@" \
|
|
38
|
+
f"{connection_host}:{connection_port}/{vt_host}"
|
|
39
|
+
|
|
40
|
+
self._print(f'Trying to connect on {generated_url}')
|
|
41
|
+
self.connection = pika.BlockingConnection(
|
|
42
|
+
pika.URLParameters(
|
|
43
|
+
generated_url
|
|
44
|
+
)
|
|
45
|
+
)
|
|
46
|
+
|
|
47
|
+
self.main_channel = self.connection.channel()
|
|
48
|
+
self._print('Finish initializing producer.')
|
|
49
|
+
except Exception as e:
|
|
50
|
+
self._print('Connection Error! Please check RabbitMQ connection')
|
|
51
|
+
raise e
|
|
52
|
+
|
|
53
|
+
def write(self, message: Dict):
|
|
54
|
+
pass
|
|
55
|
+
|
|
56
|
+
def batch_write(self, messages: List[Dict]):
|
|
57
|
+
if not messages:
|
|
58
|
+
return
|
|
59
|
+
self._print(
|
|
60
|
+
f'Batch ingest {len(messages)} messages. Sample: {messages[0]}'
|
|
61
|
+
)
|
|
62
|
+
for message in messages:
|
|
63
|
+
if isinstance(message, dict):
|
|
64
|
+
data = message.get('data', message)
|
|
65
|
+
metadata = message.get('metadata', None)
|
|
66
|
+
else:
|
|
67
|
+
data = message
|
|
68
|
+
metadata = None
|
|
69
|
+
message_properties = pika.BasicProperties(headers=metadata)
|
|
70
|
+
self.main_channel.basic_publish(
|
|
71
|
+
exchange='',
|
|
72
|
+
routing_key=self.config.queue_name,
|
|
73
|
+
body=json.dumps(data).encode('utf-8'),
|
|
74
|
+
properties=message_properties,
|
|
75
|
+
mandatory=True,
|
|
76
|
+
)
|
|
@@ -53,6 +53,10 @@ class SinkFactory:
|
|
|
53
53
|
from mage_ai.streaming.sinks.postgres import PostgresSink
|
|
54
54
|
|
|
55
55
|
return PostgresSink(config, **kwargs)
|
|
56
|
+
elif connector_type == SinkType.RABBITMQ:
|
|
57
|
+
from mage_ai.streaming.sinks.rabbitmq import RabbitMQSink
|
|
58
|
+
|
|
59
|
+
return RabbitMQSink(config, **kwargs)
|
|
56
60
|
elif connector_type in GENERIC_IO_SINK_TYPES:
|
|
57
61
|
from mage_ai.streaming.sinks.generic_io import GenericIOSink
|
|
58
62
|
|
|
@@ -3,16 +3,25 @@
|
|
|
3
3
|
|
|
4
4
|
# from mage_ai.authentication.permissions.constants import EntityName
|
|
5
5
|
# from mage_ai.data_preparation.models.constants import BlockType, PipelineType
|
|
6
|
-
# from mage_ai.data_preparation.models.global_hooks.constants import
|
|
6
|
+
# from mage_ai.data_preparation.models.global_hooks.constants import (
|
|
7
|
+
# HookOutputKey,
|
|
8
|
+
# PredicateAndOrOperator,
|
|
9
|
+
# PredicateObjectType,
|
|
10
|
+
# PredicateOperator,
|
|
11
|
+
# PredicateValueDataType,
|
|
12
|
+
# )
|
|
7
13
|
# from mage_ai.data_preparation.models.global_hooks.models import (
|
|
8
14
|
# GlobalHooks,
|
|
9
15
|
# HookCondition,
|
|
10
16
|
# HookOperation,
|
|
11
17
|
# HookOutputBlock,
|
|
12
18
|
# HookOutputSettings,
|
|
13
|
-
# HookPredicate,
|
|
14
19
|
# HookStage,
|
|
15
20
|
# )
|
|
21
|
+
# from mage_ai.data_preparation.models.global_hooks.predicates import (
|
|
22
|
+
# HookPredicate,
|
|
23
|
+
# PredicateValueType,
|
|
24
|
+
# )
|
|
16
25
|
# from mage_ai.data_preparation.models.pipeline import Pipeline
|
|
17
26
|
# from mage_ai.data_preparation.models.project.constants import FeatureUUID
|
|
18
27
|
# from mage_ai.data_preparation.repo_manager import get_repo_config
|
|
@@ -45,6 +54,62 @@
|
|
|
45
54
|
# except FileNotFoundError as err:
|
|
46
55
|
# print(err)
|
|
47
56
|
|
|
57
|
+
# def build_predicates(self,
|
|
58
|
+
# before_values,
|
|
59
|
+
# after_values,
|
|
60
|
+
# and_or_operator: PredicateAndOrOperator = None,
|
|
61
|
+
# ):
|
|
62
|
+
# predicate_match_before = HookPredicate.load(
|
|
63
|
+
# and_or_operator=and_or_operator or PredicateAndOrOperator.AND,
|
|
64
|
+
# predicates=[HookPredicate.load(
|
|
65
|
+
# left_object_keys=left_object_keys,
|
|
66
|
+
# left_object_type=left_object_type,
|
|
67
|
+
# left_value_type=PredicateValueType.load(
|
|
68
|
+
# value_data_type=PredicateValueDataType.STRING,
|
|
69
|
+
# ),
|
|
70
|
+
# operator=PredicateOperator.EQUALS,
|
|
71
|
+
# right_value=value,
|
|
72
|
+
# right_value_type=PredicateValueType.load(
|
|
73
|
+
# value_data_type=PredicateValueDataType.STRING,
|
|
74
|
+
# ),
|
|
75
|
+
# ) for left_object_keys, left_object_type, value in before_values],
|
|
76
|
+
# )
|
|
77
|
+
|
|
78
|
+
# predicate_match_after = HookPredicate.load(
|
|
79
|
+
# and_or_operator=and_or_operator or PredicateAndOrOperator.AND,
|
|
80
|
+
# predicates=[HookPredicate.load(
|
|
81
|
+
# left_object_keys=left_object_keys,
|
|
82
|
+
# left_object_type=left_object_type,
|
|
83
|
+
# left_value_type=PredicateValueType.load(
|
|
84
|
+
# value_data_type=PredicateValueDataType.STRING,
|
|
85
|
+
# ),
|
|
86
|
+
# operator=PredicateOperator.EQUALS,
|
|
87
|
+
# right_value=value,
|
|
88
|
+
# right_value_type=PredicateValueType.load(
|
|
89
|
+
# value_data_type=PredicateValueDataType.STRING,
|
|
90
|
+
# ),
|
|
91
|
+
# ) for left_object_keys, left_object_type, value in after_values],
|
|
92
|
+
# )
|
|
93
|
+
|
|
94
|
+
# predicate_miss = HookPredicate.load(
|
|
95
|
+
# and_or_operator=and_or_operator or PredicateAndOrOperator.AND,
|
|
96
|
+
# predicates=[
|
|
97
|
+
# HookPredicate.load(
|
|
98
|
+
# left_value=uuid.uuid4().hex,
|
|
99
|
+
# left_value_type=PredicateValueType.load(
|
|
100
|
+
# value_data_type=PredicateValueDataType.STRING,
|
|
101
|
+
# ),
|
|
102
|
+
# operator=PredicateOperator.EQUALS,
|
|
103
|
+
# right_value=uuid.uuid4().hex,
|
|
104
|
+
# right_value_type=PredicateValueType.load(
|
|
105
|
+
# value_data_type=PredicateValueDataType.STRING,
|
|
106
|
+
# ),
|
|
107
|
+
# ),
|
|
108
|
+
# ],
|
|
109
|
+
# )
|
|
110
|
+
|
|
111
|
+
# return predicate_match_before, predicate_match_after, predicate_miss
|
|
112
|
+
|
|
48
113
|
# async def test_list(self):
|
|
49
114
|
# await self.setUpAsync(
|
|
50
115
|
# block_settings={
|
|
@@ -54,8 +119,8 @@
|
|
|
54
119
|
# },
|
|
55
120
|
# operation_type=HookOperation.LIST,
|
|
56
121
|
# pipeline_type=PipelineType.PYTHON,
|
|
57
|
-
#
|
|
58
|
-
#
|
|
122
|
+
# predicate_match=None,
|
|
123
|
+
# predicate_miss=None,
|
|
59
124
|
# )
|
|
60
125
|
|
|
61
126
|
# pipeline3, _blocks = await build_pipeline_with_blocks_and_content(
|
|
@@ -97,8 +162,8 @@
|
|
|
97
162
|
# },
|
|
98
163
|
# operation_type=HookOperation.LIST,
|
|
99
164
|
# pipeline_type=PipelineType.PYTHON,
|
|
100
|
-
#
|
|
101
|
-
#
|
|
165
|
+
# predicate_match=None,
|
|
166
|
+
# predicate_miss=None,
|
|
102
167
|
# snapshot=False,
|
|
103
168
|
# )
|
|
104
169
|
|
|
@@ -136,6 +201,17 @@
|
|
|
136
201
|
# payload = dict(name=self.faker.unique.name(), type=PipelineType.STREAMING)
|
|
137
202
|
# name_final = self.faker.unique.name()
|
|
138
203
|
|
|
204
|
+
# predicate_match_before, predicate_match_after, predicate_miss = self.build_predicates(
|
|
205
|
+
# before_values=[
|
|
206
|
+
# (['type'], PredicateObjectType.PAYLOAD, payload['type'].value),
|
|
207
|
+
# (['name'], PredicateObjectType.PAYLOAD, payload['name']),
|
|
208
|
+
# ],
|
|
209
|
+
# after_values=[
|
|
210
|
+
# (['type'], PredicateObjectType.RESOURCE, PipelineType.INTEGRATION.value),
|
|
211
|
+
# (['name'], PredicateObjectType.RESOURCE, name_final),
|
|
212
|
+
# ],
|
|
213
|
+
# )
|
|
214
|
+
|
|
139
215
|
# await self.setUpAsync(
|
|
140
216
|
# block_settings={
|
|
141
217
|
# 0: dict(content=build_content(dict(type=PipelineType.INTEGRATION))),
|
|
@@ -159,25 +235,9 @@
|
|
|
159
235
|
# ),
|
|
160
236
|
# },
|
|
161
237
|
# operation_type=HookOperation.CREATE,
|
|
162
|
-
#
|
|
163
|
-
#
|
|
164
|
-
#
|
|
165
|
-
# type=PipelineType.STREAMING.value,
|
|
166
|
-
# )),
|
|
167
|
-
# ],
|
|
168
|
-
# [
|
|
169
|
-
# HookPredicate.load(resource=dict(
|
|
170
|
-
# name=name_final,
|
|
171
|
-
# )),
|
|
172
|
-
# ],
|
|
173
|
-
# ],
|
|
174
|
-
# predicates_miss=[
|
|
175
|
-
# [
|
|
176
|
-
# HookPredicate.load(resource=dict(
|
|
177
|
-
# name=uuid.uuid4().hex,
|
|
178
|
-
# )),
|
|
179
|
-
# ],
|
|
180
|
-
# ],
|
|
238
|
+
# predicate_match_before=predicate_match_before,
|
|
239
|
+
# predicate_match_after=predicate_match_after,
|
|
240
|
+
# predicate_miss=predicate_miss,
|
|
181
241
|
# )
|
|
182
242
|
|
|
183
243
|
# response = await self.build_create_operation(payload=payload).execute()
|
|
@@ -198,6 +258,15 @@
|
|
|
198
258
|
# async def test_detail(self):
|
|
199
259
|
# name_final = self.faker.unique.name()
|
|
200
260
|
|
|
261
|
+
# predicate_match_before, predicate_match_after, predicate_miss = self.build_predicates(
|
|
262
|
+
# before_values=[
|
|
263
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, PipelineType.PYTHON.value),
|
|
264
|
+
# ],
|
|
265
|
+
# after_values=[
|
|
266
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, PipelineType.PYTHON.value),
|
|
267
|
+
# ],
|
|
268
|
+
# )
|
|
269
|
+
|
|
201
270
|
# await self.setUpAsync(
|
|
202
271
|
# block_settings={
|
|
203
272
|
# 0: dict(content=build_content(dict())),
|
|
@@ -233,25 +302,9 @@
|
|
|
233
302
|
# },
|
|
234
303
|
# operation_type=HookOperation.DETAIL,
|
|
235
304
|
# pipeline_type=PipelineType.PYTHON.value,
|
|
236
|
-
#
|
|
237
|
-
#
|
|
238
|
-
#
|
|
239
|
-
# type=PipelineType.PYTHON.value,
|
|
240
|
-
# )),
|
|
241
|
-
# ],
|
|
242
|
-
# [
|
|
243
|
-
# HookPredicate.load(resource=dict(
|
|
244
|
-
# name=PipelineType.INTEGRATION.value,
|
|
245
|
-
# )),
|
|
246
|
-
# ],
|
|
247
|
-
# ],
|
|
248
|
-
# predicates_miss=[
|
|
249
|
-
# [
|
|
250
|
-
# HookPredicate.load(resource=dict(
|
|
251
|
-
# name=uuid.uuid4().hex,
|
|
252
|
-
# )),
|
|
253
|
-
# ],
|
|
254
|
-
# ],
|
|
305
|
+
# predicate_match_before=predicate_match_before,
|
|
306
|
+
# predicate_match_after=predicate_match_after,
|
|
307
|
+
# predicate_miss=predicate_miss,
|
|
255
308
|
# )
|
|
256
309
|
|
|
257
310
|
# response = await self.build_detail_operation(self.pipeline2.uuid).execute()
|
|
@@ -273,6 +326,15 @@
|
|
|
273
326
|
|
|
274
327
|
# payload = dict(description=description_init, tags=tags_init)
|
|
275
328
|
|
|
329
|
+
# predicate_match_before, predicate_match_after, predicate_miss = self.build_predicates(
|
|
330
|
+
# before_values=[
|
|
331
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, PipelineType.PYTHON.value),
|
|
332
|
+
# ],
|
|
333
|
+
# after_values=[
|
|
334
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, PipelineType.PYTHON.value),
|
|
335
|
+
# ],
|
|
336
|
+
# )
|
|
337
|
+
|
|
276
338
|
# await self.setUpAsync(
|
|
277
339
|
# block_settings={
|
|
278
340
|
# 0: dict(content=build_content(dict(
|
|
@@ -333,20 +395,9 @@
|
|
|
333
395
|
# },
|
|
334
396
|
# operation_type=HookOperation.UPDATE,
|
|
335
397
|
# pipeline_type=PipelineType.PYTHON.value,
|
|
336
|
-
#
|
|
337
|
-
#
|
|
338
|
-
#
|
|
339
|
-
# type=PipelineType.PYTHON.value,
|
|
340
|
-
# )),
|
|
341
|
-
# ],
|
|
342
|
-
# ],
|
|
343
|
-
# predicates_miss=[
|
|
344
|
-
# [
|
|
345
|
-
# HookPredicate.load(resource=dict(
|
|
346
|
-
# name=uuid.uuid4().hex,
|
|
347
|
-
# )),
|
|
348
|
-
# ],
|
|
349
|
-
# ],
|
|
398
|
+
# predicate_match_before=predicate_match_before,
|
|
399
|
+
# predicate_match_after=predicate_match_after,
|
|
400
|
+
# predicate_miss=predicate_miss,
|
|
350
401
|
# )
|
|
351
402
|
|
|
352
403
|
# response = await self.build_update_operation(
|
|
@@ -367,6 +418,15 @@
|
|
|
367
418
|
# name_final = uuid.uuid4().hex
|
|
368
419
|
# uuid_final = uuid.uuid4().hex
|
|
369
420
|
|
|
421
|
+
# predicate_match_before, predicate_match_after, predicate_miss = self.build_predicates(
|
|
422
|
+
# before_values=[
|
|
423
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, PipelineType.PYTHON.value),
|
|
424
|
+
# ],
|
|
425
|
+
# after_values=[
|
|
426
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, PipelineType.PYTHON.value),
|
|
427
|
+
# ],
|
|
428
|
+
# )
|
|
429
|
+
|
|
370
430
|
# await self.setUpAsync(
|
|
371
431
|
# block_settings={
|
|
372
432
|
# 0: dict(content=build_content(dict(
|
|
@@ -431,20 +491,9 @@
|
|
|
431
491
|
# },
|
|
432
492
|
# operation_type=HookOperation.DELETE,
|
|
433
493
|
# pipeline_type=PipelineType.PYTHON.value,
|
|
434
|
-
#
|
|
435
|
-
#
|
|
436
|
-
#
|
|
437
|
-
# type=PipelineType.PYTHON.value,
|
|
438
|
-
# )),
|
|
439
|
-
# ],
|
|
440
|
-
# ],
|
|
441
|
-
# predicates_miss=[
|
|
442
|
-
# [
|
|
443
|
-
# HookPredicate.load(resource=dict(
|
|
444
|
-
# name=uuid.uuid4().hex,
|
|
445
|
-
# )),
|
|
446
|
-
# ],
|
|
447
|
-
# ],
|
|
494
|
+
# predicate_match_before=predicate_match_before,
|
|
495
|
+
# predicate_match_after=predicate_match_after,
|
|
496
|
+
# predicate_miss=predicate_miss,
|
|
448
497
|
# )
|
|
449
498
|
|
|
450
499
|
# response = await self.build_delete_operation(self.pipeline2.uuid).execute()
|
|
@@ -468,6 +517,18 @@
|
|
|
468
517
|
# color = uuid.uuid4().hex
|
|
469
518
|
# configuration = dict(power=uuid.uuid4().hex)
|
|
470
519
|
|
|
520
|
+
# predicate_match_before, predicate_match_after, predicate_miss = self.build_predicates(
|
|
521
|
+
# before_values=[
|
|
522
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, BlockType.DATA_LOADER.value),
|
|
523
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, BlockType.TRANSFORMER.value),
|
|
524
|
+
# ],
|
|
525
|
+
# after_values=[
|
|
526
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, BlockType.DATA_LOADER.value),
|
|
527
|
+
# (['type'], PredicateObjectType.OPERATION_RESOURCE, BlockType.TRANSFORMER.value),
|
|
528
|
+
# ],
|
|
529
|
+
# and_or_operator=PredicateAndOrOperator.OR,
|
|
530
|
+
# )
|
|
531
|
+
|
|
471
532
|
# await self.setUpAsync(
|
|
472
533
|
# block_settings={
|
|
473
534
|
# 0: dict(content=build_content(dict(
|
|
@@ -519,25 +580,9 @@
|
|
|
519
580
|
# },
|
|
520
581
|
# operation_type=HookOperation.UPDATE_ANYWHERE,
|
|
521
582
|
# pipeline_type=PipelineType.PYTHON.value,
|
|
522
|
-
#
|
|
523
|
-
#
|
|
524
|
-
#
|
|
525
|
-
# type=BlockType.DATA_LOADER.value,
|
|
526
|
-
# )),
|
|
527
|
-
# ],
|
|
528
|
-
# [
|
|
529
|
-
# HookPredicate.load(resource=dict(
|
|
530
|
-
# type=BlockType.TRANSFORMER.value,
|
|
531
|
-
# )),
|
|
532
|
-
# ],
|
|
533
|
-
# ],
|
|
534
|
-
# predicates_miss=[
|
|
535
|
-
# [
|
|
536
|
-
# HookPredicate.load(resource=dict(
|
|
537
|
-
# type=BlockType.MARKDOWN.value,
|
|
538
|
-
# )),
|
|
539
|
-
# ],
|
|
540
|
-
# ],
|
|
583
|
+
# predicate_match_before=predicate_match_before,
|
|
584
|
+
# predicate_match_after=predicate_match_after,
|
|
585
|
+
# predicate_miss=predicate_miss,
|
|
541
586
|
# resource_type=EntityName.Block,
|
|
542
587
|
# )
|
|
543
588
|
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
from mage_ai.api.constants import AttributeOperationType
|
|
2
|
+
from mage_ai.api.policies.OauthPolicy import OauthPolicy
|
|
3
|
+
from mage_ai.api.presenters.OauthPresenter import OauthPresenter
|
|
4
|
+
from mage_ai.tests.base_test import AsyncDBTestCase
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
class OauthPolicyTestCase(AsyncDBTestCase):
|
|
8
|
+
def test_attribute_rule_with_permissions(self):
|
|
9
|
+
error = False
|
|
10
|
+
|
|
11
|
+
try:
|
|
12
|
+
write_attributes = [
|
|
13
|
+
'action_type',
|
|
14
|
+
'provider',
|
|
15
|
+
'token',
|
|
16
|
+
]
|
|
17
|
+
for key in write_attributes:
|
|
18
|
+
OauthPolicy.attribute_rule_with_permissions(
|
|
19
|
+
AttributeOperationType.WRITE,
|
|
20
|
+
key,
|
|
21
|
+
)
|
|
22
|
+
|
|
23
|
+
read_attributes = OauthPresenter.default_attributes
|
|
24
|
+
for key in read_attributes:
|
|
25
|
+
OauthPolicy.attribute_rule_with_permissions(
|
|
26
|
+
AttributeOperationType.READ,
|
|
27
|
+
key,
|
|
28
|
+
)
|
|
29
|
+
|
|
30
|
+
for key in ['doesn’t exist', 'mage']:
|
|
31
|
+
OauthPolicy.attribute_rule_with_permissions(
|
|
32
|
+
AttributeOperationType.QUERY,
|
|
33
|
+
key,
|
|
34
|
+
)
|
|
35
|
+
except Exception:
|
|
36
|
+
error = True
|
|
37
|
+
|
|
38
|
+
self.assertFalse(error)
|
|
@@ -15,11 +15,11 @@ from mage_ai.data_preparation.models.global_hooks.models import (
|
|
|
15
15
|
Hook,
|
|
16
16
|
HookCondition,
|
|
17
17
|
HookOperation,
|
|
18
|
-
HookPredicate,
|
|
19
18
|
HookRunSettings,
|
|
20
19
|
HookStage,
|
|
21
20
|
HookStrategy,
|
|
22
21
|
)
|
|
22
|
+
from mage_ai.data_preparation.models.global_hooks.predicates import HookPredicate
|
|
23
23
|
from mage_ai.shared.array import find
|
|
24
24
|
from mage_ai.shared.io import safe_write
|
|
25
25
|
from mage_ai.tests.api.operations.test_base import BaseApiTestCase
|
|
@@ -53,7 +53,7 @@ def build_hook(
|
|
|
53
53
|
operation_type: HookOperation = None,
|
|
54
54
|
output: Dict = None,
|
|
55
55
|
pipeline: Dict = None,
|
|
56
|
-
|
|
56
|
+
predicate: HookPredicate = None,
|
|
57
57
|
resource_type: EntityName = None,
|
|
58
58
|
run_settings: HookRunSettings = None,
|
|
59
59
|
stages: List[HookStage] = None,
|
|
@@ -65,7 +65,7 @@ def build_hook(
|
|
|
65
65
|
operation_type=operation_type or HookOperation.DETAIL,
|
|
66
66
|
output=output,
|
|
67
67
|
pipeline=pipeline,
|
|
68
|
-
|
|
68
|
+
predicate=predicate,
|
|
69
69
|
resource_type=resource_type or EntityName.Pipeline,
|
|
70
70
|
run_settings=run_settings,
|
|
71
71
|
stages=stages or [HookStage.BEFORE],
|
|
@@ -491,19 +491,44 @@ class GlobalHooksTest(BaseApiTestCase):
|
|
|
491
491
|
stage=HookStage.BEFORE,
|
|
492
492
|
conditions=[HookCondition.SUCCESS, HookCondition.FAILURE],
|
|
493
493
|
operation_resource=dict(mage=1),
|
|
494
|
+
resource_id=1,
|
|
495
|
+
resource_parent_id=3,
|
|
496
|
+
user=dict(id=7),
|
|
494
497
|
)
|
|
495
498
|
|
|
496
499
|
self.global_hooks.get_and_run_hooks(
|
|
497
|
-
fire=2,
|
|
498
|
-
water=3,
|
|
499
500
|
**options,
|
|
500
501
|
)
|
|
501
502
|
|
|
502
|
-
mock_get_hooks.assert_called_once_with(
|
|
503
|
+
mock_get_hooks.assert_called_once_with(
|
|
504
|
+
[HookOperation.LIST, HookOperation.CREATE],
|
|
505
|
+
EntityName.Tag,
|
|
506
|
+
HookStage.BEFORE,
|
|
507
|
+
conditions=[HookCondition.SUCCESS, HookCondition.FAILURE],
|
|
508
|
+
error=None,
|
|
509
|
+
meta=None,
|
|
510
|
+
metadata=None,
|
|
511
|
+
operation_resource=dict(mage=1),
|
|
512
|
+
payload=None,
|
|
513
|
+
query=None,
|
|
514
|
+
resource=None,
|
|
515
|
+
resource_id=1,
|
|
516
|
+
resource_parent_id=3,
|
|
517
|
+
resources=None,
|
|
518
|
+
user=dict(id=7),
|
|
519
|
+
)
|
|
503
520
|
mock_run_hooks.assert_called_once_with(
|
|
504
521
|
hooks,
|
|
505
|
-
|
|
506
|
-
|
|
522
|
+
error=None,
|
|
523
|
+
meta=None,
|
|
524
|
+
metadata=None,
|
|
525
|
+
payload=None,
|
|
526
|
+
query=None,
|
|
527
|
+
resource=None,
|
|
528
|
+
resource_id=1,
|
|
529
|
+
resource_parent_id=3,
|
|
530
|
+
resources=None,
|
|
531
|
+
user=dict(id=7),
|
|
507
532
|
)
|
|
508
533
|
|
|
509
534
|
def test_save(self):
|