Flowfile 0.5.1__tar.gz → 0.5.6__tar.gz
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.
- {flowfile-0.5.1 → flowfile-0.5.6}/PKG-INFO +3 -4
- {flowfile-0.5.1 → flowfile-0.5.6}/build_backends/build_backends/main.py +25 -22
- {flowfile-0.5.1 → flowfile-0.5.6}/build_backends/build_backends/main_prd.py +10 -19
- flowfile-0.5.6/flowfile/flowfile/__init__.py +228 -0
- flowfile-0.5.6/flowfile/flowfile/__main__.py +153 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/api.py +51 -57
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/__init__.py +14 -9
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/AdminView-c2c7942b.js +713 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/AdminView-f53bad23.css +129 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CloudConnectionManager-0dfba9f2.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CloudConnectionView-7a3042c6.js +11 -11
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/CloudConnectionView-cf85f943.css +72 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CloudStorageReader-29d14fcc.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CloudStorageReader-24c54524.css +27 -27
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CloudStorageReader-d5b1b6c9.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CloudStorageReader-709c4037.js +10 -8
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CloudStorageWriter-00d87aad.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CloudStorageWriter-604c51a8.js +10 -8
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CloudStorageWriter-b0ee067f.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CloudStorageWriter-60547855.css +26 -26
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/ColumnActionInput-c44b7aee.css +159 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/ColumnActionInput-d63d6746.js +330 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ColumnSelector-4685e75d.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ColumnSelector-0c8cd1cd.js +3 -5
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ColumnSelector-47996a16.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ColumnSelector-371637fb.css +2 -2
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/ContextMenu-366bf1b4.js +9 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/ContextMenu-85cf5b44.js +9 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/ContextMenu-9d28ae6d.js +9 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/ContextMenu.vue_vue_type_script_setup_true_lang-774c517c.js +59 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CrossJoin-702a3edd.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CrossJoin-38e5b99a.js +12 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CrossJoin-1119d18e.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CrossJoin-71b4cc10.css +20 -20
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CustomNode-b1519993.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/CustomNode-76e8f3f5.js +43 -24
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/CustomNode-edb9b939.css +42 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseConnectionSettings-6f3e4ea5.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseConnectionSettings-38155669.js +5 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseConnectionSettings-0c04b2e5.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseConnectionSettings-c20a1e16.css +23 -21
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseReader-d38c7295.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseReader-2e549c8f.js +25 -15
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseReader-ae61773c.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseReader-5bf8c75b.css +41 -46
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseView-6655afd6.css +57 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseManager-cf5ef661.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseView-dc877c29.js +11 -11
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseWriter-2f570e53.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseWriter-bdcf2c8b.css +29 -27
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseWriter-b04ef46a.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DatabaseWriter-ffb91864.js +17 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/designer-8da3ba3a.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DesignerView-71d4e9a1.css +784 -663
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/designer-9633482a.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DesignerView-a4466dab.js +1402 -3310
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/documentation-ca400224.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DocumentationView-979afc84.js +5 -5
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/documentation-12216a74.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/DocumentationView-9ea6e871.css +9 -9
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ExploreData-2d0cf4db.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ExploreData-10c5acc8.css +13 -12
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ExploreData-5fa10ed8.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ExploreData-e4b92aaf.js +18 -9
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ExternalSource-e37b6275.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ExternalSource-7ac7373f.css +20 -20
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ExternalSource-d39af878.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ExternalSource-d08e7227.js +9 -7
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/Filter-7494ea97.css +48 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/Filter-7add806d.js +287 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Formula-6b04fb1d.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Formula-36ab24d2.js +13 -11
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Formula-bb96803d.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Formula-53d58c43.css +7 -7
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/FuzzyMatch-1010f966.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/FuzzyMatch-ad6361d6.css +68 -69
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/FuzzyMatch-999521f4.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/FuzzyMatch-cc01bb04.js +12 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Pivot-cf333e3d.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/GraphSolver-4b4d7db9.css +5 -5
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/GraphSolver-17dd2198.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/GraphSolver-4fb98f3b.js +14 -12
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/GroupBy-5792782d.css +9 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/GroupBy-6b039e18.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/GroupBy-b3c8f429.js +9 -7
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Join-24d0f113.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Join-096b7b26.js +13 -11
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Join-fd79b451.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Join-28b5e18f.css +22 -22
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/LoginView-c33a246a.js +134 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/LoginView-d325d632.css +172 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/ManualInput-39111f19.css +293 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ManualInput-34639209.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ManualInput-7307e9b1.js +217 -121
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/MultiSelect-0e8724a3.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/MultiSelect-14822c48.js +2 -2
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/MultiSelect.vue_vue_type_script_setup_true_lang-b0e538c2.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/MultiSelect.vue_vue_type_script_setup_true_lang-90c4d340.js +1 -1
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/NodeDesigner-5036c392.js +2712 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/NodeDesigner-94cd4dd3.css +1429 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/NumericInput-3d63a470.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/NumericInput-15cf3b72.js +2 -2
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/NumericInput.vue_vue_type_script_setup_true_lang-e0edeccc.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/NumericInput.vue_vue_type_script_setup_true_lang-91e679d7.js +5 -2
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Output-edea9802.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Output-1f8ed42c.js +14 -10
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/Output-692dd25d.css +37 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Pivot-61d19301.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Pivot-0e153f4e.js +12 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/GraphSolver-f0cb7bfb.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Pivot-0eda81b4.css +5 -5
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/PivotValidation-0e905b1a.css +13 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/PivotValidation-41b57ad6.css +13 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/PivotValidation-f97fec5b.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/PivotValidation-5a4f7c79.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/PivotValidation-de9f43fe.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/PivotValidation-81ec2a33.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/PolarsCode-650322d1.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/PolarsCode-2b1f1f23.css +4 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/PolarsCode-bc3c9984.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/PolarsCode-a39f15ac.js +18 -9
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/PopOver-d96599db.css +33 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/PopOver-ddcfe4f6.js +138 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Read-64a3f259.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Read-39b63932.js +16 -12
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Read-e808b239.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Read-90f366bc.css +15 -15
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/RecordCount-3d5039be.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/RecordCount-e9048ccd.js +6 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/RecordId-597510e0.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/RecordId-ad02521d.js +9 -7
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SQLQueryComponent-df51adbe.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SQLQueryComponent-2eeecf0b.js +3 -3
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/SQLQueryComponent-edb90b98.css +29 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Sample-4be0a507.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Sample-9a68c23d.js +6 -4
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/SecretSelector-2429f35a.js +113 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/SecretSelector-6329f743.css +43 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/SecretsView-aa291340.css +38 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SecretManager-4839be57.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SecretsView-c6afc915.js +35 -36
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Select-9b72f201.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Select-fcd002b6.js +9 -7
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SettingsSection-71e6b7e3.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SettingsSection-07fbbc39.css +4 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SettingsSection-5c696bee.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SettingsSection-26fe48d4.css +4 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SettingsSection-e1e9c953.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SettingsSection-5ce15962.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SettingsSection-2e4d03c4.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SettingsSection-8f980839.css +4 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SettingsSection-f0f75a42.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SettingsSection-c6b1362c.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SettingsSection-7ded385d.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SettingsSection-cebb91d5.js +3 -3
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/SetupView-2d12e01f.js +160 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/SetupView-ec26f76a.css +230 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SingleSelect-6c777aac.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SingleSelect-b67de4eb.js +2 -2
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SingleSelect.vue_vue_type_script_setup_true_lang-33e3ff9b.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SingleSelect.vue_vue_type_script_setup_true_lang-eedb70eb.js +1 -1
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/SliderInput-f2e4f23c.css +4 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SliderInput-7cb93e62.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/SliderInput-fd8134ac.js +7 -4
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/Sort-4abb7fae.css +9 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Sort-6cbde21a.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Sort-c005a573.js +9 -7
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/TextInput-d9a40c11.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/TextInput-1bb31dab.js +2 -2
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/TextInput.vue_vue_type_script_setup_true_lang-5896c375.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/TextInput.vue_vue_type_script_setup_true_lang-a51fe730.js +5 -2
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/TextToRows-5d2c1190.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/TextToRows-12afb4f4.css +10 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/TextToRows-c4fcbf4d.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/TextToRows-4f363753.js +11 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ToggleSwitch-4ef91d19.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ToggleSwitch-ca0f2e5e.js +2 -2
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ToggleSwitch.vue_vue_type_script_setup_true_lang-38478c20.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/ToggleSwitch.vue_vue_type_script_setup_true_lang-49aa41d8.js +1 -1
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/UnavailableFields-5edd5322.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/UnavailableFields-394a1f78.css +14 -14
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/UnavailableFields-a03f512c.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/UnavailableFields-f6147968.js +4 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Union-bfe9b996.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Union-c65f17b7.js +8 -6
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Union-af6c3d9b.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Union-d6a8d7d5.css +7 -7
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/Unique-2b705521.css +3 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Unique-5d023a27.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Unique-a1d96fb2.js +13 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Unpivot-1e422df3.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Unpivot-b6ad6427.css +7 -7
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Unpivot-91cc5354.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/Unpivot-c2657ff3.js +11 -9
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/UnpivotValidation-7ee2de44.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/UnpivotValidation-28e29a3b.js +3 -3
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/UnpivotValidation-d5ca3b7b.css +13 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/VueGraphicWalker-e51b9924.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/VueGraphicWalker-2fc3ddd4.js +4 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/VueGraphicWalker-ed5ab88b.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/VueGraphicWalker-430f0b86.css +1 -1
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/api-cf1221f0.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/api-df48ec50.js +1 -1
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/api-c1bad5ca.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/api-ee542cf7.js +1 -1
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/dropDown-35135ba8.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/dropDown-1d6acbd9.css +41 -41
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/dropDown-614b998d.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/dropDown-7576a76a.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/fullEditor-f7971590.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/fullEditor-7583bef5.js +11 -10
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/fullEditor-178376bb.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/fullEditor-fe9f7e18.css +77 -65
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/genericNodeSettings-4fe5f36b.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/genericNodeSettings-0155288b.js +4 -5
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/genericNodeSettings-924759c7.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/genericNodeSettings-3b2507ea.css +10 -10
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/index-057d770d.js +2696 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/index-aeec439d.js +38 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/index-5429bbf8.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/index-ca6799de.js +43903 -41047
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/index-50508d4d.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/index-d60c9dd4.css +2505 -579
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/node.types-2c15bb7e.js +82 -0
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/nodeInput-d478b9ac.js +2 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/outputCsv-076b85ab.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/outputCsv-c492b15e.js +3 -3
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/outputCsv-cc84e09f.css +2499 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/outputExcel-0fd17dbe.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/outputExcel-13bfa10f.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/outputExcel-b41305c0.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/outputExcel-f5d272b2.css +26 -26
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/outputParquet-54597c3c.css +4 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/outputParquet-b61e0847.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/outputParquet-9be1523a.js +4 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/readCsv-c767cb37.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/readCsv-3bfac4c3.css +15 -15
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/readCsv-a8bb8b61.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/readCsv-5a49a8c9.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/readExcel-67b4aee0.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/readExcel-27c30ad8.js +5 -5
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/readExcel-806d2826.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/readExcel-3db6b763.css +13 -13
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/readParquet-92ce1dbc.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/readParquet-446bde68.js +3 -3
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/readParquet-48c81530.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/readParquet-c5244ad5.css +4 -4
- flowfile-0.5.6/flowfile/flowfile/web/static/assets/secrets.api-34431884.js +65 -0
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/selectDynamic-92e25ee3.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/selectDynamic-5754a2b1.js +4 -5
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/selectDynamic-aa913ff4.css → flowfile-0.5.6/flowfile/flowfile/web/static/assets/selectDynamic-f2fb394f.css +21 -20
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/vue-codemirror.esm-41b0e0d7.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/vue-codemirror.esm-8f46fb36.js +31 -640
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/vue-content-loader.es-2c8e608f.js → flowfile-0.5.6/flowfile/flowfile/web/static/assets/vue-content-loader.es-808fe33a.js +1 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/index.html +2 -2
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/__init__.py +13 -6
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/auth/jwt.py +51 -16
- flowfile-0.5.6/flowfile_core/flowfile_core/auth/models.py +65 -0
- flowfile-0.5.6/flowfile_core/flowfile_core/auth/password.py +89 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/auth/secrets.py +64 -19
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/configs/__init__.py +9 -7
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/configs/flow_logger.py +15 -14
- flowfile-0.5.6/flowfile_core/flowfile_core/configs/node_store/__init__.py +98 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/configs/node_store/nodes.py +155 -172
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/configs/node_store/user_defined_node_registry.py +108 -27
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/configs/settings.py +28 -15
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/database/connection.py +7 -6
- flowfile-0.5.6/flowfile_core/flowfile_core/database/init_db.py +138 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/database/models.py +3 -1
- flowfile-0.5.6/flowfile_core/flowfile_core/fileExplorer/__init__.py +17 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/fileExplorer/funcs.py +145 -57
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/fileExplorer/utils.py +10 -11
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/_extensions/real_time_interface.py +10 -8
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/analytics/analytics_processor.py +26 -24
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/analytics/graphic_walker.py +11 -12
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/code_generator/__init__.py +11 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/code_generator/code_generator.py +706 -247
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/connection_manager/_connection_manager.py +6 -5
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/database_connection_manager/db_connections.py +60 -44
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/database_connection_manager/models.py +1 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/extensions.py +17 -12
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/cloud_storage_reader.py +34 -32
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/create/funcs.py +206 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_data_engine.py +493 -423
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column/interface.py +4 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column/main.py +92 -52
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column/polars_type.py +25 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column/type_registry.py +6 -6
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column/utils.py +26 -30
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/fuzzy_matching/prepare_for_fuzzy_match.py +31 -20
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/join/__init__.py +1 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/join/utils.py +11 -9
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/join/verify_integrity.py +14 -15
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/pivot_table.py +18 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/polars_code_parser.py +95 -82
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/read_excel_tables.py +144 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/sample_data.py +27 -21
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/subprocess_operations/__init__.py +1 -1
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/subprocess_operations/models.py +38 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/subprocess_operations/subprocess_operations.py +202 -127
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/threaded_processes.py +8 -8
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/utils.py +99 -67
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_graph.py +920 -571
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_graph_utils.py +31 -49
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_node/flow_node.py +379 -258
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_node/models.py +53 -41
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_node/schema_callback.py +14 -19
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/graph_tree/graph_tree.py +41 -41
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/handler.py +161 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/manage/compatibility_enhancements.py +209 -126
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/manage/io_flowfile.py +54 -57
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/node_designer/__init__.py +19 -13
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/node_designer/_type_registry.py +34 -37
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/node_designer/custom_node.py +162 -36
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/node_designer/ui_components.py +521 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/schema_callbacks.py +71 -51
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/setting_generator/__init__.py +0 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/setting_generator/setting_generator.py +6 -5
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/setting_generator/settings.py +64 -53
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/base_class.py +12 -10
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/custom_external_sources/external_source.py +27 -17
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/custom_external_sources/sample_users.py +9 -9
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/factory.py +0 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/sql_source/models.py +45 -31
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/sql_source/sql_source.py +198 -73
- flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/sources/external_sources/sql_source/utils.py +433 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/util/calculate_layout.py +9 -13
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/util/execution_orderer.py +25 -17
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/util/node_skipper.py +4 -4
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/utils.py +19 -21
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/main.py +28 -23
- flowfile-0.5.6/flowfile_core/flowfile_core/routes/auth.py +307 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/routes/cloud_connections.py +25 -25
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/routes/logs.py +21 -29
- flowfile-0.5.6/flowfile_core/flowfile_core/routes/public.py +53 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/routes/routes.py +70 -34
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/routes/secrets.py +25 -27
- flowfile-0.5.6/flowfile_core/flowfile_core/routes/user_defined_components.py +534 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/run_lock.py +0 -1
- flowfile-0.5.6/flowfile_core/flowfile_core/schemas/__init__.py +6 -0
- flowfile-0.5.6/flowfile_core/flowfile_core/schemas/analysis_schemas/graphic_walker_schemas.py +118 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/schemas/cloud_storage_schemas.py +96 -66
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/schemas/input_schema.py +231 -144
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/schemas/output_model.py +49 -34
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/schemas/schemas.py +116 -89
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/schemas/transform_schema.py +518 -263
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/schemas/yaml_types.py +21 -7
- flowfile-0.5.6/flowfile_core/flowfile_core/secret_manager/secret_manager.py +169 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/types.py +29 -9
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/utils/arrow_reader.py +7 -6
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/utils/excel_file_manager.py +3 -3
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/utils/fileManager.py +7 -7
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/utils/fl_executor.py +8 -10
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/utils/utils.py +4 -4
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/utils/validate_setup.py +5 -4
- flowfile-0.5.6/flowfile_frame/flowfile_frame/__init__.py +135 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/adapters.py +2 -9
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/adding_expr.py +73 -32
- flowfile-0.5.6/flowfile_frame/flowfile_frame/cloud_storage/frame_helpers.py +43 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/cloud_storage/secret_manager.py +12 -26
- flowfile-0.5.6/flowfile_frame/flowfile_frame/config.py +6 -0
- flowfile-0.5.6/flowfile_frame/flowfile_frame/database/__init__.py +36 -0
- flowfile-0.5.6/flowfile_frame/flowfile_frame/database/connection_manager.py +205 -0
- flowfile-0.5.6/flowfile_frame/flowfile_frame/database/frame_helpers.py +249 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/expr.py +311 -218
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/expr.pyi +160 -159
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/expr_name.py +23 -23
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/flow_frame.py +571 -476
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/flow_frame.pyi +123 -104
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/flow_frame_methods.py +227 -246
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/group_frame.py +50 -20
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/join.py +2 -2
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/lazy.py +129 -87
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/lazy_methods.py +83 -30
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/list_name_space.py +55 -50
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/selectors.py +148 -68
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/series.py +9 -7
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_frame/flowfile_frame/utils.py +19 -21
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/__init__.py +12 -7
- flowfile-0.5.6/flowfile_worker/flowfile_worker/configs.py +103 -0
- flowfile-0.5.6/flowfile_worker/flowfile_worker/create/__init__.py +24 -0
- flowfile-0.5.6/flowfile_worker/flowfile_worker/create/funcs.py +195 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/create/models.py +46 -43
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/create/pl_types.py +14 -15
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/create/read_excel_tables.py +34 -41
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/create/utils.py +22 -19
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/external_sources/s3_source/main.py +18 -51
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/external_sources/s3_source/models.py +34 -27
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/external_sources/sql_source/main.py +8 -5
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/external_sources/sql_source/models.py +13 -9
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/flow_logger.py +10 -8
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/funcs.py +214 -155
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/main.py +11 -17
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/models.py +35 -28
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/process_manager.py +2 -3
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/routes.py +121 -90
- flowfile-0.5.6/flowfile_worker/flowfile_worker/secrets.py +241 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/spawner.py +89 -54
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_worker/flowfile_worker/utils.py +3 -2
- {flowfile-0.5.1 → flowfile-0.5.6}/pyproject.toml +75 -4
- {flowfile-0.5.1 → flowfile-0.5.6}/shared/__init__.py +2 -7
- {flowfile-0.5.1 → flowfile-0.5.6}/shared/storage_config.py +25 -13
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/postgres/commands.py +3 -2
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/postgres/fixtures.py +9 -9
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/s3/commands.py +1 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/s3/data_generator.py +3 -4
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/s3/demo_data_generator.py +4 -7
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/s3/fixtures.py +7 -5
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/__init__.py +1 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/__main__.py +16 -29
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/legacy_schemas.py +251 -190
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/migrate.py +193 -181
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/tests/conftest.py +1 -3
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/tests/test_migrate.py +36 -41
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/tests/test_migration_e2e.py +28 -29
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/tests/test_node_migrations.py +50 -20
- flowfile-0.5.1/flowfile/flowfile/__init__.py +0 -108
- flowfile-0.5.1/flowfile/flowfile/__main__.py +0 -57
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CloudConnectionManager-2dfdce2f.css +0 -86
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ContextMenu-23e909da.js +0 -41
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ContextMenu-4c74eef1.css +0 -26
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ContextMenu-63cfa99b.css +0 -26
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ContextMenu-70ae0c79.js +0 -41
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ContextMenu-c13f91d0.css +0 -26
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ContextMenu-f149cf7c.js +0 -41
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/CustomNode-74a37f74.css +0 -32
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/DatabaseManager-30fa27e5.css +0 -64
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Filter-9b6d08db.js +0 -164
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Filter-f62091b3.css +0 -20
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/GroupBy-b9505323.css +0 -51
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/ManualInput-3246a08d.css +0 -96
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Output-283fe388.css +0 -37
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/PivotValidation-891ddfb0.css +0 -13
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/PivotValidation-c46cd420.css +0 -13
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SQLQueryComponent-36cef432.css +0 -27
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/SliderInput-b8fb6a8c.css +0 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Sort-3643d625.css +0 -51
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/Unique-f9fb0809.css +0 -51
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/UnpivotValidation-0d240eeb.css +0 -13
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/nodeInput-5d0d6b79.js +0 -41
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/outputCsv-9cc59e0b.css +0 -2499
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/outputParquet-cf8cf3f2.css +0 -4
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/secretApi-68435402.js +0 -46
- flowfile-0.5.1/flowfile/flowfile/web/static/assets/vue-codemirror-bccfde04.css +0 -32
- flowfile-0.5.1/flowfile_core/flowfile_core/auth/models.py +0 -40
- flowfile-0.5.1/flowfile_core/flowfile_core/configs/node_store/__init__.py +0 -30
- flowfile-0.5.1/flowfile_core/flowfile_core/database/init_db.py +0 -44
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/create/funcs.py +0 -174
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column/interface.py +0 -4
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column/polars_type.py +0 -24
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/pivot_table.py +0 -20
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/read_excel_tables.py +0 -143
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/subprocess_operations/models.py +0 -36
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/handler.py +0 -111
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/node_designer/ui_components.py +0 -277
- flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/sources/external_sources/sql_source/utils.py +0 -379
- flowfile-0.5.1/flowfile_core/flowfile_core/routes/auth.py +0 -34
- flowfile-0.5.1/flowfile_core/flowfile_core/routes/public.py +0 -11
- flowfile-0.5.1/flowfile_core/flowfile_core/routes/user_defined_components.py +0 -55
- flowfile-0.5.1/flowfile_core/flowfile_core/schemas/__init__.py +0 -8
- flowfile-0.5.1/flowfile_core/flowfile_core/schemas/analysis_schemas/graphic_walker_schemas.py +0 -118
- flowfile-0.5.1/flowfile_core/flowfile_core/secret_manager/secret_manager.py +0 -64
- flowfile-0.5.1/flowfile_frame/flowfile_frame/__init__.py +0 -69
- flowfile-0.5.1/flowfile_frame/flowfile_frame/cloud_storage/frame_helpers.py +0 -39
- flowfile-0.5.1/flowfile_frame/flowfile_frame/config.py +0 -9
- flowfile-0.5.1/flowfile_worker/flowfile_worker/configs.py +0 -95
- flowfile-0.5.1/flowfile_worker/flowfile_worker/create/__init__.py +0 -19
- flowfile-0.5.1/flowfile_worker/flowfile_worker/create/funcs.py +0 -158
- flowfile-0.5.1/flowfile_worker/flowfile_worker/secrets.py +0 -148
- flowfile-0.5.1/tools/__init__.py +0 -0
- flowfile-0.5.1/tools/migrate/tests/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/LICENSE +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/build_backends/build_backends/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/airbyte-292aa232.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/cloud_storage_reader-aa1415d6.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/cross_join-d30c0290.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/database_reader-ce1e55f3.svg +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/database_writer-b4ad0753.svg +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/element-icons-9c88a535.woff +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/element-icons-de5eb258.ttf +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/explore_data-8a0a2861.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-brands-400-808443ae.ttf +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-brands-400-d7236a19.woff2 +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-regular-400-54cf6086.ttf +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-regular-400-e3456d12.woff2 +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-solid-900-aa759986.woff2 +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-solid-900-d2f05935.ttf +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-v4compatibility-0ce9033c.woff2 +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fa-v4compatibility-30f6abf6.ttf +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/filter-d7708bda.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/formula-eeeb1611.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/fuzzy_match-40c161b2.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/graph_solver-8b7888b8.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/group_by-80561fc3.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/input_data-ab2eb678.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/join-349043ae.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/manual_input-ae98f31d.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/old_join-5d0eb604.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/output-06ec0371.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/pivot-9660df51.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/polars_code-05ce5dc6.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/record_count-dab44eb5.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/record_id-0b15856b.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/sample-693a88b5.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/select-b0d0437a.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/sort-2aa579f0.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/summarize-2a099231.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/text_to_rows-859b29ea.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/union-2d8609f4.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/unique-1958b98a.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/unpivot-d3cb4b5b.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/user-defined-icon-0ae16c90.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/assets/view-7a0f0be1.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/favicon.ico +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/flowfile.svg +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/icons/flowfile.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/images/airbyte.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/images/flowfile.svg +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/images/google.svg +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/images/sheets.png +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/vite.svg +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile/flowfile/web/static/vue.svg +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/auth/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/configs/utils.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/database/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/fileExplorer → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/_extensions}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/_extensions → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/analytics}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/analytics → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/analytics/schemas}/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/analytics/utils.py +1 -1
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/connection_manager/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/connection_manager/models.py +1 -1
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/analytics/schemas → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/database_connection_manager}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/code_generator → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/database_connection_manager → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/create}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/create → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_data_engine/fuzzy_matching}/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/flow_data_engine/types.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/flow_file_column → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/flow_node}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_data_engine/fuzzy_matching → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/graph_tree}/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/graph_tree/models.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/flow_node → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/manage}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/graph_tree → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/sources}/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/custom_external_sources/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/flowfile_core/flowfile_core/flowfile/sources/external_sources/custom_external_sources/exchange_rate.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/manage → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/sources/external_sources/sql_source}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/sources → flowfile-0.5.6/flowfile_core/flowfile_core/flowfile/util}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/sources/external_sources/sql_source → flowfile-0.5.6/flowfile_core/flowfile_core/routes}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/flowfile/util → flowfile-0.5.6/flowfile_core/flowfile_core/schemas/analysis_schemas}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/routes → flowfile-0.5.6/flowfile_core/flowfile_core/secret_manager}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/schemas/analysis_schemas → flowfile-0.5.6/flowfile_core/flowfile_core/utils}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/secret_manager → flowfile-0.5.6/flowfile_frame/flowfile_frame/cloud_storage}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_core/flowfile_core/utils → flowfile-0.5.6/flowfile_worker/flowfile_worker/external_sources}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_frame/flowfile_frame/cloud_storage → flowfile-0.5.6/flowfile_worker/flowfile_worker/external_sources/s3_source}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_worker/flowfile_worker/external_sources → flowfile-0.5.6/flowfile_worker/flowfile_worker/external_sources/sql_source}/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/readme-pypi.md +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/test_utils/postgres/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_worker/flowfile_worker/external_sources/s3_source → flowfile-0.5.6/test_utils/s3}/__init__.py +0 -0
- {flowfile-0.5.1/flowfile_worker/flowfile_worker/external_sources/sql_source → flowfile-0.5.6/tools}/__init__.py +0 -0
- {flowfile-0.5.1 → flowfile-0.5.6}/tools/migrate/README.md +0 -0
- {flowfile-0.5.1/test_utils/s3 → flowfile-0.5.6/tools/migrate/tests}/__init__.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: Flowfile
|
|
3
|
-
Version: 0.5.
|
|
3
|
+
Version: 0.5.6
|
|
4
4
|
Summary: Project combining flowfile core (backend) and flowfile_worker (compute offloader) and flowfile_frame (api)
|
|
5
5
|
License-File: LICENSE
|
|
6
6
|
Author: Edward van Eechoud
|
|
@@ -33,16 +33,15 @@ Requires-Dist: polars (>=1.8.2,<1.32) ; sys_platform != "win32"
|
|
|
33
33
|
Requires-Dist: polars (>=1.8.2,<=1.25.2) ; sys_platform == "win32"
|
|
34
34
|
Requires-Dist: polars-distance (>=0.4.3,<0.5.0)
|
|
35
35
|
Requires-Dist: polars-ds (>=0.6.0)
|
|
36
|
-
Requires-Dist: polars-expr-transformer (>=0.
|
|
36
|
+
Requires-Dist: polars-expr-transformer (>=0.5.0)
|
|
37
37
|
Requires-Dist: polars-grouper (>=0.3.0,<0.4.0)
|
|
38
38
|
Requires-Dist: polars_simed (>=0.3.4,<0.4.0)
|
|
39
39
|
Requires-Dist: pyarrow (>=18.0.0,<19.0.0)
|
|
40
40
|
Requires-Dist: pydantic (>=2.9.2,<2.10.0)
|
|
41
41
|
Requires-Dist: pyiceberg[hadoop] (>=0.9.1,<0.10.0)
|
|
42
|
-
Requires-Dist: pyinstaller (>=6.11.0,<7.0.0)
|
|
43
|
-
Requires-Dist: pytest (>=8.3.4,<9.0.0)
|
|
44
42
|
Requires-Dist: python-jose (>=3.4.0,<4.0.0)
|
|
45
43
|
Requires-Dist: python-multipart (>=0.0.12,<0.1.0)
|
|
44
|
+
Requires-Dist: pyyaml (>=6.0.3,<7.0.0)
|
|
46
45
|
Requires-Dist: s3fs (>=2025.7.0,<2026.0.0)
|
|
47
46
|
Requires-Dist: tqdm (>=4.67.1,<5.0.0)
|
|
48
47
|
Requires-Dist: uvicorn (>=0.32.0,<0.33.0)
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import os
|
|
2
|
-
import subprocess
|
|
3
2
|
import platform
|
|
4
3
|
import shutil
|
|
4
|
+
import subprocess
|
|
5
5
|
from pathlib import Path
|
|
6
|
-
from typing import List
|
|
7
6
|
|
|
8
7
|
|
|
9
|
-
def merge_directories(directories:
|
|
8
|
+
def merge_directories(directories: list[str], target_dir: str, cleanup_after_merge: bool = True):
|
|
10
9
|
"""
|
|
11
10
|
Merge all files from two folders into a new target directory.
|
|
12
11
|
After successful merge, removes the original folders.
|
|
@@ -16,9 +15,9 @@ def merge_directories(directories: List[str], target_dir: str, cleanup_after_mer
|
|
|
16
15
|
for directory in directories:
|
|
17
16
|
if os.path.exists(directory):
|
|
18
17
|
shutil.copytree(directory, target_dir, dirs_exist_ok=True)
|
|
19
|
-
print(
|
|
18
|
+
print("Merged directories:", directories, "into", target_dir)
|
|
20
19
|
if cleanup_after_merge:
|
|
21
|
-
print(
|
|
20
|
+
print("Cleaning up directories:", directories)
|
|
22
21
|
for directory in directories:
|
|
23
22
|
if os.path.exists(directory):
|
|
24
23
|
shutil.rmtree(directory)
|
|
@@ -197,25 +196,28 @@ coll = COLLECT(
|
|
|
197
196
|
name='{output_name}'
|
|
198
197
|
)
|
|
199
198
|
'''
|
|
200
|
-
spec_path = f
|
|
201
|
-
with open(spec_path,
|
|
199
|
+
spec_path = f"{output_name}.spec"
|
|
200
|
+
with open(spec_path, "w") as f:
|
|
202
201
|
f.write(spec_content)
|
|
203
202
|
return spec_path
|
|
204
203
|
|
|
204
|
+
|
|
205
205
|
def build_backend(directory, script_name, output_name, hidden_imports=None):
|
|
206
206
|
try:
|
|
207
207
|
spec_path = create_spec_file(directory, script_name, output_name, hidden_imports)
|
|
208
208
|
|
|
209
209
|
env = os.environ.copy()
|
|
210
|
-
env[
|
|
210
|
+
env["PYTHONOPTIMIZE"] = "1"
|
|
211
211
|
|
|
212
212
|
command = [
|
|
213
213
|
"pyinstaller",
|
|
214
214
|
"--clean",
|
|
215
215
|
"-y",
|
|
216
|
-
"--dist",
|
|
217
|
-
"
|
|
218
|
-
|
|
216
|
+
"--dist",
|
|
217
|
+
"./services_dist",
|
|
218
|
+
"--workpath",
|
|
219
|
+
"/tmp" if platform.system() != "Windows" else os.path.join(os.getenv("TEMP"), "pyinstaller"),
|
|
220
|
+
spec_path,
|
|
219
221
|
]
|
|
220
222
|
|
|
221
223
|
print(f"Building {output_name}...")
|
|
@@ -247,7 +249,7 @@ def combine_packages():
|
|
|
247
249
|
exe_name = project + ".exe" if platform.system() == "Windows" else project
|
|
248
250
|
src_exe = os.path.join(src_dir, exe_name)
|
|
249
251
|
temp_target_exe = os.path.join(dist_dir, "_" + exe_name)
|
|
250
|
-
target_exe = os.path.join(dist_dir,
|
|
252
|
+
target_exe = os.path.join(dist_dir, exe_name)
|
|
251
253
|
if os.path.exists(src_exe) and os.path.isfile(src_exe):
|
|
252
254
|
# Instead of removing, overwrite the target
|
|
253
255
|
shutil.move(src_exe, temp_target_exe)
|
|
@@ -257,9 +259,10 @@ def combine_packages():
|
|
|
257
259
|
if platform.system() == "Windows" and os.path.exists(os.path.join(dist_dir, project)):
|
|
258
260
|
shutil.rmtree(os.path.join(dist_dir, project))
|
|
259
261
|
|
|
262
|
+
|
|
260
263
|
def main():
|
|
261
264
|
# Clean previous builds
|
|
262
|
-
for dir_name in [
|
|
265
|
+
for dir_name in ["services_dist"]:
|
|
263
266
|
if os.path.exists(dir_name):
|
|
264
267
|
shutil.rmtree(dir_name)
|
|
265
268
|
|
|
@@ -286,20 +289,20 @@ def main():
|
|
|
286
289
|
# Build flowfile_worker
|
|
287
290
|
|
|
288
291
|
if not build_backend(
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
292
|
+
directory=os.path.join("flowfile_worker", "flowfile_worker"),
|
|
293
|
+
script_name="main.py",
|
|
294
|
+
output_name="flowfile_worker",
|
|
295
|
+
hidden_imports=common_imports,
|
|
293
296
|
):
|
|
294
297
|
builds_successful = False
|
|
295
298
|
|
|
296
299
|
# Build flowfile_core
|
|
297
300
|
|
|
298
301
|
if not build_backend(
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
302
|
+
directory=os.path.join("flowfile_core", "flowfile_core"),
|
|
303
|
+
script_name="main.py",
|
|
304
|
+
output_name="flowfile_core",
|
|
305
|
+
hidden_imports=common_imports,
|
|
303
306
|
):
|
|
304
307
|
builds_successful = False
|
|
305
308
|
|
|
@@ -310,4 +313,4 @@ def main():
|
|
|
310
313
|
|
|
311
314
|
|
|
312
315
|
# if __name__ == "__main__":
|
|
313
|
-
# main()
|
|
316
|
+
# main()
|
|
@@ -1,14 +1,9 @@
|
|
|
1
|
-
import os
|
|
2
|
-
import subprocess
|
|
3
|
-
import platform
|
|
4
|
-
from concurrent.futures import ProcessPoolExecutor, wait
|
|
5
|
-
|
|
6
1
|
import subprocess
|
|
7
2
|
import time
|
|
8
|
-
import requests
|
|
9
|
-
from statistics import mean, stdev
|
|
10
|
-
import sys
|
|
11
3
|
from datetime import datetime
|
|
4
|
+
from statistics import mean, stdev
|
|
5
|
+
|
|
6
|
+
import requests
|
|
12
7
|
|
|
13
8
|
|
|
14
9
|
def wait_for_endpoint(url, timeout=60):
|
|
@@ -27,11 +22,7 @@ def wait_for_endpoint(url, timeout=60):
|
|
|
27
22
|
def shutdown_service():
|
|
28
23
|
"""Shutdown the service gracefully using the shutdown endpoint."""
|
|
29
24
|
try:
|
|
30
|
-
response = requests.post(
|
|
31
|
-
'http://0.0.0.0:63578/shutdown',
|
|
32
|
-
headers={'accept': 'application/json'},
|
|
33
|
-
data=''
|
|
34
|
-
)
|
|
25
|
+
response = requests.post("http://0.0.0.0:63578/shutdown", headers={"accept": "application/json"}, data="")
|
|
35
26
|
print("Shutdown request sent, waiting for service to stop...")
|
|
36
27
|
time.sleep(1) # Wait 10 seconds to ensure the service is fully stopped
|
|
37
28
|
return True
|
|
@@ -97,14 +88,14 @@ def run_comparison_test(old_exe, new_exe, num_runs=3):
|
|
|
97
88
|
print("\nResults:")
|
|
98
89
|
print("-" * 50)
|
|
99
90
|
if old_times:
|
|
100
|
-
print(
|
|
91
|
+
print("Old executable:")
|
|
101
92
|
print(f" Average: {mean(old_times):.3f} seconds")
|
|
102
93
|
print(f" Std Dev: {stdev(old_times):.3f} seconds" if len(old_times) > 1 else " Std Dev: N/A")
|
|
103
94
|
print(f" Min: {min(old_times):.3f} seconds")
|
|
104
95
|
print(f" Max: {max(old_times):.3f} seconds")
|
|
105
96
|
|
|
106
97
|
if new_times:
|
|
107
|
-
print(
|
|
98
|
+
print("\nNew executable:")
|
|
108
99
|
print(f" Average: {mean(new_times):.3f} seconds")
|
|
109
100
|
print(f" Std Dev: {stdev(new_times):.3f} seconds" if len(new_times) > 1 else " Std Dev: N/A")
|
|
110
101
|
print(f" Min: {min(new_times):.3f} seconds")
|
|
@@ -112,13 +103,13 @@ def run_comparison_test(old_exe, new_exe, num_runs=3):
|
|
|
112
103
|
|
|
113
104
|
if old_times and new_times:
|
|
114
105
|
improvement = (mean(old_times) - mean(new_times)) / mean(old_times) * 100
|
|
115
|
-
print(
|
|
106
|
+
print("\nPerformance difference:")
|
|
116
107
|
print(f" {improvement:.1f}% {'faster' if improvement > 0 else 'slower'} than old version")
|
|
117
108
|
|
|
118
109
|
|
|
119
110
|
if __name__ == "__main__":
|
|
120
|
-
old_exe =
|
|
121
|
-
new_exe =
|
|
111
|
+
old_exe = "/Users/edwardvanechoud/personal_dev/Flowfile/dist/flowfile_core/flowfile_core"
|
|
112
|
+
new_exe = "/Users/edwardvanechoud/personal_dev/Flowfile/dist_flowfile_core/flowfile_core"
|
|
122
113
|
|
|
123
114
|
run_comparison_test(old_exe, old_exe)
|
|
124
115
|
|
|
@@ -199,4 +190,4 @@ if __name__ == "__main__":
|
|
|
199
190
|
#
|
|
200
191
|
#
|
|
201
192
|
# if __name__ == "__main__":
|
|
202
|
-
# main()
|
|
193
|
+
# main()
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
"""
|
|
2
|
+
FlowFile: A framework combining visual ETL with a Polars-like API.
|
|
3
|
+
|
|
4
|
+
This package ties together the FlowFile ecosystem components:
|
|
5
|
+
- flowfile_core: Core ETL functionality
|
|
6
|
+
- flowfile_frame: Polars-like DataFrame API
|
|
7
|
+
- flowfile_worker: Computation engine
|
|
8
|
+
"""
|
|
9
|
+
|
|
10
|
+
from importlib.metadata import PackageNotFoundError, version
|
|
11
|
+
|
|
12
|
+
try:
|
|
13
|
+
__version__ = version("Flowfile")
|
|
14
|
+
except PackageNotFoundError:
|
|
15
|
+
__version__ = "0.5.0"
|
|
16
|
+
|
|
17
|
+
import logging
|
|
18
|
+
import os
|
|
19
|
+
|
|
20
|
+
os.environ["FLOWFILE_WORKER_PORT"] = "63578"
|
|
21
|
+
os.environ["FLOWFILE_SINGLE_FILE_MODE"] = "1"
|
|
22
|
+
|
|
23
|
+
from polars.datatypes import (
|
|
24
|
+
Array,
|
|
25
|
+
Binary,
|
|
26
|
+
Boolean,
|
|
27
|
+
Categorical,
|
|
28
|
+
DataType,
|
|
29
|
+
DataTypeClass,
|
|
30
|
+
Date,
|
|
31
|
+
Datetime,
|
|
32
|
+
Decimal,
|
|
33
|
+
Duration,
|
|
34
|
+
Enum,
|
|
35
|
+
Field,
|
|
36
|
+
Float32,
|
|
37
|
+
Float64,
|
|
38
|
+
Int8,
|
|
39
|
+
Int16,
|
|
40
|
+
Int32,
|
|
41
|
+
Int64,
|
|
42
|
+
Int128,
|
|
43
|
+
List,
|
|
44
|
+
Null,
|
|
45
|
+
Object,
|
|
46
|
+
String,
|
|
47
|
+
Struct,
|
|
48
|
+
Time,
|
|
49
|
+
UInt8,
|
|
50
|
+
UInt16,
|
|
51
|
+
UInt32,
|
|
52
|
+
UInt64,
|
|
53
|
+
Unknown,
|
|
54
|
+
Utf8,
|
|
55
|
+
)
|
|
56
|
+
|
|
57
|
+
from flowfile.api import open_graph_in_editor
|
|
58
|
+
from flowfile.web import start_server as start_web_ui
|
|
59
|
+
from flowfile_core.flowfile import node_designer
|
|
60
|
+
from flowfile_core.flowfile.flow_data_engine.flow_data_engine import FlowDataEngine
|
|
61
|
+
from flowfile_core.flowfile.flow_data_engine.flow_file_column.main import FlowfileColumn
|
|
62
|
+
from flowfile_core.flowfile.flow_graph import FlowGraph
|
|
63
|
+
from flowfile_core.flowfile.flow_node.flow_node import FlowNode
|
|
64
|
+
from flowfile_core.schemas import input_schema as node_interface
|
|
65
|
+
from flowfile_core.schemas import transform_schema
|
|
66
|
+
from flowfile_core.schemas.cloud_storage_schemas import FullCloudStorageConnection
|
|
67
|
+
from flowfile_core.schemas.schemas import FlowInformation, FlowSettings
|
|
68
|
+
from flowfile_frame import (
|
|
69
|
+
FuzzyMapping,
|
|
70
|
+
concat,
|
|
71
|
+
create_cloud_storage_connection,
|
|
72
|
+
create_cloud_storage_connection_if_not_exists,
|
|
73
|
+
create_database_connection,
|
|
74
|
+
create_database_connection_if_not_exists,
|
|
75
|
+
del_cloud_storage_connection,
|
|
76
|
+
del_database_connection,
|
|
77
|
+
from_dict,
|
|
78
|
+
get_all_available_cloud_storage_connections,
|
|
79
|
+
get_all_available_database_connections,
|
|
80
|
+
get_database_connection_by_name,
|
|
81
|
+
read_csv,
|
|
82
|
+
read_database,
|
|
83
|
+
read_parquet,
|
|
84
|
+
scan_csv,
|
|
85
|
+
scan_csv_from_cloud_storage,
|
|
86
|
+
scan_delta,
|
|
87
|
+
scan_json_from_cloud_storage,
|
|
88
|
+
scan_parquet,
|
|
89
|
+
scan_parquet_from_cloud_storage,
|
|
90
|
+
write_database,
|
|
91
|
+
)
|
|
92
|
+
from flowfile_frame.expr import col, column, count, cum_count, len, lit, max, mean, min, sum, when
|
|
93
|
+
from flowfile_frame.flow_frame import FlowFrame
|
|
94
|
+
from flowfile_frame.group_frame import GroupByFrame
|
|
95
|
+
from flowfile_frame.selectors import (
|
|
96
|
+
all_,
|
|
97
|
+
boolean,
|
|
98
|
+
by_dtype,
|
|
99
|
+
categorical,
|
|
100
|
+
contains,
|
|
101
|
+
date,
|
|
102
|
+
datetime,
|
|
103
|
+
duration,
|
|
104
|
+
ends_with,
|
|
105
|
+
float_,
|
|
106
|
+
integer,
|
|
107
|
+
list_,
|
|
108
|
+
matches,
|
|
109
|
+
numeric,
|
|
110
|
+
object_,
|
|
111
|
+
starts_with,
|
|
112
|
+
string,
|
|
113
|
+
struct,
|
|
114
|
+
temporal,
|
|
115
|
+
time,
|
|
116
|
+
)
|
|
117
|
+
from flowfile_frame.utils import create_flow_graph
|
|
118
|
+
|
|
119
|
+
__all__ = [
|
|
120
|
+
# Core FlowFrame classes
|
|
121
|
+
"FlowFrame",
|
|
122
|
+
"GroupByFrame",
|
|
123
|
+
"FullCloudStorageConnection",
|
|
124
|
+
# Main creation functions
|
|
125
|
+
"read_csv",
|
|
126
|
+
"read_parquet",
|
|
127
|
+
"from_dict",
|
|
128
|
+
"concat",
|
|
129
|
+
"scan_csv",
|
|
130
|
+
"scan_parquet",
|
|
131
|
+
"scan_delta",
|
|
132
|
+
"scan_parquet_from_cloud_storage",
|
|
133
|
+
"scan_json_from_cloud_storage",
|
|
134
|
+
"scan_csv_from_cloud_storage",
|
|
135
|
+
# Cloud storage connection management
|
|
136
|
+
"get_all_available_cloud_storage_connections",
|
|
137
|
+
"create_cloud_storage_connection",
|
|
138
|
+
"del_cloud_storage_connection",
|
|
139
|
+
"create_cloud_storage_connection_if_not_exists",
|
|
140
|
+
# Database functions
|
|
141
|
+
"read_database",
|
|
142
|
+
"write_database",
|
|
143
|
+
"create_database_connection",
|
|
144
|
+
"create_database_connection_if_not_exists",
|
|
145
|
+
"del_database_connection",
|
|
146
|
+
"get_all_available_database_connections",
|
|
147
|
+
"get_database_connection_by_name",
|
|
148
|
+
"FlowGraph",
|
|
149
|
+
"FlowDataEngine",
|
|
150
|
+
"node_interface",
|
|
151
|
+
"FlowSettings",
|
|
152
|
+
"transform_schema",
|
|
153
|
+
"FlowNode",
|
|
154
|
+
"FlowfileColumn",
|
|
155
|
+
"FlowInformation",
|
|
156
|
+
"FuzzyMapping",
|
|
157
|
+
# Expression API
|
|
158
|
+
"col",
|
|
159
|
+
"lit",
|
|
160
|
+
"column",
|
|
161
|
+
"cum_count",
|
|
162
|
+
"len",
|
|
163
|
+
"sum",
|
|
164
|
+
"min",
|
|
165
|
+
"max",
|
|
166
|
+
"mean",
|
|
167
|
+
"count",
|
|
168
|
+
"when",
|
|
169
|
+
# Selector utilities
|
|
170
|
+
"numeric",
|
|
171
|
+
"float_",
|
|
172
|
+
"integer",
|
|
173
|
+
"string",
|
|
174
|
+
"temporal",
|
|
175
|
+
"datetime",
|
|
176
|
+
"date",
|
|
177
|
+
"time",
|
|
178
|
+
"duration",
|
|
179
|
+
"boolean",
|
|
180
|
+
"categorical",
|
|
181
|
+
"object_",
|
|
182
|
+
"list_",
|
|
183
|
+
"struct",
|
|
184
|
+
"all_",
|
|
185
|
+
"by_dtype",
|
|
186
|
+
"contains",
|
|
187
|
+
"starts_with",
|
|
188
|
+
"ends_with",
|
|
189
|
+
"matches",
|
|
190
|
+
"node_designer",
|
|
191
|
+
# Utilities
|
|
192
|
+
"create_flow_graph",
|
|
193
|
+
"open_graph_in_editor",
|
|
194
|
+
# Data types from Polars
|
|
195
|
+
"Int8",
|
|
196
|
+
"Int16",
|
|
197
|
+
"Int32",
|
|
198
|
+
"Int64",
|
|
199
|
+
"Int128",
|
|
200
|
+
"UInt8",
|
|
201
|
+
"UInt16",
|
|
202
|
+
"UInt32",
|
|
203
|
+
"UInt64",
|
|
204
|
+
"Float32",
|
|
205
|
+
"Float64",
|
|
206
|
+
"Boolean",
|
|
207
|
+
"String",
|
|
208
|
+
"Utf8",
|
|
209
|
+
"Binary",
|
|
210
|
+
"Null",
|
|
211
|
+
"List",
|
|
212
|
+
"Array",
|
|
213
|
+
"Struct",
|
|
214
|
+
"Object",
|
|
215
|
+
"Date",
|
|
216
|
+
"Time",
|
|
217
|
+
"Datetime",
|
|
218
|
+
"Duration",
|
|
219
|
+
"Categorical",
|
|
220
|
+
"Decimal",
|
|
221
|
+
"Enum",
|
|
222
|
+
"Unknown",
|
|
223
|
+
"DataType",
|
|
224
|
+
"DataTypeClass",
|
|
225
|
+
"Field",
|
|
226
|
+
"start_web_ui",
|
|
227
|
+
]
|
|
228
|
+
logging.getLogger("PipelineHandler").setLevel(logging.WARNING)
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
# flowfile/__main__.py
|
|
2
|
+
|
|
3
|
+
import sys
|
|
4
|
+
from pathlib import Path
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
def run_flow(flow_path: str) -> int:
|
|
8
|
+
"""
|
|
9
|
+
Load and execute a flow from a YAML/JSON file.
|
|
10
|
+
|
|
11
|
+
Args:
|
|
12
|
+
flow_path: Path to the flow file (.yaml, .yml, or .json)
|
|
13
|
+
|
|
14
|
+
Returns:
|
|
15
|
+
Exit code (0 for success, 1 for failure)
|
|
16
|
+
"""
|
|
17
|
+
# Disable worker communication for CLI execution
|
|
18
|
+
from flowfile_core.configs.settings import OFFLOAD_TO_WORKER
|
|
19
|
+
|
|
20
|
+
OFFLOAD_TO_WORKER.set(False)
|
|
21
|
+
|
|
22
|
+
from flowfile_core.flowfile.manage.io_flowfile import open_flow
|
|
23
|
+
|
|
24
|
+
path = Path(flow_path)
|
|
25
|
+
if not path.exists():
|
|
26
|
+
print(f"Error: File not found: {flow_path}", file=sys.stderr)
|
|
27
|
+
return 1
|
|
28
|
+
|
|
29
|
+
if path.suffix.lower() not in (".yaml", ".yml", ".json"):
|
|
30
|
+
print(f"Error: Unsupported file format: {path.suffix}", file=sys.stderr)
|
|
31
|
+
print("Supported formats: .yaml, .yml, .json", file=sys.stderr)
|
|
32
|
+
return 1
|
|
33
|
+
|
|
34
|
+
print(f"Loading flow from: {flow_path}")
|
|
35
|
+
|
|
36
|
+
try:
|
|
37
|
+
flow = open_flow(path)
|
|
38
|
+
except Exception as e:
|
|
39
|
+
print(f"Error loading flow: {e}", file=sys.stderr)
|
|
40
|
+
return 1
|
|
41
|
+
|
|
42
|
+
# Force local execution for CLI - no worker service needed
|
|
43
|
+
flow.execution_location = "local"
|
|
44
|
+
|
|
45
|
+
# Remove explore_data nodes - they're UI-only and require a worker service
|
|
46
|
+
explore_data_nodes = [n.node_id for n in flow.nodes if n.node_type == "explore_data"]
|
|
47
|
+
for node_id in explore_data_nodes:
|
|
48
|
+
flow.delete_node(node_id)
|
|
49
|
+
if explore_data_nodes:
|
|
50
|
+
print(f"Skipping {len(explore_data_nodes)} explore_data node(s) (UI-only)")
|
|
51
|
+
|
|
52
|
+
flow_name = flow.flow_settings.name or f"Flow {flow.flow_id}"
|
|
53
|
+
print(f"Running flow: {flow_name} (id={flow.flow_id})")
|
|
54
|
+
print(f"Nodes: {len(flow.nodes)}")
|
|
55
|
+
flow.print_tree()
|
|
56
|
+
print("-" * 40)
|
|
57
|
+
|
|
58
|
+
try:
|
|
59
|
+
result = flow.run_graph()
|
|
60
|
+
except Exception as e:
|
|
61
|
+
print(f"Error running flow: {e}", file=sys.stderr)
|
|
62
|
+
return 1
|
|
63
|
+
|
|
64
|
+
if result is None:
|
|
65
|
+
print("Error: Flow execution returned no result", file=sys.stderr)
|
|
66
|
+
return 1
|
|
67
|
+
|
|
68
|
+
# Display results
|
|
69
|
+
print("-" * 40)
|
|
70
|
+
if result.success:
|
|
71
|
+
duration = ""
|
|
72
|
+
if result.start_time and result.end_time:
|
|
73
|
+
duration = f" in {(result.end_time - result.start_time).total_seconds():.2f}s"
|
|
74
|
+
print(f"Flow completed successfully{duration}")
|
|
75
|
+
print(f"Nodes completed: {result.nodes_completed}/{result.number_of_nodes}")
|
|
76
|
+
else:
|
|
77
|
+
print("Flow execution failed", file=sys.stderr)
|
|
78
|
+
for node_result in result.node_step_result:
|
|
79
|
+
if not node_result.success and node_result.error:
|
|
80
|
+
node_name = node_result.node_name or f"Node {node_result.node_id}"
|
|
81
|
+
print(f" - {node_name}: {node_result.error}", file=sys.stderr)
|
|
82
|
+
return 1
|
|
83
|
+
|
|
84
|
+
return 0
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
def main():
|
|
88
|
+
"""
|
|
89
|
+
Display information about FlowFile when run directly as a module.
|
|
90
|
+
"""
|
|
91
|
+
import argparse
|
|
92
|
+
|
|
93
|
+
import flowfile
|
|
94
|
+
|
|
95
|
+
parser = argparse.ArgumentParser(description="FlowFile: A visual ETL tool with a Polars-like API")
|
|
96
|
+
parser.add_argument("command", nargs="?", choices=["run"], help="Command to execute")
|
|
97
|
+
parser.add_argument(
|
|
98
|
+
"component", nargs="?", choices=["ui", "core", "worker", "flow"], help="Component to run"
|
|
99
|
+
)
|
|
100
|
+
parser.add_argument("file_path", nargs="?", help="Path to flow file (for 'flow' component)")
|
|
101
|
+
parser.add_argument("--host", default="127.0.0.1", help="Host to bind the server to")
|
|
102
|
+
parser.add_argument("--port", type=int, default=63578, help="Port to bind the server to")
|
|
103
|
+
parser.add_argument("--no-browser", action="store_true", help="Don't open a browser window")
|
|
104
|
+
|
|
105
|
+
# Parse arguments
|
|
106
|
+
args = parser.parse_args()
|
|
107
|
+
|
|
108
|
+
if args.command == "run" and args.component:
|
|
109
|
+
if args.component == "ui":
|
|
110
|
+
try:
|
|
111
|
+
flowfile.start_web_ui(open_browser=not args.no_browser)
|
|
112
|
+
except KeyboardInterrupt:
|
|
113
|
+
print("\nFlowFile service stopped.")
|
|
114
|
+
elif args.component == "core":
|
|
115
|
+
# Only for direct core service usage
|
|
116
|
+
from flowfile_core.main import run as run_core
|
|
117
|
+
|
|
118
|
+
run_core(host=args.host, port=args.port)
|
|
119
|
+
elif args.component == "worker":
|
|
120
|
+
# Only for direct worker service usage
|
|
121
|
+
from flowfile_worker.main import run as run_worker
|
|
122
|
+
|
|
123
|
+
run_worker(host=args.host, port=args.port)
|
|
124
|
+
elif args.component == "flow":
|
|
125
|
+
if not args.file_path:
|
|
126
|
+
print("Error: 'flow' component requires a file path", file=sys.stderr)
|
|
127
|
+
print("Usage: flowfile run flow <path-to-flow-file>", file=sys.stderr)
|
|
128
|
+
sys.exit(1)
|
|
129
|
+
sys.exit(run_flow(args.file_path))
|
|
130
|
+
else:
|
|
131
|
+
# Default action - show info
|
|
132
|
+
print(f"FlowFile v{flowfile.__version__}")
|
|
133
|
+
print("A framework combining visual ETL with a Polars-like API")
|
|
134
|
+
print("\nUsage:")
|
|
135
|
+
print(" # Start the FlowFile web UI with integrated services")
|
|
136
|
+
print(" flowfile run ui")
|
|
137
|
+
print("")
|
|
138
|
+
print(" # Run a flow from a file")
|
|
139
|
+
print(" flowfile run flow my_pipeline.yaml")
|
|
140
|
+
print("")
|
|
141
|
+
print(" # Advanced: Run individual components")
|
|
142
|
+
print(" flowfile run core # Start only the core service")
|
|
143
|
+
print(" flowfile run worker # Start only the worker service")
|
|
144
|
+
print("")
|
|
145
|
+
print(" # Options")
|
|
146
|
+
print(" flowfile run ui --host 0.0.0.0 --port 8080 # Custom host/port")
|
|
147
|
+
print(" flowfile run ui --no-browser # Don't open browser")
|
|
148
|
+
print("")
|
|
149
|
+
print(" # Python API usage examples")
|
|
150
|
+
print(" import flowfile as ff")
|
|
151
|
+
print(" df = ff.read_csv('data.csv')")
|
|
152
|
+
print(" result = df.filter(ff.col('value') > 10)")
|
|
153
|
+
print(" ff.open_graph_in_editor(result)")
|