pyegeria 5.4.0.28__py3-none-any.whl → 5.5.3.3__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.
Potentially problematic release.
This version of pyegeria might be problematic. Click here for more details.
- commands/__init__.py +24 -0
- commands/cat/Dr-Egeria_md-orig.py +2 -2
- commands/cat/collection_actions.py +197 -0
- commands/cat/dr_egeria_command_help.py +137 -38
- commands/cat/dr_egeria_jupyter.py +7 -7
- commands/cat/dr_egeria_md.py +10 -267
- commands/cat/exp_list_glossaries.py +11 -14
- commands/cat/get_asset_graph.py +37 -267
- commands/cat/{get_collection.py → get_collection_tree.py} +10 -18
- commands/cat/get_project_dependencies.py +14 -14
- commands/cat/get_project_structure.py +15 -14
- commands/cat/get_tech_type_elements.py +16 -116
- commands/cat/glossary_actions.py +145 -298
- commands/cat/list_assets.py +3 -11
- commands/cat/list_cert_types.py +17 -63
- commands/cat/list_collections.py +17 -139
- commands/cat/list_deployed_catalogs.py +15 -27
- commands/cat/list_deployed_database_schemas.py +27 -43
- commands/cat/list_deployed_databases.py +16 -31
- commands/cat/list_deployed_servers.py +35 -54
- commands/cat/list_glossaries.py +18 -17
- commands/cat/list_projects.py +10 -12
- commands/cat/list_tech_type_elements.py +21 -37
- commands/cat/list_tech_types.py +13 -25
- commands/cat/list_terms.py +38 -79
- commands/cat/list_todos.py +4 -11
- commands/cat/list_user_ids.py +3 -10
- commands/cat/my_reports.py +559 -0
- commands/cat/run_report.py +394 -0
- commands/cat/{list_format_set.py → run_report_orig.py} +136 -44
- commands/cli/egeria.py +182 -219
- commands/cli/egeria_cat.py +32 -59
- commands/cli/egeria_my.py +13 -0
- commands/cli/egeria_ops.py +69 -74
- commands/cli/egeria_tech.py +17 -93
- commands/{cat → deprecated}/list_data_designer.py +2 -4
- commands/{cat → deprecated}/list_data_structures_full.py +3 -6
- commands/deprecated/old_get_asset_graph.py +315 -0
- commands/my/__init__.py +0 -2
- commands/my/list_my_profile.py +27 -34
- commands/my/list_my_roles.py +1 -7
- commands/my/monitor_my_todos.py +1 -7
- commands/my/monitor_open_todos.py +6 -7
- commands/my/todo_actions.py +4 -5
- commands/ops/__init__.py +0 -2
- commands/ops/gov_server_actions.py +17 -21
- commands/ops/list_archives.py +17 -38
- commands/ops/list_catalog_targets.py +33 -40
- commands/ops/load_archive.py +14 -11
- commands/ops/{monitor_engine_activity_c.py → monitor_active_engine_activity.py} +51 -82
- commands/ops/{monitor_integ_daemon_status.py → monitor_daemon_status.py} +35 -55
- commands/ops/monitor_engine_activity.py +79 -77
- commands/ops/{monitor_gov_eng_status.py → monitor_engine_status.py} +10 -7
- commands/ops/monitor_platform_status.py +38 -50
- commands/ops/monitor_server_startup.py +6 -11
- commands/ops/monitor_server_status.py +7 -11
- commands/ops/orig_monitor_server_list.py +8 -8
- commands/ops/orig_monitor_server_status.py +1 -5
- commands/ops/refresh_integration_daemon.py +5 -5
- commands/ops/restart_integration_daemon.py +5 -5
- commands/ops/table_integ_daemon_status.py +6 -6
- commands/ops/x_engine_actions.py +7 -7
- commands/tech/__init__.py +0 -2
- commands/tech/{generic_actions.py → element_actions.py} +6 -11
- commands/tech/get_element_info.py +20 -29
- commands/tech/get_guid_info.py +23 -42
- commands/tech/get_tech_details.py +20 -35
- commands/tech/get_tech_type_template.py +28 -39
- commands/tech/list_all_om_type_elements.py +24 -30
- commands/tech/list_all_om_type_elements_x.py +22 -28
- commands/tech/list_all_related_elements.py +19 -28
- commands/tech/list_anchored_elements.py +22 -30
- commands/tech/list_asset_types.py +19 -24
- commands/tech/list_elements_by_classification_by_property_value.py +26 -32
- commands/tech/list_elements_by_property_value.py +19 -25
- commands/tech/list_elements_by_property_value_x.py +20 -28
- commands/tech/list_elements_for_classification.py +28 -41
- commands/tech/list_gov_action_processes.py +16 -27
- commands/tech/list_information_supply_chains.py +22 -30
- commands/tech/list_registered_services.py +14 -26
- commands/tech/list_related_elements_with_prop_value.py +15 -25
- commands/tech/list_related_specification.py +1 -4
- commands/tech/list_relationship_types.py +15 -25
- commands/tech/list_relationships.py +20 -36
- commands/tech/list_solution_blueprints.py +28 -33
- commands/tech/list_solution_components.py +23 -29
- commands/tech/list_solution_roles.py +21 -32
- commands/tech/list_tech_templates.py +51 -54
- commands/tech/list_valid_metadata_values.py +5 -9
- commands/tech/table_tech_templates.py +2 -6
- commands/tech/x_list_related_elements.py +1 -4
- examples/GeoSpatial Products Example.py +524 -0
- examples/Jupyter Notebooks/P-egeria-server-config.ipynb +2137 -0
- examples/Jupyter Notebooks/README.md +2 -0
- examples/Jupyter Notebooks/common/P-environment-check.ipynb +115 -0
- examples/Jupyter Notebooks/common/__init__.py +14 -0
- examples/Jupyter Notebooks/common/common-functions.ipynb +4694 -0
- examples/Jupyter Notebooks/common/environment-check.ipynb +52 -0
- examples/Jupyter Notebooks/common/globals.ipynb +184 -0
- examples/Jupyter Notebooks/common/globals.py +154 -0
- examples/Jupyter Notebooks/common/orig_globals.py +152 -0
- examples/format_sets/all_format_sets.json +910 -0
- examples/format_sets/custom_format_sets.json +268 -0
- examples/format_sets/subset_format_sets.json +187 -0
- examples/format_sets_save_load_example.py +291 -0
- examples/jacquard_data_sets.py +129 -0
- examples/output_formats_example.py +193 -0
- examples/test_jacquard_data_sets.py +54 -0
- examples/test_jacquard_data_sets_scenarios.py +94 -0
- md_processing/__init__.py +33 -24
- md_processing/command_dispatcher.py +33 -0
- md_processing/command_mapping.py +221 -0
- md_processing/data/commands/commands_data_designer.json +537 -0
- md_processing/data/commands/commands_external_reference.json +733 -0
- md_processing/data/commands/commands_feedback.json +155 -0
- md_processing/data/commands/commands_general.json +204 -0
- md_processing/data/commands/commands_glossary.json +218 -0
- md_processing/data/commands/commands_governance.json +3678 -0
- md_processing/data/commands/commands_product_manager.json +865 -0
- md_processing/data/commands/commands_project.json +642 -0
- md_processing/data/commands/commands_solution_architect.json +366 -0
- md_processing/data/commands.json +6489 -30060
- md_processing/data/{commands-working.json → commands_working.json} +9304 -13513
- md_processing/data/gened_report_specs.py +6584 -0
- md_processing/data/generated_format_sets.json +6533 -0
- md_processing/data/generated_format_sets_old.json +4137 -0
- md_processing/data/generated_format_sets_old.py +45 -0
- md_processing/dr_egeria.py +182 -0
- md_processing/md_commands/data_designer_commands.py +195 -583
- md_processing/md_commands/ext_ref_commands.py +530 -0
- md_processing/md_commands/feedback_commands.py +726 -0
- md_processing/md_commands/glossary_commands.py +106 -490
- md_processing/md_commands/governance_officer_commands.py +129 -18
- md_processing/md_commands/product_manager_commands.py +362 -115
- md_processing/md_commands/project_commands.py +351 -134
- md_processing/md_commands/solution_architect_commands.py +276 -232
- md_processing/md_commands/view_commands.py +295 -0
- md_processing/md_processing_utils/common_md_proc_utils.py +258 -166
- md_processing/md_processing_utils/common_md_utils.py +138 -43
- md_processing/md_processing_utils/determine_width.py +103 -0
- md_processing/md_processing_utils/extraction_utils.py +100 -39
- md_processing/md_processing_utils/gen_report_specs.py +643 -0
- md_processing/md_processing_utils/generate_dr_help.py +61 -33
- md_processing/md_processing_utils/generate_md_cmd_templates.py +20 -19
- md_processing/md_processing_utils/generate_md_templates.py +3 -12
- md_processing/md_processing_utils/md_processing_constants.py +1053 -72
- pyegeria/__init__.py +203 -158
- pyegeria/core/__init__.py +40 -0
- pyegeria/core/_base_platform_client.py +574 -0
- pyegeria/core/_base_server_client.py +573 -0
- pyegeria/{_exceptions_new.py → core/_exceptions.py} +62 -30
- pyegeria/{_globals.py → core/_globals.py} +14 -3
- pyegeria/core/_server_client.py +6073 -0
- pyegeria/{_validators.py → core/_validators.py} +7 -8
- pyegeria/core/config.py +654 -0
- pyegeria/{create_tech_guid_lists.py → core/create_tech_guid_lists.py} +0 -1
- pyegeria/core/load_config.py +37 -0
- pyegeria/{logging_configuration.py → core/logging_configuration.py} +1 -1
- pyegeria/core/mcp_adapter.py +144 -0
- pyegeria/core/mcp_server.py +212 -0
- pyegeria/core/utils.py +405 -0
- pyegeria/{_client.py → deprecated/_client.py} +24 -25
- pyegeria/{_deprecated_gov_engine.py → deprecated/_deprecated_gov_engine.py} +16 -16
- pyegeria/{classification_manager_omvs.py → deprecated/classification_manager_omvs.py} +1987 -1877
- pyegeria/{output_formatter.py → deprecated/output_formatter_with_machine_keys.py} +298 -45
- pyegeria/{runtime_manager_omvs.py → deprecated/runtime_manager_omvs.py} +155 -171
- pyegeria/{valid_metadata_omvs.py → deprecated/valid_metadata_omvs.py} +93 -93
- pyegeria/{x_action_author_omvs.py → deprecated/x_action_author_omvs.py} +2 -3
- pyegeria/egeria_cat_client.py +26 -70
- pyegeria/egeria_client.py +130 -93
- pyegeria/egeria_config_client.py +40 -46
- pyegeria/egeria_tech_client.py +141 -54
- pyegeria/models/__init__.py +150 -0
- pyegeria/{models.py → models/models.py} +156 -20
- pyegeria/omvs/__init__.py +84 -0
- pyegeria/omvs/action_author.py +342 -0
- pyegeria/omvs/actor_manager.py +5980 -0
- pyegeria/omvs/asset_catalog.py +842 -0
- pyegeria/omvs/asset_maker.py +2736 -0
- pyegeria/omvs/automated_curation.py +4403 -0
- pyegeria/omvs/classification_manager.py +11213 -0
- pyegeria/{collection_manager.py → omvs/collection_manager.py} +1334 -1160
- pyegeria/omvs/community_matters_omvs.py +468 -0
- pyegeria/{core_omag_server_config.py → omvs/core_omag_server_config.py} +157 -157
- pyegeria/{data_designer.py → omvs/data_designer.py} +1115 -660
- pyegeria/omvs/data_discovery.py +869 -0
- pyegeria/omvs/data_engineer.py +372 -0
- pyegeria/omvs/digital_business.py +1133 -0
- pyegeria/omvs/external_links.py +1752 -0
- pyegeria/omvs/feedback_manager.py +834 -0
- pyegeria/{full_omag_server_config.py → omvs/full_omag_server_config.py} +73 -69
- pyegeria/{glossary_manager.py → omvs/glossary_manager.py} +857 -519
- pyegeria/{governance_officer.py → omvs/governance_officer.py} +964 -468
- pyegeria/omvs/lineage_linker.py +314 -0
- pyegeria/omvs/location_arena.py +1525 -0
- pyegeria/omvs/metadata_expert.py +668 -0
- pyegeria/omvs/metadata_explorer_omvs.py +2943 -0
- pyegeria/omvs/my_profile.py +1042 -0
- pyegeria/omvs/notification_manager.py +358 -0
- pyegeria/omvs/people_organizer.py +394 -0
- pyegeria/{platform_services.py → omvs/platform_services.py} +113 -193
- pyegeria/omvs/product_manager.py +1825 -0
- pyegeria/omvs/project_manager.py +1907 -0
- pyegeria/omvs/reference_data.py +1140 -0
- pyegeria/omvs/registered_info.py +334 -0
- pyegeria/omvs/runtime_manager.py +2817 -0
- pyegeria/omvs/schema_maker.py +446 -0
- pyegeria/{server_operations.py → omvs/server_operations.py} +27 -26
- pyegeria/{solution_architect_omvs.py → omvs/solution_architect.py} +1886 -1505
- pyegeria/omvs/specification_properties.py +37 -0
- pyegeria/omvs/subject_area.py +1042 -0
- pyegeria/omvs/template_manager_omvs.py +236 -0
- pyegeria/omvs/time_keeper.py +1761 -0
- pyegeria/omvs/valid_metadata.py +3221 -0
- pyegeria/omvs/valid_metadata_lists.py +37 -0
- pyegeria/omvs/valid_type_lists.py +37 -0
- pyegeria/view/__init__.py +28 -0
- pyegeria/{_output_format_models.py → view/_output_format_models.py} +160 -24
- pyegeria/view/_output_formats.py +14 -0
- pyegeria/view/base_report_formats.py +2719 -0
- pyegeria/view/dr_egeria_reports.py +56 -0
- pyegeria/view/format_set_executor.py +397 -0
- pyegeria/{md_processing_utils.py → view/md_processing_utils.py} +5 -5
- pyegeria/{mermaid_utilities.py → view/mermaid_utilities.py} +2 -154
- pyegeria/view/output_formatter.py +1297 -0
- pyegeria-5.5.3.3.dist-info/METADATA +218 -0
- pyegeria-5.5.3.3.dist-info/RECORD +241 -0
- {pyegeria-5.4.0.28.dist-info → pyegeria-5.5.3.3.dist-info}/WHEEL +2 -1
- pyegeria-5.5.3.3.dist-info/entry_points.txt +103 -0
- pyegeria-5.5.3.3.dist-info/top_level.txt +4 -0
- commands/cat/.DS_Store +0 -0
- commands/cat/.env +0 -8
- commands/cat/README.md +0 -16
- commands/cat/debug_log +0 -1126
- commands/cat/debug_log.2025-08-18_11-34-38_088636.zip +0 -0
- commands/cat/list_categories.py +0 -192
- commands/cat/logs/pyegeria.log +0 -4
- commands/cli/debug_log +0 -0
- commands/cli/debug_log.log +0 -0
- commands/cli/txt_custom_v2.tcss +0 -19
- commands/my/README.md +0 -17
- commands/ops/README.md +0 -24
- commands/ops/logs/pyegeria.log +0 -0
- commands/ops/monitor_asset_events.py +0 -108
- commands/tech/README.md +0 -24
- md_processing/.DS_Store +0 -0
- md_processing/dr-egeria-outbox/Collections-2025-08-12-13-30-37.md +0 -163
- md_processing/dr-egeria-outbox/Collections-2025-08-12-13-35-58.md +0 -474
- md_processing/dr_egeria_inbox/Derive-Dr-Gov-Defs.md +0 -8
- md_processing/dr_egeria_inbox/Dr.Egeria Templates.md +0 -873
- md_processing/dr_egeria_inbox/arch_test.md +0 -57
- md_processing/dr_egeria_inbox/archive/dr_egeria_intro.md +0 -254
- md_processing/dr_egeria_inbox/archive/dr_egeria_intro_more_terms.md +0 -696
- md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part1.md +0 -254
- md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part2.md +0 -298
- md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part3.md +0 -608
- md_processing/dr_egeria_inbox/archive/dr_egeria_intro_part4.md +0 -94
- md_processing/dr_egeria_inbox/archive/freddie_intro.md +0 -284
- md_processing/dr_egeria_inbox/archive/freddie_intro_orig.md +0 -275
- md_processing/dr_egeria_inbox/archive/test-term.md +0 -110
- md_processing/dr_egeria_inbox/cat_test.md +0 -100
- md_processing/dr_egeria_inbox/collections.md +0 -39
- md_processing/dr_egeria_inbox/data_designer_debug.log +0 -6
- md_processing/dr_egeria_inbox/data_designer_out.md +0 -60
- md_processing/dr_egeria_inbox/data_designer_search_test.md +0 -11
- md_processing/dr_egeria_inbox/data_field.md +0 -54
- md_processing/dr_egeria_inbox/data_spec.md +0 -77
- md_processing/dr_egeria_inbox/data_spec_test.md +0 -2406
- md_processing/dr_egeria_inbox/data_test.md +0 -179
- md_processing/dr_egeria_inbox/data_test2.md +0 -429
- md_processing/dr_egeria_inbox/data_test3.md +0 -462
- md_processing/dr_egeria_inbox/dr_egeria_data_designer_1.md +0 -124
- md_processing/dr_egeria_inbox/dr_egeria_intro_categories.md +0 -168
- md_processing/dr_egeria_inbox/dr_egeria_intro_part1.md +0 -280
- md_processing/dr_egeria_inbox/dr_egeria_intro_part2.md +0 -318
- md_processing/dr_egeria_inbox/dr_egeria_intro_part3.md +0 -1073
- md_processing/dr_egeria_inbox/dr_egeria_isc1.md +0 -44
- md_processing/dr_egeria_inbox/generated_help_report.md +0 -9
- md_processing/dr_egeria_inbox/glossary_creation_experiment.ipynb +0 -341
- md_processing/dr_egeria_inbox/glossary_list.md +0 -5
- md_processing/dr_egeria_inbox/glossary_search_test.md +0 -40
- md_processing/dr_egeria_inbox/glossary_test1.md +0 -324
- md_processing/dr_egeria_inbox/gov_def.md +0 -482
- md_processing/dr_egeria_inbox/gov_def2.md +0 -447
- md_processing/dr_egeria_inbox/img.png +0 -0
- md_processing/dr_egeria_inbox/product.md +0 -211
- md_processing/dr_egeria_inbox/rel.md +0 -8
- md_processing/dr_egeria_inbox/sb.md +0 -119
- md_processing/dr_egeria_inbox/solution-components.md +0 -136
- md_processing/dr_egeria_inbox/solution_blueprints.md +0 -118
- md_processing/dr_egeria_inbox/synonym_test.md +0 -42
- md_processing/dr_egeria_inbox/t2.md +0 -268
- md_processing/dr_egeria_outbox/.obsidian/app.json +0 -1
- md_processing/dr_egeria_outbox/.obsidian/appearance.json +0 -1
- md_processing/dr_egeria_outbox/.obsidian/community-plugins.json +0 -6
- md_processing/dr_egeria_outbox/.obsidian/core-plugins.json +0 -31
- md_processing/dr_egeria_outbox/.obsidian/plugins/calendar/data.json +0 -10
- md_processing/dr_egeria_outbox/.obsidian/plugins/calendar/main.js +0 -4459
- md_processing/dr_egeria_outbox/.obsidian/plugins/calendar/manifest.json +0 -10
- md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/data.json +0 -3
- md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/main.js +0 -153
- md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/manifest.json +0 -11
- md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-kanban/styles.css +0 -1
- md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-tasks-plugin/main.js +0 -500
- md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-tasks-plugin/manifest.json +0 -12
- md_processing/dr_egeria_outbox/.obsidian/plugins/obsidian-tasks-plugin/styles.css +0 -1
- md_processing/dr_egeria_outbox/.obsidian/plugins/templater-obsidian/main.js +0 -37
- md_processing/dr_egeria_outbox/.obsidian/plugins/templater-obsidian/manifest.json +0 -11
- md_processing/dr_egeria_outbox/.obsidian/plugins/templater-obsidian/styles.css +0 -220
- md_processing/dr_egeria_outbox/.obsidian/types.json +0 -28
- md_processing/dr_egeria_outbox/.obsidian/workspace.json +0 -220
- md_processing/dr_egeria_outbox/Untitled.canvas +0 -1
- md_processing/dr_egeria_outbox/friday/processed-2025-08-22 21:22-dr_egeria_intro_part1.md +0 -312
- md_processing/dr_egeria_outbox/friday/processed-2025-08-22 21:23-dr_egeria_intro_part1.md +0 -265
- md_processing/dr_egeria_outbox/friday/processed-2025-08-23 15:06-dr_egeria_intro_part1.md +0 -230
- md_processing/dr_egeria_outbox/friday/processed-2025-08-23 15:30-dr_egeria_intro_part1.md +0 -296
- md_processing/dr_egeria_outbox/friday/processed-2025-08-23 15:31-dr_egeria_intro_part1.md +0 -253
- md_processing/dr_egeria_outbox/friday/processed-2025-08-23 16:08-dr_egeria_intro_part2.md +0 -343
- md_processing/dr_egeria_outbox/friday/processed-2025-08-23 16:12-dr_egeria_intro_part2.md +0 -343
- md_processing/dr_egeria_outbox/monday/processed-2025-08-19 07:05-product.md +0 -426
- md_processing/dr_egeria_outbox/monday/processed-2025-08-19 07:56-product.md +0 -212
- md_processing/dr_egeria_outbox/monday/processed-2025-08-19 09:43-product.md +0 -201
- md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 14:55-product.md +0 -77
- md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 15:05-product.md +0 -75
- md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 15:11-product.md +0 -74
- md_processing/dr_egeria_outbox/sunday/processed-2025-07-20 20:40-collections.md +0 -49
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 15:00-Derive-Dr-Gov-Defs.md +0 -719
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 20:13-Derive-Dr-Gov-Defs.md +0 -41
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 20:14-Derive-Dr-Gov-Defs.md +0 -33
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 20:50-Derive-Dr-Gov-Defs.md +0 -192
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 22:08-gov_def2.md +0 -486
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-17 22:10-gov_def2.md +0 -486
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 08:53-gov_def2.md +0 -486
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 08:54-gov_def2.md +0 -486
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 09:03-gov_def2.md +0 -486
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 09:06-gov_def2.md +0 -486
- md_processing/dr_egeria_outbox/thursday/processed-2025-07-18 09:10-gov_def2.md +0 -486
- md_processing/dr_egeria_outbox/tuesday/processed-2025-07-16 19:15-gov_def2.md +0 -527
- md_processing/dr_egeria_outbox/tuesday/processed-2025-07-17 12:08-gov_def2.md +0 -527
- md_processing/dr_egeria_outbox/tuesday/processed-2025-07-17 14:27-gov_def2.md +0 -485
- md_processing/dr_egeria_outbox/tuesday/processed-2025-08-19 10:55-product.md +0 -209
- md_processing/family_docs/Data Designer/Create_Data_Class.md +0 -164
- md_processing/family_docs/Data Designer/Create_Data_Dictionary.md +0 -30
- md_processing/family_docs/Data Designer/Create_Data_Field.md +0 -162
- md_processing/family_docs/Data Designer/Create_Data_Specification.md +0 -36
- md_processing/family_docs/Data Designer/Create_Data_Structure.md +0 -38
- md_processing/family_docs/Data Designer/View_Data_Classes.md +0 -78
- md_processing/family_docs/Data Designer/View_Data_Dictionaries.md +0 -78
- md_processing/family_docs/Data Designer/View_Data_Fields.md +0 -78
- md_processing/family_docs/Data Designer/View_Data_Specifications.md +0 -78
- md_processing/family_docs/Data Designer/View_Data_Structures.md +0 -78
- md_processing/family_docs/Data Designer.md +0 -842
- md_processing/family_docs/Digital Product Manager/Add_Member->Collection.md +0 -42
- md_processing/family_docs/Digital Product Manager/Attach_Collection->Resource.md +0 -36
- md_processing/family_docs/Digital Product Manager/Create_Agreement.md +0 -96
- md_processing/family_docs/Digital Product Manager/Create_Data_Sharing_Agreement.md +0 -72
- md_processing/family_docs/Digital Product Manager/Create_DigitalSubscription.md +0 -102
- md_processing/family_docs/Digital Product Manager/Create_Digital_Product.md +0 -134
- md_processing/family_docs/Digital Product Manager/Link_Agreement_Items.md +0 -60
- md_processing/family_docs/Digital Product Manager/Link_Contracts.md +0 -26
- md_processing/family_docs/Digital Product Manager/Link_Digital_Product_-_Digital_Product.md +0 -30
- md_processing/family_docs/Digital Product Manager/Link_Subscribers.md +0 -48
- md_processing/family_docs/Digital Product Manager.md +0 -668
- md_processing/family_docs/Glossary/Attach_Category_Parent.md +0 -18
- md_processing/family_docs/Glossary/Attach_Term-Term_Relationship.md +0 -26
- md_processing/family_docs/Glossary/Create_Category.md +0 -38
- md_processing/family_docs/Glossary/Create_Glossary.md +0 -42
- md_processing/family_docs/Glossary/Create_Term.md +0 -70
- md_processing/family_docs/Glossary.md +0 -206
- md_processing/family_docs/Governance Officer/Create_Business_Imperative.md +0 -106
- md_processing/family_docs/Governance Officer/Create_Certification_Type.md +0 -112
- md_processing/family_docs/Governance Officer/Create_Governance_Approach.md +0 -114
- md_processing/family_docs/Governance Officer/Create_Governance_Obligation.md +0 -114
- md_processing/family_docs/Governance Officer/Create_Governance_Principle.md +0 -114
- md_processing/family_docs/Governance Officer/Create_Governance_Procedure.md +0 -128
- md_processing/family_docs/Governance Officer/Create_Governance_Process.md +0 -122
- md_processing/family_docs/Governance Officer/Create_Governance_Processing_Purpose.md +0 -106
- md_processing/family_docs/Governance Officer/Create_Governance_Responsibility.md +0 -122
- md_processing/family_docs/Governance Officer/Create_Governance_Rule.md +0 -122
- md_processing/family_docs/Governance Officer/Create_Governance_Strategy.md +0 -106
- md_processing/family_docs/Governance Officer/Create_License_Type.md +0 -112
- md_processing/family_docs/Governance Officer/Create_Naming_Standard_Rule.md +0 -122
- md_processing/family_docs/Governance Officer/Create_Regulation_Article.md +0 -106
- md_processing/family_docs/Governance Officer/Create_Regulation_Definition.md +0 -118
- md_processing/family_docs/Governance Officer/Create_Security_Access_Control.md +0 -114
- md_processing/family_docs/Governance Officer/Create_Security_Group.md +0 -120
- md_processing/family_docs/Governance Officer/Create_Service_Level_Objectives.md +0 -122
- md_processing/family_docs/Governance Officer/Create_Threat_Definition.md +0 -106
- md_processing/family_docs/Governance Officer/Link_Governance_Controls.md +0 -32
- md_processing/family_docs/Governance Officer/Link_Governance_Drivers.md +0 -32
- md_processing/family_docs/Governance Officer/Link_Governance_Policies.md +0 -32
- md_processing/family_docs/Governance Officer/View_Governance_Definitions.md +0 -82
- md_processing/family_docs/Governance Officer.md +0 -2412
- md_processing/family_docs/Solution Architect/Create_Information_Supply_Chain.md +0 -70
- md_processing/family_docs/Solution Architect/Create_Solution_Blueprint.md +0 -44
- md_processing/family_docs/Solution Architect/Create_Solution_Component.md +0 -96
- md_processing/family_docs/Solution Architect/Create_Solution_Role.md +0 -66
- md_processing/family_docs/Solution Architect/Link_Information_Supply_Chain_Peers.md +0 -32
- md_processing/family_docs/Solution Architect/Link_Solution_Component_Peers.md +0 -32
- md_processing/family_docs/Solution Architect/View_Information_Supply_Chains.md +0 -32
- md_processing/family_docs/Solution Architect/View_Solution_Blueprints.md +0 -32
- md_processing/family_docs/Solution Architect/View_Solution_Components.md +0 -32
- md_processing/family_docs/Solution Architect/View_Solution_Roles.md +0 -32
- md_processing/family_docs/Solution Architect.md +0 -490
- md_processing/md_processing_utils/debug_log +0 -574
- md_processing/md_processing_utils/debug_log.log +0 -0
- md_processing/md_processing_utils/dr-egeria-help-2025-07-17T17:22:09.md +0 -2065
- md_processing/md_processing_utils/generated_help_terms.md +0 -842
- pyegeria/.DS_Store +0 -0
- pyegeria/README.md +0 -35
- pyegeria/_client_new.py +0 -1102
- pyegeria/_output_formats.py +0 -730
- pyegeria/asset_catalog_omvs.py +0 -864
- pyegeria/automated_curation_omvs.py +0 -3765
- pyegeria/config.py +0 -523
- pyegeria/egeria_my_client.py +0 -91
- pyegeria/feedback_manager_omvs.py +0 -4573
- pyegeria/load_config_orig.py +0 -218
- pyegeria/md_processing_helpers.py +0 -58
- pyegeria/md_processing_utils_orig.py +0 -1103
- pyegeria/metadata_explorer_omvs.py +0 -2326
- pyegeria/my_profile_omvs.py +0 -1022
- pyegeria/project_manager.py +0 -1591
- pyegeria/registered_info.py +0 -167
- pyegeria/template_manager_omvs.py +0 -1414
- pyegeria/utils.py +0 -256
- pyegeria-5.4.0.28.dist-info/METADATA +0 -77
- pyegeria-5.4.0.28.dist-info/RECORD +0 -343
- pyegeria-5.4.0.28.dist-info/entry_points.txt +0 -105
- /commands/cat/debug_log.log → /pyegeria/deprecated/__init__.py +0 -0
- /pyegeria/{_exceptions.py → deprecated/_exceptions.py} +0 -0
- /pyegeria/{collection_models.py → models/collection_models.py} +0 -0
- {pyegeria-5.4.0.28.dist-info → pyegeria-5.5.3.3.dist-info/licenses}/LICENSE +0 -0
|
@@ -2,165 +2,382 @@
|
|
|
2
2
|
This file contains project-related object_action functions for processing Egeria Markdown
|
|
3
3
|
"""
|
|
4
4
|
|
|
5
|
+
import json
|
|
6
|
+
from typing import Optional
|
|
7
|
+
|
|
8
|
+
from loguru import logger
|
|
9
|
+
from pydantic import ValidationError
|
|
10
|
+
from rich import print
|
|
5
11
|
from rich.markdown import Markdown
|
|
6
12
|
|
|
7
|
-
from md_processing.md_processing_utils.
|
|
8
|
-
from md_processing.md_processing_utils.
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
13
|
+
from md_processing.md_processing_utils.common_md_proc_utils import (parse_upsert_command, parse_view_command)
|
|
14
|
+
from md_processing.md_processing_utils.common_md_utils import set_update_body, \
|
|
15
|
+
set_element_prop_body, set_delete_request_body, set_create_body, set_object_classifications, \
|
|
16
|
+
set_rel_request_body_for_type
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
from pyegeria import PyegeriaException, print_basic_exception, \
|
|
20
|
+
print_validation_error
|
|
21
|
+
|
|
22
|
+
from md_processing.md_processing_utils.common_md_utils import (update_element_dictionary,
|
|
23
|
+
)
|
|
24
|
+
from md_processing.md_processing_utils.extraction_utils import (extract_command_plus, update_a_command)
|
|
25
|
+
|
|
26
|
+
from pyegeria.egeria_tech_client import EgeriaTech
|
|
27
|
+
from pyegeria.core.utils import make_format_set_name_from_type, body_slimmer
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
# EGERIA_WIDTH = int(os.environ.get("EGERIA_WIDTH", "170"))
|
|
31
|
+
# console = Console(width=EGERIA_WIDTH)
|
|
32
|
+
|
|
12
33
|
|
|
13
|
-
setup_log()
|
|
14
34
|
|
|
15
|
-
def
|
|
35
|
+
def process_project_upsert_command(egeria_client: EgeriaTech, txt: str, directive: str = "display") -> Optional[str]:
|
|
16
36
|
"""
|
|
17
|
-
Processes a
|
|
18
|
-
glossary name, language, description, and usage from the given
|
|
37
|
+
Processes a project create or update object_action by extracting key attributes such as
|
|
38
|
+
glossary name, language, description, and usage from the given text.
|
|
19
39
|
|
|
20
40
|
:param txt: A string representing the input cell to be processed for
|
|
21
41
|
extracting glossary-related attributes.
|
|
22
42
|
:param directive: an optional string indicating the directive to be used - display, validate or execute
|
|
23
43
|
:return: A string summarizing the outcome of the processing.
|
|
24
44
|
"""
|
|
25
|
-
from md_processing.md_processing_utils.common_md_utils import set_debug_level
|
|
26
45
|
|
|
27
|
-
command =
|
|
46
|
+
command, object_type, object_action = extract_command_plus(txt)
|
|
28
47
|
print(Markdown(f"# {command}\n"))
|
|
29
48
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
valid = True
|
|
52
|
-
msg = ""
|
|
53
|
-
known_guid = None
|
|
54
|
-
known_q_name = None
|
|
55
|
-
|
|
56
|
-
project_details = egeria_client.get_projects_by_name(project_name)
|
|
57
|
-
if project_details == NO_PROJECTS_FOUND:
|
|
58
|
-
project_exists = False
|
|
59
|
-
else:
|
|
60
|
-
project_exists = True
|
|
61
|
-
|
|
62
|
-
if project_name is None:
|
|
63
|
-
msg = f"* {ERROR}Project name is missing\n"
|
|
64
|
-
valid = False
|
|
65
|
-
if project_status is None:
|
|
66
|
-
msg += f"* {INFO}No Project status found\n"
|
|
67
|
-
|
|
68
|
-
if description is None:
|
|
69
|
-
msg += f"* {INFO}No Description found\n"
|
|
70
|
-
|
|
71
|
-
if project_identifier is None:
|
|
72
|
-
msg += f"* {INFO}No Project Identifier found\n"
|
|
73
|
-
|
|
74
|
-
if project_phase is None:
|
|
75
|
-
msg += f"* {INFO}No Project Phase found\n"
|
|
76
|
-
|
|
77
|
-
if project_health is None:
|
|
78
|
-
msg += f"* {INFO}No Project Health found\n"
|
|
79
|
-
|
|
80
|
-
if start_date is None:
|
|
81
|
-
msg += f"* {INFO}No Start Date found\n"
|
|
82
|
-
elif not is_valid_iso_date(start_date):
|
|
83
|
-
msg += f"* {ERROR}Start Date is not a valid ISO date of form YYYY-MM-DD\n"
|
|
84
|
-
valid = False
|
|
85
|
-
|
|
86
|
-
if planned_end_date is None:
|
|
87
|
-
msg += f"* {INFO} No Planned End Date found\n"
|
|
88
|
-
elif not is_valid_iso_date(planned_end_date):
|
|
89
|
-
msg += f"* {ERROR}Planned End Date is not a valid ISO date of form YYYY-MM-DD\n"
|
|
90
|
-
valid = False
|
|
91
|
-
|
|
92
|
-
if obj_action == "Update":
|
|
93
|
-
q_name = process_simple_attribute(txt, 'Qualified Name')
|
|
94
|
-
|
|
95
|
-
if not project_exists:
|
|
96
|
-
msg += f"* {ERROR}Project {project_name} does not exist\n"
|
|
97
|
-
valid = False
|
|
98
|
-
if len(project_details) > 1 and project_exists:
|
|
99
|
-
msg += f"* {ERROR}More than one project with name {project_name} found\n"
|
|
100
|
-
valid = False
|
|
101
|
-
if len(project_details) == 1:
|
|
102
|
-
known_guid = project_details[0]['elementHeader'].get('guid', None)
|
|
103
|
-
known_q_name = project_details[0]['glossaryProperties'].get('qualifiedName', None)
|
|
104
|
-
if q_name is None:
|
|
105
|
-
msg += f"* {INFO}Qualified Name is missing => can use known qualified name of {known_q_name}\n"
|
|
106
|
-
valid = True
|
|
107
|
-
elif q_name != known_q_name:
|
|
108
|
-
msg += (f"* {ERROR}Project {project_name} qualifiedName mismatch between {q_name} and {known_q_name}\n")
|
|
109
|
-
valid = False
|
|
110
|
-
if valid:
|
|
111
|
-
msg += project_display
|
|
112
|
-
msg += f"* -->Project {project_name} exists and can be updated\n"
|
|
113
|
-
else:
|
|
114
|
-
msg += f"* --> validation failed\n"
|
|
115
|
-
msg += '---'
|
|
116
|
-
print(Markdown(msg))
|
|
117
|
-
return valid, project_exists, known_guid, known_q_name
|
|
118
|
-
|
|
119
|
-
elif obj_action == "Create":
|
|
120
|
-
if project_exists:
|
|
121
|
-
msg += f"\n{ERROR}Project {project_name} already exists"
|
|
122
|
-
else:
|
|
123
|
-
msg += f"\n-->It is valid to create Project \'{project_name}\' with:\n"
|
|
124
|
-
print(Markdown(msg))
|
|
125
|
-
return valid, project_exists, known_guid, known_q_name
|
|
49
|
+
parsed_output = parse_upsert_command(egeria_client, object_type, object_action, txt, directive)
|
|
50
|
+
if not parsed_output:
|
|
51
|
+
logger.error(f"No output for `{object_action}`")
|
|
52
|
+
return None
|
|
53
|
+
|
|
54
|
+
valid = parsed_output['valid']
|
|
55
|
+
exists = parsed_output['exists']
|
|
56
|
+
|
|
57
|
+
qualified_name = parsed_output.get('qualified_name', None)
|
|
58
|
+
guid = parsed_output.get('guid', None)
|
|
59
|
+
|
|
60
|
+
print(Markdown(parsed_output['display']))
|
|
61
|
+
|
|
62
|
+
logger.debug(json.dumps(parsed_output, indent=4))
|
|
63
|
+
|
|
64
|
+
attributes = parsed_output['attributes']
|
|
65
|
+
|
|
66
|
+
display_name = attributes['Display Name'].get('value', None)
|
|
67
|
+
status = attributes.get('Status', {}).get('value', None)
|
|
68
|
+
output_set = make_format_set_name_from_type(object_type)
|
|
69
|
+
#
|
|
126
70
|
|
|
127
71
|
if directive == "display":
|
|
128
|
-
print(Markdown(project_display))
|
|
129
72
|
return None
|
|
130
73
|
elif directive == "validate":
|
|
131
|
-
valid
|
|
74
|
+
if valid:
|
|
75
|
+
print(Markdown(f"==> Validation of {command} completed successfully!\n"))
|
|
76
|
+
else:
|
|
77
|
+
msg = f"Validation failed for object_action `{command}`\n"
|
|
132
78
|
return valid
|
|
79
|
+
|
|
133
80
|
elif directive == "process":
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
81
|
+
try:
|
|
82
|
+
obj = "Project"
|
|
83
|
+
project_types = ["Campaign", "Task", "Personal Project", "Study Project"]
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
# Set the property body for a glossary collection
|
|
87
|
+
#
|
|
88
|
+
prop_body = set_element_prop_body(obj, qualified_name, attributes)
|
|
89
|
+
prop_body["identifier"] = attributes.get('Identifier', {}).get('value', None)
|
|
90
|
+
prop_body["mission"] = attributes.get('Mission', {}).get('value', None)
|
|
91
|
+
prop_body["purposes"] = attributes.get('Purposes', {}).get('value', None)
|
|
92
|
+
prop_body["startDate"] = attributes.get('Start Date', {}).get('value', None)
|
|
93
|
+
prop_body["endDate"] = attributes.get('End Date', {}).get('value', None)
|
|
94
|
+
prop_body["priority"] = attributes.get('Priority', {}).get('value', None)
|
|
95
|
+
prop_body["projectPhase"] = attributes.get('Project Phase', {}).get('value', None)
|
|
96
|
+
prop_body["projectStatus"] = attributes.get('Project Status', {}).get('value', None)
|
|
97
|
+
prop_body["projectHealth"] = attributes.get('Project Health', {}).get('value', None)
|
|
98
|
+
|
|
99
|
+
if object_action == "Update":
|
|
100
|
+
if not exists:
|
|
101
|
+
msg = (f" Element `{display_name}` does not exist! Updating result document with Create "
|
|
102
|
+
f"{object_action}\n")
|
|
103
|
+
logger.error(msg)
|
|
104
|
+
return update_a_command(txt, object_action, object_type, qualified_name, guid)
|
|
105
|
+
elif not valid:
|
|
106
|
+
msg = (" The input data is invalid and cannot be processed. \nPlease review")
|
|
107
|
+
logger.error(msg)
|
|
108
|
+
print(Markdown(f"==> Validation of {command} failed!!\n"))
|
|
109
|
+
print(Markdown(msg))
|
|
139
110
|
return None
|
|
140
111
|
else:
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
112
|
+
print(Markdown(
|
|
113
|
+
f"==> Validation of {command} completed successfully! Proceeding to apply the changes.\n"))
|
|
114
|
+
|
|
115
|
+
|
|
116
|
+
body = set_update_body(obj, attributes)
|
|
117
|
+
body['properties'] = prop_body
|
|
118
|
+
|
|
119
|
+
egeria_client.update_project(guid, body)
|
|
120
|
+
# if status:
|
|
121
|
+
# egeria_client.update_project_status(guid, status)
|
|
122
|
+
|
|
123
|
+
logger.success(f"Updated {object_type} `{display_name}` with GUID {guid}\n\n___")
|
|
124
|
+
update_element_dictionary(qualified_name, {
|
|
125
|
+
'guid': guid, 'display_name': display_name
|
|
126
|
+
})
|
|
127
|
+
return egeria_client.get_project_by_guid(guid, element_type='Project',
|
|
128
|
+
output_format='MD', report_spec = output_set)
|
|
129
|
+
|
|
130
|
+
|
|
131
|
+
elif object_action == "Create":
|
|
132
|
+
if valid is False and exists:
|
|
133
|
+
msg = (f"Project `{display_name}` already exists and result document updated changing "
|
|
134
|
+
f"`Create` to `Update` in processed output\n\n___")
|
|
135
|
+
logger.error(msg)
|
|
136
|
+
return update_a_command(txt, object_action, object_type, qualified_name, guid)
|
|
137
|
+
elif not valid:
|
|
138
|
+
msg = ("The input data is invalid and cannot be processed. \nPlease review")
|
|
139
|
+
logger.error(msg)
|
|
140
|
+
print(Markdown(f"==> Validation of {command} failed!!\n"))
|
|
141
|
+
print(Markdown(msg))
|
|
153
142
|
return None
|
|
143
|
+
|
|
154
144
|
else:
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
145
|
+
body = set_create_body(object_type,attributes)
|
|
146
|
+
|
|
147
|
+
# if this is a root or folder (maybe more in the future), then make sure that the classification is set.
|
|
148
|
+
body["initialClassifications"] = set_object_classifications(object_type, attributes, project_types)
|
|
149
|
+
|
|
150
|
+
body["properties"] = prop_body
|
|
151
|
+
slim_body = body_slimmer(body)
|
|
152
|
+
guid = egeria_client.create_project(body = slim_body)
|
|
153
|
+
if guid:
|
|
154
|
+
update_element_dictionary(qualified_name, {
|
|
155
|
+
'guid': guid, 'display_name': display_name
|
|
156
|
+
})
|
|
157
|
+
msg = f"Created Element `{display_name}` with GUID {guid}\n\n___"
|
|
158
|
+
logger.success(msg)
|
|
159
|
+
return egeria_client.get_project_by_guid(guid, output_format='MD', report_spec = output_set)
|
|
162
160
|
else:
|
|
163
|
-
|
|
161
|
+
msg = f"Failed to create element `{display_name}` with GUID {guid}\n\n___"
|
|
162
|
+
logger.error(msg)
|
|
164
163
|
return None
|
|
164
|
+
|
|
165
|
+
except PyegeriaException as e:
|
|
166
|
+
logger.error(f"Pyegeria error performing {command}: {e}")
|
|
167
|
+
print_basic_exception(e)
|
|
168
|
+
return None
|
|
169
|
+
except Exception as e:
|
|
170
|
+
logger.error(f"Error performing {command}: {e}")
|
|
171
|
+
else:
|
|
172
|
+
return None
|
|
173
|
+
|
|
174
|
+
|
|
175
|
+
|
|
176
|
+
def process_link_project_hierarchy_command(egeria_client: EgeriaTech, txt: str, directive: str = "display") -> Optional[str]:
|
|
177
|
+
|
|
178
|
+
# """ Set one project to manage another."""
|
|
179
|
+
#
|
|
180
|
+
command, object_type, object_action = extract_command_plus(txt)
|
|
181
|
+
print(Markdown(f"# {command}\n"))
|
|
182
|
+
|
|
183
|
+
parsed_output = parse_view_command(egeria_client, object_type, object_action,
|
|
184
|
+
txt, directive)
|
|
185
|
+
|
|
186
|
+
if not parsed_output:
|
|
187
|
+
logger.error(f"No output for `{object_action}`")
|
|
188
|
+
print(Markdown("## Parsing failed"))
|
|
189
|
+
return None
|
|
190
|
+
|
|
191
|
+
print(Markdown(parsed_output['display']))
|
|
192
|
+
|
|
193
|
+
logger.debug(json.dumps(parsed_output, indent=4))
|
|
194
|
+
|
|
195
|
+
attributes = parsed_output['attributes']
|
|
196
|
+
|
|
197
|
+
parent_project_guid = attributes.get('Parent Project', {}).get('guid', None)
|
|
198
|
+
child_project_guid = attributes.get('Child Project', {}).get('guid', None)
|
|
199
|
+
label = attributes.get('Link Label', {}).get('value', "")
|
|
200
|
+
|
|
201
|
+
valid = parsed_output['valid']
|
|
202
|
+
exists = parent_project_guid is not None and child_project_guid is not None
|
|
203
|
+
|
|
204
|
+
if directive == "display":
|
|
205
|
+
|
|
206
|
+
return None
|
|
207
|
+
elif directive == "validate":
|
|
208
|
+
if valid:
|
|
209
|
+
print(Markdown(f"==> Validation of {command} completed successfully!\n"))
|
|
210
|
+
else:
|
|
211
|
+
msg = f"Validation failed for object_action `{command}`\n"
|
|
212
|
+
logger.error(msg)
|
|
213
|
+
print(Markdown(f"==> Validation of {command} failed!!\n"))
|
|
214
|
+
return valid
|
|
215
|
+
|
|
216
|
+
elif directive == "process":
|
|
217
|
+
|
|
218
|
+
|
|
219
|
+
try:
|
|
220
|
+
if object_action == "Detach":
|
|
221
|
+
if not exists:
|
|
222
|
+
msg = (f" Link `{label}` does not exist! Updating result document with Link "
|
|
223
|
+
f"object_action\n")
|
|
224
|
+
logger.error(msg)
|
|
225
|
+
out = parsed_output['display'].replace('Link', 'Detach', 1)
|
|
226
|
+
return out
|
|
227
|
+
elif not valid:
|
|
228
|
+
return None
|
|
229
|
+
else:
|
|
230
|
+
print(Markdown(
|
|
231
|
+
f"==> Validation of {command} completed successfully! Proceeding to apply the changes.\n"))
|
|
232
|
+
body = set_delete_request_body(object_type, attributes)
|
|
233
|
+
|
|
234
|
+
egeria_client.clear_project_hierarchy(child_project_guid, parent_project_guid,body)
|
|
235
|
+
|
|
236
|
+
logger.success(f"===> Detached segment with {label} from `{child_project_guid}`to {parent_project_guid}\n")
|
|
237
|
+
out = parsed_output['display'].replace('Unlink', 'Link', 1)
|
|
238
|
+
|
|
239
|
+
return (out)
|
|
240
|
+
|
|
241
|
+
|
|
242
|
+
elif object_action == "Link":
|
|
243
|
+
if valid is False and exists:
|
|
244
|
+
msg = (f"--> Link called `{label}` already exists and result document updated changing "
|
|
245
|
+
f"`Link` to `Detach` in processed output\n")
|
|
246
|
+
logger.error(msg)
|
|
247
|
+
|
|
248
|
+
elif valid is False:
|
|
249
|
+
msg = f"==>{object_type} Link with label `{label}` is not valid and can't be created"
|
|
250
|
+
logger.error(msg)
|
|
251
|
+
return
|
|
252
|
+
|
|
253
|
+
else:
|
|
254
|
+
body = set_rel_request_body_for_type("ProjectHierarchy", attributes)
|
|
255
|
+
|
|
256
|
+
egeria_client.set_project_hierarchy(project_guid =child_project_guid,
|
|
257
|
+
parent_project_guid = parent_project_guid)
|
|
258
|
+
# body=body_slimmer(body))
|
|
259
|
+
msg = f"==>Created {object_type} link named `{label}`\n"
|
|
260
|
+
logger.success(msg)
|
|
261
|
+
out = parsed_output['display'].replace('Link', 'Detach', 1)
|
|
262
|
+
return out
|
|
263
|
+
|
|
264
|
+
except ValidationError as e:
|
|
265
|
+
print_validation_error(e)
|
|
266
|
+
logger.error(f"Validation Error performing {command}: {e}")
|
|
267
|
+
return None
|
|
268
|
+
except PyegeriaException as e:
|
|
269
|
+
print_basic_exception(e)
|
|
270
|
+
logger.error(f"PyegeriaException occurred: {e}")
|
|
271
|
+
return None
|
|
272
|
+
|
|
273
|
+
except Exception as e:
|
|
274
|
+
logger.error(f"Error performing {command}: {e}")
|
|
275
|
+
return None
|
|
276
|
+
else:
|
|
277
|
+
return None
|
|
278
|
+
|
|
279
|
+
|
|
280
|
+
|
|
281
|
+
def process_link_project_dependency_command(egeria_client: EgeriaTech, txt: str, directive: str = "display") -> Optional[str]:
|
|
282
|
+
|
|
283
|
+
# """ Set one project dependence on another."""
|
|
284
|
+
#
|
|
285
|
+
|
|
286
|
+
command, object_type, object_action = extract_command_plus(txt)
|
|
287
|
+
print(Markdown(f"# {command}\n"))
|
|
288
|
+
|
|
289
|
+
parsed_output = parse_view_command(egeria_client, object_type, object_action,
|
|
290
|
+
txt, directive)
|
|
291
|
+
|
|
292
|
+
if not parsed_output:
|
|
293
|
+
logger.error(f"No output for `{object_action}`")
|
|
294
|
+
print(Markdown("## Parsing failed"))
|
|
295
|
+
return None
|
|
296
|
+
|
|
297
|
+
print(Markdown(parsed_output['display']))
|
|
298
|
+
|
|
299
|
+
logger.debug(json.dumps(parsed_output, indent=4))
|
|
300
|
+
|
|
301
|
+
attributes = parsed_output['attributes']
|
|
302
|
+
|
|
303
|
+
parent_project_guid = attributes.get('Parent Project', {}).get('guid', None)
|
|
304
|
+
child_project_guid = attributes.get('Child Project', {}).get('guid', None)
|
|
305
|
+
label = attributes.get('Link Label', {}).get('value', "")
|
|
306
|
+
|
|
307
|
+
valid = parsed_output['valid']
|
|
308
|
+
exists = parent_project_guid is not None and child_project_guid is not None
|
|
309
|
+
|
|
310
|
+
if directive == "display":
|
|
311
|
+
|
|
312
|
+
return None
|
|
313
|
+
elif directive == "validate":
|
|
314
|
+
if valid:
|
|
315
|
+
print(Markdown(f"==> Validation of {command} completed successfully!\n"))
|
|
165
316
|
else:
|
|
317
|
+
msg = f"Validation failed for object_action `{command}`\n"
|
|
318
|
+
logger.error(msg)
|
|
319
|
+
print(Markdown(f"==> Validation of {command} failed!!\n"))
|
|
320
|
+
return valid
|
|
321
|
+
|
|
322
|
+
elif directive == "process":
|
|
323
|
+
|
|
324
|
+
|
|
325
|
+
try:
|
|
326
|
+
if object_action == "Detach":
|
|
327
|
+
if not exists:
|
|
328
|
+
msg = (f" Link `{label}` does not exist! Updating result document with Link "
|
|
329
|
+
f"object_action\n")
|
|
330
|
+
logger.error(msg)
|
|
331
|
+
out = parsed_output['display'].replace('Link', 'Detach', 1)
|
|
332
|
+
return out
|
|
333
|
+
elif not valid:
|
|
334
|
+
return None
|
|
335
|
+
else:
|
|
336
|
+
print(Markdown(
|
|
337
|
+
f"==> Validation of {command} completed successfully! Proceeding to apply the changes.\n"))
|
|
338
|
+
body = set_delete_request_body(object_type, attributes)
|
|
339
|
+
|
|
340
|
+
egeria_client.clear_project_dependency(child_project_guid, parent_project_guid,body)
|
|
341
|
+
|
|
342
|
+
logger.success(f"===> Detached segment with {label} from `{child_project_guid}`to {parent_project_guid}\n")
|
|
343
|
+
out = parsed_output['display'].replace('Unlink', 'Link', 1)
|
|
344
|
+
|
|
345
|
+
return (out)
|
|
346
|
+
|
|
347
|
+
|
|
348
|
+
elif object_action == "Link":
|
|
349
|
+
if valid is False and exists:
|
|
350
|
+
msg = (f"--> Link called `{label}` already exists and result document updated changing "
|
|
351
|
+
f"`Link` to `Detach` in processed output\n")
|
|
352
|
+
logger.error(msg)
|
|
353
|
+
|
|
354
|
+
elif valid is False:
|
|
355
|
+
msg = f"==>{object_type} Link with label `{label}` is not valid and can't be created"
|
|
356
|
+
logger.error(msg)
|
|
357
|
+
return
|
|
358
|
+
|
|
359
|
+
else:
|
|
360
|
+
body = set_rel_request_body_for_type("ProjectDependency", attributes)
|
|
361
|
+
|
|
362
|
+
egeria_client.set_project_dependency(project_guid =child_project_guid,
|
|
363
|
+
upstream_project_guid = parent_project_guid,
|
|
364
|
+
body=body_slimmer(body))
|
|
365
|
+
msg = f"==>Created {object_type} link named `{label}`\n"
|
|
366
|
+
logger.success(msg)
|
|
367
|
+
out = parsed_output['display'].replace('Link', 'Detach', 1)
|
|
368
|
+
return out
|
|
369
|
+
|
|
370
|
+
except ValidationError as e:
|
|
371
|
+
print_validation_error(e)
|
|
372
|
+
logger.error(f"Validation Error performing {command}: {e}")
|
|
373
|
+
return None
|
|
374
|
+
except PyegeriaException as e:
|
|
375
|
+
print_basic_exception(e)
|
|
376
|
+
logger.error(f"PyegeriaException occurred: {e}")
|
|
166
377
|
return None
|
|
378
|
+
|
|
379
|
+
except Exception as e:
|
|
380
|
+
logger.error(f"Error performing {command}: {e}")
|
|
381
|
+
return None
|
|
382
|
+
else:
|
|
383
|
+
return None
|