Flowfile 0.4.1__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 +3 -1
- flowfile/api.py +1 -2
- flowfile/web/static/assets/{CloudConnectionManager-d3248f8d.js → CloudConnectionManager-0dfba9f2.js} +2 -2
- flowfile/web/static/assets/{CloudStorageReader-d65bf041.js → CloudStorageReader-d5b1b6c9.js} +6 -6
- flowfile/web/static/assets/{CloudStorageWriter-e83be3ed.js → CloudStorageWriter-00d87aad.js} +6 -6
- flowfile/web/static/assets/{ColumnSelector-cce661cf.js → ColumnSelector-4685e75d.js} +1 -1
- flowfile/web/static/assets/{ContextMenu-cf18d2cc.js → ContextMenu-23e909da.js} +1 -1
- flowfile/web/static/assets/{ContextMenu-160afb08.js → ContextMenu-70ae0c79.js} +1 -1
- flowfile/web/static/assets/{ContextMenu-11a4652a.js → ContextMenu-f149cf7c.js} +1 -1
- flowfile/web/static/assets/{CrossJoin-d395d38c.js → CrossJoin-702a3edd.js} +7 -7
- flowfile/web/static/assets/{CustomNode-b812dc0b.js → CustomNode-b1519993.js} +11 -11
- flowfile/web/static/assets/{DatabaseConnectionSettings-7000bf2c.js → DatabaseConnectionSettings-6f3e4ea5.js} +2 -2
- flowfile/web/static/assets/{DatabaseManager-9662ec5b.js → DatabaseManager-cf5ef661.js} +2 -2
- flowfile/web/static/assets/{DatabaseReader-4f035d0c.js → DatabaseReader-d38c7295.js} +9 -9
- flowfile/web/static/assets/{DatabaseWriter-f65dcd54.js → DatabaseWriter-b04ef46a.js} +8 -8
- flowfile/web/static/assets/{ExploreData-94c43dfc.js → ExploreData-5fa10ed8.js} +5 -5
- flowfile/web/static/assets/{ExternalSource-ac04b3cc.js → ExternalSource-d39af878.js} +5 -5
- flowfile/web/static/assets/{Filter-812dcbca.js → Filter-9b6d08db.js} +7 -7
- flowfile/web/static/assets/{Formula-71472193.js → Formula-6b04fb1d.js} +7 -7
- flowfile/web/static/assets/{FuzzyMatch-b317f631.js → FuzzyMatch-999521f4.js} +8 -8
- flowfile/web/static/assets/{GraphSolver-754a234f.js → GraphSolver-17dd2198.js} +6 -6
- flowfile/web/static/assets/{GroupBy-6c6f9802.js → GroupBy-6b039e18.js} +5 -5
- flowfile/web/static/assets/{Join-a1b800be.js → Join-24d0f113.js} +8 -8
- flowfile/web/static/assets/{ManualInput-a9640276.js → ManualInput-34639209.js} +4 -4
- flowfile/web/static/assets/{MultiSelect-97213888.js → MultiSelect-0e8724a3.js} +2 -2
- flowfile/web/static/assets/{MultiSelect.vue_vue_type_script_setup_true_lang-6ffe088a.js → MultiSelect.vue_vue_type_script_setup_true_lang-b0e538c2.js} +1 -1
- flowfile/web/static/assets/{NumericInput-e638088a.js → NumericInput-3d63a470.js} +2 -2
- flowfile/web/static/assets/{NumericInput.vue_vue_type_script_setup_true_lang-90eb2cba.js → NumericInput.vue_vue_type_script_setup_true_lang-e0edeccc.js} +1 -1
- flowfile/web/static/assets/{Output-ddc9079f.css → Output-283fe388.css} +5 -5
- flowfile/web/static/assets/{Output-76750610.js → Output-edea9802.js} +57 -38
- flowfile/web/static/assets/{Pivot-7814803f.js → Pivot-61d19301.js} +7 -7
- flowfile/web/static/assets/{PivotValidation-f92137d2.js → PivotValidation-de9f43fe.js} +1 -1
- flowfile/web/static/assets/{PivotValidation-76dd431a.js → PivotValidation-f97fec5b.js} +1 -1
- flowfile/web/static/assets/{PolarsCode-889c3008.js → PolarsCode-bc3c9984.js} +5 -5
- flowfile/web/static/assets/{Read-637b72a7.js → Read-64a3f259.js} +80 -105
- flowfile/web/static/assets/{Read-6b17491f.css → Read-e808b239.css} +10 -10
- flowfile/web/static/assets/{RecordCount-2b050c41.js → RecordCount-3d5039be.js} +4 -4
- flowfile/web/static/assets/{RecordId-81df7784.js → RecordId-597510e0.js} +6 -6
- flowfile/web/static/assets/{SQLQueryComponent-88dcfe53.js → SQLQueryComponent-df51adbe.js} +1 -1
- flowfile/web/static/assets/{Sample-258ad2a9.js → Sample-4be0a507.js} +4 -4
- flowfile/web/static/assets/{SecretManager-2a2cb7e2.js → SecretManager-4839be57.js} +2 -2
- flowfile/web/static/assets/{Select-850215fd.js → Select-9b72f201.js} +7 -7
- flowfile/web/static/assets/{SettingsSection-29b4fa6b.js → SettingsSection-7ded385d.js} +1 -1
- flowfile/web/static/assets/{SettingsSection-0e8d9123.js → SettingsSection-e1e9c953.js} +1 -1
- flowfile/web/static/assets/{SettingsSection-55bae608.js → SettingsSection-f0f75a42.js} +1 -1
- flowfile/web/static/assets/{SingleSelect-bebd408b.js → SingleSelect-6c777aac.js} +2 -2
- flowfile/web/static/assets/{SingleSelect.vue_vue_type_script_setup_true_lang-6093741c.js → SingleSelect.vue_vue_type_script_setup_true_lang-33e3ff9b.js} +1 -1
- flowfile/web/static/assets/{SliderInput-6a05ab61.js → SliderInput-7cb93e62.js} +1 -1
- flowfile/web/static/assets/{Sort-10ab48ed.js → Sort-6cbde21a.js} +5 -5
- flowfile/web/static/assets/{TextInput-df9d6259.js → TextInput-d9a40c11.js} +2 -2
- flowfile/web/static/assets/{TextInput.vue_vue_type_script_setup_true_lang-000e1178.js → TextInput.vue_vue_type_script_setup_true_lang-5896c375.js} +1 -1
- flowfile/web/static/assets/{TextToRows-6c2d93d8.js → TextToRows-c4fcbf4d.js} +7 -7
- flowfile/web/static/assets/{ToggleSwitch-0ff7ac52.js → ToggleSwitch-4ef91d19.js} +2 -2
- flowfile/web/static/assets/{ToggleSwitch.vue_vue_type_script_setup_true_lang-c6dc3029.js → ToggleSwitch.vue_vue_type_script_setup_true_lang-38478c20.js} +1 -1
- flowfile/web/static/assets/{UnavailableFields-1bab97cb.js → UnavailableFields-a03f512c.js} +2 -2
- flowfile/web/static/assets/{Union-b563478a.js → Union-bfe9b996.js} +4 -4
- flowfile/web/static/assets/{Unique-f90db5db.js → Unique-5d023a27.js} +8 -20
- flowfile/web/static/assets/{Unpivot-bcb0025f.js → Unpivot-91cc5354.js} +6 -6
- flowfile/web/static/assets/{UnpivotValidation-c4e73b04.js → UnpivotValidation-7ee2de44.js} +1 -1
- flowfile/web/static/assets/{VueGraphicWalker-bb8535e2.js → VueGraphicWalker-e51b9924.js} +1 -1
- flowfile/web/static/assets/{api-2d6adc4f.js → api-c1bad5ca.js} +1 -1
- flowfile/web/static/assets/{api-4c8e3822.js → api-cf1221f0.js} +1 -1
- flowfile/web/static/assets/{designer-e3c150ec.css → designer-8da3ba3a.css} +90 -67
- flowfile/web/static/assets/{designer-f3656d8c.js → designer-9633482a.js} +119 -51
- flowfile/web/static/assets/{documentation-52b241e7.js → documentation-ca400224.js} +1 -1
- flowfile/web/static/assets/{dropDown-1bca8a74.js → dropDown-614b998d.js} +1 -1
- flowfile/web/static/assets/{fullEditor-2985687e.js → fullEditor-f7971590.js} +2 -2
- flowfile/web/static/assets/{genericNodeSettings-0476ba4e.js → genericNodeSettings-4fe5f36b.js} +3 -3
- flowfile/web/static/assets/{index-246f201c.js → index-5429bbf8.js} +6 -8
- flowfile/web/static/assets/nodeInput-5d0d6b79.js +41 -0
- flowfile/web/static/assets/{outputCsv-d686eeaf.js → outputCsv-076b85ab.js} +1 -1
- flowfile/web/static/assets/{outputExcel-8809ea2f.js → outputExcel-0fd17dbe.js} +1 -1
- flowfile/web/static/assets/{outputParquet-53ba645a.js → outputParquet-b61e0847.js} +1 -1
- flowfile/web/static/assets/{readCsv-053bf97b.js → readCsv-a8bb8b61.js} +21 -20
- flowfile/web/static/assets/{readCsv-bca3ed53.css → readCsv-c767cb37.css} +13 -13
- flowfile/web/static/assets/{readExcel-ad531eab.js → readExcel-67b4aee0.js} +10 -12
- flowfile/web/static/assets/{readExcel-e1b381ea.css → readExcel-806d2826.css} +12 -12
- flowfile/web/static/assets/{readParquet-cee068e2.css → readParquet-48c81530.css} +3 -3
- flowfile/web/static/assets/{readParquet-58e899a1.js → readParquet-92ce1dbc.js} +4 -7
- flowfile/web/static/assets/{secretApi-538058f3.js → secretApi-68435402.js} +1 -1
- flowfile/web/static/assets/{selectDynamic-b38de2ba.js → selectDynamic-92e25ee3.js} +3 -3
- flowfile/web/static/assets/{vue-codemirror.esm-db9b8936.js → vue-codemirror.esm-41b0e0d7.js} +7 -4
- flowfile/web/static/assets/{vue-content-loader.es-b5f3ac30.js → vue-content-loader.es-2c8e608f.js} +1 -1
- flowfile/web/static/index.html +1 -1
- {flowfile-0.4.1.dist-info → flowfile-0.5.1.dist-info}/METADATA +3 -2
- {flowfile-0.4.1.dist-info → flowfile-0.5.1.dist-info}/RECORD +138 -126
- {flowfile-0.4.1.dist-info → flowfile-0.5.1.dist-info}/WHEEL +1 -1
- {flowfile-0.4.1.dist-info → flowfile-0.5.1.dist-info}/entry_points.txt +1 -0
- flowfile_core/__init__.py +3 -0
- 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/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 +184 -78
- flowfile_core/flowfile/flow_data_engine/utils.py +2 -0
- flowfile_core/flowfile/flow_graph.py +129 -26
- flowfile_core/flowfile/flow_node/flow_node.py +3 -0
- flowfile_core/flowfile/flow_node/models.py +2 -1
- flowfile_core/flowfile/handler.py +5 -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 +1 -1
- flowfile_core/flowfile/node_designer/_type_registry.py +2 -2
- flowfile_core/flowfile/node_designer/custom_node.py +1 -1
- flowfile_core/flowfile/node_designer/ui_components.py +1 -1
- flowfile_core/flowfile/schema_callbacks.py +8 -5
- flowfile_core/flowfile/setting_generator/settings.py +15 -9
- flowfile_core/routes/routes.py +8 -10
- flowfile_core/schemas/cloud_storage_schemas.py +0 -2
- flowfile_core/schemas/input_schema.py +222 -65
- flowfile_core/schemas/output_model.py +1 -1
- flowfile_core/schemas/schemas.py +145 -32
- flowfile_core/schemas/transform_schema.py +1083 -413
- flowfile_core/schemas/yaml_types.py +103 -0
- flowfile_core/{flowfile/node_designer/data_types.py → types.py} +11 -1
- flowfile_frame/__init__.py +3 -1
- flowfile_frame/flow_frame.py +15 -18
- flowfile_frame/flow_frame_methods.py +12 -9
- flowfile_worker/__init__.py +3 -0
- flowfile_worker/create/__init__.py +3 -21
- flowfile_worker/create/funcs.py +68 -56
- flowfile_worker/create/models.py +130 -62
- flowfile_worker/routes.py +5 -8
- 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_core/flowfile/manage/open_flowfile.py +0 -143
- {flowfile-0.4.1.dist-info → flowfile-0.5.1.dist-info}/licenses/LICENSE +0 -0
- /flowfile_core/flowfile/manage/manage_flowfile.py → /tools/__init__.py +0 -0
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
from flowfile_core.schemas import schemas, input_schema
|
|
2
|
-
from typing import List, Tuple
|
|
3
|
-
from flowfile_core.flowfile.manage.compatibility_enhancements import ensure_compatibility
|
|
4
|
-
import pickle
|
|
5
|
-
from flowfile_core.flowfile.flow_graph import FlowGraph
|
|
6
|
-
from pathlib import Path
|
|
7
|
-
from flowfile_core.configs.node_store import CUSTOM_NODE_STORE
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
def determine_insertion_order(node_storage: schemas.FlowInformation):
|
|
11
|
-
ingest_order: List[int] = []
|
|
12
|
-
ingest_order_set: set[int] = set()
|
|
13
|
-
all_nodes = set(node_storage.data.keys())
|
|
14
|
-
|
|
15
|
-
def assure_output_id(input_node: schemas.NodeInformation, output_node: schemas.NodeInformation):
|
|
16
|
-
# assure the output id is in the list with outputs of the input node this is a quick fix
|
|
17
|
-
if output_node.id not in input_node.outputs:
|
|
18
|
-
input_node.outputs.append(output_node.id)
|
|
19
|
-
|
|
20
|
-
def determine_order(node_id: int):
|
|
21
|
-
current_node = node_storage.data.get(node_id)
|
|
22
|
-
if current_node is None:
|
|
23
|
-
return
|
|
24
|
-
output_ids = current_node.outputs
|
|
25
|
-
main_input_ids = current_node.input_ids if current_node.input_ids else []
|
|
26
|
-
input_ids = [n for n in [current_node.left_input_id,
|
|
27
|
-
current_node.right_input_id] + main_input_ids if (n is not None
|
|
28
|
-
and n not in
|
|
29
|
-
ingest_order_set)]
|
|
30
|
-
if len(input_ids) > 0:
|
|
31
|
-
for input_id in input_ids:
|
|
32
|
-
new_node = node_storage.data.get(input_id)
|
|
33
|
-
if new_node is None:
|
|
34
|
-
ingest_order.append(current_node.id)
|
|
35
|
-
ingest_order_set.add(current_node.id)
|
|
36
|
-
continue
|
|
37
|
-
assure_output_id(new_node, current_node)
|
|
38
|
-
if new_node.id not in ingest_order_set:
|
|
39
|
-
determine_order(input_id)
|
|
40
|
-
elif current_node.id not in ingest_order_set:
|
|
41
|
-
ingest_order.append(current_node.id)
|
|
42
|
-
ingest_order_set.add(current_node.id)
|
|
43
|
-
|
|
44
|
-
for output_id in output_ids:
|
|
45
|
-
if output_id not in ingest_order_set:
|
|
46
|
-
determine_order(output_id)
|
|
47
|
-
|
|
48
|
-
if len(node_storage.node_starts) > 0:
|
|
49
|
-
determine_order(node_storage.node_starts[0])
|
|
50
|
-
# add the random not connected nodes
|
|
51
|
-
else:
|
|
52
|
-
for node_id in all_nodes:
|
|
53
|
-
determine_order(node_id)
|
|
54
|
-
ingest_order += list(all_nodes - ingest_order_set)
|
|
55
|
-
return ingest_order
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
def open_flow(flow_path: Path) -> FlowGraph:
|
|
59
|
-
"""
|
|
60
|
-
Open a flowfile from a given path
|
|
61
|
-
Args:
|
|
62
|
-
flow_path (Path): The absolute or relative path to the flowfile
|
|
63
|
-
|
|
64
|
-
Returns:
|
|
65
|
-
FlowGraph: The flowfile object
|
|
66
|
-
"""
|
|
67
|
-
with open(str(flow_path), 'rb') as f:
|
|
68
|
-
flow_storage_obj: schemas.FlowInformation = pickle.load(f)
|
|
69
|
-
flow_storage_obj.flow_settings.path = str(flow_path)
|
|
70
|
-
flow_storage_obj.flow_settings.name = str(flow_path.stem)
|
|
71
|
-
flow_storage_obj.flow_name = str(flow_path.stem)
|
|
72
|
-
ensure_compatibility(flow_storage_obj, str(flow_path))
|
|
73
|
-
ingestion_order = determine_insertion_order(flow_storage_obj)
|
|
74
|
-
new_flow = FlowGraph(name=flow_storage_obj.flow_name, flow_settings=flow_storage_obj.flow_settings)
|
|
75
|
-
for node_id in ingestion_order:
|
|
76
|
-
node_info: schemas.NodeInformation = flow_storage_obj.data[node_id]
|
|
77
|
-
node_promise = input_schema.NodePromise(flow_id=new_flow.flow_id, node_id=node_info.id,
|
|
78
|
-
pos_x=node_info.x_position, pos_y=node_info.y_position,
|
|
79
|
-
node_type=node_info.type)
|
|
80
|
-
if hasattr(node_info.setting_input, 'cache_results'):
|
|
81
|
-
node_promise.cache_results = node_info.setting_input.cache_results
|
|
82
|
-
new_flow.add_node_promise(node_promise)
|
|
83
|
-
for node_id in ingestion_order:
|
|
84
|
-
node_info: schemas.NodeInformation = flow_storage_obj.data[node_id]
|
|
85
|
-
if hasattr(node_info.setting_input, "is_user_defined") and node_info.setting_input.is_user_defined:
|
|
86
|
-
if node_info.type not in CUSTOM_NODE_STORE:
|
|
87
|
-
continue
|
|
88
|
-
user_defined_node_class = CUSTOM_NODE_STORE[node_info.type]
|
|
89
|
-
new_flow.add_user_defined_node(custom_node=user_defined_node_class.from_settings(node_info.setting_input.settings),
|
|
90
|
-
user_defined_node_settings=node_info.setting_input)
|
|
91
|
-
else:
|
|
92
|
-
getattr(new_flow, 'add_' + node_info.type)(node_info.setting_input)
|
|
93
|
-
from_node = new_flow.get_node(node_id)
|
|
94
|
-
for output_node_id in node_info.outputs:
|
|
95
|
-
to_node = new_flow.get_node(output_node_id)
|
|
96
|
-
if to_node is not None:
|
|
97
|
-
output_node_obj = flow_storage_obj.data[output_node_id]
|
|
98
|
-
is_left_input = (output_node_obj.left_input_id == node_id) and (to_node.left_input.node_id != node_id
|
|
99
|
-
if to_node.left_input is not None
|
|
100
|
-
else True)
|
|
101
|
-
is_right_input = (output_node_obj.right_input_id == node_id) and (to_node.right_input.node_id != node_id
|
|
102
|
-
if to_node.right_input is not None
|
|
103
|
-
else True)
|
|
104
|
-
is_main_input = node_id in output_node_obj.input_ids
|
|
105
|
-
if is_left_input:
|
|
106
|
-
insert_type = 'left'
|
|
107
|
-
elif is_right_input:
|
|
108
|
-
insert_type = 'right'
|
|
109
|
-
elif is_main_input:
|
|
110
|
-
insert_type = 'main'
|
|
111
|
-
else:
|
|
112
|
-
continue
|
|
113
|
-
to_node.add_node_connection(from_node, insert_type)
|
|
114
|
-
else:
|
|
115
|
-
from_node.delete_lead_to_node(output_node_id)
|
|
116
|
-
if not (from_node.node_id, output_node_id) in flow_storage_obj.node_connections:
|
|
117
|
-
continue
|
|
118
|
-
flow_storage_obj.node_connections.pop(
|
|
119
|
-
flow_storage_obj.node_connections.index((from_node.node_id, output_node_id)))
|
|
120
|
-
|
|
121
|
-
for missing_connection in set(flow_storage_obj.node_connections) - set(new_flow.node_connections):
|
|
122
|
-
to_node = new_flow.get_node(missing_connection[1])
|
|
123
|
-
if not to_node.has_input:
|
|
124
|
-
test_if_circular_connection(missing_connection, new_flow)
|
|
125
|
-
from_node = new_flow.get_node(missing_connection[0])
|
|
126
|
-
if from_node:
|
|
127
|
-
to_node.add_node_connection(from_node)
|
|
128
|
-
return new_flow
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
def test_if_circular_connection(connection: Tuple[int, int], flow: FlowGraph):
|
|
132
|
-
to_node = flow.get_node(connection[1])
|
|
133
|
-
leads_to_nodes_queue = [n for n in to_node.leads_to_nodes]
|
|
134
|
-
circular_connection: bool = False
|
|
135
|
-
while len(leads_to_nodes_queue) > 0:
|
|
136
|
-
leads_to_node = leads_to_nodes_queue.pop(0)
|
|
137
|
-
if leads_to_node.node_id == connection[0]:
|
|
138
|
-
circular_connection = True
|
|
139
|
-
break
|
|
140
|
-
for leads_to_node_leads_to in leads_to_node.leads_to_nodes:
|
|
141
|
-
leads_to_nodes_queue.append(leads_to_node_leads_to)
|
|
142
|
-
return circular_connection
|
|
143
|
-
|
|
File without changes
|
|
File without changes
|