Flowfile 0.3.9__py3-none-any.whl → 0.5.1__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.
- flowfile/__init__.py +8 -1
- flowfile/api.py +1 -3
- flowfile/web/static/assets/{CloudConnectionManager-c97c25f8.js → CloudConnectionManager-0dfba9f2.js} +2 -2
- flowfile/web/static/assets/{CloudStorageReader-f1ff509e.js → CloudStorageReader-d5b1b6c9.js} +11 -78
- flowfile/web/static/assets/{CloudStorageWriter-034f8b78.js → CloudStorageWriter-00d87aad.js} +12 -79
- flowfile/web/static/assets/{CloudStorageWriter-49c9a4b2.css → CloudStorageWriter-b0ee067f.css} +24 -24
- flowfile/web/static/assets/ColumnSelector-4685e75d.js +83 -0
- flowfile/web/static/assets/ColumnSelector-47996a16.css +10 -0
- flowfile/web/static/assets/ContextMenu-23e909da.js +41 -0
- flowfile/web/static/assets/{SettingsSection-9c836ecc.css → ContextMenu-4c74eef1.css} +0 -21
- flowfile/web/static/assets/ContextMenu-63cfa99b.css +26 -0
- flowfile/web/static/assets/ContextMenu-70ae0c79.js +41 -0
- flowfile/web/static/assets/ContextMenu-c13f91d0.css +26 -0
- flowfile/web/static/assets/ContextMenu-f149cf7c.js +41 -0
- flowfile/web/static/assets/{CrossJoin-41efa4cb.css → CrossJoin-1119d18e.css} +18 -18
- flowfile/web/static/assets/{CrossJoin-9e156ebe.js → CrossJoin-702a3edd.js} +14 -84
- flowfile/web/static/assets/CustomNode-74a37f74.css +32 -0
- flowfile/web/static/assets/CustomNode-b1519993.js +211 -0
- flowfile/web/static/assets/{DatabaseConnectionSettings-d5c625b3.js → DatabaseConnectionSettings-6f3e4ea5.js} +3 -3
- flowfile/web/static/assets/{DatabaseManager-265adc5e.js → DatabaseManager-cf5ef661.js} +2 -2
- flowfile/web/static/assets/{DatabaseReader-f50c6558.css → DatabaseReader-ae61773c.css} +0 -27
- flowfile/web/static/assets/{DatabaseReader-0b10551e.js → DatabaseReader-d38c7295.js} +14 -114
- flowfile/web/static/assets/{DatabaseWriter-c17c6916.js → DatabaseWriter-b04ef46a.js} +13 -74
- flowfile/web/static/assets/{ExploreData-5bdae813.css → ExploreData-2d0cf4db.css} +8 -14
- flowfile/web/static/assets/ExploreData-5fa10ed8.js +192 -0
- flowfile/web/static/assets/{ExternalSource-3a66556c.js → ExternalSource-d39af878.js} +8 -79
- flowfile/web/static/assets/{Filter-91ad87e7.js → Filter-9b6d08db.js} +12 -85
- flowfile/web/static/assets/{Filter-a9d08ba1.css → Filter-f62091b3.css} +3 -3
- flowfile/web/static/assets/{Formula-3c395ab1.js → Formula-6b04fb1d.js} +20 -87
- flowfile/web/static/assets/{Formula-29f19d21.css → Formula-bb96803d.css} +4 -4
- flowfile/web/static/assets/{FuzzyMatch-6857de82.css → FuzzyMatch-1010f966.css} +42 -42
- flowfile/web/static/assets/{FuzzyMatch-2df0d230.js → FuzzyMatch-999521f4.js} +16 -87
- flowfile/web/static/assets/{GraphSolver-d285877f.js → GraphSolver-17dd2198.js} +13 -159
- flowfile/web/static/assets/GraphSolver-f0cb7bfb.css +22 -0
- flowfile/web/static/assets/{GroupBy-0bd1cc6b.js → GroupBy-6b039e18.js} +12 -75
- flowfile/web/static/assets/{Unique-b5615727.css → GroupBy-b9505323.css} +8 -8
- flowfile/web/static/assets/{Join-5a78a203.js → Join-24d0f113.js} +15 -85
- flowfile/web/static/assets/{Join-f45eff22.css → Join-fd79b451.css} +20 -20
- flowfile/web/static/assets/{ManualInput-a71b52c6.css → ManualInput-3246a08d.css} +20 -20
- flowfile/web/static/assets/{ManualInput-93aef9d6.js → ManualInput-34639209.js} +11 -82
- flowfile/web/static/assets/MultiSelect-0e8724a3.js +5 -0
- flowfile/web/static/assets/MultiSelect.vue_vue_type_script_setup_true_lang-b0e538c2.js +63 -0
- flowfile/web/static/assets/NumericInput-3d63a470.js +5 -0
- flowfile/web/static/assets/NumericInput.vue_vue_type_script_setup_true_lang-e0edeccc.js +35 -0
- flowfile/web/static/assets/Output-283fe388.css +37 -0
- flowfile/web/static/assets/{Output-411ecaee.js → Output-edea9802.js} +62 -273
- flowfile/web/static/assets/{Pivot-89db4b04.js → Pivot-61d19301.js} +14 -138
- flowfile/web/static/assets/Pivot-cf333e3d.css +22 -0
- flowfile/web/static/assets/PivotValidation-891ddfb0.css +13 -0
- flowfile/web/static/assets/PivotValidation-c46cd420.css +13 -0
- flowfile/web/static/assets/PivotValidation-de9f43fe.js +61 -0
- flowfile/web/static/assets/PivotValidation-f97fec5b.js +61 -0
- flowfile/web/static/assets/{PolarsCode-a9f974f8.js → PolarsCode-bc3c9984.js} +13 -80
- flowfile/web/static/assets/Read-64a3f259.js +218 -0
- flowfile/web/static/assets/Read-e808b239.css +62 -0
- flowfile/web/static/assets/RecordCount-3d5039be.js +53 -0
- flowfile/web/static/assets/{RecordId-55ae7d36.js → RecordId-597510e0.js} +8 -80
- flowfile/web/static/assets/SQLQueryComponent-36cef432.css +27 -0
- flowfile/web/static/assets/SQLQueryComponent-df51adbe.js +38 -0
- flowfile/web/static/assets/{Sample-b4a18476.js → Sample-4be0a507.js} +8 -77
- flowfile/web/static/assets/{SecretManager-b066d13a.js → SecretManager-4839be57.js} +2 -2
- flowfile/web/static/assets/{Select-727688dc.js → Select-9b72f201.js} +11 -85
- flowfile/web/static/assets/SettingsSection-2e4d03c4.css +21 -0
- flowfile/web/static/assets/SettingsSection-5c696bee.css +20 -0
- flowfile/web/static/assets/SettingsSection-71e6b7e3.css +21 -0
- flowfile/web/static/assets/SettingsSection-7ded385d.js +45 -0
- flowfile/web/static/assets/{SettingsSection-695ac487.js → SettingsSection-e1e9c953.js} +2 -40
- flowfile/web/static/assets/SettingsSection-f0f75a42.js +53 -0
- flowfile/web/static/assets/SingleSelect-6c777aac.js +5 -0
- flowfile/web/static/assets/SingleSelect.vue_vue_type_script_setup_true_lang-33e3ff9b.js +62 -0
- flowfile/web/static/assets/SliderInput-7cb93e62.js +40 -0
- flowfile/web/static/assets/SliderInput-b8fb6a8c.css +4 -0
- flowfile/web/static/assets/{GroupBy-ab1ea74b.css → Sort-3643d625.css} +8 -8
- flowfile/web/static/assets/{Sort-be3339a8.js → Sort-6cbde21a.js} +12 -97
- flowfile/web/static/assets/TextInput-d9a40c11.js +5 -0
- flowfile/web/static/assets/TextInput.vue_vue_type_script_setup_true_lang-5896c375.js +32 -0
- flowfile/web/static/assets/{TextToRows-c92d1ec2.css → TextToRows-5d2c1190.css} +9 -9
- flowfile/web/static/assets/{TextToRows-7b8998da.js → TextToRows-c4fcbf4d.js} +14 -83
- flowfile/web/static/assets/ToggleSwitch-4ef91d19.js +5 -0
- flowfile/web/static/assets/ToggleSwitch.vue_vue_type_script_setup_true_lang-38478c20.js +31 -0
- flowfile/web/static/assets/{UnavailableFields-8b0cb48e.js → UnavailableFields-a03f512c.js} +2 -2
- flowfile/web/static/assets/{Union-8d9ac7f9.css → Union-af6c3d9b.css} +6 -6
- flowfile/web/static/assets/Union-bfe9b996.js +77 -0
- flowfile/web/static/assets/{Unique-af5a80b4.js → Unique-5d023a27.js} +23 -104
- flowfile/web/static/assets/{Sort-7ccfa0fe.css → Unique-f9fb0809.css} +8 -8
- flowfile/web/static/assets/Unpivot-1e422df3.css +30 -0
- flowfile/web/static/assets/{Unpivot-5195d411.js → Unpivot-91cc5354.js} +12 -166
- flowfile/web/static/assets/UnpivotValidation-0d240eeb.css +13 -0
- flowfile/web/static/assets/UnpivotValidation-7ee2de44.js +51 -0
- flowfile/web/static/assets/{ExploreData-18a4fe52.js → VueGraphicWalker-e51b9924.js} +4 -264
- flowfile/web/static/assets/VueGraphicWalker-ed5ab88b.css +6 -0
- flowfile/web/static/assets/{api-cb00cce6.js → api-c1bad5ca.js} +1 -1
- flowfile/web/static/assets/{api-023d1733.js → api-cf1221f0.js} +1 -1
- flowfile/web/static/assets/{designer-2197d782.css → designer-8da3ba3a.css} +859 -201
- flowfile/web/static/assets/{designer-6c322d8e.js → designer-9633482a.js} +2297 -733
- flowfile/web/static/assets/{documentation-4d1fafe1.js → documentation-ca400224.js} +1 -1
- flowfile/web/static/assets/{dropDown-0b46dd77.js → dropDown-614b998d.js} +1 -1
- flowfile/web/static/assets/{fullEditor-ec4e4f95.js → fullEditor-f7971590.js} +2 -2
- flowfile/web/static/assets/{genericNodeSettings-def5879b.js → genericNodeSettings-4fe5f36b.js} +3 -3
- flowfile/web/static/assets/{index-681a3ed0.css → index-50508d4d.css} +8 -0
- flowfile/web/static/assets/{index-683fc198.js → index-5429bbf8.js} +208 -31
- flowfile/web/static/assets/nodeInput-5d0d6b79.js +41 -0
- flowfile/web/static/assets/outputCsv-076b85ab.js +86 -0
- flowfile/web/static/assets/{Output-48f81019.css → outputCsv-9cc59e0b.css} +0 -143
- flowfile/web/static/assets/outputExcel-0fd17dbe.js +56 -0
- flowfile/web/static/assets/outputExcel-b41305c0.css +102 -0
- flowfile/web/static/assets/outputParquet-b61e0847.js +31 -0
- flowfile/web/static/assets/outputParquet-cf8cf3f2.css +4 -0
- flowfile/web/static/assets/readCsv-a8bb8b61.js +179 -0
- flowfile/web/static/assets/readCsv-c767cb37.css +52 -0
- flowfile/web/static/assets/readExcel-67b4aee0.js +201 -0
- flowfile/web/static/assets/readExcel-806d2826.css +64 -0
- flowfile/web/static/assets/readParquet-48c81530.css +19 -0
- flowfile/web/static/assets/readParquet-92ce1dbc.js +23 -0
- flowfile/web/static/assets/{secretApi-baceb6f9.js → secretApi-68435402.js} +1 -1
- flowfile/web/static/assets/{selectDynamic-de91449a.js → selectDynamic-92e25ee3.js} +7 -7
- flowfile/web/static/assets/{selectDynamic-b062bc9b.css → selectDynamic-aa913ff4.css} +16 -16
- flowfile/web/static/assets/user-defined-icon-0ae16c90.png +0 -0
- flowfile/web/static/assets/{vue-codemirror.esm-dc5e3348.js → vue-codemirror.esm-41b0e0d7.js} +65 -36
- flowfile/web/static/assets/{vue-content-loader.es-ba94b82f.js → vue-content-loader.es-2c8e608f.js} +1 -1
- flowfile/web/static/index.html +2 -2
- {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/METADATA +5 -3
- {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/RECORD +191 -121
- {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/WHEEL +1 -1
- {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info}/entry_points.txt +1 -0
- flowfile_core/__init__.py +3 -0
- flowfile_core/configs/flow_logger.py +5 -13
- flowfile_core/configs/node_store/__init__.py +30 -0
- flowfile_core/configs/node_store/nodes.py +383 -99
- flowfile_core/configs/node_store/user_defined_node_registry.py +193 -0
- flowfile_core/configs/settings.py +2 -1
- flowfile_core/database/connection.py +5 -21
- flowfile_core/fileExplorer/funcs.py +239 -121
- flowfile_core/flowfile/analytics/analytics_processor.py +1 -0
- flowfile_core/flowfile/code_generator/code_generator.py +62 -64
- flowfile_core/flowfile/flow_data_engine/create/funcs.py +73 -56
- flowfile_core/flowfile/flow_data_engine/flow_data_engine.py +77 -86
- flowfile_core/flowfile/flow_data_engine/flow_file_column/interface.py +4 -0
- flowfile_core/flowfile/flow_data_engine/flow_file_column/main.py +19 -34
- flowfile_core/flowfile/flow_data_engine/flow_file_column/type_registry.py +36 -0
- flowfile_core/flowfile/flow_data_engine/fuzzy_matching/prepare_for_fuzzy_match.py +23 -23
- flowfile_core/flowfile/flow_data_engine/join/utils.py +1 -1
- flowfile_core/flowfile/flow_data_engine/join/verify_integrity.py +9 -4
- flowfile_core/flowfile/flow_data_engine/subprocess_operations/subprocess_operations.py +212 -86
- flowfile_core/flowfile/flow_data_engine/utils.py +2 -0
- flowfile_core/flowfile/flow_graph.py +240 -54
- flowfile_core/flowfile/flow_node/flow_node.py +48 -13
- flowfile_core/flowfile/flow_node/models.py +2 -1
- flowfile_core/flowfile/handler.py +24 -5
- flowfile_core/flowfile/manage/compatibility_enhancements.py +404 -41
- flowfile_core/flowfile/manage/io_flowfile.py +394 -0
- flowfile_core/flowfile/node_designer/__init__.py +47 -0
- flowfile_core/flowfile/node_designer/_type_registry.py +197 -0
- flowfile_core/flowfile/node_designer/custom_node.py +371 -0
- flowfile_core/flowfile/node_designer/ui_components.py +277 -0
- flowfile_core/flowfile/schema_callbacks.py +17 -10
- flowfile_core/flowfile/setting_generator/settings.py +15 -10
- flowfile_core/main.py +5 -1
- flowfile_core/routes/routes.py +73 -30
- flowfile_core/routes/user_defined_components.py +55 -0
- flowfile_core/schemas/cloud_storage_schemas.py +0 -2
- flowfile_core/schemas/input_schema.py +228 -65
- flowfile_core/schemas/output_model.py +5 -2
- flowfile_core/schemas/schemas.py +153 -35
- flowfile_core/schemas/transform_schema.py +1083 -412
- flowfile_core/schemas/yaml_types.py +103 -0
- flowfile_core/types.py +156 -0
- flowfile_core/utils/validate_setup.py +3 -1
- flowfile_frame/__init__.py +3 -1
- flowfile_frame/flow_frame.py +31 -24
- flowfile_frame/flow_frame_methods.py +12 -9
- flowfile_worker/__init__.py +9 -35
- flowfile_worker/create/__init__.py +3 -21
- flowfile_worker/create/funcs.py +68 -56
- flowfile_worker/create/models.py +130 -62
- flowfile_worker/main.py +5 -2
- flowfile_worker/routes.py +52 -13
- shared/__init__.py +15 -0
- shared/storage_config.py +258 -0
- tools/migrate/README.md +56 -0
- tools/migrate/__init__.py +12 -0
- tools/migrate/__main__.py +131 -0
- tools/migrate/legacy_schemas.py +621 -0
- tools/migrate/migrate.py +598 -0
- tools/migrate/tests/__init__.py +0 -0
- tools/migrate/tests/conftest.py +23 -0
- tools/migrate/tests/test_migrate.py +627 -0
- tools/migrate/tests/test_migration_e2e.py +1010 -0
- tools/migrate/tests/test_node_migrations.py +813 -0
- flowfile/web/static/assets/GraphSolver-17fd26db.css +0 -68
- flowfile/web/static/assets/Pivot-f415e85f.css +0 -35
- flowfile/web/static/assets/Read-80dc1675.css +0 -197
- flowfile/web/static/assets/Read-c3b1929c.js +0 -701
- flowfile/web/static/assets/RecordCount-4e95f98e.js +0 -122
- flowfile/web/static/assets/Union-89fd73dc.js +0 -146
- flowfile/web/static/assets/Unpivot-246e9bbd.css +0 -77
- flowfile/web/static/assets/nodeTitle-a16db7c3.js +0 -227
- flowfile/web/static/assets/nodeTitle-f4b12bcb.css +0 -134
- flowfile_core/flowfile/manage/open_flowfile.py +0 -135
- {flowfile-0.3.9.dist-info → flowfile-0.5.1.dist-info/licenses}/LICENSE +0 -0
- /flowfile_core/flowfile/manage/manage_flowfile.py → /tools/__init__.py +0 -0
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
from flowfile_core.configs.node_store.user_defined_node_registry import get_all_nodes_from_standard_location
|
|
2
|
+
from flowfile_core.configs.node_store.nodes import get_all_standard_nodes
|
|
3
|
+
from flowfile_core.schemas.schemas import NodeTemplate
|
|
4
|
+
from flowfile_core.flowfile.node_designer.custom_node import CustomNodeBase
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
nodes_with_defaults = {'sample', 'sort', 'union', 'select', 'record_count'}
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
def register_custom_node(node: NodeTemplate):
|
|
11
|
+
nodes_list.append(node)
|
|
12
|
+
node_dict[node.item] = node
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
def add_to_custom_node_store(custom_node: type[CustomNodeBase]):
|
|
16
|
+
CUSTOM_NODE_STORE[custom_node().item] = custom_node
|
|
17
|
+
if custom_node().item not in node_dict:
|
|
18
|
+
register_custom_node(custom_node().to_node_template())
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
CUSTOM_NODE_STORE = get_all_nodes_from_standard_location()
|
|
22
|
+
nodes_list, node_dict, node_defaults = get_all_standard_nodes()
|
|
23
|
+
|
|
24
|
+
for custom_node in CUSTOM_NODE_STORE.values():
|
|
25
|
+
register_custom_node(custom_node().to_node_template())
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
def check_if_has_default_setting(node_item: str):
|
|
29
|
+
|
|
30
|
+
return node_item in nodes_with_defaults
|
|
@@ -1,99 +1,383 @@
|
|
|
1
|
-
|
|
2
|
-
from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
NodeTemplate
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
1
|
+
|
|
2
|
+
from typing import List, Dict
|
|
3
|
+
from flowfile_core.schemas.schemas import NodeTemplate, NodeDefault
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
def get_all_standard_nodes() -> tuple[List[NodeTemplate], Dict[str, NodeTemplate], Dict[str, NodeDefault]]:
|
|
7
|
+
"""
|
|
8
|
+
Initializes and returns the complete list, dict, and defaults for all nodes.
|
|
9
|
+
"""
|
|
10
|
+
nodes_list: List[NodeTemplate] = [
|
|
11
|
+
NodeTemplate(
|
|
12
|
+
name='External source',
|
|
13
|
+
item='external_source',
|
|
14
|
+
input=0,
|
|
15
|
+
output=1,
|
|
16
|
+
image='external_source.png',
|
|
17
|
+
node_type="input",
|
|
18
|
+
transform_type="other",
|
|
19
|
+
node_group='input',
|
|
20
|
+
prod_ready=False,
|
|
21
|
+
drawer_title="External Source",
|
|
22
|
+
drawer_intro="Connect to external data sources and APIs"
|
|
23
|
+
),
|
|
24
|
+
|
|
25
|
+
NodeTemplate(
|
|
26
|
+
name='Manual input',
|
|
27
|
+
item='manual_input',
|
|
28
|
+
input=0,
|
|
29
|
+
output=1,
|
|
30
|
+
transform_type="other",
|
|
31
|
+
node_type="input",
|
|
32
|
+
image='manual_input.png',
|
|
33
|
+
node_group='input',
|
|
34
|
+
drawer_title="Manual Input",
|
|
35
|
+
drawer_intro="Create data directly"
|
|
36
|
+
),
|
|
37
|
+
|
|
38
|
+
NodeTemplate(
|
|
39
|
+
name='Read data',
|
|
40
|
+
item='read',
|
|
41
|
+
input=0,
|
|
42
|
+
output=1,
|
|
43
|
+
transform_type="other",
|
|
44
|
+
node_type="input",
|
|
45
|
+
image='input_data.png',
|
|
46
|
+
node_group='input',
|
|
47
|
+
drawer_title="Read Data",
|
|
48
|
+
drawer_intro="Load data from CSV, Excel, or Parquet files"
|
|
49
|
+
),
|
|
50
|
+
|
|
51
|
+
NodeTemplate(
|
|
52
|
+
name='Join',
|
|
53
|
+
item='join',
|
|
54
|
+
input=2,
|
|
55
|
+
output=1,
|
|
56
|
+
transform_type="wide",
|
|
57
|
+
node_type="process",
|
|
58
|
+
image='join.png',
|
|
59
|
+
node_group='combine',
|
|
60
|
+
drawer_title="Join Datasets",
|
|
61
|
+
drawer_intro="Merge two datasets based on matching column values"
|
|
62
|
+
),
|
|
63
|
+
|
|
64
|
+
NodeTemplate(
|
|
65
|
+
name='Formula',
|
|
66
|
+
item='formula',
|
|
67
|
+
input=1,
|
|
68
|
+
output=1,
|
|
69
|
+
transform_type="narrow",
|
|
70
|
+
node_type="process",
|
|
71
|
+
image='formula.png',
|
|
72
|
+
node_group='transform',
|
|
73
|
+
drawer_title="Formula Editor",
|
|
74
|
+
drawer_intro="Create or modify columns using custom expressions"
|
|
75
|
+
),
|
|
76
|
+
|
|
77
|
+
NodeTemplate(
|
|
78
|
+
name='Write data',
|
|
79
|
+
item='output',
|
|
80
|
+
input=1,
|
|
81
|
+
output=0,
|
|
82
|
+
transform_type="other",
|
|
83
|
+
image='output.png',
|
|
84
|
+
node_type="output",
|
|
85
|
+
node_group='output',
|
|
86
|
+
drawer_title="Write Data",
|
|
87
|
+
drawer_intro="Save your data as CSV, Excel, or Parquet files"
|
|
88
|
+
),
|
|
89
|
+
|
|
90
|
+
NodeTemplate(
|
|
91
|
+
name='Select data',
|
|
92
|
+
item='select',
|
|
93
|
+
input=1,
|
|
94
|
+
output=1,
|
|
95
|
+
transform_type="narrow",
|
|
96
|
+
node_type="process",
|
|
97
|
+
image='select.png',
|
|
98
|
+
node_group='transform',
|
|
99
|
+
drawer_title="Select Columns",
|
|
100
|
+
drawer_intro="Choose, rename, and reorder columns to keep"
|
|
101
|
+
),
|
|
102
|
+
|
|
103
|
+
NodeTemplate(
|
|
104
|
+
name='Filter data',
|
|
105
|
+
item='filter',
|
|
106
|
+
input=1,
|
|
107
|
+
output=1,
|
|
108
|
+
transform_type="narrow",
|
|
109
|
+
node_type="process",
|
|
110
|
+
image='filter.png',
|
|
111
|
+
node_group='transform',
|
|
112
|
+
drawer_title="Filter Rows",
|
|
113
|
+
drawer_intro="Keep only rows that match your conditions"
|
|
114
|
+
),
|
|
115
|
+
|
|
116
|
+
NodeTemplate(
|
|
117
|
+
name='Group by',
|
|
118
|
+
item='group_by',
|
|
119
|
+
input=1,
|
|
120
|
+
output=1,
|
|
121
|
+
transform_type="wide",
|
|
122
|
+
node_type="process",
|
|
123
|
+
image='group_by.png',
|
|
124
|
+
node_group='aggregate',
|
|
125
|
+
drawer_title="Group By",
|
|
126
|
+
drawer_intro="Aggregate data by grouping and calculating statistics"
|
|
127
|
+
),
|
|
128
|
+
|
|
129
|
+
NodeTemplate(
|
|
130
|
+
name='Fuzzy match',
|
|
131
|
+
item='fuzzy_match',
|
|
132
|
+
input=2,
|
|
133
|
+
output=1,
|
|
134
|
+
transform_type="wide",
|
|
135
|
+
image='fuzzy_match.png',
|
|
136
|
+
node_type="process",
|
|
137
|
+
node_group='combine',
|
|
138
|
+
drawer_title="Fuzzy Match",
|
|
139
|
+
drawer_intro="Join datasets based on similar values instead of exact matches"
|
|
140
|
+
),
|
|
141
|
+
|
|
142
|
+
NodeTemplate(
|
|
143
|
+
name='Sort data',
|
|
144
|
+
item='sort',
|
|
145
|
+
input=1,
|
|
146
|
+
output=1,
|
|
147
|
+
transform_type="wide",
|
|
148
|
+
node_type="process",
|
|
149
|
+
image='sort.png',
|
|
150
|
+
node_group='transform',
|
|
151
|
+
drawer_title="Sort Data",
|
|
152
|
+
drawer_intro="Order your data by one or more columns"
|
|
153
|
+
),
|
|
154
|
+
|
|
155
|
+
NodeTemplate(
|
|
156
|
+
name='Add record Id',
|
|
157
|
+
item='record_id',
|
|
158
|
+
input=1,
|
|
159
|
+
output=1,
|
|
160
|
+
transform_type="wide",
|
|
161
|
+
node_type="process",
|
|
162
|
+
image='record_id.png',
|
|
163
|
+
node_group='transform',
|
|
164
|
+
drawer_title="Add Record ID",
|
|
165
|
+
drawer_intro="Generate unique identifiers for each row"
|
|
166
|
+
),
|
|
167
|
+
|
|
168
|
+
NodeTemplate(
|
|
169
|
+
name='Take Sample',
|
|
170
|
+
item='sample',
|
|
171
|
+
input=1,
|
|
172
|
+
output=1,
|
|
173
|
+
transform_type="narrow",
|
|
174
|
+
node_type="process",
|
|
175
|
+
image='sample.png',
|
|
176
|
+
node_group='transform',
|
|
177
|
+
drawer_title="Take Sample",
|
|
178
|
+
drawer_intro="Work with a subset of your data"
|
|
179
|
+
),
|
|
180
|
+
|
|
181
|
+
NodeTemplate(
|
|
182
|
+
name='Explore data',
|
|
183
|
+
item='explore_data',
|
|
184
|
+
input=1,
|
|
185
|
+
output=0,
|
|
186
|
+
transform_type="other",
|
|
187
|
+
node_type="output",
|
|
188
|
+
image='explore_data.png',
|
|
189
|
+
node_group='output',
|
|
190
|
+
drawer_title="Explore Data",
|
|
191
|
+
drawer_intro="Interactive data exploration and analysis"
|
|
192
|
+
),
|
|
193
|
+
|
|
194
|
+
NodeTemplate(
|
|
195
|
+
name='Pivot data',
|
|
196
|
+
item='pivot',
|
|
197
|
+
input=1,
|
|
198
|
+
output=1,
|
|
199
|
+
transform_type="wide",
|
|
200
|
+
image='pivot.png',
|
|
201
|
+
node_type="process",
|
|
202
|
+
node_group='aggregate',
|
|
203
|
+
drawer_title="Pivot Data",
|
|
204
|
+
drawer_intro="Convert data from long format to wide format"
|
|
205
|
+
),
|
|
206
|
+
|
|
207
|
+
NodeTemplate(
|
|
208
|
+
name='Unpivot data',
|
|
209
|
+
item='unpivot',
|
|
210
|
+
input=1,
|
|
211
|
+
output=1,
|
|
212
|
+
transform_type="wide",
|
|
213
|
+
node_type="process",
|
|
214
|
+
image='unpivot.png',
|
|
215
|
+
node_group='aggregate',
|
|
216
|
+
drawer_title="Unpivot Data",
|
|
217
|
+
drawer_intro="Transform data from wide format to long format"
|
|
218
|
+
),
|
|
219
|
+
|
|
220
|
+
NodeTemplate(
|
|
221
|
+
name='Union data',
|
|
222
|
+
item='union',
|
|
223
|
+
input=10,
|
|
224
|
+
output=1,
|
|
225
|
+
transform_type="narrow",
|
|
226
|
+
node_type="process",
|
|
227
|
+
image='union.png',
|
|
228
|
+
multi=True,
|
|
229
|
+
node_group='combine',
|
|
230
|
+
drawer_title="Union Data",
|
|
231
|
+
drawer_intro="Stack multiple datasets by combining rows"
|
|
232
|
+
),
|
|
233
|
+
|
|
234
|
+
NodeTemplate(
|
|
235
|
+
name='Drop duplicates',
|
|
236
|
+
item='unique',
|
|
237
|
+
input=1,
|
|
238
|
+
output=1,
|
|
239
|
+
transform_type="wide",
|
|
240
|
+
node_type="process",
|
|
241
|
+
image='unique.png',
|
|
242
|
+
node_group='transform',
|
|
243
|
+
drawer_title="Drop Duplicates",
|
|
244
|
+
drawer_intro="Remove duplicate rows based on selected columns"
|
|
245
|
+
),
|
|
246
|
+
|
|
247
|
+
NodeTemplate(
|
|
248
|
+
name='Graph solver',
|
|
249
|
+
item='graph_solver',
|
|
250
|
+
input=1,
|
|
251
|
+
output=1,
|
|
252
|
+
transform_type="other",
|
|
253
|
+
node_type="process",
|
|
254
|
+
image='graph_solver.png',
|
|
255
|
+
node_group='combine',
|
|
256
|
+
drawer_title="Graph Solver",
|
|
257
|
+
drawer_intro="Group related records in graph-structured data"
|
|
258
|
+
),
|
|
259
|
+
|
|
260
|
+
NodeTemplate(
|
|
261
|
+
name='Count records',
|
|
262
|
+
item='record_count',
|
|
263
|
+
input=1,
|
|
264
|
+
output=1,
|
|
265
|
+
transform_type="wide",
|
|
266
|
+
node_type="process",
|
|
267
|
+
image='record_count.png',
|
|
268
|
+
node_group='aggregate',
|
|
269
|
+
drawer_title="Count Records",
|
|
270
|
+
drawer_intro="Calculate the total number of rows"
|
|
271
|
+
),
|
|
272
|
+
|
|
273
|
+
NodeTemplate(
|
|
274
|
+
name='Cross join',
|
|
275
|
+
item='cross_join',
|
|
276
|
+
input=2,
|
|
277
|
+
output=1,
|
|
278
|
+
transform_type="wide",
|
|
279
|
+
node_type="process",
|
|
280
|
+
image='cross_join.png',
|
|
281
|
+
node_group='combine',
|
|
282
|
+
drawer_title="Cross Join",
|
|
283
|
+
drawer_intro="Create all possible combinations between two datasets"
|
|
284
|
+
),
|
|
285
|
+
|
|
286
|
+
NodeTemplate(
|
|
287
|
+
name='Text to rows',
|
|
288
|
+
item='text_to_rows',
|
|
289
|
+
input=1,
|
|
290
|
+
output=1,
|
|
291
|
+
transform_type="wide",
|
|
292
|
+
node_type="process",
|
|
293
|
+
image='text_to_rows.png',
|
|
294
|
+
node_group='transform',
|
|
295
|
+
drawer_title="Text to Rows",
|
|
296
|
+
drawer_intro="Split text into multiple rows based on a delimiter"
|
|
297
|
+
),
|
|
298
|
+
|
|
299
|
+
NodeTemplate(
|
|
300
|
+
name="Polars code",
|
|
301
|
+
item="polars_code",
|
|
302
|
+
input=10,
|
|
303
|
+
output=1,
|
|
304
|
+
transform_type="narrow",
|
|
305
|
+
image='polars_code.png',
|
|
306
|
+
node_group='transform',
|
|
307
|
+
node_type="process",
|
|
308
|
+
multi=True,
|
|
309
|
+
can_be_start=True,
|
|
310
|
+
drawer_title="Polars Code",
|
|
311
|
+
drawer_intro="Write custom Polars DataFrame transformations"
|
|
312
|
+
),
|
|
313
|
+
|
|
314
|
+
NodeTemplate(
|
|
315
|
+
name="Read from Database",
|
|
316
|
+
item="database_reader",
|
|
317
|
+
input=0,
|
|
318
|
+
output=1,
|
|
319
|
+
node_type="input",
|
|
320
|
+
transform_type="other",
|
|
321
|
+
image='database_reader.svg',
|
|
322
|
+
node_group='input',
|
|
323
|
+
drawer_title="Database Reader",
|
|
324
|
+
drawer_intro="Load data from database tables or queries"
|
|
325
|
+
),
|
|
326
|
+
|
|
327
|
+
NodeTemplate(
|
|
328
|
+
name='Write to Database',
|
|
329
|
+
item='database_writer',
|
|
330
|
+
input=1,
|
|
331
|
+
output=0,
|
|
332
|
+
transform_type="other",
|
|
333
|
+
node_type="output",
|
|
334
|
+
image='database_writer.svg',
|
|
335
|
+
node_group='output',
|
|
336
|
+
drawer_title="Database Writer",
|
|
337
|
+
drawer_intro="Save data to database tables"
|
|
338
|
+
),
|
|
339
|
+
|
|
340
|
+
NodeTemplate(
|
|
341
|
+
name='Read from cloud provider',
|
|
342
|
+
item='cloud_storage_reader',
|
|
343
|
+
input=0,
|
|
344
|
+
output=1,
|
|
345
|
+
transform_type="other",
|
|
346
|
+
node_type="input",
|
|
347
|
+
image='cloud_storage_reader.png',
|
|
348
|
+
node_group='input',
|
|
349
|
+
drawer_title="Cloud Storage Reader",
|
|
350
|
+
drawer_intro="Read data from AWS S3 and other cloud storage"
|
|
351
|
+
),
|
|
352
|
+
|
|
353
|
+
NodeTemplate(
|
|
354
|
+
name='Write to cloud provider',
|
|
355
|
+
item='cloud_storage_writer',
|
|
356
|
+
input=1,
|
|
357
|
+
output=0,
|
|
358
|
+
transform_type="other",
|
|
359
|
+
node_type="output",
|
|
360
|
+
image='cloud_storage_writer.png',
|
|
361
|
+
node_group='output',
|
|
362
|
+
drawer_title="Cloud Storage Writer",
|
|
363
|
+
drawer_intro="Save data to AWS S3 and other cloud storage"
|
|
364
|
+
),
|
|
365
|
+
]
|
|
366
|
+
nodes_list.sort(key=lambda x: x.name)
|
|
367
|
+
nodes_with_defaults = {'sample', 'sort', 'union', 'select', 'record_count'}
|
|
368
|
+
|
|
369
|
+
def check_if_has_default_setting(node_item: str):
|
|
370
|
+
|
|
371
|
+
return node_item in nodes_with_defaults
|
|
372
|
+
|
|
373
|
+
node_defaults = {node.item: NodeDefault(node_name=node.name,
|
|
374
|
+
node_type=node.node_type,
|
|
375
|
+
transform_type=node.transform_type,
|
|
376
|
+
has_default_settings=check_if_has_default_setting(node.item)
|
|
377
|
+
) for node in nodes_list}
|
|
378
|
+
node_dict = {n.item: n for n in nodes_list}
|
|
379
|
+
|
|
380
|
+
node_dict["polars_lazy_frame"] = NodeTemplate(name='LazyFrame node', item='polars_lazy_frame', input=0, output=1,
|
|
381
|
+
node_group="special", image="", node_type="input", transform_type="other",)
|
|
382
|
+
|
|
383
|
+
return nodes_list, node_dict, node_defaults
|